101 lines
3.0 KiB
PHP
101 lines
3.0 KiB
PHP
<?php
|
|
use Respect\Validation\Validator as DataValidator;
|
|
DataValidator::with('CustomValidations', true);
|
|
|
|
class AddStaffController extends Controller {
|
|
const PATH = '/add';
|
|
const METHOD = 'POST';
|
|
|
|
private $name;
|
|
private $email;
|
|
private $password;
|
|
private $profilePic;
|
|
private $level;
|
|
private $departments;
|
|
|
|
|
|
public function validations() {
|
|
return [
|
|
'permission' => 'staff_3',
|
|
'requestData' => [
|
|
'name' => [
|
|
'validation' => DataValidator::length(2, 55)->alpha(),
|
|
'error' => ERRORS::INVALID_NAME
|
|
],
|
|
'email' => [
|
|
'validation' => DataValidator::email(),
|
|
'error' => ERRORS::INVALID_EMAIL
|
|
],
|
|
'password' => [
|
|
'validation' => DataValidator::length(5, 200),
|
|
'error' => ERRORS::INVALID_PASSWORD
|
|
],
|
|
'level' => [
|
|
'validation' => DataValidator::between(1, 3, true),
|
|
'error' => ERRORS::INVALID_LEVEL
|
|
]
|
|
|
|
]
|
|
];
|
|
}
|
|
|
|
public function handler() {
|
|
$this->storeRequestData();
|
|
$staff = new Staff();
|
|
|
|
$staffRow = Staff::getDataStore($this->email,'email');
|
|
|
|
if($staffRow->isNull()) {
|
|
$staff->setProperties([
|
|
'name'=> $this->name,
|
|
'email' => $this->email,
|
|
'password'=> Hashing::hashPassword($this->password),
|
|
'profilePic' => $this->profilePic,
|
|
'level' => $this->level,
|
|
'sharedDepartmentList' => $this->getDepartmentList()
|
|
|
|
]);
|
|
|
|
$this->addOwner();
|
|
|
|
Log::createLog('ADD_STAFF', $this->name);
|
|
|
|
Response::respondSuccess([
|
|
'id' => $staff->store()
|
|
]);
|
|
return;
|
|
}
|
|
|
|
Response::respondError(ERRORS::ALREADY_A_STAFF);
|
|
}
|
|
|
|
public function storeRequestData() {
|
|
$this->name = Controller::request('name');
|
|
$this->email = Controller::request('email');
|
|
$this->password = Controller::request('password');
|
|
$this->profilePic = Controller::request('profilePic');
|
|
$this->level = Controller::request('level');
|
|
$this->departments = Controller::request('departments');
|
|
}
|
|
|
|
public function getDepartmentList() {
|
|
$listDepartments = new DataStoreList();
|
|
$departmentIds = json_decode($this->departments);
|
|
|
|
foreach($departmentIds as $id) {
|
|
$department = Department::getDataStore($id);
|
|
$listDepartments->add($department);
|
|
}
|
|
|
|
return $listDepartments;
|
|
}
|
|
public function addOwner() {
|
|
$departmentIds = json_decode($this->departments);
|
|
|
|
foreach($departmentIds as $id) {
|
|
$departmentRow = Department::getDataStore($id);
|
|
$departmentRow->owners++;
|
|
$departmentRow->store();
|
|
}
|
|
}
|
|
} |