aboutsummaryrefslogtreecommitdiffstats
path: root/src/server/state/database.rs
diff options
context:
space:
mode:
authorrtkay123 <dev@kanjala.com>2026-02-01 13:33:07 +0200
committerrtkay123 <dev@kanjala.com>2026-02-01 13:33:07 +0200
commitce65d9eeafcd1f9d5c3adef1c9b1af6258ee711a (patch)
tree953f6c49f8affd667ec740a949b2d93f82b7d31b /src/server/state/database.rs
parent6a9d21bc87f8a738e14f27a1305bf04d0c4b7a0c (diff)
downloadsellershut-ce65d9eeafcd1f9d5c3adef1c9b1af6258ee711a.tar.bz2
sellershut-ce65d9eeafcd1f9d5c3adef1c9b1af6258ee711a.zip
feat: conn to db
Diffstat (limited to 'src/server/state/database.rs')
-rw-r--r--src/server/state/database.rs17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/server/state/database.rs b/src/server/state/database.rs
new file mode 100644
index 0000000..32d3f98
--- /dev/null
+++ b/src/server/state/database.rs
@@ -0,0 +1,17 @@
+use anyhow::Result;
+use sqlx::{PgPool, postgres::PgPoolOptions};
+use tracing::{debug, trace};
+
+use crate::config::DatabaseOptions;
+
+
+pub(super) async fn connect(opts: &DatabaseOptions) -> Result<PgPool> {
+ trace!(host = ?opts.url.host(), "connecting to database");
+ let pg = PgPoolOptions::new()
+ .max_connections(opts.pool_size)
+ .connect(opts.url.as_str())
+ .await?;
+ debug!(host = ?opts.url.host(), "connected to database");
+
+ Ok(pg)
+}