Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fMeow/arangors
Easy to use rust driver for arangoDB
https://github.com/fMeow/arangors
arangodb arangodb-client nosql rust rust-library
Last synced: 2 months ago
JSON representation
Easy to use rust driver for arangoDB
- Host: GitHub
- URL: https://github.com/fMeow/arangors
- Owner: fMeow
- License: mit
- Created: 2018-09-06T03:05:57.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-06-06T12:51:20.000Z (7 months ago)
- Last Synced: 2024-08-09T12:12:43.269Z (5 months ago)
- Topics: arangodb, arangodb-client, nosql, rust, rust-library
- Language: Rust
- Homepage: https://docs.rs/arangors
- Size: 736 KB
- Stars: 124
- Watchers: 5
- Forks: 28
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rust - Arangors - An ArangoDB driver (Libraries / Database)
- awesome-rust-cn - Arangors - (库 Libraries / 数据库 Database)
- awesome-rust - Arangors - An ArangoDB driver (Libraries / Database)
- fucking-awesome-rust - Arangors - An ArangoDB driver (Libraries / Database)
- fucking-awesome-rust - Arangors - An ArangoDB driver (Libraries / Database)
README
![Maintenance](https://img.shields.io/badge/maintenance-activly--developed-brightgreen.svg)
# arangors
[![Build Status](https://github.com/fMeow/arangors/workflows/CI%20%28Linux%29/badge.svg?branch=main)](https://github.com/fMeow/arangors/actions)
[![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)](./LICENSE)
[![Crates.io](https://img.shields.io/crates/v/arangors.svg)](https://crates.io/crates/arangors)
[![arangors](https://docs.rs/arangors/badge.svg)](https://docs.rs/arangors)`arangors` is an intuitive rust client for [ArangoDB](https://www.arangodb.com/),
inspired by [pyArango](https://github.com/tariqdaouda/pyArango).`arangors` enables you to connect with ArangoDB server, access to database,
execute AQL query, manage ArangoDB in an easy and intuitive way,
both `async` and plain synchronous code with any HTTP ecosystem you love.## Philosophy of arangors
`arangors` is targeted at ergonomic, intuitive and OOP-like API for
ArangoDB, both top level and low level API for users' choice.Overall architecture of ArangoDB:
> databases -> collections -> documents/edges
In fact, the design of `arangors` just mimic this architecture, with a
slight difference that in the top level, there is a connection object on top
of databases, containing a HTTP client with authentication information in
HTTP headers.Hierarchy of arangors:
> connection -> databases -> collections -> documents/edges## Features & TODO
- [X] make connection to ArangoDB
- [X] get list of databases and collections
- [X] fetch database and collection info
- [X] create and delete database or collections
- [X] full featured AQL query
- [X] Synchronous connection based on `reqwest` and full featured AQL query.
- [X] Fill the unimplemented API in `Connection`, `Database`, `Collection` and `Document`.
- [X] support both `async` and sync client
- [X] Offers a way to use custom HTTP client ecosystem.
- [X] Index Management (since 0.4.3)
- [X] Graph Management (since 0.4.5)
- [X] User Management (since 0.5.4)## Glance
### Use Different HTTP Ecosystem, Regardless of Async or Sync
You can switch to different HTTP ecosystem with a feature gate, or implement
the Client yourself (see examples).Currently out-of-box supported ecosystem are:
- `reqwest_async`
- `reqwest_blocking`
- `surf_async`By default, `arangors` use `reqwest_async` as underling HTTP Client to
connect with ArangoDB. You can switch other ecosystem in feature gate:```toml
[dependencies]
arangors = { version = "0.6", features = ["surf_async"], default-features = false }
```Or if you want to stick with other ecosystem that are not listed in the
feature gate, you can get vanilla `arangors` without any HTTP client
dependency:```toml
[dependencies]
## This one is async
arangors = { version = "0.6", default-features = false }
## This one is synchronous
arangors = { version = "0.6", features = ["blocking"], default-features = false }
```Thanks to `maybe_async`, `arangors` can unify sync and async API and toggle
with a feature gate. Arangors adopts async first policy.### Connection
There is three way to establish connections:
- jwt
- basic auth
- no authenticationSo are the `arangors` API.
Example:
- With authentication
```rust
use arangors::Connection;// (Recommended) Handy functions
let conn = Connection::establish_jwt("http://localhost:8529", "username", "password")
.await
.unwrap();
let conn = Connection::establish_basic_auth("http://localhost:8529", "username", "password")
.await
.unwrap();
```- Without authentication
**Only use in evaluation setting**.
``` rust
use arangors::Connection;
let conn = Connection::establish_without_auth("http://localhost:8529").await.unwrap();
```## Database && Collection
To get info or operate on database or collections:
```rust
use arangors::Connection;let db = conn.db("test_db").await.unwrap();
let collection = db.collection("test_collection").await.unwrap();
```### AQL Query
All [AQL](https://www.arangodb.com/docs/stable/aql/index.html) query related functions are associated with database, as AQL query
is performed at database level.There are several way to execute AQL query, and can be categorized into two
classes:- batch query with cursor
- `aql_query_batch`
- `aql_next_batch`- query to fetch all results
- `aql_str`
- `aql_bind_vars`
- `aql_query`This later ones provide a convenient high level API, whereas batch
queries offer more control.#### Typed or Not Typed
Note that results from ArangoDB server, e.x. fetched documents, can be
strong typed given deserializable struct, or arbitrary JSON object with
`serde::Value`.```rust
#[derive(Deserialize, Debug)]
struct User {
pub username: String,
pub password: String,
}// Typed
let resp: Vec = db
.aql_str("FOR u IN test_collection RETURN u")
.await
.unwrap();
// Not typed: Arbitrary JSON objects
let resp: Vec = db
.aql_str("FOR u IN test_collection RETURN u")
.await
.unwrap();
```#### Batch query
`arangors` offers a way to manually handle batch query.
Use `aql_query_batch` to get a cursor, and use `aql_next_batch` to fetch
next batch and update cursor with the cursor.```rust
let aql = AqlQuery::builder()
.query("FOR u IN @@collection LIMIT 3 RETURN u")
.bind_var("@collection", "test_collection")
.batch_size(1)
.count(true)
.build();// fetch the first cursor
let mut cursor = db.aql_query_batch(aql).await.unwrap();
// see metadata in cursor
println!("count: {:?}", cursor.count);
println!("cached: {}", cursor.cached);
let mut results: Vec = Vec::new();
loop {
if cursor.more {
let id = cursor.id.unwrap().clone();
// save data
results.extend(cursor.result.into_iter());
// update cursor
cursor = db.aql_next_batch(id.as_str()).await.unwrap();
} else {
break;
}
}
println!("{:?}", results);
```#### Fetch All Results
There are three functions for AQL query that fetch all results from
ArangoDB. These functions internally fetch batch results one after another
to get all results.The functions for fetching all results are listed as bellow:
##### `aql_str`
This function only accept a AQL query string.
Here is an example of strong typed query result with `aql_str`:
```rust
#[derive(Deserialize, Debug)]
struct User {
pub username: String,
pub password: String,
}let result: Vec = db
.aql_str(r#"FOR i in test_collection FILTER i.username=="test2" return i"#)
.await
.unwrap();
```##### `aql_bind_vars`
This function can be used to start a AQL query with bind variables.
```rust
use arangors::{Connection, Document};#[derive(Serialize, Deserialize, Debug)]
struct User {
pub username: String,
pub password: String,
}let mut vars = HashMap::new();
let user = User {
username: "test".to_string(),
password: "test_pwd".to_string(),
};
vars.insert("user", serde_json::value::to_value(&user).unwrap());
let result: Vec> = db
.aql_bind_vars(r#"FOR i in test_collection FILTER i==@user return i"#, vars)
.await
.unwrap();
```##### `aql_query`
This function offers all the options available to tweak a AQL query.
Users have to construct a `AqlQuery` object first. And `AqlQuery` offer all
the options needed to tweak AQL query. You can set batch size, add bind
vars, limit memory, and all others
options available.```rust
use arangors::{AqlQuery, Connection, Cursor, Database};
use serde_json::value::Value;let aql = AqlQuery::builder()
.query("FOR u IN @@collection LIMIT 3 RETURN u")
.bind_var("@collection", "test_collection")
.batch_size(1)
.count(true)
.build();let resp: Vec = db.aql_query(aql).await.unwrap();
println!("{:?}", resp);
```### Contributing
Contributions and feed back are welcome following Github workflow.
### License
`arangors` is provided under the MIT license. See [LICENSE](./LICENSE).
An ergonomic [ArangoDB](https://www.arangodb.com/) client for rust.License: MIT