mirror of
https://github.com/pierre42100/ComunicAPI
synced 2025-01-24 03:21:05 +00:00
Can create groups
This commit is contained in:
parent
1637885a97
commit
30d6a1fd9d
43
RestControllers/GroupsController.php
Normal file
43
RestControllers/GroupsController.php
Normal file
@ -0,0 +1,43 @@
|
||||
<?php
|
||||
/**
|
||||
* API Groups controller
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
class GroupsController {
|
||||
|
||||
/**
|
||||
* Create a group
|
||||
*
|
||||
* @url POST /groups/create
|
||||
*/
|
||||
public function create(){
|
||||
|
||||
//Login required
|
||||
user_login_required();
|
||||
|
||||
//Get the name of the new group
|
||||
$name = postString("name", 3);
|
||||
|
||||
//Prepare group creation
|
||||
$newGroup = new NewGroup();
|
||||
$newGroup->set_name($name);
|
||||
$newGroup->set_userID(userID);
|
||||
$newGroup->set_time_sent(time());
|
||||
|
||||
//Try to create the group
|
||||
$groupID = components()->groups->create($newGroup);
|
||||
|
||||
//Check for errors
|
||||
if($groupID < 1)
|
||||
Rest_fatal_error(500, "An error occurred while trying to create the group!");
|
||||
|
||||
//Success
|
||||
return array(
|
||||
"success" => "The group has been successfully created!",
|
||||
"id" => $groupID
|
||||
);
|
||||
}
|
||||
|
||||
}
|
72
classes/components/GroupsComponent.php
Normal file
72
classes/components/GroupsComponent.php
Normal file
@ -0,0 +1,72 @@
|
||||
<?php
|
||||
/**
|
||||
* Groups component
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
class GroupsComponent {
|
||||
|
||||
/**
|
||||
* Groups list table
|
||||
*/
|
||||
const GROUPS_LIST_TABLE = DBprefix . "groups";
|
||||
|
||||
/**
|
||||
* Groups members table
|
||||
*/
|
||||
const GROUPS_MEMBERS_TABLE = DBprefix."groups_members";
|
||||
|
||||
/**
|
||||
* Create a new group
|
||||
*
|
||||
* @param NewGroup $newGroup Information about the new group
|
||||
* to create
|
||||
* @return int The ID of the created group / -1 in case of failure
|
||||
*/
|
||||
public function create(NewGroup $newGroup) : int {
|
||||
|
||||
//Insert the group in the database
|
||||
db()->addLine(self::GROUPS_LIST_TABLE, array(
|
||||
"time_create" => $newGroup->get_time_sent(),
|
||||
"userid_create" => $newGroup->get_userID(),
|
||||
"name" => $newGroup->get_name()
|
||||
));
|
||||
|
||||
//Get the ID of the last inserted group
|
||||
$groupID = db()->getLastInsertedID();
|
||||
|
||||
//Check for errors
|
||||
if(!$groupID > 0)
|
||||
return -1;
|
||||
|
||||
//Register the user who created the group as an admin of the group
|
||||
$member = new GroupMember;
|
||||
$member->set_group_id($groupID);
|
||||
$member->set_userID($newGroup->get_userID());
|
||||
$member->set_time_sent($newGroup->get_time_sent());
|
||||
$member->set_level(GroupMember::ADMINISTRATOR);
|
||||
$this->insertMember($member);
|
||||
|
||||
return $groupID;
|
||||
}
|
||||
|
||||
/**
|
||||
* Insert a new group member
|
||||
*
|
||||
* @param GroupMember $member Information about the member to insert
|
||||
* @return bool TRUE for a success / FALSE else
|
||||
*/
|
||||
private function insertMember(GroupMember $member) : bool {
|
||||
return db()->addLine(self::GROUPS_MEMBERS_TABLE, array(
|
||||
"groups_id" => $member->get_group_id(),
|
||||
"user_id" => $member->get_userID(),
|
||||
"time_create" => $member->get_time_sent(),
|
||||
"level" => $member->get_level()
|
||||
));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
//Register component
|
||||
Components::register("groups", new GroupsComponent());
|
47
classes/models/GroupMember.php
Normal file
47
classes/models/GroupMember.php
Normal file
@ -0,0 +1,47 @@
|
||||
<?php
|
||||
/**
|
||||
* Group member object model
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
class GroupMember extends BaseUniqueObjectFromUser {
|
||||
|
||||
/**
|
||||
* Groups membership levels
|
||||
*/
|
||||
const ADMINISTRATOR = 0;
|
||||
const MODERATOR = 1;
|
||||
const MEMBER = 2;
|
||||
const PENDING = 3; //When the group membership has not been approved yet
|
||||
|
||||
//Private fields
|
||||
private $group_id = 1;
|
||||
private $level = -1;
|
||||
|
||||
//Set and get group id
|
||||
public function set_group_id(int $group_id){
|
||||
$this->group_id = $group_id;
|
||||
}
|
||||
|
||||
public function has_group_id() : bool {
|
||||
return $this->group_id > -1;
|
||||
}
|
||||
|
||||
public function get_group_id() : int {
|
||||
return $this->group_id;
|
||||
}
|
||||
|
||||
//Set and get user membership level
|
||||
public function set_level(int $level){
|
||||
$this->level = $level;
|
||||
}
|
||||
|
||||
public function has_level() : bool {
|
||||
return $this->level > -1;
|
||||
}
|
||||
|
||||
public function get_level() : int {
|
||||
return $this->level;
|
||||
}
|
||||
}
|
25
classes/models/NewGroup.php
Normal file
25
classes/models/NewGroup.php
Normal file
@ -0,0 +1,25 @@
|
||||
<?php
|
||||
/**
|
||||
* New Group Object
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
class NewGroup extends BaseUniqueObjectFromUser {
|
||||
|
||||
//Private properties
|
||||
private $name;
|
||||
|
||||
//Set and get name
|
||||
public function set_name(string $name){
|
||||
$this->name = $name == "" ? null : $name;
|
||||
}
|
||||
|
||||
public function has_name() : bool {
|
||||
return $this->name != null;
|
||||
}
|
||||
|
||||
public function get_name() : string {
|
||||
return $this->name != null ? $this->name : "null";
|
||||
}
|
||||
}
|
15
helpers/database.php
Normal file
15
helpers/database.php
Normal file
@ -0,0 +1,15 @@
|
||||
<?php
|
||||
/**
|
||||
* Database helper
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
/**
|
||||
* Get and return database object
|
||||
*
|
||||
* @param DBLibrary The database object
|
||||
*/
|
||||
function db() : DBLibrary {
|
||||
return CS::get()->db;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user