Compare commits
2 Commits
d0ce9e47af
...
9f7ce7e9b6
Author | SHA1 | Date | |
---|---|---|---|
Arsen Mirzaev Tatyano-Muradovich | 9f7ce7e9b6 | ||
Arsen Mirzaev Tatyano-Muradovich | 4e04d09b32 |
|
@ -1,3 +1,3 @@
|
|||
# PHP 8.2 Framework for working with ArangoDB
|
||||
# PHP 8.3 Framework for working with ArangoDB
|
||||
|
||||
🤟 Very simple and flexible, easy to scale and integrate
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"keywords": [
|
||||
"ArangoDB"
|
||||
],
|
||||
"type": "library",
|
||||
"type": "framework",
|
||||
"license": "WTFPL",
|
||||
"homepage": "https://git.hood.su/mirzaev/arangodb",
|
||||
"authors": [
|
||||
|
|
|
@ -4,51 +4,59 @@ declare(strict_types=1);
|
|||
|
||||
namespace mirzaev\arangodb;
|
||||
|
||||
use mirzaev\arangodb\terminal;
|
||||
// Files of the project
|
||||
use mirzaev\arangodb\connection,
|
||||
mirzaev\arangodb\terminal,
|
||||
mirzaev\arangodb\enumerations\collection\type;
|
||||
|
||||
use ArangoDBClient\Connection as _connection;
|
||||
use ArangoDBClient\Collection as _collection;
|
||||
use ArangoDBClient\Statement as _statement;
|
||||
use ArangoDBClient\Document as _document;
|
||||
use ArangoDBClient\CollectionHandler as _collection_handler;
|
||||
// Library for ArangoDB
|
||||
use ArangoDBClient\Statement as _statement,
|
||||
ArangoDBClient\Document as _document,
|
||||
ArangoDBClient\CollectionHandler as _collection_handler;
|
||||
|
||||
// Built-in libraries
|
||||
use exception;
|
||||
|
||||
/**
|
||||
* Коллекция
|
||||
* Collection
|
||||
*
|
||||
* @package mirzaev\arangodb
|
||||
*
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
class collection
|
||||
{
|
||||
/**
|
||||
* Инициализация
|
||||
* Initialize a collection
|
||||
*
|
||||
* @param _connection $session Сессия соединения с базой данных
|
||||
* @param string $name Название
|
||||
* @param bool $edge Обрабатывать как ребро? (иначе: вершина)
|
||||
* @param string $collection Name of the collection
|
||||
* @param type $type Type of the collection
|
||||
* @param ?terminal $terminal Инстанция терминала
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return string|null Идентификатор коллекции
|
||||
* @return string|null Identifier of the collection
|
||||
*/
|
||||
public static function init(_connection $session, string $name, bool $edge = false, ?terminal $terminal = null): ?string
|
||||
public static function initialize(string $name, type $type = type::document, ?terminal $terminal = null, array &$errors = []): ?string
|
||||
{
|
||||
try {
|
||||
// Инициализация
|
||||
$collections = new _collection_handler($session);
|
||||
$collections = new _collection_handler(connection::$session);
|
||||
|
||||
if (!$collections->has($name)) {
|
||||
// Не найдана коллекция
|
||||
|
||||
// Запись в вывод
|
||||
if ($terminal instanceof terminal) $terminal::write("Коллекция \"$name\" не найдена");
|
||||
if ($terminal instanceof terminal) $terminal::write("Not found $type collection: $name");
|
||||
|
||||
// Запись коллекции на сервер и его ответ в буфер возврата
|
||||
$id = $collections->create($name, ['type' => $edge ? _collection::TYPE_EDGE : _collection::TYPE_DOCUMENT]);
|
||||
$id = $collections->create($name, ['type' => $type->code()]);
|
||||
|
||||
if ($collections->has($name)) {
|
||||
// Коллекция найдена (записана)
|
||||
|
||||
// Запись в вывод
|
||||
if ($terminal instanceof terminal) $terminal::write("Создана коллекция \"$name\" с типом " . ($edge ? 'ребро' : 'документ'));
|
||||
if ($terminal instanceof terminal) $terminal::write("Created $type collection: $name");
|
||||
|
||||
// Возврат идентификатора коллекции
|
||||
return $id;
|
||||
|
@ -59,24 +67,34 @@ class collection
|
|||
// Возврат идентификатора коллекции
|
||||
return $name;
|
||||
}
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Поиск
|
||||
* Execute
|
||||
*
|
||||
* @param _connection $session Сессия соединения с базой данных
|
||||
* @param string $query AQL-запрос
|
||||
* @param array $binds Binds for query [bind => value]
|
||||
* @param string $query Query (AQL)
|
||||
* @param array $parameters Binded parameters for placeholders [placholder => parameter]
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return _document|array|string|int|null Инстанция документа
|
||||
* @return _document|array|string|int|null Instance of the document
|
||||
*/
|
||||
public static function search(_connection $session, string $query, array $binds = []): _document|string|array|int|null
|
||||
public static function execute(string $query, array $parameters = [], array &$errors = []): _document|string|array|int|null
|
||||
{
|
||||
try {
|
||||
// Statement instance initialization
|
||||
$instance = new _statement(
|
||||
$session,
|
||||
connection::$session,
|
||||
[
|
||||
'query' => $query,
|
||||
"batchSize" => 1000,
|
||||
|
@ -85,7 +103,7 @@ class collection
|
|||
);
|
||||
|
||||
// Binds application
|
||||
$instance->bind($binds);
|
||||
$instance->bind($parameters);
|
||||
|
||||
// Sending the request
|
||||
$response = $instance->execute();
|
||||
|
@ -97,29 +115,87 @@ class collection
|
|||
$buffer[$key] = $value;
|
||||
}
|
||||
|
||||
// Exit (success)
|
||||
return is_array($buffer) && count($buffer) > 1 ? $buffer : $buffer[0] ?? null;
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Очистка
|
||||
* Truncate
|
||||
*
|
||||
* @param _connection $session Сессия соединения с базой данных
|
||||
* @param string $name Название
|
||||
* @param string $name Name of the collection
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return bool Статус выполнения
|
||||
*/
|
||||
public static function truncate(_connection $session, string $name): bool
|
||||
public static function truncate(string $collection, array &$errors = []): bool
|
||||
{
|
||||
// Инициализация
|
||||
$collections = new _collection_handler($session);
|
||||
try {
|
||||
// Initizlizing of the collection handler
|
||||
$collections = new _collection_handler(connection::$session);
|
||||
|
||||
if ($collections->has($name)) {
|
||||
// Найдена коллекция
|
||||
if ($collections->has($collection)) {
|
||||
// Fount the collection
|
||||
|
||||
// Очистка
|
||||
return $collections->truncate($name);
|
||||
// Truncate and exit (success)
|
||||
return $collections->truncate($collection);
|
||||
}
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Count documents in ArangoDB
|
||||
*
|
||||
* @param string $collection Name of the collection
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return int|null Amount of documents in ArangoDB
|
||||
*/
|
||||
public static function count(string $collection, array &$errors = []): ?int
|
||||
{
|
||||
try {
|
||||
// Count and exit (success)
|
||||
return static::execute(
|
||||
<<<'AQL'
|
||||
RETURN LENGTH(@collection)
|
||||
AQL,
|
||||
[
|
||||
'collection' => $collection
|
||||
]
|
||||
);
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -4,17 +4,21 @@ declare(strict_types=1);
|
|||
|
||||
namespace mirzaev\arangodb;
|
||||
|
||||
use ArangoDBClient\Connection as _connection;
|
||||
use ArangoDBClient\Exception as _exception;
|
||||
use ArangoDBClient\UpdatePolicy as _update;
|
||||
use ArangoDBClient\ConnectionOptions as _options;
|
||||
// Library for ArangoDB
|
||||
use ArangoDBClient\Connection as _connection,
|
||||
ArangoDBClient\Exception as _exception,
|
||||
ArangoDBClient\UpdatePolicy as _update,
|
||||
ArangoDBClient\ConnectionOptions as _options;
|
||||
|
||||
// Built-in libraries
|
||||
use exception;
|
||||
|
||||
/**
|
||||
* Подключение
|
||||
* Connection
|
||||
*
|
||||
* @package mirzaev\arangodb
|
||||
*
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
final class connection
|
||||
|
@ -82,7 +86,7 @@ final class connection
|
|||
/**
|
||||
* Сессия соединения
|
||||
*/
|
||||
protected _connection $session;
|
||||
public static _connection $session;
|
||||
|
||||
/**
|
||||
* Конструктор
|
||||
|
@ -112,7 +116,7 @@ final class connection
|
|||
}
|
||||
|
||||
// Подключение
|
||||
$this->session = new _connection([
|
||||
static::$session = new _connection([
|
||||
_options::OPTION_ENDPOINT => $this->adress,
|
||||
_options::OPTION_DATABASE => $this->storage,
|
||||
_options::OPTION_AUTH_TYPE => $this->auth,
|
||||
|
@ -171,7 +175,6 @@ final class connection
|
|||
'reconnect' => $this->reconnect,
|
||||
'create' => $this->create,
|
||||
'update', 'policy' => $this->update,
|
||||
'session' => $this->session,
|
||||
'journal' => $this->journal,
|
||||
default => throw new exception("Свойство \"$name\" не найдено", 404)
|
||||
};
|
||||
|
@ -196,7 +199,6 @@ final class connection
|
|||
'reconnect' => isset($this->reconnect),
|
||||
'create' => isset($this->create),
|
||||
'update', 'policy' => isset($this->update),
|
||||
'session' => isset($this->session),
|
||||
'journal' => isset($this->journal),
|
||||
default => throw new exception("Свойство \"$name\" не найдено", 404)
|
||||
};
|
||||
|
|
|
@ -4,43 +4,63 @@ declare(strict_types=1);
|
|||
|
||||
namespace mirzaev\arangodb;
|
||||
|
||||
use mirzaev\arangodb\terminal;
|
||||
// Files of the project
|
||||
use mirzaev\arangodb\terminal,
|
||||
mirzaev\arangodb\connection,
|
||||
mirzaev\arangodb\enumerations\collection\type;
|
||||
|
||||
use ArangoDBClient\Connection as _connection;
|
||||
use ArangoDBClient\Document as _document;
|
||||
use ArangoDBClient\Edge as _edge;
|
||||
use ArangoDBClient\DocumentHandler as _document_handler;
|
||||
use ArangoDBClient\EdgeHandler as _edge_handler;
|
||||
// Librsry for ArangoDB
|
||||
use ArangoDBClient\Connection as _connection,
|
||||
ArangoDBClient\Document as _document,
|
||||
ArangoDBClient\Edge as _edge,
|
||||
ArangoDBClient\DocumentHandler as _document_handler,
|
||||
ArangoDBClient\EdgeHandler as _edge_handler;
|
||||
|
||||
// Built-in libraries
|
||||
use exception;
|
||||
|
||||
/**
|
||||
* Документ
|
||||
* Document
|
||||
*
|
||||
* Handlers of document in ArangoDB
|
||||
*
|
||||
* @package mirzaev\arangodb
|
||||
*
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
class document
|
||||
{
|
||||
/**
|
||||
* Записать
|
||||
* Write
|
||||
*
|
||||
* @param _connection $session Сессия соединения с базой данных
|
||||
* @param string $collection Коллекция
|
||||
* @param ?array $data Данные
|
||||
* @param bool $check Проверка на запись в базу данных
|
||||
* @param ?terminal $terminal Инстанция терминала
|
||||
* @param ?terminal $terminal Instance of the terminal
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return string|null Идентификатор
|
||||
*
|
||||
* @todo
|
||||
* 1. Bind parameters
|
||||
*/
|
||||
public static function write(_connection $session, string $collection, ?array $data = [], bool $check = false, ?terminal $terminal = null): ?string
|
||||
{
|
||||
public static function write(
|
||||
string $collection,
|
||||
?array $data = [],
|
||||
bool $check = false,
|
||||
?terminal $terminal = null,
|
||||
array &$errors = []
|
||||
): ?string {
|
||||
try {
|
||||
// Инициализация коллекции
|
||||
collection::init($session, $collection, isset($data['_from'], $data['_to']));
|
||||
collection::initialize($collection, isset($data['_from'], $data['_to']) ? type::edge : type::document);
|
||||
|
||||
if (isset($data['_from'], $data['_to'])) {
|
||||
// Ребро
|
||||
|
||||
// Инициализация обработчика рёбер
|
||||
$documents = new _edge_handler($session);
|
||||
$documents = new _edge_handler(connection::$session);
|
||||
|
||||
// Инициализация ребра
|
||||
$document = new _edge();
|
||||
|
@ -55,7 +75,7 @@ class document
|
|||
// Вершина
|
||||
|
||||
// Инициализация обработчика вершин
|
||||
$documents = new _document_handler($session);
|
||||
$documents = new _document_handler(connection::$session);
|
||||
|
||||
// Инициализация вершины
|
||||
$document = new _document();
|
||||
|
@ -90,25 +110,80 @@ class document
|
|||
|
||||
// Возврат идентификатора коллекции
|
||||
return $id;
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Обновить
|
||||
* Update
|
||||
*
|
||||
* @param _connection $session Сессия соединения с базой данных
|
||||
* @param _document $document Инстанция документа вершины
|
||||
* @param array &$errors Registry of errors
|
||||
* @param _document $document Instance of the document
|
||||
*
|
||||
* @return bool Статус обработки
|
||||
* @return bool Has the document been updated?
|
||||
*/
|
||||
public static function update(_connection $session, _document $document): bool
|
||||
public static function update(_document $document, array &$errors = []): bool
|
||||
{
|
||||
// Инициализация обработчика вершин
|
||||
$documents = new _document_handler($session);
|
||||
try {
|
||||
// Initialize the handler of documents
|
||||
$documents = new _document_handler(connection::$session);
|
||||
|
||||
// Запись даты обновления в инстанцию документа
|
||||
// Writing date of the updating to the updating document
|
||||
$document->set('updated', time());
|
||||
|
||||
// Запись в базу данных
|
||||
// Writing and exit (success)
|
||||
return $documents->update($document);
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Delete
|
||||
*
|
||||
* @param _document $document Instance of the document
|
||||
* @param array &$errors Registry of errors
|
||||
*
|
||||
* @return bool Has the document been deleted?
|
||||
*/
|
||||
public static function delete(_document $document, array &$errors = []): bool
|
||||
{
|
||||
try {
|
||||
// Initialize the handler of documents
|
||||
$documents = new _document_handler(connection::$session);
|
||||
|
||||
// Delete abd exit (success)
|
||||
return $documents->remove($document);
|
||||
} catch (exception $e) {
|
||||
// Writing to registry of errors
|
||||
$errors[] = [
|
||||
'text' => $e->getMessage(),
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'stack' => $e->getTrace()
|
||||
];
|
||||
}
|
||||
|
||||
// Exit (fail)
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,36 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace mirzaev\arangodb\enumerations\collection;
|
||||
|
||||
// Library for ArangoDB
|
||||
use ArangoDBClient\Collection as _collection;
|
||||
|
||||
/**
|
||||
* Types of collections
|
||||
*
|
||||
* @package mirzaev\arangodb\enumerations\collection
|
||||
*
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
enum type
|
||||
{
|
||||
case document;
|
||||
case edge;
|
||||
|
||||
/**
|
||||
* Read code of the type from library for ArangoDB
|
||||
*
|
||||
* @return int Code of the type
|
||||
*/
|
||||
public function code(): int
|
||||
{
|
||||
// Exit (success)
|
||||
return match ($this) {
|
||||
type::document => _collection::TYPE_DOCUMENT,
|
||||
type::edge => _collection::TYPE_EDGE
|
||||
};
|
||||
}
|
||||
}
|
|
@ -4,12 +4,26 @@ declare(strict_types=1);
|
|||
|
||||
namespace mirzaev\arangodb;
|
||||
|
||||
// Built-in libraries
|
||||
use exception;
|
||||
|
||||
/**
|
||||
* Terminal
|
||||
*
|
||||
* lol sorry
|
||||
* i did not want to do this
|
||||
*
|
||||
* @package mirzaev\arangodb
|
||||
*
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
class terminal
|
||||
{
|
||||
/**
|
||||
* Префикс
|
||||
*/
|
||||
protected const PREFIX = 'arangodb';
|
||||
protected const string PREFIX = 'arangodb';
|
||||
|
||||
/**
|
||||
* Запись в вывод
|
||||
|
|
Loading…
Reference in New Issue