mirror of
https://github.com/pierre42100/ComunicAPI
synced 2024-11-23 13:59:29 +00:00
Can get and check a user domain directory validity from a $_POST request
This commit is contained in:
parent
f2a5477f12
commit
37d21ee6c3
@ -444,4 +444,47 @@ function save_post_image(string $fieldName, int $userID, string $folder, int $ma
|
|||||||
//Return image path
|
//Return image path
|
||||||
return $target_file_path;
|
return $target_file_path;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check a user directory validity
|
||||||
|
*
|
||||||
|
* @param string $directory The directory to check
|
||||||
|
* @return bool TRUE if the domain seems to be valid / FALSE else
|
||||||
|
*/
|
||||||
|
function checkUserDirectoryValidity(string $directory) : bool {
|
||||||
|
|
||||||
|
//Check domain length
|
||||||
|
if(strlen($directory) < 4)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
//Check if the domain contains forbidden characters
|
||||||
|
if(str_replace(array(".html", ".txt", ".php", "à", "â", "é", "ê", "@", "/", "\"", "'", '"'), "", $directory) != $directory)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
//If we get there, the domain is valid
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a user post directory from a $_POST request and transform it to make it SQL-safe
|
||||||
|
*
|
||||||
|
* @param string $name The name of the $_POST Request
|
||||||
|
* @return string The user virtual directory, safe for saving
|
||||||
|
* @throws RESTException If the directory is missing, or invalid
|
||||||
|
*/
|
||||||
|
function getPostUserDirectory(string $name) : string {
|
||||||
|
|
||||||
|
//Check if the $_POST variable exists or not
|
||||||
|
if(!isset($_POST[$name]))
|
||||||
|
Rest_fatal_error(400, "Please specify a user directory in '".$name."'!");
|
||||||
|
$directory = (string) $_POST[$name];
|
||||||
|
|
||||||
|
//Check domain validity
|
||||||
|
if(!checkUserDirectoryValidity($directory))
|
||||||
|
Rest_fatal_error(401, "Specified directory seems to be invalid!");
|
||||||
|
|
||||||
|
//Return the directory
|
||||||
|
return $name;
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user