You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
73 lines
2.1 KiB
73 lines
2.1 KiB
use std::ops::Deref;
|
|
|
|
use diesel::r2d2;
|
|
use diesel::r2d2::ConnectionManager;
|
|
#[cfg(feature = "sqlite")]
|
|
use diesel::sqlite::SqliteConnection;
|
|
#[cfg(feature = "mysql")]
|
|
use diesel::mysql::MysqlConnection;
|
|
use diesel::{Connection as DieselConnection, ConnectionError};
|
|
|
|
use rocket::http::Status;
|
|
use rocket::request::{self, FromRequest};
|
|
use rocket::{Outcome, Request, State};
|
|
|
|
use crate::CONFIG;
|
|
|
|
/// An alias to the database connection used
|
|
#[cfg(feature = "sqlite")]
|
|
type Connection = SqliteConnection;
|
|
#[cfg(feature = "mysql")]
|
|
type Connection = MysqlConnection;
|
|
|
|
/// An alias to the type for a pool of Diesel MySQL connections.
|
|
type Pool = r2d2::Pool<ConnectionManager<Connection>>;
|
|
|
|
/// Connection request guard type: a wrapper around an r2d2 pooled connection.
|
|
pub struct DbConn(pub r2d2::PooledConnection<ConnectionManager<Connection>>);
|
|
|
|
pub mod models;
|
|
#[cfg(feature = "sqlite")]
|
|
#[path = "schemas/sqlite/schema.rs"]
|
|
pub mod schema;
|
|
#[cfg(feature = "mysql")]
|
|
#[path = "schemas/mysql/schema.rs"]
|
|
pub mod schema;
|
|
|
|
|
|
/// Initializes a database pool.
|
|
pub fn init_pool() -> Pool {
|
|
let manager = ConnectionManager::new(CONFIG.database_url());
|
|
|
|
r2d2::Pool::builder().build(manager).expect("Failed to create pool")
|
|
}
|
|
|
|
pub fn get_connection() -> Result<Connection, ConnectionError> {
|
|
let url = CONFIG.database_url();
|
|
println!("{}", url.to_string());
|
|
Connection::establish(&url)
|
|
}
|
|
|
|
/// Attempts to retrieve a single connection from the managed database pool. If
|
|
/// no pool is currently managed, fails with an `InternalServerError` status. If
|
|
/// no connections are available, fails with a `ServiceUnavailable` status.
|
|
impl<'a, 'r> FromRequest<'a, 'r> for DbConn {
|
|
type Error = ();
|
|
|
|
fn from_request(request: &'a Request<'r>) -> request::Outcome<DbConn, ()> {
|
|
let pool = request.guard::<State<Pool>>()?;
|
|
match pool.get() {
|
|
Ok(conn) => Outcome::Success(DbConn(conn)),
|
|
Err(_) => Outcome::Failure((Status::ServiceUnavailable, ())),
|
|
}
|
|
}
|
|
}
|
|
|
|
// For the convenience of using an &DbConn as a &Database.
|
|
impl Deref for DbConn {
|
|
type Target = Connection;
|
|
fn deref(&self) -> &Self::Target {
|
|
&self.0
|
|
}
|
|
}
|