2019-07-12 22:43:54 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-05-06 21:17:54 +08:00
|
|
|
Canaid::Permissions.register_for(RepositoryBase) do
|
2019-07-17 22:00:49 +08:00
|
|
|
# repository: read/export
|
|
|
|
can :read_repository do |user, repository|
|
2020-05-06 21:17:54 +08:00
|
|
|
if repository.is_a?(RepositorySnapshot)
|
|
|
|
user.teams.include?(repository.team)
|
|
|
|
else
|
|
|
|
user.teams.include?(repository.team) || repository.shared_with?(user.current_team)
|
|
|
|
end
|
2019-07-17 22:00:49 +08:00
|
|
|
end
|
2020-05-06 21:17:54 +08:00
|
|
|
end
|
2019-07-17 22:00:49 +08:00
|
|
|
|
2020-05-06 21:17:54 +08:00
|
|
|
Canaid::Permissions.register_for(Repository) do
|
2020-05-15 23:46:59 +08:00
|
|
|
# Should be no provisioning snapshots for repository for all the specified permissions
|
|
|
|
%i(manage_repository
|
|
|
|
create_repository_rows
|
|
|
|
manage_repository_rows
|
|
|
|
update_repository_rows
|
|
|
|
delete_repository_rows
|
|
|
|
create_repository_columns)
|
|
|
|
.each do |perm|
|
|
|
|
can perm do |_, repository|
|
|
|
|
repository.repository_snapshots.provisioning.none?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-07-12 22:43:54 +08:00
|
|
|
# repository: update, delete
|
|
|
|
can :manage_repository do |user, repository|
|
2019-08-23 16:57:02 +08:00
|
|
|
user.is_admin_of_team?(repository.team) unless repository.shared_with?(user.current_team)
|
2019-07-12 22:43:54 +08:00
|
|
|
end
|
|
|
|
|
2020-06-24 17:32:20 +08:00
|
|
|
# repository: archive, restore
|
|
|
|
can :archive_repository do |user, repository|
|
2021-08-24 21:55:13 +08:00
|
|
|
next false if repository.is_a?(BmtRepository)
|
|
|
|
|
2020-06-24 17:32:20 +08:00
|
|
|
!repository.shared_with?(user.current_team) && user.is_admin_of_team?(repository.team)
|
|
|
|
end
|
|
|
|
|
2022-02-28 17:33:43 +08:00
|
|
|
# repository: destroy
|
|
|
|
can :delete_repository do |user, repository|
|
|
|
|
repository.archived? && can_manage_repository?(user, repository)
|
|
|
|
end
|
|
|
|
|
2019-08-20 21:08:53 +08:00
|
|
|
# repository: share
|
|
|
|
can :share_repository do |user, repository|
|
2019-08-23 16:57:02 +08:00
|
|
|
user.is_admin_of_team?(repository.team) unless repository.shared_with?(user.current_team)
|
2019-08-20 21:08:53 +08:00
|
|
|
end
|
|
|
|
|
2020-04-21 20:49:36 +08:00
|
|
|
# repository: make a snapshot with assigned rows
|
|
|
|
can :create_repository_snapshot do |user, repository|
|
|
|
|
user.is_normal_user_or_admin_of_team?(repository.team)
|
|
|
|
end
|
|
|
|
|
|
|
|
# repository: delete a snapshot with assigned rows
|
|
|
|
can :delete_repository_snapshot do |user, repository|
|
|
|
|
user.is_normal_user_or_admin_of_team?(repository.team)
|
|
|
|
end
|
|
|
|
|
2019-07-12 22:43:54 +08:00
|
|
|
# repository: create/import record
|
|
|
|
can :create_repository_rows do |user, repository|
|
2021-08-24 21:55:13 +08:00
|
|
|
next false if repository.is_a?(BmtRepository)
|
2022-03-30 20:33:26 +08:00
|
|
|
next false if repository.archived?
|
2021-08-24 21:55:13 +08:00
|
|
|
|
2019-08-23 16:57:02 +08:00
|
|
|
if repository.shared_with?(user.current_team)
|
|
|
|
repository.shared_with_write?(user.current_team) && user.is_normal_user_or_admin_of_team?(user.current_team)
|
2022-06-08 19:23:39 +08:00
|
|
|
else
|
2019-07-12 22:43:54 +08:00
|
|
|
user.is_normal_user_or_admin_of_team?(repository.team)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-04-25 18:18:01 +08:00
|
|
|
can :manage_repository_assets do |user, repository|
|
|
|
|
can_create_repository_rows?(user, repository)
|
|
|
|
end
|
|
|
|
|
2019-07-12 22:43:54 +08:00
|
|
|
# repository: update/delete records
|
|
|
|
can :manage_repository_rows do |user, repository|
|
|
|
|
can_create_repository_rows?(user, repository)
|
|
|
|
end
|
|
|
|
|
2019-11-21 00:12:47 +08:00
|
|
|
can :update_repository_rows do |user, repository|
|
|
|
|
can_manage_repository_rows?(user, repository)
|
|
|
|
end
|
|
|
|
|
|
|
|
can :delete_repository_rows do |user, repository|
|
|
|
|
can_manage_repository_rows?(user, repository)
|
|
|
|
end
|
|
|
|
|
2019-07-12 22:43:54 +08:00
|
|
|
# repository: create field
|
|
|
|
can :create_repository_columns do |user, repository|
|
2019-08-23 16:57:02 +08:00
|
|
|
can_create_repository_rows?(user, repository) unless repository.shared_with?(user.current_team)
|
2019-07-12 22:43:54 +08:00
|
|
|
end
|
2022-02-01 16:59:31 +08:00
|
|
|
|
|
|
|
# repository: create/update/delete filters
|
|
|
|
can :manage_repository_filters do |user, repository|
|
2022-02-15 21:37:42 +08:00
|
|
|
((repository.team == user.current_team) && user.is_normal_user_or_admin_of_team?(repository.team)) ||
|
2022-02-11 17:47:18 +08:00
|
|
|
(repository.shared_with_write?(user.current_team) && user.is_normal_user_or_admin_of_team?(user.current_team))
|
2022-02-01 16:59:31 +08:00
|
|
|
end
|
2022-03-29 18:33:28 +08:00
|
|
|
|
|
|
|
can :manage_repository_stock do |user, repository|
|
2022-04-01 19:54:08 +08:00
|
|
|
RepositoryBase.stock_management_enabled? && can_manage_repository_rows?(user, repository)
|
2022-03-29 18:33:28 +08:00
|
|
|
end
|
2019-07-12 22:43:54 +08:00
|
|
|
end
|