BonsaiDb's networked database implementation.
This crate implements BonsaiDb's networked database implementation. The
Server
and CustomServer<Backend>
types provide their most common functionality by implementing the
StorageConnection
.
This crate supports two methods for exposing a BonsaiDb server: QUIC and WebSockets.
QUIC is a new protocol built atop UDP. It is designed to operate more reliably than TCP, and features TLS built-in at the protocol level. WebSockets are an established protocol built atop TCP and HTTP.
Our user's guide has a section covering setting up and accessing a BonsaiDb server.
By default, the full
feature is enabled. These features are prefixed by
server-
when being enabled from the omnibus bonsaidb
crate.
full
: Enables all the flags below,acme
: Enables automtic certificate acquisition through ACME/LetsEncrypt.cli
: Enables the cli
module.encryption
: Enables at-rest encryption.hyper
: Enables convenience functions for upgrading websockets using hyper
.instrument
: Enables instrumenting with tracing
.pem
: Enables the ability to install a certificate using the PEM format.websockets
: Enables WebSocket
support.password-hashing
: Enables the ability to use password authentication
using Argon2.This project, like all projects from Khonsu Labs, are open-source. This repository is available under the MIT License or the Apache License 2.0.
To learn more about contributing, please see CONTRIBUTING.md.