mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2024-12-22 11:21:24 +00:00
Implement first query
This commit is contained in:
parent
5167fe331e
commit
8eb4cda256
4 changed files with 31 additions and 16 deletions
|
@ -72,6 +72,9 @@ pub(crate) enum RepoError {
|
|||
#[error("Error in sled")]
|
||||
SledError(#[from] crate::repo::sled::SledError),
|
||||
|
||||
#[error("Error in postgres")]
|
||||
PostgresError(#[from] crate::repo::postgres::PostgresError),
|
||||
|
||||
#[error("Upload was already claimed")]
|
||||
AlreadyClaimed,
|
||||
|
||||
|
|
|
@ -1,20 +1,17 @@
|
|||
mod embedded {
|
||||
use refinery::embed_migrations;
|
||||
|
||||
embed_migrations!("./src/repo/postgres/migrations");
|
||||
}
|
||||
mod embedded;
|
||||
mod schema;
|
||||
|
||||
use diesel::prelude::*;
|
||||
use diesel_async::{
|
||||
pooled_connection::{
|
||||
deadpool::{BuildError, Pool},
|
||||
deadpool::{BuildError, Pool, PoolError},
|
||||
AsyncDieselConnectionManager,
|
||||
},
|
||||
AsyncPgConnection,
|
||||
AsyncPgConnection, RunQueryDsl,
|
||||
};
|
||||
use url::Url;
|
||||
|
||||
use super::{BaseRepo, HashRepo};
|
||||
use super::{BaseRepo, HashRepo, RepoError};
|
||||
|
||||
#[derive(Clone)]
|
||||
pub(crate) struct PostgresRepo {
|
||||
|
@ -34,7 +31,13 @@ pub(crate) enum ConnectPostgresError {
|
|||
}
|
||||
|
||||
#[derive(Debug, thiserror::Error)]
|
||||
enum PostgresError {}
|
||||
pub(crate) enum PostgresError {
|
||||
#[error("Error in db pool")]
|
||||
Pool(#[source] PoolError),
|
||||
|
||||
#[error("Error in database")]
|
||||
Diesel(#[source] diesel::result::Error),
|
||||
}
|
||||
|
||||
impl PostgresRepo {
|
||||
pub(crate) async fn connect(postgres_url: Url) -> Result<Self, ConnectPostgresError> {
|
||||
|
@ -64,14 +67,22 @@ impl PostgresRepo {
|
|||
|
||||
impl BaseRepo for PostgresRepo {}
|
||||
|
||||
/*
|
||||
#[async_trait::async_trait]
|
||||
#[async_trait::async_trait(?Send)]
|
||||
impl HashRepo for PostgresRepo {
|
||||
async fn size(&self) -> Result<u64, RepoError> {
|
||||
let conn = self.pool.get().await.map_err(PostgresError::from)?;
|
||||
use schema::hashes::dsl::*;
|
||||
|
||||
let mut conn = self.pool.get().await.map_err(PostgresError::Pool)?;
|
||||
|
||||
let count = hashes
|
||||
.count()
|
||||
.get_result::<i64>(&mut conn)
|
||||
.await
|
||||
.map_err(PostgresError::Diesel)?;
|
||||
|
||||
Ok(count.try_into().expect("non-negative count"))
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
impl std::fmt::Debug for PostgresRepo {
|
||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||
|
|
3
src/repo/postgres/embedded.rs
Normal file
3
src/repo/postgres/embedded.rs
Normal file
|
@ -0,0 +1,3 @@
|
|||
use refinery::embed_migrations;
|
||||
|
||||
embed_migrations!("./src/repo/postgres/migrations");
|
|
@ -24,7 +24,5 @@ pub(crate) fn migration() -> String {
|
|||
);
|
||||
});
|
||||
|
||||
let s = m.make::<Pg>().to_string();
|
||||
println!("{s}");
|
||||
s
|
||||
m.make::<Pg>().to_string()
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue