1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63:
<?php
/**
* Copyright 2017 MICRORISC s.r.o.
* Copyright 2017 IQRF Tech s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
declare(strict_types=1);
namespace App\Model;
use Nette;
use Nette\Utils\Json;
/**
* Tool for reading and writing JSON files.
*/
class JsonFileManager extends FileManager {
use Nette\SmartObject;
/**
* Constructor
* @param string $configDir Directory with configuration files
*/
public function __construct(string $configDir) {
parent::__construct($configDir);
}
/**
* Read JSON file and decode JSON to array
* @param string $fileName File name (without .json)
* @return array
*/
public function read(string $fileName) {
$file = parent::read($fileName . '.json');
return Json::decode($file, Json::FORCE_ARRAY);
}
/**
* Encode JSON from array and write JSON file
* @param string $name File name (without .json)
* @param array $array JSON array
*/
public function write(string $name, $array) {
$json = Json::encode($array, Json::PRETTY);
parent::write($name . '.json', $json);
}
}