diff --git a/src/guards/channel.rs b/src/guards/channel.rs index 5681ee957be3a79348afb14061b7d0676e008e3c..9142c178e2570e8ad0bb0802c4487386c0f453e4 100644 --- a/src/guards/channel.rs +++ b/src/guards/channel.rs @@ -30,7 +30,7 @@ impl<'r> FromParam<'r> for Channel { if let Some(channel) = result { Ok(Channel ( Ulid::from_string(channel.get_str("_id").unwrap()).unwrap(), - ChannelType::try_from(channel.get_i32("username").unwrap() as usize).unwrap(), + ChannelType::try_from(channel.get_i32("type").unwrap() as usize).unwrap(), channel )) } else { diff --git a/src/routes/channel.rs b/src/routes/channel.rs index c7c8f11c3ba4d235ef42494ae2cb1309bc491a0a..3517c09203b3bc5696b3353d569c3d2bc6ba2a6f 100644 --- a/src/routes/channel.rs +++ b/src/routes/channel.rs @@ -1,4 +1,4 @@ -use crate::guards::auth::User; +use crate::guards::{ auth::User, channel::Channel }; use crate::database; use rocket_contrib::json::{ Json, JsonValue }; @@ -15,3 +15,35 @@ pub enum ChannelType { GROUP_DM = 1, GUILD_CHANNEL = 2, } + +fn has_permission(user: &User, target: &Channel) -> bool { + let id = user.0.to_string(); + match target.1 { + ChannelType::DM | + ChannelType::GROUP_DM => { + for user in target.2.get_array("recipients").expect("DB[recipients]") { + if user.as_str().expect("Expected string id.") == id { + return true; + } + } + + false + }, + ChannelType::GUILD_CHANNEL => + false + } +} + +/// fetch channel information +#[get("/<target>")] +pub fn channel(user: User, target: Channel) -> Option<JsonValue> { + if !has_permission(&user, &target) { + return None + } + + Some( + json!({ + "aa": "b" + } + )) +} diff --git a/src/routes/mod.rs b/src/routes/mod.rs index a7ea2ab884bcfdece162c9c18136563bd7050cf4..b1890803fdaf8e5654b1ec430fd9dd2f37078709 100644 --- a/src/routes/mod.rs +++ b/src/routes/mod.rs @@ -8,4 +8,5 @@ pub fn mount(rocket: Rocket) -> Rocket { rocket .mount("/api/account", routes![ account::create, account::verify_email, account::resend_email, account::login ]) .mount("/api/users", routes![ user::me, user::user, user::lookup, user::dms, user::dm, user::get_friends, user::get_friend, user::add_friend, user::remove_friend ]) + .mount("/api/channels", routes![ channel::channel ]) }