systemprompt_database/
lib.rs1pub mod admin;
2pub mod error;
3pub mod extension;
4pub mod lifecycle;
5pub mod models;
6#[macro_use]
7pub mod repository;
8pub mod services;
9
10pub use extension::DatabaseExtension;
11
12pub use models::{
13 ArtifactId, ClientId, ColumnInfo, ContentId, ContextId, DatabaseInfo, DatabaseQuery,
14 DatabaseTransaction, DbValue, ExecutionStepId, FileId, FromDatabaseRow, FromDbValue, IndexInfo,
15 JsonRow, LogId, QueryResult, QueryRow, QuerySelector, SessionId, SkillId, TableInfo, TaskId,
16 ToDbValue, TokenId, TraceId, UserId, parse_database_datetime,
17};
18
19pub use services::{
20 BoxFuture, Database, DatabaseCliDisplay, DatabaseExt, DatabaseProvider, DatabaseProviderExt,
21 DbPool, PostgresProvider, SqlExecutor, with_transaction, with_transaction_raw,
22 with_transaction_retry,
23};
24
25pub use error::RepositoryError;
26pub use lifecycle::{
27 AppliedMigration, MigrationResult, MigrationService, MigrationStatus, ModuleInstaller,
28 install_extension_schemas, install_extension_schemas_with_config,
29 install_module_schemas_from_source, install_module_seeds_from_path, install_schema,
30 install_seed, validate_column_exists, validate_database_connection, validate_table_exists,
31};
32pub use repository::{
33 CleanupRepository, CreateServiceInput, DatabaseInfoRepository, PgDbPool, ServiceConfig,
34 ServiceRepository,
35};
36
37pub use admin::{DatabaseAdminService, QueryExecutor, QueryExecutorError};
38pub use sqlx::types::Json;
39pub use sqlx::{PgPool, Pool, Postgres, Transaction};
40
41use systemprompt_traits::DatabaseHandle;
42
43impl DatabaseHandle for Database {
44 fn is_connected(&self) -> bool {
45 true
46 }
47
48 fn as_any(&self) -> &dyn std::any::Any {
49 self
50 }
51}