diff options
Diffstat (limited to 'app/Model/ProjectRoleModel.php')
-rw-r--r-- | app/Model/ProjectRoleModel.php | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/app/Model/ProjectRoleModel.php b/app/Model/ProjectRoleModel.php index 962ff44f..c5cd7b0e 100644 --- a/app/Model/ProjectRoleModel.php +++ b/app/Model/ProjectRoleModel.php @@ -193,4 +193,42 @@ class ProjectRoleModel extends Base $this->db->cancelTransaction(); return false; } + + /** + * Copy project custom_roles from a project to another one + * + * @param integer $project_src_id + * @param integer $project_dst_id + * @return boolean + */ + public function duplicate($project_src_id, $project_dst_id) + { + $rows = $this->db->table(self::TABLE)->eq('project_id', $project_src_id)->findAll(); + + foreach ($rows as $row) { + $role_src_id = $row['role_id']; + $role_dst_id = $this->db->table(self::TABLE)->persist(array( + 'project_id' => $project_dst_id, + 'role' => $row['role'], + )); + + if (! $role_dst_id) { + return false; + } + + if (! $this->columnRestrictionModel->duplicate($project_src_id, $project_dst_id, $role_src_id, $role_dst_id)) { + return false; + } + + if (! $this->columnMoveRestrictionModel->duplicate($project_src_id, $project_dst_id, $role_src_id, $role_dst_id)) { + return false; + } + + if (! $this->projectRoleRestrictionModel->duplicate($project_src_id, $project_dst_id, $role_src_id, $role_dst_id)) { + return false; + } + } + + return true; + } } |