Scrapping the APi because rocket is not mature enough for this project
This commit is contained in:
parent
1c9d0a6207
commit
44530ff327
1678
Cargo.lock
generated
1678
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
1602
api/Cargo.lock
generated
1602
api/Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@ -1,10 +0,0 @@
|
|||||||
[package]
|
|
||||||
name = "api"
|
|
||||||
version = "0.1.0"
|
|
||||||
edition = "2021"
|
|
||||||
|
|
||||||
[dependencies]
|
|
||||||
tokio = { version = "1", features = [ "full" ] }
|
|
||||||
serde = "1.0.213"
|
|
||||||
rocket = { version = "0.5.1", features = [ "json" ] }
|
|
||||||
clap = { version = "4.5.20", features = ["derive"] }
|
|
@ -1,41 +0,0 @@
|
|||||||
use serde::Serialize;
|
|
||||||
use rocket::serde::json::Json;
|
|
||||||
|
|
||||||
#[derive(Serialize)]
|
|
||||||
enum Type {
|
|
||||||
Voice,
|
|
||||||
Text,
|
|
||||||
Video
|
|
||||||
}
|
|
||||||
#[derive(Serialize)]
|
|
||||||
struct Channel {
|
|
||||||
id: i64,
|
|
||||||
name: String,
|
|
||||||
desc: Option<String>,
|
|
||||||
r#type: Type
|
|
||||||
}
|
|
||||||
|
|
||||||
#[get("/list")]
|
|
||||||
pub async fn list() -> Json<Vec<Channel>> {
|
|
||||||
// TODO
|
|
||||||
Json(vec![])
|
|
||||||
}
|
|
||||||
|
|
||||||
#[post("/create")]
|
|
||||||
pub async fn create() -> Json<Option<Channel>> {
|
|
||||||
// TODO
|
|
||||||
Json(None)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[delete("/delete")]
|
|
||||||
pub async fn delete() -> Json<Option<i64>> {
|
|
||||||
// TODO
|
|
||||||
Json(None)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[post("/update")]
|
|
||||||
pub async fn update() -> Json<Option<Channel>> {
|
|
||||||
// TODO
|
|
||||||
Json(None)
|
|
||||||
}
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
|||||||
use rocket::serde::json::Json;
|
|
||||||
use serde::Serialize;
|
|
||||||
|
|
||||||
#[derive(Serialize)]
|
|
||||||
pub struct User {
|
|
||||||
id: i64,
|
|
||||||
name: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[get("/<id>")]
|
|
||||||
pub async fn invite_user(id: i64) -> Json<Option<User>> {
|
|
||||||
// First we check to see if the id is present in the invites table
|
|
||||||
Json(None)
|
|
||||||
}
|
|
@ -1,48 +0,0 @@
|
|||||||
#[macro_use] extern crate rocket;
|
|
||||||
use std::env;
|
|
||||||
|
|
||||||
use clap::Parser;
|
|
||||||
mod invites;
|
|
||||||
mod channels;
|
|
||||||
|
|
||||||
struct Config {
|
|
||||||
postgres_user: String,
|
|
||||||
postgrse_pass: String
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Parser)]
|
|
||||||
#[command(version, about, long_about = None)]
|
|
||||||
struct Args {
|
|
||||||
/// Set the postgres username to use for the API ( default is bubble_admin )
|
|
||||||
#[arg(short, long, default_value = "bubble_admin")]
|
|
||||||
psql_user: String,
|
|
||||||
/// Set the postgres password to use for the API ( Uses POSTGRES_PASSWORD
|
|
||||||
/// environment variable by default )
|
|
||||||
psql_pass: Option<String>,
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#[rocket::main]
|
|
||||||
async fn main() -> Result<(), rocket::Error> {
|
|
||||||
let args = Args::parse();
|
|
||||||
let psql_pass = match args.psql_pass {
|
|
||||||
Some(pass) => pass,
|
|
||||||
None => match env::var("PSQL_PASS") {
|
|
||||||
Ok(pass) => pass,
|
|
||||||
Err(_) => panic!("PSQL_PASS is not set!")
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
let _ = rocket::build()
|
|
||||||
.mount("/channels", routes![
|
|
||||||
channels::list,
|
|
||||||
channels::create,
|
|
||||||
channels::delete
|
|
||||||
])
|
|
||||||
.mount("/invite", routes![invites::invite_user])
|
|
||||||
.ignite().await?
|
|
||||||
.launch().await?;
|
|
||||||
Ok(())
|
|
||||||
}
|
|
@ -16,3 +16,10 @@ CREATE TABLE IF NOT EXISTS invites (
|
|||||||
expires INTEGER,
|
expires INTEGER,
|
||||||
PRIMARY KEY (id)
|
PRIMARY KEY (id)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS channels (
|
||||||
|
id BIGINT,
|
||||||
|
name varchar(256),
|
||||||
|
description varchar(256),
|
||||||
|
PRIMARY KEY (id)
|
||||||
|
);
|
||||||
|
8
dev.py
8
dev.py
@ -23,6 +23,12 @@ if __name__ == '__main__':
|
|||||||
'--check-container',
|
'--check-container',
|
||||||
help='Execs into the given container with bash for debugging'
|
help='Execs into the given container with bash for debugging'
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'-a',
|
||||||
|
'--api-run',
|
||||||
|
help='Runs the debug version of the api',
|
||||||
|
action='store_true'
|
||||||
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
os.environ['DB_CONNECTION_STRING'] = args.db_url
|
os.environ['DB_CONNECTION_STRING'] = args.db_url
|
||||||
if args.init_db:
|
if args.init_db:
|
||||||
@ -33,3 +39,5 @@ if __name__ == '__main__':
|
|||||||
)
|
)
|
||||||
if args.check_container:
|
if args.check_container:
|
||||||
run(f'docker exec -it {args.check_container} bash'.split())
|
run(f'docker exec -it {args.check_container} bash'.split())
|
||||||
|
if args.api_run:
|
||||||
|
run( f'cargo run --bin api -- -p {args.db_url}'.split())
|
||||||
|
Loading…
Reference in New Issue
Block a user