{"id":15579263,"url":"https://github.com/andrey-tech/data-storage-php","last_synced_at":"2026-04-29T15:06:26.174Z","repository":{"id":56948073,"uuid":"283823023","full_name":"andrey-tech/data-storage-php","owner":"andrey-tech","description":"Простое хранилище данных в виде ключ-значение в JSON-файлах с разделяемой блокировкой на чтение и эксклюзивной блокировкой на запись.","archived":false,"fork":false,"pushed_at":"2020-08-03T08:45:35.000Z","size":9,"stargazers_count":2,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-03-29T07:44:52.879Z","etag":null,"topics":["data","data-storage","files","json","php","php7","storage"],"latest_commit_sha":null,"homepage":"","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/andrey-tech.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-07-30T16:21:59.000Z","updated_at":"2021-04-01T14:37:44.000Z","dependencies_parsed_at":"2022-08-21T07:20:59.630Z","dependency_job_id":null,"html_url":"https://github.com/andrey-tech/data-storage-php","commit_stats":null,"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"purl":"pkg:github/andrey-tech/data-storage-php","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fdata-storage-php","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fdata-storage-php/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fdata-storage-php/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fdata-storage-php/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/andrey-tech","download_url":"https://codeload.github.com/andrey-tech/data-storage-php/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/andrey-tech%2Fdata-storage-php/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":259352437,"owners_count":22844737,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["data","data-storage","files","json","php","php7","storage"],"created_at":"2024-10-02T19:14:17.778Z","updated_at":"2026-04-29T15:06:21.154Z","avatar_url":"https://github.com/andrey-tech.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Data Storage PHP\n\nПростое хранилище данных в виде ключ-значение в JSON-файлах \nс разделяемой блокировкой на чтение и эксклюзивной блокировкой на запись.\n\n## Содержание\n\n\u003c!-- MarkdownTOC levels=\"1,2,3,4,5,6\" autoanchor=\"true\" autolink=\"true\" --\u003e\n\n- [Требования](#%D0%A2%D1%80%D0%B5%D0%B1%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F)\n- [Установка](#%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0)\n- [Класс `FileStorage`](#%D0%9A%D0%BB%D0%B0%D1%81%D1%81-filestorage)\n- [Примеры](#%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B)\n- [Автор](#%D0%90%D0%B2%D1%82%D0%BE%D1%80)\n- [Лицензия](#%D0%9B%D0%B8%D1%86%D0%B5%D0%BD%D0%B7%D0%B8%D1%8F)\n\n\u003c!-- /MarkdownTOC --\u003e\n\n\u003ca id=\"%D0%A2%D1%80%D0%B5%D0%B1%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F\"\u003e\u003c/a\u003e\n## Требования\n\n- PHP \u003e= 7.0.\n- Трейт [`\\App\\Utils\\JsonUtils`](https://github.com/andrey-tech/utils-php), содержащий методы для работы c данными в формате JSON.\n- Произвольный автозагрузчик классов, реализующий стандарт [PSR-4](https://www.php-fig.org/psr/psr-4/).\n\n\u003ca id=\"%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0\"\u003e\u003c/a\u003e\n## Установка\n\nУстановка через composer:\n```\n$ composer require andrey-tech/data-storage-php\n```\n\nили добавить\n\n```\n\"andrey-tech/data-storage-php\"\n```\n\nв секцию require файла composer.json.\n\n\u003ca id=\"%D0%9A%D0%BB%D0%B0%D1%81%D1%81-filestorage\"\u003e\u003c/a\u003e\n## Класс `FileStorage`\n\nРабота с хранилищами производится с помощью класса `\\App\\DataStorage\\FileStorage`.  \nПри возникновении ошибок выбрасывается исключение с объектом класса `\\App\\DataStorage\\FileStorageException`. \n\nКласс `\\App\\DataStorage\\FileStorage` имеет следующие публичные методы:\n\n- `__construct(string $storageName = 'storage', string $storageDir = 'storage/')` Конструктор класса-хранилища.\n    * `$storageName` - имя хранилища. Должно удовлетворять регулярному выражению `'/^[\\w\\.-]+$/i`;\n    * `$storageDir` - каталог, в котором будут располагаться JSON-файлы хранилища.\n- `set(array $set) :void` Устанавливает в хранилище значения по ключам.\n    * `$set` - ассоциативный массив ключей и значений: `[ 'key1' =\u003e 'value1', 'key2' =\u003e 'value2',... ]`.\n- `get(array|string $keys)` Возвращает из хранилища значение по ключу или значения по ключам.\n    * `$keys` - ключ или массив ключей.\n- `delete(array|string $keys) :void` Удаляет из хранилища пару(ы) ключ-значение по ключу(ам).\n    * `$keys` - ключ или массив ключей.\n- `load() :array` Загружает и возвращает все данные из хранилища в виде массива.\n- `update(array $set = [], array $delete = []) :void` Обновляет и/или удаляет значения по ключам в хранилище.\n    * `$set` - ассоциативный массив ключей и значений: `[ 'key1' =\u003e 'value1', 'key2' =\u003e 'value2',... ]`;\n    * `$delete` - массив удаляемых ключей.\n- `hasKey(string $key) :bool` Проверяет наличие пары ключ-значение в хранилище.\n    * `$key` - имя ключа.\n- `getStorageFileName() :string` Возвращает абсолютное имя JSON-файла хранилища.\n\n\u003ca id=\"%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D1%80%D1%8B\"\u003e\u003c/a\u003e\n## Примеры\n\n```php\nuse \\App\\DataStorage\\FileStorage;\nuse \\App\\DataStorage\\FileStorageException;\nuse \\App\\AppException;\n\ntry {\n\n    $storage = new FileStorage('storage-1');\n\n    $storage-\u003eset([\n        'manager_id' =\u003e 2369305,\n        'numbers'    =\u003e [ 4, 8, 15, 16, 23, 42 ],\n        'error_time' =\u003e null,\n        'user_ids'   =\u003e [ 'alex' =\u003e 23, 'bob' =\u003e 2 ],\n        'months'     =\u003e [ '0' =\u003e [ 1, 4 ], '1' =\u003e [  1, 2, 5  ] ]\n    ]);\n    $storage-\u003eset([ 'group_id' =\u003e 94824 ]);\n\n    var_dump($storage-\u003ehasKey('numbers'));\n\n    print_r($storage-\u003eget('numbers'));\n    print_r($storage-\u003eget([ 'manager_id', 'user_ids' ]));\n\n    $storage-\u003edelete('group_id');\n\n    $storage-\u003eupdate(\n        $set = [ 'error_time' =\u003e 1596124230 ],\n        $delete = [ 'manager_id' ]\n    );\n\n    print_r($storage-\u003eload());\n\n} catch (FileStorageException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n} catch (AppException $e) {\n    printf('Ошибка (%d): %s' . PHP_EOL, $e-\u003egetCode(), $e-\u003egetMessage());\n}\n```\n\n\u003ca id=\"%D0%90%D0%B2%D1%82%D0%BE%D1%80\"\u003e\u003c/a\u003e\n## Автор\n\n© 2020 andrey-tech\n\n\u003ca id=\"%D0%9B%D0%B8%D1%86%D0%B5%D0%BD%D0%B7%D0%B8%D1%8F\"\u003e\u003c/a\u003e\n## Лицензия\n\nДанный код распространяется на условиях лицензии [MIT](./LICENSE).\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fandrey-tech%2Fdata-storage-php","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fandrey-tech%2Fdata-storage-php","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fandrey-tech%2Fdata-storage-php/lists"}