|
<?php |
|
|
|
namespace Kanboard\Controller; |
|
|
|
use Kanboard\Core\Controller\AccessForbiddenException; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ProjectRoleController extends BaseController |
|
{ |
|
|
|
|
|
|
|
public function show() |
|
{ |
|
$project = $this->getProject(); |
|
|
|
$this->response->html($this->helper->layout->project('project_role/show', array( |
|
'project' => $project, |
|
'roles' => $this->projectRoleModel->getAllWithRestrictions($project['id']), |
|
'title' => t('Custom Project Roles'), |
|
))); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function create(array $values = array(), array $errors = array()) |
|
{ |
|
$project = $this->getProject(); |
|
|
|
$this->response->html($this->template->render('project_role/create', array( |
|
'project' => $project, |
|
'values' => $values + array('project_id' => $project['id']), |
|
'errors' => $errors, |
|
))); |
|
} |
|
|
|
|
|
|
|
|
|
public function save() |
|
{ |
|
$project = $this->getProject(); |
|
$values = $this->request->getValues(); |
|
|
|
list($valid, $errors) = $this->projectRoleValidator->validateCreation($values); |
|
|
|
if ($valid) { |
|
$role_id = $this->projectRoleModel->create($project['id'], $values['role']); |
|
|
|
if ($role_id !== false) { |
|
$this->flash->success(t('Your custom project role has been created successfully.')); |
|
} else { |
|
$this->flash->failure(t('Unable to create custom project role.')); |
|
} |
|
|
|
$this->response->redirect($this->helper->url->to('ProjectRoleController', 'show', array('project_id' => $project['id']))); |
|
} else { |
|
$this->create($values, $errors); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function edit(array $values = array(), array $errors = array()) |
|
{ |
|
$project = $this->getProject(); |
|
$role = $this->getRole($project['id']); |
|
|
|
if (empty($values)) { |
|
$values = $role; |
|
} |
|
|
|
$this->response->html($this->template->render('project_role/edit', array( |
|
'role' => $role, |
|
'project' => $project, |
|
'values' => $values, |
|
'errors' => $errors, |
|
))); |
|
} |
|
|
|
|
|
|
|
|
|
public function update() |
|
{ |
|
$project = $this->getProject(); |
|
$role = $this->getRole($project['id']); |
|
|
|
$values = $this->request->getValues(); |
|
|
|
list($valid, $errors) = $this->projectRoleValidator->validateModification($values); |
|
|
|
if ($valid) { |
|
if ($this->projectRoleModel->update($role['role_id'], $project['id'], $values['role'])) { |
|
$this->flash->success(t('Your custom project role has been updated successfully.')); |
|
} else { |
|
$this->flash->failure(t('Unable to update custom project role.')); |
|
} |
|
|
|
$this->response->redirect($this->helper->url->to('ProjectRoleController', 'show', array('project_id' => $project['id']))); |
|
} else { |
|
$this->edit($values, $errors); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
public function confirm() |
|
{ |
|
$project = $this->getProject(); |
|
$role = $this->getRole($project['id']); |
|
|
|
$this->response->html($this->helper->layout->project('project_role/remove', array( |
|
'project' => $project, |
|
'role' => $role, |
|
))); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
public function remove() |
|
{ |
|
$project = $this->getProject(); |
|
$this->checkCSRFParam(); |
|
$role_id = $this->request->getIntegerParam('role_id'); |
|
|
|
if ($this->projectRoleModel->remove($project['id'], $role_id)) { |
|
$this->flash->success(t('Custom project role removed successfully.')); |
|
} else { |
|
$this->flash->failure(t('Unable to remove this project role.')); |
|
} |
|
|
|
$this->response->redirect($this->helper->url->to('ProjectRoleController', 'show', array('project_id' => $project['id']))); |
|
} |
|
|
|
protected function getRole($project_id) |
|
{ |
|
$role_id = $this->request->getIntegerParam('role_id'); |
|
return $this->projectRoleModel->getById($project_id, $role_id); |
|
} |
|
} |
|
|