X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=application%2Fconfig%2FConfigJson.php;h=23b22269540d46f3a03770ea50865738e31c1209;hb=05c616f7a08936108d6feee4460dca9407e83d9f;hp=8c8d5610efb145c49c3b319514f7e3ba0dab68ca;hpb=2e6314af312229467ca63b6dc0c337f92eb5ddeb;p=github%2Fshaarli%2FShaarli.git diff --git a/application/config/ConfigJson.php b/application/config/ConfigJson.php index 8c8d5610..23b22269 100644 --- a/application/config/ConfigJson.php +++ b/application/config/ConfigJson.php @@ -19,7 +19,7 @@ class ConfigJson implements ConfigIO $data = file_get_contents($filepath); $data = str_replace(self::getPhpHeaders(), '', $data); $data = str_replace(self::getPhpSuffix(), '', $data); - $data = json_decode($data, true); + $data = json_decode(trim($data), true); if ($data === null) { $errorCode = json_last_error(); $error = sprintf( @@ -46,8 +46,8 @@ class ConfigJson implements ConfigIO // JSON_PRETTY_PRINT is available from PHP 5.4. $print = defined('JSON_PRETTY_PRINT') ? JSON_PRETTY_PRINT : 0; $data = self::getPhpHeaders() . json_encode($conf, $print) . self::getPhpSuffix(); - if (!file_put_contents($filepath, $data)) { - throw new \IOException( + if (empty($filepath) || !file_put_contents($filepath, $data)) { + throw new \Shaarli\Exceptions\IOException( $filepath, t('Shaarli could not create the config file. '. 'Please make sure Shaarli has the right to write in the folder is it installed in.') @@ -73,7 +73,7 @@ class ConfigJson implements ConfigIO */ public static function getPhpHeaders() { - return ''; + return '*/ ?>'; } }