mirror of
				https://github.com/RaspbianFrance/raspisms.git
				synced 2025-10-25 11:20:02 +02:00 
			
		
		
		
	Properly working mms reception with public dir in data and valid rights, etc.
This commit is contained in:
		
							parent
							
								
									04a40049ce
								
							
						
					
					
						commit
						6acf28e3ce
					
				
					 5 changed files with 37 additions and 12 deletions
				
			
		|  | @ -186,7 +186,7 @@ namespace adapters; | ||||||
| 
 | 
 | ||||||
|         /** |         /** | ||||||
|          * Read from a files to simulate sms reception. |          * Read from a files to simulate sms reception. | ||||||
|          * In the file we expect a json string representing an array of sms of format : |          * In the file we expect a series of lines, each line beeing a SMS as a json string of format : | ||||||
|          * { |          * { | ||||||
|          *    "at" : "2021-03-26 11:21:48", |          *    "at" : "2021-03-26 11:21:48", | ||||||
|          *    "medias" : [ |          *    "medias" : [ | ||||||
|  |  | ||||||
|  | @ -29,7 +29,12 @@ class Media extends StandardController | ||||||
|     public function create(int $id_user, string $tmpfile_path, ?string $extension = null) |     public function create(int $id_user, string $tmpfile_path, ?string $extension = null) | ||||||
|     { |     { | ||||||
|         $user_path = \controllers\internals\Tool::create_user_public_path($id_user); |         $user_path = \controllers\internals\Tool::create_user_public_path($id_user); | ||||||
|         if (!file_exists($tmpfile_path) || !is_readable($tmpfile_path)) |         if (!file_exists($tmpfile_path)) | ||||||
|  |         { | ||||||
|  |             throw new \Exception('File ' . $tmpfile_path . ' does not exists.'); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         if (!is_readable($tmpfile_path)) | ||||||
|         { |         { | ||||||
|             throw new \Exception('File ' . $tmpfile_path . ' is not readable.'); |             throw new \Exception('File ' . $tmpfile_path . ' is not readable.'); | ||||||
|         } |         } | ||||||
|  | @ -41,6 +46,11 @@ class Media extends StandardController | ||||||
|         $new_file_path = $user_path . '/' . $new_file_name; |         $new_file_path = $user_path . '/' . $new_file_name; | ||||||
|         $new_file_relpath = $id_user . '/' . $new_file_name; |         $new_file_relpath = $id_user . '/' . $new_file_name; | ||||||
| 
 | 
 | ||||||
|  |         if (!file_put_contents($new_file_path, 'a')) | ||||||
|  |         { | ||||||
|  |             throw new \Exception('pute de merde'); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         if (!rename($tmpfile_path, $new_file_path)) |         if (!rename($tmpfile_path, $new_file_path)) | ||||||
|         { |         { | ||||||
|             throw new \Exception('Cannot create file ' . $new_file_path); |             throw new \Exception('Cannot create file ' . $new_file_path); | ||||||
|  | @ -90,10 +100,18 @@ class Media extends StandardController | ||||||
|             throw new \Exception($upload_result['content']); |             throw new \Exception($upload_result['content']); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return $this->create($id_user, $upload_result['tmp_name'], $upload_result['extension']); |         //Move uploaded file to a tmp file
 | ||||||
|  |         if (!$tmp_file = tempnam('/tmp', 'raspisms-media-')) | ||||||
|  |         { | ||||||
|  |             throw new \Exception('Cannot create tmp file in /tmp to store the uploaded file.'); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         $new_filepath = 'medias/' . $id_user . '/' . $upload_result['content']; |         if (!move_uploaded_file($upload_result['tmp_name'], $tmp_file)) | ||||||
|         return $this->create($id_user, $new_filepath); |         { | ||||||
|  |             throw new \Exception('Cannot move uploaded file to : ' . $tmp_file); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         return $this->create($id_user, $tmp_file, $upload_result['extension']); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -306,19 +306,26 @@ namespace controllers\internals; | ||||||
|                 return $new_dir; |                 return $new_dir; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (!mkdir($new_dir, fileperms(PWD_DATA_PUBLIC))) |             clearstatcache(); | ||||||
|  |             if (!mkdir($new_dir)) | ||||||
|             { |             { | ||||||
|                 throw new \Exception('Cannot create dir ' . $new_dir); |                 throw new \Exception('Cannot create dir ' . $new_dir); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (!chown($new_dir, fileowner(PWD_DATA_PUBLIC))) |             //We do chmod in two times because else umask fuck mkdir permissions
 | ||||||
|  |             if (!chmod($new_dir, fileperms(PWD_DATA_PUBLIC) & 0777)) //Fileperms return garbage in addition to perms. Perms are only in weak bytes. We must use an octet notation with 0
 | ||||||
|             { |             { | ||||||
|                 throw new \Exception('Cannot give dir ' . $new_dir . ' to user : ' . fileowner(PWD_DATA)); |                 throw new \Exception('Cannot give dir ' . $new_dir . ' rights : ' . decoct(fileperms(PWD_DATA_PUBLIC) & 0777)); //Show error in dec
 | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (posix_getuid() === 0 && !chown($new_dir, fileowner(PWD_DATA_PUBLIC))) //If we are root, try to give the file to a proper user
 | ||||||
|  |             { | ||||||
|  |                 throw new \Exception('Cannot give dir ' . $new_dir . ' to user : ' . fileowner(PWD_DATA_PUBLIC)); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (!chgrp($new_dir, filegroup(PWD_DATA_PUBLIC))) |             if (!chgrp($new_dir, filegroup(PWD_DATA_PUBLIC))) | ||||||
|             { |             { | ||||||
|                 throw new \Exception('Cannot give dir ' . $new_dir . ' to group : ' . filegroup(PWD_DATA)); |                 throw new \Exception('Cannot give dir ' . $new_dir . ' to group : ' . filegroup(PWD_DATA_PUBLIC)); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             return $new_dir; |             return $new_dir; | ||||||
|  |  | ||||||
|  | @ -144,7 +144,7 @@ namespace controllers\publics; | ||||||
|                 } |                 } | ||||||
|                  |                  | ||||||
|                 $medias = []; |                 $medias = []; | ||||||
|                 if ($sended['mms']) |                 if ($received['mms']) | ||||||
|                 { |                 { | ||||||
|                     $medias = $this->internal_media->gets_for_received($received['id']); |                     $medias = $this->internal_media->gets_for_received($received['id']); | ||||||
|                     foreach ($medias as &$media) |                     foreach ($medias as &$media) | ||||||
|  |  | ||||||
|  | @ -87,7 +87,7 @@ | ||||||
|                         } |                         } | ||||||
|                         else |                         else | ||||||
|                         { |                         { | ||||||
|                             return '<div class="discussion-message-media"><a href="' + mediaUrl + '" target="_blank">Voir le fichier ' + ((int)index + 1) + '</a></div>'; |                             return '<div class="discussion-message-media"><a href="' + mediaUrl + '" target="_blank">Voir le fichier ' + (Number(index) + 1) + '</a></div>'; | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
|                     var medias_html = '<div class="discussion-message-medias">' + medias.join('') + '</div>'; |                     var medias_html = '<div class="discussion-message-medias">' + medias.join('') + '</div>'; | ||||||
|  | @ -99,7 +99,7 @@ | ||||||
| 							'<div class="clearfix message-container">' + | 							'<div class="clearfix message-container">' + | ||||||
| 								'<div class="discussion-message message-received">' + | 								'<div class="discussion-message message-received">' + | ||||||
|                                     '<div class="discussion-message-text">' + message.text + '</div>' + |                                     '<div class="discussion-message-text">' + message.text + '</div>' + | ||||||
|                                     medias.html +  |                                     medias_html +  | ||||||
|                                     '<div class="discussion-message-date">' + message.date + '</div>' + |                                     '<div class="discussion-message-date">' + message.date + '</div>' + | ||||||
| 								'</div>' + | 								'</div>' + | ||||||
| 							'</div>'; | 							'</div>'; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 osaajani
						osaajani