https://github.com/h2co3/avocado
  
  
    Strongly-typed MongoDB driver for Rust 
    https://github.com/h2co3/avocado
  
bson bson-document database databases json json-schema mongo mongodb mongodb-driver
        Last synced: 1 day ago 
        JSON representation
    
Strongly-typed MongoDB driver for Rust
- Host: GitHub
- URL: https://github.com/h2co3/avocado
- Owner: H2CO3
- License: mit
- Created: 2018-07-12T18:13:30.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-07-07T12:49:47.000Z (over 6 years ago)
- Last Synced: 2025-01-29T10:21:20.382Z (9 months ago)
- Topics: bson, bson-document, database, databases, json, json-schema, mongo, mongodb, mongodb-driver
- Language: Rust
- Size: 275 KB
- Stars: 80
- Watchers: 4
- Forks: 2
- Open Issues: 3
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE.txt
 
Awesome Lists containing this project
README
          # Avocado, the strongly-typed MongoDB driver
[](https://crates.io/crates/avocado)
[](https://docs.rs/avocado)
[](https://blog.rust-lang.org/2019/01/17/Rust-1.32.0.html)
[](https://crates.io/crates/avocado)
[](https://github.com/H2CO3/avocado/blob/master/LICENSE.txt)
[](https://github.com/Aaronepower/tokei)
[](http://twitter.com/H2CO3_iOS)
[](https://github.com/H2CO3/avocado/search?q=goto)
[](https://github.com/H2CO3/avocado/search?q=unsafe)
[](https://github.com/H2CO3/avocado/search?q=fuck)
## Usage
* See the [online documentation](https://docs.rs/avocado) above, or open it locally:
* `cargo doc --open`
* Check out the [`examples/`](https://github.com/H2CO3/avocado/blob/master/examples/) folder
* More high-level information can be found on the [project page](https://h2co3.github.io/avocado/).
* The `schema_validation` feature can be enabled (it's enabled by default), in which case the `DatabaseExt::empty_collection()` method becomes available. If a collection is created using this method, it will add a JSON schema validation pass and specify the schema as generated by [`magnet`](https://github.com/H2CO3/magnet).
* The `raw_uuid` feature (also enabled by default) adds some useful extension methods to make it more convenient to work with UUIDs as the type of the `_id` field.
    **This can potentially be slow if you are performing many insertions into a collection of a complex type. However, it dynamically ensures that other users/drivers can't put malformed data in the collection.** Therefore it's probably more useful if you or somebody else are accessing a database from outside the Avocado driver too. It's also great for debugging Avocado itself.
## Changelog
### v0.6.0
* Fix [#6](https://github.com/H2CO3/avocado/issues/6) by adding a context dictionary to `Error`.
### v0.5.0
* Fix [#5](https://github.com/H2CO3/avocado/issues/5) by adding an `#[options(...)]` attribute to the `Doc` derive proc-macro.
### v0.4.0
* Fix [#2](https://github.com/H2CO3/avocado/issues/2) by adding a `&self` parameter to the `options()` methods on `ops::` traits.
### v0.3.3
* Fix a deprecation warning related to `Uuid::from_random_bytes()`
* Catch some errors that incorrectly pass through the MongoDB client's `Cursor` API
### v0.3.2
* Added a `remove_inner_doc()` method to `DocumentExt`. This allows for the easy chaining of removal from hierarchically contained `Document`s in `transform()`.
* Fixed a bug where inserting 0 entities into a collection failed.
* Fixed the incorrect ordering of the key and the value type in the error message generated by `DocumentExt::remove_*()` methods.
### v0.3.1
* Added a `DocumentExt` trait to the prelude for convenient and idiomatic implementation of `transform(raw: Document) -> Result` methods
* Hopefully fixed the code so that docs.rs can handle it now
### v0.3.0
* Added `Doc::id()` and `Doc::set_id()` methods for the sake of better efficiency in some `Collection` methods
    * This means that single-element wrappers such as `Box` and `RefCell` can no longer implement `Doc` themselves
* Added `Collection::find_one_and_delete()`,  `Collection::find_one_and_replace()`, and `Collection::find_one_and_update()` methods
* Added more documentation and clarified/improved existing docs
* Added more tests, including compile-time tests for cases when `#[derive(Doc)]` should fail, as well as testing that an optional `_id` is correctly allowed
## Compile-time testing the derive macro
Due to a bug in `compiletest_rs`, running the tests that check the error
messages of the `#[derive(Doc)]` proc-macro requires running `cargo clean`
first, otherwise compilation will fail with `E0464`.
Therefore, the recommended way of running the tests is:
    cargo clean && cargo test
## TODO:
* Add `weights` property to text indices
* Add migrations
* Default `Doc::Id` to `ObjectId` and `Query::Output` and `FindAndUpdate::Output` to `T`, once [#29661](https://github.com/rust-lang/rust/issues/29661) is stabilized