2023-05-22 19:19:35 +00:00
|
|
|
use crate::cli::abstraction::{
|
|
|
|
AuthArguments, DatabaseConnectionArguments, DatabaseSelectionArguments,
|
|
|
|
};
|
2022-02-16 23:45:23 +00:00
|
|
|
use crate::err::Error;
|
2023-05-22 19:19:35 +00:00
|
|
|
use clap::Args;
|
2023-01-07 08:32:18 +00:00
|
|
|
use surrealdb::engine::any::connect;
|
2022-12-31 08:02:41 +00:00
|
|
|
use surrealdb::opt::auth::Root;
|
2020-06-29 15:36:01 +00:00
|
|
|
|
2023-05-22 19:19:35 +00:00
|
|
|
#[derive(Args, Debug)]
|
|
|
|
pub struct ExportCommandArguments {
|
|
|
|
#[arg(help = "Path to the sql file to export. Use dash - to write into stdout.")]
|
|
|
|
#[arg(default_value = "-")]
|
|
|
|
#[arg(index = 1)]
|
|
|
|
file: String,
|
|
|
|
|
|
|
|
#[command(flatten)]
|
|
|
|
conn: DatabaseConnectionArguments,
|
|
|
|
#[command(flatten)]
|
|
|
|
auth: AuthArguments,
|
|
|
|
#[command(flatten)]
|
|
|
|
sel: DatabaseSelectionArguments,
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn init(
|
|
|
|
ExportCommandArguments {
|
|
|
|
file,
|
|
|
|
conn: DatabaseConnectionArguments {
|
|
|
|
endpoint,
|
|
|
|
},
|
|
|
|
auth: AuthArguments {
|
|
|
|
username,
|
|
|
|
password,
|
|
|
|
},
|
|
|
|
sel: DatabaseSelectionArguments {
|
|
|
|
namespace: ns,
|
|
|
|
database: db,
|
|
|
|
},
|
|
|
|
}: ExportCommandArguments,
|
|
|
|
) -> Result<(), Error> {
|
2023-03-29 18:16:18 +00:00
|
|
|
// Initialize opentelemetry and logging
|
2023-07-19 14:35:56 +00:00
|
|
|
crate::telemetry::builder().with_log_level("error").init();
|
2023-05-22 19:19:35 +00:00
|
|
|
|
2022-12-31 08:02:41 +00:00
|
|
|
let root = Root {
|
2023-05-22 19:19:35 +00:00
|
|
|
username: &username,
|
|
|
|
password: &password,
|
2022-12-31 08:02:41 +00:00
|
|
|
};
|
2023-06-09 13:45:07 +00:00
|
|
|
// Connect to the database engine
|
2023-07-04 10:25:59 +00:00
|
|
|
#[cfg(feature = "has-storage")]
|
2023-07-03 20:23:18 +00:00
|
|
|
let address = (endpoint, root);
|
2023-07-04 10:25:59 +00:00
|
|
|
#[cfg(not(feature = "has-storage"))]
|
2023-07-03 20:23:18 +00:00
|
|
|
let address = endpoint;
|
|
|
|
let client = connect(address).await?;
|
2023-06-09 13:45:07 +00:00
|
|
|
// Sign in to the server
|
|
|
|
client.signin(root).await?;
|
2022-12-31 08:02:41 +00:00
|
|
|
// Use the specified namespace / database
|
|
|
|
client.use_ns(ns).use_db(db).await?;
|
|
|
|
// Export the data from the database
|
|
|
|
client.export(file).await?;
|
2023-07-04 21:02:10 +00:00
|
|
|
info!("The SQL file was exported successfully");
|
2022-07-19 11:57:59 +00:00
|
|
|
// Everything OK
|
2020-06-29 15:36:01 +00:00
|
|
|
Ok(())
|
|
|
|
}
|