ferri/ferri-cli/src/main.rs

56 lines
1.2 KiB
Rust
Raw Normal View History

2025-04-10 19:40:50 +01:00
use server::launch;
extern crate rocket;
use sqlx::sqlite::SqlitePool;
use std::env;
use clap::Parser;
#[derive(Parser)]
#[command(version, about, long_about = None)]
struct Cli {
2025-04-11 12:29:29 +01:00
#[arg(short, long)]
init: bool,
2025-04-10 19:40:50 +01:00
}
#[rocket::main]
async fn main() {
2025-04-11 12:29:29 +01:00
let cli = Cli::parse();
if cli.init {
// Seed DB
let pool = SqlitePool::connect(&env::var("DATABASE_URL").unwrap())
.await
.unwrap();
let mut conn = pool.acquire().await.unwrap();
sqlx::query!(
r#"
2025-04-10 19:40:50 +01:00
INSERT INTO actor (id, inbox, outbox)
VALUES (?1, ?2, ?3)
2025-04-11 12:29:29 +01:00
"#,
"https://ferri.amy.mov/users/amy",
"https://ferri.amy.mov/users/amy/inbox",
"https://ferri.amy.mov/users/amy/outbox"
)
.execute(&mut *conn)
.await
.unwrap();
2025-04-10 19:40:50 +01:00
2025-04-11 12:29:29 +01:00
sqlx::query!(
r#"
INSERT INTO user (id, username, actor_id, display_name)
VALUES (?1, ?2, ?3, ?4)
"#,
"9b9d497b-2731-435f-a929-e609ca69dac9",
"amy",
"https://ferri.amy.mov/users/amy",
"amy"
)
.execute(&mut *conn)
.await
.unwrap();
} else {
let _ = launch().launch().await;
}
2025-04-10 19:40:50 +01:00
}