diff --git a/src/api/v1/servers/uuid/channels/uuid/mod.rs b/src/api/v1/servers/uuid/channels/uuid/mod.rs index a223ad1..277052c 100644 --- a/src/api/v1/servers/uuid/channels/uuid/mod.rs +++ b/src/api/v1/servers/uuid/channels/uuid/mod.rs @@ -1,12 +1,12 @@ pub mod messages; -use actix_web::{get, web, Error, HttpRequest, HttpResponse}; +use actix_web::{delete, get, web, Error, HttpRequest, HttpResponse}; use crate::{api::v1::auth::check_access_token, structs::{Channel, Member}, utils::get_auth_header, Data}; use ::uuid::Uuid; use log::error; #[get("{uuid}/channels/{channel_uuid}")] -pub async fn res(req: HttpRequest, path: web::Path<(Uuid, Uuid)>, data: web::Data) -> Result { +pub async fn get(req: HttpRequest, path: web::Path<(Uuid, Uuid)>, data: web::Data) -> Result { let headers = req.headers(); let auth_header = get_auth_header(headers); @@ -54,3 +54,61 @@ pub async fn res(req: HttpRequest, path: web::Path<(Uuid, Uuid)>, data: web::Dat Ok(HttpResponse::Ok().json(channel)) } + +#[delete("{uuid}/channels/{channel_uuid}")] +pub async fn delete(req: HttpRequest, path: web::Path<(Uuid, Uuid)>, data: web::Data) -> Result { + let headers = req.headers(); + + let auth_header = get_auth_header(headers); + + if let Err(error) = auth_header { + return Ok(error) + } + + let (guild_uuid, channel_uuid) = path.into_inner(); + + let authorized = check_access_token(auth_header.unwrap(), &data.pool).await; + + if let Err(error) = authorized { + return Ok(error) + } + + let uuid = authorized.unwrap(); + + let member = Member::fetch_one(&data.pool, uuid, guild_uuid).await; + + if let Err(error) = member { + return Ok(error); + } + + let cache_result = data.get_cache_key(format!("{}", channel_uuid)).await; + + let channel: Channel; + + if let Ok(cache_hit) = cache_result { + channel = serde_json::from_str(&cache_hit).unwrap(); + + let result = data.del_cache_key(format!("{}", channel_uuid)).await; + + if let Err(error) = result { + error!("{}", error) + } + } else { + let channel_result = Channel::fetch_one(&data.pool, guild_uuid, channel_uuid).await; + + if let Err(error) = channel_result { + return Ok(error) + } + + channel = channel_result.unwrap(); + } + + let delete_result = channel.delete(&data.pool).await; + + if let Err(error) = delete_result { + return Ok(error) + } + + Ok(HttpResponse::Ok().finish()) +} + diff --git a/src/api/v1/servers/uuid/mod.rs b/src/api/v1/servers/uuid/mod.rs index e9c14a8..0f567d0 100644 --- a/src/api/v1/servers/uuid/mod.rs +++ b/src/api/v1/servers/uuid/mod.rs @@ -14,7 +14,8 @@ pub fn web() -> Scope { // Channels .service(channels::response) .service(channels::response_post) - .service(channels::uuid::res) + .service(channels::uuid::get) + .service(channels::uuid::delete) .service(channels::uuid::messages::res) // Roles .service(roles::response) diff --git a/src/structs.rs b/src/structs.rs index 0f72aaf..ac34e9d 100644 --- a/src/structs.rs +++ b/src/structs.rs @@ -156,6 +156,20 @@ impl Channel { Ok(channel) } + pub async fn delete(self, pool: &Pool) -> Result<(), HttpResponse> { + let result = sqlx::query(&format!("DELETE FROM channels WHERE channel_uuid = '{}'", self.uuid)) + .execute(pool) + .await; + + if let Err(error) = result { + error!("{}", error); + + return Err(HttpResponse::InternalServerError().finish()) + } + + Ok(()) + } + pub async fn fetch_messages(&self, pool: &Pool, amount: i64, offset: i64) -> Result, HttpResponse> { let row = sqlx::query_as(&format!("SELECT uuid, user_uuid, message FROM channels WHERE channel_uuid = '{}' ORDER BY uuid LIMIT $1 OFFSET $2", self.uuid)) .bind(amount)