naphtha icon indicating copy to clipboard operation
naphtha copied to clipboard

Universal database connection layer for your application in Rust. Implements the most common functions insert, update and remove for database connections. Change the database without having to adjust...

naphtha

Universal database connection layer

License

Crates.io docs.rs naphtha

Crates.io naphtha-proc-macro

Please checkout the documentation page for more information (also see examples folder in naphtha)

About

This crate is to simplify the creation and usage of models that require a database connection. If applied correct, changing the database type is only a feature flag away.

The models can also be compiled and used without database connection support for better usage on server and client side.

Roadmap

  • [x] Connect to database using a wrapper, defining the base for interchangeable Databases
  • [x] Implement support for diesel::SQLiteConnection
  • [x] Create traits to enable database interaction before and after the execution of the insert, update or remove transactions
  • [x] Implement query_by_{property} for querying models from the database using an exact match of the given property
  • [x] Thread safe sharing of the database connection
  • [x] Integrate barrel crate for writing migrations in Rust, available at runtime
  • [x] Implement support for diesel::MySqlConnection
  • [x] Implement support for diesel::PgConnection
  • [ ] Connection pooling?
  • [ ] More databases?

Troubleshooting

It is very easy to get a whole bunch of trait bound not satisfied error messages when your model is not configured correctly. Make sure that your schema module and the containing table! definition is in line with your model definition and that it uses the correct types defined by barrel.

Contributing

Unless explicitly stated, any contribution intentionally submitted for inclusion in this project, as defined in the Apache-2.0 license, shall be dual licensed as below, without any additional terms or conditions.

License

Licensed under either of

  • Apache License, Version 2.0 (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
  • MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)

at your option.