2017-05-19 18:07:52 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* User functions
|
|
|
|
*
|
|
|
|
* @author Pierre HUBERT
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A function that check login information are specified,
|
|
|
|
* else it quit the scripts because of missing login
|
|
|
|
*
|
2018-04-18 18:49:29 +02:00
|
|
|
* @return bool True for a success
|
2017-05-19 18:07:52 +02:00
|
|
|
*/
|
2018-04-18 18:49:29 +02:00
|
|
|
function user_login_required() : bool {
|
2017-12-16 15:30:04 +01:00
|
|
|
if(!user_signed_in()){
|
2017-05-19 18:07:52 +02:00
|
|
|
Rest_fatal_error(401, "This function requires user to be logged in!");
|
|
|
|
}
|
|
|
|
|
|
|
|
//User logged in
|
|
|
|
return true;
|
2017-12-16 15:30:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check wether the user is signed in or not
|
|
|
|
*
|
2018-04-18 18:49:29 +02:00
|
|
|
* @return bool TRUE if user is signed in / FALSE else
|
2017-12-16 15:30:04 +01:00
|
|
|
*/
|
|
|
|
function user_signed_in() : bool {
|
|
|
|
|
|
|
|
//Check constant
|
|
|
|
if(!defined("userID"))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
//Check user ID
|
|
|
|
if(userID == 0)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
//User seems to be signed in
|
|
|
|
return true;
|
|
|
|
|
2018-04-18 18:49:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check the validity of a password provided in a $_POST request
|
|
|
|
*
|
|
|
|
* @param int $userID The ID of the user to check
|
|
|
|
* @param string $name The name of the POST field containing the password
|
|
|
|
* @return bool TRUE in case of success / (stop by default in case of failure)
|
|
|
|
*/
|
|
|
|
function check_post_password(int $userID, string $name) : bool {
|
|
|
|
|
|
|
|
//Get POST field
|
|
|
|
$password = postString($name, 2);
|
|
|
|
|
|
|
|
//Check the password
|
|
|
|
if(!components()->account->checkUserPassword($userID, $password))
|
|
|
|
Rest_fatal_error(401, "The password is invalid!");
|
|
|
|
|
|
|
|
//Else the password seems to be valid
|
|
|
|
return TRUE;
|
2017-05-19 18:07:52 +02:00
|
|
|
}
|