rollun-com / rollun-datastore
Datastore
Installs: 10 074
Dependents: 10
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 10
Open Issues: 29
pkg:composer/rollun-com/rollun-datastore
Requires
- php: ^8.0
- ext-json: *
- ext-pdo: *
- ajgl/csv-rfc: ^0.4.0
- laminas/laminas-db: ^2.13.4
- laminas/laminas-diactoros: ^2.8.0
- laminas/laminas-http: ^2.15.1
- laminas/laminas-servicemanager: ^3.10
- laminas/laminas-stratigility: ^3.5.0
- rollun-com/rollun-logger: ^7.6.4
- rollun-com/rollun-utils: ^9.0.0
- symfony/filesystem: ^6.0
- xiag/rql-parser: ^v1.0.0
Requires (Dev)
- ext-mysqli: *
- laminas/laminas-config-aggregator: ^1.7
- mezzio/mezzio: ^3.9
- phpunit/phpunit: ^9.5.10
- rector/rector: ^2.0
- symfony/dotenv: ^6.0.3
- dev-master
- 11.2.2
- 11.2.1
- 11.2.0
- 11.1.0
- 11.0.5
- 11.0.4
- 11.0.3
- 11.0.2
- 11.0.1
- 11.0.0
- 10.x-dev
- 10.6.2
- 10.6.1
- 10.6.0
- 10.5.0
- 10.4.4
- 10.4.3
- 10.4.2
- 10.4.1
- 10.4.0
- 10.3.1
- v10.3.0
- 10.2.6
- 10.2.5
- 10.2.4
- 10.2.3
- 10.2.2
- 10.2.1
- 10.2.0
- 10.1.0
- 10.0.0
- 9.x-dev
- 9.0.3
- 9.0.2
- 9.0.1
- 9.0.0
- 8.1.2
- 8.1.1
- 8.1.0
- 8.0.3
- 8.0.2
- 8.0.1
- 8.0.0
- 7.0.0
- 6.x-dev
- 6.14.2
- 6.14.1
- 6.14.0
- 6.13.0
- 6.12.7
- 6.12.6
- 6.12.5
- 6.12.4
- 6.12.3
- 6.12.2
- 6.12.1
- 6.12.0
- 6.11.6
- 6.11.5
- 6.11.4
- 6.11.3
- 6.11.2
- 6.11.1
- 6.11.0
- 6.10.1
- 6.10.0
- 6.9.0
- 6.8.1
- 6.8.0
- 6.7.1
- 6.7.0
- 6.6.7
- 6.6.6
- 6.6.5
- 6.6.4
- 6.6.3
- 6.6.2
- 6.6.1
- 6.6
- 6.5.0
- 6.4.29
- 6.4.28
- 6.4.27
- 6.4.26
- 6.4.25
- 6.4.24
- 6.4.23
- 6.4.22
- 6.4.21
- 6.4.20
- 6.4.19
- 6.4.18
- 6.4.17
- 6.4.16
- 6.4.15
- 6.4.14
- 6.4.13
- 6.4.12
- 6.4.11
- 6.4.10
- 6.4.1
- 6.4.0
- 6.3.7
- 6.3.6
- 6.3.5
- 6.3.4
- 6.3.3
- 6.3.2
- 6.3.1
- 6.3.0
- 6.2.1
- 6.2.0
- 6.1.5
- 6.1.4
- 6.1.3
- 6.1.2
- 6.1.1
- 6.1.0
- 6.0.9
- 6.0.8
- 6.0.7
- 6.0.6
- 6.0.5
- 6.0.4
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.11.2
- 4.11.1
- 4.11.0
- 4.10.0
- 4.9.0
- 4.8
- 4.7.4
- 4.7.3
- 4.7.2
- 4.7.1
- 4.7.0
- 4.6.0
- 4.5.1
- 4.5.0
- 4.4.0
- 4.3.1
- 4.3.0
- 4.2.6
- 4.2.5
- 4.2.4
- 4.2.3
- 4.2.1
- 4.2.0
- 4.1.0
- 4.0.3
- 4.0.2
- 4.0.1
- 4.0.0
- 3.0.1
- 3.0.0
- 2.3.0
- 2.2.0
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.1
- 2.0.0
- 1.1.0
- 1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- dev-vadymk/docs-7.2
- dev-vadymk/docs-8.0
- dev-vadymk/docs
- dev-vadymk/llm-docs
- dev-vadymk/multi-update-cursor-8.0
- dev-vadymk/multi-update-spec-8.0
- dev-001-http-dbtable-multiupdate
- dev-vadymk/iterator-7.2
- dev-vadymk/iterator-8.0
- dev-vadymk/iterator
- dev-vadymk/equals-json-field-bug-7.2
- dev-vadymk/equals-json-field-bug-8.0
- dev-vadymk/equals-json-fiels-bug
- dev-vadymk/escaping-underline-bug-7.2
- dev-vadymk/escaping-underline-bug-8.0
- dev-vadymk/escaping-underline-bug
- dev-vadymk/xiag-dependency
- dev-vadymk/xiag-rql
- dev-vadymk/undercore-bug-8.0
- dev-fix/rql-encode-for-zero
- dev-hack-getTableNames
- dev-issues/empty-array-filter-in-mysql
- dev-set-tests
- dev-filter-with-underscore
- dev-test-refactor-feature
This package is auto-updated.
Last update: 2025-11-04 18:34:15 UTC
README
rollun-datastore - это библиотека, которая предоставляет единый интерфейс взаимодействие с любым хранилищем данных
на основе Resource Query Language (RQL).
Существующие реализации: DbTable (для таблицы бд), CsvBase (для csv файлов), HttpClient (для внешнего ресурса через
http), Memory (для RAM).
- Документация
- Опис історії змін по версіям CHANGELOG.md
Краткая таблица операций
| Операция | HTTP | RQL (в query) | Тело запроса | Примечания | Заголовки и атрибуты запроса | Ограничения и известные проблемы |
|---|---|---|---|---|---|---|
| Создание записи (create) | POST | Нет | Объект | При коллизии ID поведение задаёт overwriteMode: false — ошибка; true — перезаписать существующую запись. Если PK указан и в path, и в body — приоритет у body (НУЖНО ПРОВЕРИТЬ). |
Опционально атрибут overwriteMode. Опционально атрибут primaryKeyValue. |
Если PK нет ни в body, ни в path, то попытка создания записи все равно произойдет для DbTable. Это может вызвать ошибку если PK не AUTO_INCREMENT. overwriteMode вызывает ошибку уровня deprecated для DbTable и по умолчанию имеет значение false |
| Множественное создание (multiCreate) | POST | Нет | Массив объектов | Если пакетное создание не поддержиевается, выполняются последовательные вызовы create() для каждого элемента. | — | — |
| Получение записи (read) | GET | Нет | — | Требуется ID (в path). | Требуется атрибут primaryKeyValue |
— |
| Поиск (query) | GET | Обязателен | — | — | Атрибут primaryKeyValue должен отсутствовать |
— |
| Обновление записи (update) | PUT | Нет | Объект | ID обязателен; если указан и в path, и в body — приоритет у body. Upsert при overwriteMode = true (создать, если записи нет). |
Опционально атрибут overwriteMode. Опционально атрибут primaryKeyValue. |
overwriteMode вызывает ошибку уровня deprecated для DbTable и по умолчание имеет значение false. Согласно стандартам, частичное обновление записи должно выполнятся методом PATCH - об этом известно. |
| Множественное обновление (multiUpdate) | В данный момент не реализовано | |||||
| Обновление по фильтру (queriedUpdate) | PATCH | Обязателен | Объект | Требуется наличие limit в RQL; нельзя select/groupBy; без PK (первичный ключ) в body. | Атрибут primaryKeyValue должен отсутствовать |
Для DbTable обновление по фильтру выполняется с помощью SELECT FOR UPDATE. |
| Удаление (delete) | DELETE | Нет | — | Требуется ID (в path). | Требуется атрибут primaryKeyValue. |
Для DbTable переданный в запросе PK быть либо типа integer, либо double, либо string. |
| Удаление по фильтру (queriedDelete) | В данный момент не реализовано | |||||
| Удаление всех записей (deleteAll) | В данный момент не реализовано | |||||
| Получение метаданных (getIdentifier) | HEAD | Нет | — | Метаданные/хедеры по PK. | — | Заголовки возвращаются в формате X_OPE_RATION и т.д. |
| Загрузить контент в CSV файле | GET | Можно | — | При экспорте RQL-ограничение limit(...) принудительно снимается обработчиком CSV, поэтому возвращается весь контент датастора. | Требуется заголовок download со значением csv |
В данный момент ситуация с limit это баг и о нём известно. Требуемый заголовок также в дальнейшем будет изменен согласно стандартам (Accept: text/csv). |
| Refresh (если поддерживается) | PATCH | Нет | — | Только для датасторов с RefreshableInterface. |
— | — |
| Пересоздание записи (rewrite) | В данный момент не реализовано | |||||
| Множественное пересоздание (multiRewrite) | В данный момент не реализовано |
Примечания к таблице
Атрибут overwriteMode
Это атрибут запроса ($request->getAttribute('overwriteMode')), булев флаг, который middleware RequestDecoder
устанавливает на основании заголовка If-Match. Если заголовок равен * (If-Match: *) — значение true;
при любом другом значении или отсутствии заголовка — false. Он задает поведение при конфликте/отсутствии записи.
CSV и LIMIT
При экспорте CSV обработчик принудительно снимает/заменяет клиентский limit(...) на «без ограничений», поэтому выгружается всё (это поведение реализовано в CSV-хендлере).
Атрибут primaryKeyValue
Это атрибут запроса ($request->getAttribute('primaryKeyValue')), строковый PK записи, который middleware ResourceResolver
извлекает из роут-параметра id или из последнего сегмента пути /api/datastore/{resourceName}/{id} (после rawurldecode(...)).
Если ID не задан — null.
Расширенный формат таблицы выше
Для сторонних клиентов
В DataStore используется дополненная версия rawurlencode.
К перечню стандартных символов добавлены следующие преобразования
-=>%2D_=>%5F.=>%2E~=>%7E