Download the PHP package agnesoft/agdb_api without Composer
On this page you can find all versions of the php package agnesoft/agdb_api. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download agnesoft/agdb_api
More information about agnesoft/agdb_api
Files in agnesoft/agdb_api
Package agdb_api
Short Description Agnesoft Graph Database API client for PHP
License Apache-2.0
Homepage https://github.com/agnesoft/agdb
Informations about the package agdb_api
agdb
The graph database.
Agnesoft Graph Database
Quickstart Db | Quickstart Client | QUERIES | DECISION TREE
The Agnesoft Graph Database (aka agdb) is persistent, optionally memory mapped graph database with native object 'no-text' queries. It can be used as a main persistent storage, data analytics platform as well as fast in-memory cache. Its typed schema-less data store allows for flexible and seamless data updates with no downtime or costly migrations. All queries are constructed via a builder pattern or directly as objects with no special language or text parsing.
- Key Features
- At a glance
- Crate Features
- Decision Tree
- Roadmap
- Reference
Key Features
- Data plotted on a graph
- Typed key-value properties attached to graph elements (nodes & edges)
- Persistent platform agnostic file based storage (transferable between platforms)
- ACID compliant
- Object queries with builder pattern (no text, no query language)
- Memory mapped for fast querying
- Server mode
- OpenAPI clients in any programming language
- Cloud hosted SaaS database
- Db itself has no dependencies
At a glance [Db]
Basic usage demonstrating creating a database, inserting graph elements with data and querying them back with select and search. The function using this code must handle agdb::DbError
and agdb::QueryError
error types for operator ?
to work:
This code creates a database called user_db.agdb
with a simple graph of 4 nodes. The first node is aliased users
and 3 user nodes for Alice, Bob and John are then connected with edges to the users
node. The arbitrary name
property is attached to the user nodes. Rather than inserting values directly with keys (which is also possible) we use our own type and derive from agdb::UserValue
to allow it to be used with the database.
You can select the graph elements (both nodes & edges) with their ids to get them back with their associated data (key-value properties). Lets select our users and convert the result into the list (notice we select only values relevant to our User
type with passing User::db_keys()
):
You can also search through the graph to get back only certain elements based on conditions. For example:
For database concepts and primitive data types see concepts. For comprehensive overview of all queries see the queries reference or continue with more in-depth efficient agdb.
Crate Features
agdb
Feature | Default | Description |
---|---|---|
derive | yes | Enables derive macro to enable custom user types to be directly used with the database. |
opeanapi | no | Enables ToSchema macro on query structs so they can be exported to json OpeanAPI/Swagger schema. |
serde | no | Enables serialiation/deserialization of queries and QueryResult using serde . |
agdb_api
Feature | Default | Description |
---|---|---|
reqwest | no | Enables referential implementation of the HttpClient trait for agdb API client using reqwest . |
Decision Tree
Roadmap
The following are planned features:
Feature | Description |
---|---|
Agdb Studio | Graphical interface to agdb |
Python Client | Convenience client using bindings genereated from OpenAPI. |
Java Client | Convenience client using bindings genereated from OpenAPI. |
C# Client | Convenience client using bindings genereated from OpenAPI. |
C Client | Convenience client using bindings genereated from OpenAPI. |
C++ Client | Convenience client using bindings genereated from OpenAPI. |
Data replication & consensus protocol | Allow replication by connecting several database nodes together with a RAFT protocol. |
Agdb Playground | Free public cloud-based playground to tinker with agdb . |
#[no_std] | The agdb does not require any dependencies and thus should be (in theory) no_std friendly but it will likely require some development & testing. |
Public Cloud Offering | Commercial & supported agdb instance hosted in a public cloud. |
Reference
All versions of agdb_api with dependencies
ext-curl Version *
ext-json Version *
ext-mbstring Version *
guzzlehttp/guzzle Version ^7.3
guzzlehttp/psr7 Version ^1.7 || ^2.0