mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-01-30 22:13:01 +00:00
Can get information about a single post
This commit is contained in:
parent
f8413850ae
commit
d49a4737e4
@ -6,6 +6,7 @@ use crate::api_data::post_api::PostAPI;
|
|||||||
use crate::controllers::routes::RequestResult;
|
use crate::controllers::routes::RequestResult;
|
||||||
use crate::data::group::GroupAccessLevel;
|
use crate::data::group::GroupAccessLevel;
|
||||||
use crate::data::http_request_handler::HttpRequestHandler;
|
use crate::data::http_request_handler::HttpRequestHandler;
|
||||||
|
use crate::data::post::PostAccessLevel;
|
||||||
use crate::helpers::{posts_helper, user_helper};
|
use crate::helpers::{posts_helper, user_helper};
|
||||||
|
|
||||||
/// Get the list of posts of a user
|
/// Get the list of posts of a user
|
||||||
@ -47,3 +48,10 @@ pub fn get_latest(r: &mut HttpRequestHandler) -> RequestResult {
|
|||||||
|
|
||||||
r.set_response(PostAPI::for_list(&posts, r.user_id_opt())?)
|
r.set_response(PostAPI::for_list(&posts, r.user_id_opt())?)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get information about a single post
|
||||||
|
pub fn get_single(r: &mut HttpRequestHandler) -> RequestResult {
|
||||||
|
let post = r.post_post_with_access("postID", PostAccessLevel::BASIC_ACCESS)?;
|
||||||
|
|
||||||
|
r.set_response(PostAPI::new(&post, &r.user_id_opt())?)
|
||||||
|
}
|
@ -204,6 +204,8 @@ pub fn get_routes() -> Vec<Route> {
|
|||||||
|
|
||||||
Route::post("/posts/get_latest", Box::new(posts_controller::get_latest)),
|
Route::post("/posts/get_latest", Box::new(posts_controller::get_latest)),
|
||||||
|
|
||||||
|
Route::post("/posts/get_single", Box::new(posts_controller::get_single)),
|
||||||
|
|
||||||
|
|
||||||
// Virtual directory controller
|
// Virtual directory controller
|
||||||
Route::post("/user/findbyfolder", Box::new(virtual_directory_controller::find_user)),
|
Route::post("/user/findbyfolder", Box::new(virtual_directory_controller::find_user)),
|
||||||
|
@ -16,8 +16,9 @@ use crate::data::config::conf;
|
|||||||
use crate::data::error::{ExecError, ResultBoxError};
|
use crate::data::error::{ExecError, ResultBoxError};
|
||||||
use crate::data::group::GroupAccessLevel;
|
use crate::data::group::GroupAccessLevel;
|
||||||
use crate::data::group_id::GroupID;
|
use crate::data::group_id::GroupID;
|
||||||
|
use crate::data::post::{Post, PostAccessLevel};
|
||||||
use crate::data::user::UserID;
|
use crate::data::user::UserID;
|
||||||
use crate::helpers::{account_helper, api_helper, conversations_helper, friends_helper, groups_helper, user_helper, virtual_directory_helper};
|
use crate::helpers::{account_helper, api_helper, conversations_helper, friends_helper, groups_helper, posts_helper, user_helper, virtual_directory_helper};
|
||||||
use crate::helpers::virtual_directory_helper::VirtualDirType;
|
use crate::helpers::virtual_directory_helper::VirtualDirType;
|
||||||
use crate::utils::string_utils::{check_url, remove_html_nodes};
|
use crate::utils::string_utils::{check_url, remove_html_nodes};
|
||||||
use crate::utils::user_data_utils::{generate_new_user_data_file_name, prepare_file_creation, user_data_path};
|
use crate::utils::user_data_utils::{generate_new_user_data_file_name, prepare_file_creation, user_data_path};
|
||||||
@ -545,4 +546,19 @@ impl HttpRequestHandler {
|
|||||||
|
|
||||||
Ok(Some(dir))
|
Ok(Some(dir))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get information about a post whose ID was specified in the request
|
||||||
|
pub fn post_post_with_access(&mut self, name: &str, min_level: PostAccessLevel) -> ResultBoxError<Post> {
|
||||||
|
let post_id = self.post_u64(name)?;
|
||||||
|
let post = self.ok_or_not_found(
|
||||||
|
posts_helper::get_single(post_id),
|
||||||
|
"Requested post not found!",
|
||||||
|
)?;
|
||||||
|
|
||||||
|
if posts_helper::get_access_level(&post, &self.user_id_opt())? < min_level {
|
||||||
|
self.forbidden("You are not allowed to access this post information!".to_string())?;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(post)
|
||||||
|
}
|
||||||
}
|
}
|
@ -34,6 +34,7 @@ impl PostVisibilityLevel {
|
|||||||
|
|
||||||
/// Post access level (for a given user)
|
/// Post access level (for a given user)
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
|
#[derive(PartialEq, PartialOrd)]
|
||||||
pub enum PostAccessLevel {
|
pub enum PostAccessLevel {
|
||||||
//When a user can't access to a post
|
//When a user can't access to a post
|
||||||
NO_ACCESS = 0,
|
NO_ACCESS = 0,
|
||||||
@ -142,3 +143,15 @@ impl Post {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use crate::data::post::PostAccessLevel;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn access_level_coherence() {
|
||||||
|
assert!(PostAccessLevel::NO_ACCESS < PostAccessLevel::BASIC_ACCESS);
|
||||||
|
assert!(PostAccessLevel::BASIC_ACCESS < PostAccessLevel::INTERMEDIATE_ACCESS);
|
||||||
|
assert!(PostAccessLevel::INTERMEDIATE_ACCESS < PostAccessLevel::FULL_ACCESS);
|
||||||
|
}
|
||||||
|
}
|
@ -230,6 +230,13 @@ pub fn get_latest(query: &PostsQuery, include_group_posts: bool) -> ResultBoxErr
|
|||||||
.exec(db_to_post)
|
.exec(db_to_post)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get information about a single post
|
||||||
|
pub fn get_single(post_id: u64) -> ResultBoxError<Post> {
|
||||||
|
database::QueryInfo::new(POSTS_TABLE)
|
||||||
|
.cond_u64("ID", post_id)
|
||||||
|
.query_row(db_to_post)
|
||||||
|
}
|
||||||
|
|
||||||
/// Get the access level of a user over a post
|
/// Get the access level of a user over a post
|
||||||
pub fn get_access_level(p: &Post, user_id: &Option<UserID>) -> ResultBoxError<PostAccessLevel> {
|
pub fn get_access_level(p: &Post, user_id: &Option<UserID>) -> ResultBoxError<PostAccessLevel> {
|
||||||
if user_id == &p.user_id.as_option() {
|
if user_id == &p.user_id.as_option() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user