JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbrpath = (string) $path; $this->filesystem = $filesystem ?: new Filesystem(); $this->attributes = Collection::make($this->getAttributes()); } /** * Get filesystem. * * @return Filesystem */ public function getFilesystem() { return $this->filesystem; } /** * Set filesystem. * * * @return $this */ public function setFilesystem(Filesystem $filesystem) { $this->filesystem = $filesystem; return $this; } /** * Get path. * * @return string */ public function getPath() { return $this->path; } /** * Set path. * * @param mixed $path * @return $this */ public function setPath($path) { $this->path = (string) $path; return $this; } /** * Make new instance. * * @param string $path * @return static */ public static function make($path, ?Filesystem $filesystem = null) { return new static($path, $filesystem); } /** * Get file content. * * @return string */ public function getContents() { return $this->filesystem->get($this->getPath()); } /** * Decode contents as array. * * @return array * * @throws InvalidJsonException */ public function decodeContents() { $attributes = $this->filesystem->json($this->getPath()); // any JSON parsing errors should throw an exception if (json_last_error() > 0) { throw new InvalidJsonException('Error processing file: '.$this->getPath().'. Error: '.json_last_error_msg()); } return $attributes; } /** * Get file contents as array, either from the cache or from * the json content file if the cache is disabled. * * @return array * * @throws \Exception */ public function getAttributes() { return $this->attributes ?? $this->decodeContents(); } /** * Convert the given array data to pretty json. * * * @return string */ public function toJsonPretty(?array $data = null) { return json_encode($data ?: $this->attributes, JSON_PRETTY_PRINT); } /** * Update json contents from array data. * * * @return bool */ public function update(array $data) { $this->attributes = new Collection(array_merge($this->attributes->toArray(), $data)); return $this->save(); } /** * Set a specific key & value. * * @param string $key * @param mixed $value * @return $this */ public function set($key, $value) { $this->attributes->offsetSet($key, $value); return $this; } /** * Save the current attributes array to the file storage. * * @return bool */ public function save() { return $this->filesystem->put($this->getPath(), $this->toJsonPretty()); } /** * Handle magic method __get. * * @param string $key * @return mixed */ public function __get($key) { return $this->get($key); } /** * Get the specified attribute from json file. * * @param null $default * @return mixed */ public function get($key, $default = null) { return $this->attributes->get($key, $default); } /** * Handle call to __call method. * * @param string $method * @param array $arguments * @return mixed */ public function __call($method, $arguments = []) { if (method_exists($this, $method)) { return call_user_func_array([$this, $method], $arguments); } return call_user_func_array([$this->attributes, $method], $arguments); } /** * Handle call to __toString method. * * @return string */ public function __toString() { return $this->getContents(); } }