30 releases (16 stable)

4.0.0 Mar 9, 2023
3.0.4 Dec 27, 2022
3.0.3 Aug 16, 2022
3.0.2 Jun 17, 2022
0.12.1 Mar 1, 2018

#251 in Database implementations

Download history 128/week @ 2024-11-30 279/week @ 2024-12-07 142/week @ 2024-12-14 44/week @ 2024-12-21 34/week @ 2024-12-28 112/week @ 2025-01-04 73/week @ 2025-01-11 82/week @ 2025-01-18 30/week @ 2025-01-25 94/week @ 2025-02-01 92/week @ 2025-02-08 71/week @ 2025-02-15 112/week @ 2025-02-22 53/week @ 2025-03-01 77/week @ 2025-03-08 100/week @ 2025-03-15

367 downloads per month
Used in 69 crates (54 directly)

MPL-2.0 license

215KB
4.5K SLoC

IndraDB library Docs

This is the IndraDB library. Most users can use the server, which provides higher-level methods for working with IndraDB databases. Linking directly against the library would be necessary if you want to make a new datastore implementation, or if you want to work at a lower-level than the server affords.

Pluggable datastores

IndraDB stores graph data in datastores. Datastores are pluggable: there are a few built-in ones, but you can implement a new custom datastore.

In-memory

To use the in-memory datastore, add this to your Cargo.toml's dependencies section:

indradb-lib = "*"

RocksDB

To use the rocksdb datastore, add this to your Cargo.toml's dependencies section:

indradb-lib = { version = "*", features = ["rocksdb-datastore"] }

Custom datastores

To implement a custom datastore, you need to implement the Datastore trait. See the in-memory datastore for a simpler example implementation. To help you get off the ground faster, there is a standard test suite that can execute against any datastore and check for common bugs and regressions. See the in-memory datastore tests for an implementation of it.

Dependencies

~6–19MB
~293K SLoC