diff options
author | Daniel Weipert <code@drogueronin.de> | 2022-01-02 13:57:40 +0100 |
---|---|---|
committer | Daniel Weipert <code@drogueronin.de> | 2022-01-10 11:29:13 +0100 |
commit | da0d49a8472a3472ed24c99ed08435bf43a2ca3f (patch) | |
tree | 0e4728c2029347c157913e9e4ba37e634a95ad1e | |
parent | 7783aeb63ec08bed159942fb0df100cfc4e93d3c (diff) |
Add config and make configurable
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | config.example.toml | 6 | ||||
-rw-r--r-- | public/index.php | 29 | ||||
-rw-r--r-- | src/App.php | 6 |
4 files changed, 39 insertions, 3 deletions
@@ -1,3 +1,4 @@ /vendor/ /content/ +/config.toml diff --git a/config.example.toml b/config.example.toml new file mode 100644 index 0000000..a506a09 --- /dev/null +++ b/config.example.toml @@ -0,0 +1,6 @@ +[app] +contentFolderPath = './content' + +[form] +entriesFolderName = 'entries' + diff --git a/public/index.php b/public/index.php index 1cd408e..b7895e7 100644 --- a/public/index.php +++ b/public/index.php @@ -1,8 +1,37 @@ <?php use FlatFileForms\App; +use Yosymfony\Toml\Toml; require_once dirname(__DIR__) . '/vendor/autoload.php'; +function findAppConfigFile($path) +{ + $currentFolder = $path; + while ($currentFolder !== '/') { + $configFile = $currentFolder . '/config.toml'; + if (file_exists($configFile)) { + return $configFile; + } + + $currentFolder = dirname($currentFolder); + } + + die('config.toml missing'); +} + +$configFile = findAppConfigFile(dirname(__DIR__)); +$config = Toml::parseFile($configFile); + +chdir(dirname($configFile)); +$contentFolderPath = realpath($config['app']['contentFolderPath']); +$contentFolderPath === false && die('Content folder "' . $config['app']['contentFolderPath'] . '" missing'); +$config['app']['contentFolderPath'] = $contentFolderPath; +chdir($_SERVER['DOCUMENT_ROOT']); + +foreach ($config as $key => $value) { + $_ENV[$key] = $value; +} + new App(); diff --git a/src/App.php b/src/App.php index fcf2699..7e0cabd 100644 --- a/src/App.php +++ b/src/App.php @@ -20,7 +20,7 @@ class App $content = [ 'data' => [], ]; - $contentRoot = dirname(__DIR__) . '/content'; + $contentRoot = $_ENV['app']['contentFolderPath']; $method = $request->getMethod(); $path = $request->getPathInfo(); @@ -85,7 +85,7 @@ class App $builder->addValue($entryKey, $entryValue); } - $entryDirectory = $formPath . '/entries/' . $date->format('Y/m/d'); + $entryDirectory = $formPath . '/' . $_ENV['form']['entriesFolderName'] . '/' . $date->format('Y/m/d'); @mkdir($entryDirectory, 0774, true); $entryFilename = $date->format('Ymd_Hi_') . hash('adler32', serialize($entry)) . '.toml'; file_put_contents( @@ -158,7 +158,7 @@ class App $config['api']['keys'] = $apiKeys; } - if (str_ends_with($currentFolder, '/content') || $currentFolder == '/') { + if (str_ends_with($currentFolder, '/' . basename($_ENV['app']['contentFolderPath'])) || $currentFolder == '/') { break; } |