mirror of
https://github.com/pierre42100/ComunicAPI
synced 2025-01-01 08:28:58 +00:00
73 lines
1.6 KiB
PHP
73 lines
1.6 KiB
PHP
<?php
|
|
/**
|
|
* API likes controller
|
|
*
|
|
* @author Pierre HUBERT
|
|
*/
|
|
|
|
class likesController {
|
|
|
|
/**
|
|
* Update a specific component like
|
|
*
|
|
* @url POST /likes/update
|
|
*/
|
|
public function update_like(){
|
|
|
|
user_login_required(); //Need login
|
|
|
|
//Get component kind
|
|
if(!isset($_POST["type"]))
|
|
Rest_fatal_error(401, "Please specify like type !");
|
|
|
|
$type = $_POST["type"];
|
|
|
|
//Check new status for the like
|
|
if(!isset($_POST['like']))
|
|
Rest_fatal_error(400, "Please specify the new like status with the request !");
|
|
$like = $_POST['like'] == "true";
|
|
|
|
//Find the right component type for checks
|
|
switch($type){
|
|
|
|
//In case of user
|
|
case "user":
|
|
|
|
//Extract informations
|
|
$id = getPostUserId("id");
|
|
$componentType = Likes::LIKE_USER;
|
|
|
|
//Check if user can access page
|
|
if(!CS::get()->components->user->userAllowed(userID, $id))
|
|
Rest_fatal_error(401, "You can not access this user information !");
|
|
|
|
break;
|
|
|
|
|
|
//In case of post
|
|
case "post":
|
|
|
|
//Extract informations
|
|
$id = getPostPostID("id");
|
|
$componentType = Likes::LIKE_POST;
|
|
|
|
//Check user can see the post
|
|
if(CS::get()->components->posts->access_level($id, userID) === Posts::NO_ACCESS)
|
|
Rest_fatal_error(401, "You are not allowed to access this post informations !");
|
|
|
|
break;
|
|
|
|
|
|
//Default case : error
|
|
default:
|
|
Rest_fatal_error(404, "Specifed component type currently not supported !");
|
|
}
|
|
|
|
//Update like status
|
|
CS::get()->components->likes->update(userID, $like, $id, $componentType);
|
|
|
|
//Success
|
|
return array("success" => "Like status updated.");
|
|
}
|
|
|
|
} |