mirror of
				https://gitlab.com/comunic/comunicapiv3
				synced 2025-10-26 05:04:42 +00:00 
			
		
		
		
	Can create post images
This commit is contained in:
		
							
								
								
									
										26
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										26
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -549,6 +549,7 @@ dependencies = [ | |||||||
|  "kamadak-exif", |  "kamadak-exif", | ||||||
|  "lazy_static", |  "lazy_static", | ||||||
|  "mailchecker", |  "mailchecker", | ||||||
|  |  "mime_guess", | ||||||
|  "mysql", |  "mysql", | ||||||
|  "percent-encoding", |  "percent-encoding", | ||||||
|  "rand", |  "rand", | ||||||
| @@ -1283,6 +1284,16 @@ version = "0.3.16" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2a60c7ce501c71e03a9c9c0d35b861413ae925bd979cc7a4e30d060069aaac8d" | checksum = "2a60c7ce501c71e03a9c9c0d35b861413ae925bd979cc7a4e30d060069aaac8d" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "mime_guess" | ||||||
|  | version = "2.0.3" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "2684d4c2e97d99848d30b324b00c8fcc7e5c897b7cbb5819b09e7c90e8baf212" | ||||||
|  | dependencies = [ | ||||||
|  |  "mime", | ||||||
|  |  "unicase", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "miniz_oxide" | name = "miniz_oxide" | ||||||
| version = "0.3.6" | version = "0.3.6" | ||||||
| @@ -2176,6 +2187,15 @@ version = "0.2.2" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "eeba86d422ce181a719445e51872fa30f1f7413b62becb52e95ec91aa262d85c" | checksum = "eeba86d422ce181a719445e51872fa30f1f7413b62becb52e95ec91aa262d85c" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "unicase" | ||||||
|  | version = "2.6.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "50f37be617794602aabbeee0be4f259dc1778fabe05e2d67ee8f79326d5cb4f6" | ||||||
|  | dependencies = [ | ||||||
|  |  "version_check", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "unicode-bidi" | name = "unicode-bidi" | ||||||
| version = "0.3.4" | version = "0.3.4" | ||||||
| @@ -2229,6 +2249,12 @@ version = "0.2.8" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3fc439f2794e98976c88a2a2dafce96b930fe8010b0a256b3c2199a773933168" | checksum = "3fc439f2794e98976c88a2a2dafce96b930fe8010b0a256b3c2199a773933168" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "version_check" | ||||||
|  | version = "0.9.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "b5a972e5669d67ba988ce3dc826706fb0a8b01471c088cb0b6110b805cc36aed" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "void" | name = "void" | ||||||
| version = "1.0.2" | version = "1.0.2" | ||||||
|   | |||||||
| @@ -25,3 +25,4 @@ bytes = "0.5.4" | |||||||
| image = "0.23.5" | image = "0.23.5" | ||||||
| kamadak-exif = "0.5.1" | kamadak-exif = "0.5.1" | ||||||
| lazy_static = "1.4.0" | lazy_static = "1.4.0" | ||||||
|  | mime_guess = "2.0.3" | ||||||
| @@ -66,5 +66,8 @@ pub const PATH_GROUPS_LOGOS: &str = "groups_logo"; | |||||||
| /// The group logo to use when no custom logo have been uploaded | /// The group logo to use when no custom logo have been uploaded | ||||||
| pub const DEFAULT_GROUP_LOGO: &str = "groups_logo/default.png"; | pub const DEFAULT_GROUP_LOGO: &str = "groups_logo/default.png"; | ||||||
|  |  | ||||||
|  | /// The path where image associated with posts should be stored | ||||||
|  | pub const PATH_POST_IMAGES: &str ="imgpost"; | ||||||
|  |  | ||||||
| /// Maximum requests size (50 Mo) | /// Maximum requests size (50 Mo) | ||||||
| pub const MAX_REQUEST_SIZE: usize = 50000000; | pub const MAX_REQUEST_SIZE: usize = 50000000; | ||||||
| @@ -4,14 +4,30 @@ | |||||||
|  |  | ||||||
| use crate::api_data::post_api::PostAPI; | use crate::api_data::post_api::PostAPI; | ||||||
| use crate::api_data::res_create_post::ResCreatePost; | use crate::api_data::res_create_post::ResCreatePost; | ||||||
|  | use crate::constants::PATH_POST_IMAGES; | ||||||
| use crate::controllers::routes::RequestResult; | use crate::controllers::routes::RequestResult; | ||||||
| use crate::data::error::ExecError; | use crate::data::error::{ExecError, ResultBoxError}; | ||||||
| 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::{Post, PostAccessLevel, PostKind, PostPageKind, PostVisibilityLevel}; | use crate::data::post::{Post, PostAccessLevel, PostFile, PostKind, PostPageKind, PostVisibilityLevel}; | ||||||
| use crate::helpers::{groups_helper, posts_helper, user_helper}; | use crate::helpers::{groups_helper, posts_helper, user_helper}; | ||||||
| use crate::utils::date_utils::time; | use crate::utils::date_utils::time; | ||||||
| use crate::utils::string_utils::check_string_before_insert; | use crate::utils::string_utils::check_string_before_insert; | ||||||
|  | use crate::utils::user_data_utils::user_data_path; | ||||||
|  |  | ||||||
|  | impl PostFile { | ||||||
|  |     /// Initialize a `PostFile` instance based on a file that have just been created | ||||||
|  |     pub fn new_from_created_file(path: &str) -> ResultBoxError<PostFile> { | ||||||
|  |         let data = std::fs::metadata(user_data_path(path.as_ref()))?; | ||||||
|  |         Ok(PostFile { | ||||||
|  |             path: path.to_string(), | ||||||
|  |             size: data.len() as usize, | ||||||
|  |             file_type: mime_guess::from_path(path) | ||||||
|  |                 .first() | ||||||
|  |                 .map(|m| format!("{}/{}", m.type_(), m.subtype())), | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| /// Get the list of posts of a user | /// Get the list of posts of a user | ||||||
| pub fn get_list_user(r: &mut HttpRequestHandler) -> RequestResult { | pub fn get_list_user(r: &mut HttpRequestHandler) -> RequestResult { | ||||||
| @@ -113,6 +129,18 @@ pub fn create_post(r: &mut HttpRequestHandler) -> RequestResult { | |||||||
|             PostKind::POST_KIND_TEXT |             PostKind::POST_KIND_TEXT | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         // Image post | ||||||
|  |         "image" => { | ||||||
|  |             if !r.has_file("image") { | ||||||
|  |                 r.bad_request("An error occured while receiving the image!".to_string())?; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             let path = r.save_post_image("image", PATH_POST_IMAGES, 2000, 2000)?; | ||||||
|  |  | ||||||
|  |             PostKind::POST_KIND_IMAGE(PostFile::new_from_created_file(&path)?) | ||||||
|  |         } | ||||||
|  |  | ||||||
|         _ => { |         _ => { | ||||||
|             r.internal_error(ExecError::boxed_new("Unsupported kind of post!"))?; |             r.internal_error(ExecError::boxed_new("Unsupported kind of post!"))?; | ||||||
|             unreachable!(); |             unreachable!(); | ||||||
|   | |||||||
| @@ -555,6 +555,11 @@ impl InsertQuery { | |||||||
|         self |         self | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     pub fn add_usize(mut self, key: &str, value: usize) -> InsertQuery { | ||||||
|  |         self.values.insert(key.to_string(), Value::from(value)); | ||||||
|  |         self | ||||||
|  |     } | ||||||
|  |  | ||||||
|     pub fn add_u32(mut self, key: &str, value: u32) -> InsertQuery { |     pub fn add_u32(mut self, key: &str, value: u32) -> InsertQuery { | ||||||
|         self.values.insert(key.to_string(), Value::from(value)); |         self.values.insert(key.to_string(), Value::from(value)); | ||||||
|         self |         self | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ pub fn create(p: &Post) -> ResultBoxError<u64> { | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     // Start insert query |     // Start insert query | ||||||
|     let insert_query = database::InsertQuery::new(POSTS_TABLE) |     let mut insert_query = database::InsertQuery::new(POSTS_TABLE) | ||||||
|         .add_user_id("ID_personne", user_id) |         .add_user_id("ID_personne", user_id) | ||||||
|         .add_u64("ID_amis", friend_id.map(|f| f.id()).unwrap_or(0)) |         .add_u64("ID_amis", friend_id.map(|f| f.id()).unwrap_or(0)) | ||||||
|         .add_u64("group_id", group_id.map(|f| f.id()).unwrap_or(0)) |         .add_u64("group_id", group_id.map(|f| f.id()).unwrap_or(0)) | ||||||
| @@ -74,6 +74,26 @@ pub fn create(p: &Post) -> ResultBoxError<u64> { | |||||||
|         .add_str("type", &p.kind.to_db()) |         .add_str("type", &p.kind.to_db()) | ||||||
|         .add_opt_str("texte", p.content.as_ref()); |         .add_opt_str("texte", p.content.as_ref()); | ||||||
|  |  | ||||||
|  |     match &p.kind { | ||||||
|  |         PostKind::POST_KIND_TEXT => {/* nothing to do */}, | ||||||
|  |  | ||||||
|  |         // Posts with associated file | ||||||
|  |         POST_KIND_IMAGE(file) | POST_KIND_PDF(file) => { | ||||||
|  |             insert_query = insert_query.add_str("path", &file.path) | ||||||
|  |                 .add_usize("size", file.size) | ||||||
|  |                 .add_opt_str("file_type", file.file_type.as_ref()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         _ => unimplemented!() | ||||||
|  |         /* | ||||||
|  |         POST_KIND_WEBLINK(_) => {}, | ||||||
|  |         POST_KIND_MOVIE(_) => {}, | ||||||
|  |         POST_KIND_COUNTDOWN(_) => {}, | ||||||
|  |         POST_KIND_SURVEY => {}, | ||||||
|  |         POST_KIND_YOUTUBE(_) => {},*/ | ||||||
|  |     } | ||||||
|  |  | ||||||
|     // Execute insertion |     // Execute insertion | ||||||
|     let post_id = insert_query.insert()? |     let post_id = insert_query.insert()? | ||||||
|         .ok_or(ExecError::new("Insert post query did not return a result!"))?; |         .ok_or(ExecError::new("Insert post query did not return a result!"))?; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user