From f28d7a15b96e25e38a3e4bcfb95dbd804158e339 Mon Sep 17 00:00:00 2001 From: Matteo Mazza Date: Thu, 23 Aug 2018 06:00:01 +0200 Subject: Add custom roles project duplication --- app/Model/ColumnRestrictionModel.php | 40 ++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) (limited to 'app/Model/ColumnRestrictionModel.php') diff --git a/app/Model/ColumnRestrictionModel.php b/app/Model/ColumnRestrictionModel.php index 92b2ac60..6c770a83 100644 --- a/app/Model/ColumnRestrictionModel.php +++ b/app/Model/ColumnRestrictionModel.php @@ -149,4 +149,44 @@ class ColumnRestrictionModel extends Base { return $this->db->table(self::TABLE)->eq('restriction_id', $restriction_id)->remove(); } + + /** + * Copy column_restriction models from a custome_role in the src project to the dst custom_role of the dst project + * + * @param integer $project_src_id + * @param integer $project_dst_id + * @param integer $role_src_id + * @param integer $role_dst_id + * @return boolean + */ + public function duplicate($project_src_id, $project_dst_id, $role_src_id, $role_dst_id) + { + $rows = $this->db->table(self::TABLE) + ->eq('project_id', $project_src_id) + ->eq('role_id', $role_src_id) + ->findAll(); + + foreach ($rows as $row) { + $column_title = $this->columnModel->getColumnTitleById($row['column_id']); + $dst_column_id = $this->columnModel->getColumnIdByTitle($project_dst_id, $column_title); + + if (! $dst_column_id) { + $this->logger->error("The column $column_title is not present in project $project_dst_id"); + return false; + } + + $result = $this->db->table(self::TABLE)->persist(array( + 'project_id' => $project_dst_id, + 'role_id' => $role_dst_id, + 'column_id' => $dst_column_id, + 'rule' => $row['rule'], + )); + + if (! $result) { + return false; + } + } + + return true; + } } -- cgit v1.2.3