https://github.com/andrey-tech/data-storage-php
Простое хранилище данных в виде ключ-значение в JSON-файлах с разделяемой блокировкой на чтение и эксклюзивной блокировкой на запись.
https://github.com/andrey-tech/data-storage-php
data data-storage files json php php7 storage
Last synced: about 2 months ago
JSON representation
Простое хранилище данных в виде ключ-значение в JSON-файлах с разделяемой блокировкой на чтение и эксклюзивной блокировкой на запись.
- Host: GitHub
- URL: https://github.com/andrey-tech/data-storage-php
- Owner: andrey-tech
- License: mit
- Created: 2020-07-30T16:21:59.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2020-08-03T08:45:35.000Z (almost 6 years ago)
- Last Synced: 2025-03-29T07:44:52.879Z (about 1 year ago)
- Topics: data, data-storage, files, json, php, php7, storage
- Language: PHP
- Homepage:
- Size: 8.79 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Data Storage PHP
Простое хранилище данных в виде ключ-значение в JSON-файлах
с разделяемой блокировкой на чтение и эксклюзивной блокировкой на запись.
## Содержание
- [Требования](#%D0%A2%D1%80%D0%B5%D0%B1%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F)
- [Установка](#%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0)
- [Класс `FileStorage`](#%D0%9A%D0%BB%D0%B0%D1%81%D1%81-filestorage)
- [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B)
- [Автор](#%D0%90%D0%B2%D1%82%D0%BE%D1%80)
- [Лицензия](#%D0%9B%D0%B8%D1%86%D0%B5%D0%BD%D0%B7%D0%B8%D1%8F)
- PHP >= 7.0.
- Трейт [`\App\Utils\JsonUtils`](https://github.com/andrey-tech/utils-php), содержащий методы для работы c данными в формате JSON.
- Произвольный автозагрузчик классов, реализующий стандарт [PSR-4](https://www.php-fig.org/psr/psr-4/).
Установка через composer:
```
$ composer require andrey-tech/data-storage-php
```
или добавить
```
"andrey-tech/data-storage-php"
```
в секцию require файла composer.json.
Работа с хранилищами производится с помощью класса `\App\DataStorage\FileStorage`.
При возникновении ошибок выбрасывается исключение с объектом класса `\App\DataStorage\FileStorageException`.
Класс `\App\DataStorage\FileStorage` имеет следующие публичные методы:
- `__construct(string $storageName = 'storage', string $storageDir = 'storage/')` Конструктор класса-хранилища.
* `$storageName` - имя хранилища. Должно удовлетворять регулярному выражению `'/^[\w\.-]+$/i`;
* `$storageDir` - каталог, в котором будут располагаться JSON-файлы хранилища.
- `set(array $set) :void` Устанавливает в хранилище значения по ключам.
* `$set` - ассоциативный массив ключей и значений: `[ 'key1' => 'value1', 'key2' => 'value2',... ]`.
- `get(array|string $keys)` Возвращает из хранилища значение по ключу или значения по ключам.
* `$keys` - ключ или массив ключей.
- `delete(array|string $keys) :void` Удаляет из хранилища пару(ы) ключ-значение по ключу(ам).
* `$keys` - ключ или массив ключей.
- `load() :array` Загружает и возвращает все данные из хранилища в виде массива.
- `update(array $set = [], array $delete = []) :void` Обновляет и/или удаляет значения по ключам в хранилище.
* `$set` - ассоциативный массив ключей и значений: `[ 'key1' => 'value1', 'key2' => 'value2',... ]`;
* `$delete` - массив удаляемых ключей.
- `hasKey(string $key) :bool` Проверяет наличие пары ключ-значение в хранилище.
* `$key` - имя ключа.
- `getStorageFileName() :string` Возвращает абсолютное имя JSON-файла хранилища.
```php
use \App\DataStorage\FileStorage;
use \App\DataStorage\FileStorageException;
use \App\AppException;
try {
$storage = new FileStorage('storage-1');
$storage->set([
'manager_id' => 2369305,
'numbers' => [ 4, 8, 15, 16, 23, 42 ],
'error_time' => null,
'user_ids' => [ 'alex' => 23, 'bob' => 2 ],
'months' => [ '0' => [ 1, 4 ], '1' => [ 1, 2, 5 ] ]
]);
$storage->set([ 'group_id' => 94824 ]);
var_dump($storage->hasKey('numbers'));
print_r($storage->get('numbers'));
print_r($storage->get([ 'manager_id', 'user_ids' ]));
$storage->delete('group_id');
$storage->update(
$set = [ 'error_time' => 1596124230 ],
$delete = [ 'manager_id' ]
);
print_r($storage->load());
} catch (FileStorageException $e) {
printf('Ошибка (%d): %s' . PHP_EOL, $e->getCode(), $e->getMessage());
} catch (AppException $e) {
printf('Ошибка (%d): %s' . PHP_EOL, $e->getCode(), $e->getMessage());
}
```
© 2020 andrey-tech
Данный код распространяется на условиях лицензии [MIT](./LICENSE).