scinote-web/app/permissions/team.rb
2020-02-26 17:25:38 +01:00

108 lines
3.2 KiB
Ruby

Canaid::Permissions.register_for(Team) do
# team: leave, read users, read projects, read/export samples,
# read protocols
#
can :read_team do |user, team|
user.is_member_of_team?(team)
end
# team: update
can :update_team do |user, team|
user.is_admin_of_team?(team)
end
# team: assign/unassing user, change user role
can :manage_team_users do |user, team|
user.is_admin_of_team?(team)
end
# team: invite new users to the team
can :invite_team_users do
true
end
# project: create
can :create_projects do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
# protocol in repository: create, import
can :create_protocols_in_repository do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
# sample: create, import
can :create_samples do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
# sample: create field
can :create_sample_columns do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
# create/update/delete sample type/group
can :manage_sample_types_and_groups do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
# repository: create, copy
can :create_repositories do |user, team|
user.is_admin_of_team?(team) &&
team.repositories.count < Rails.configuration.x.repositories_limit
end
# this permission is scattered around the application
# if you want to make changes here keep in mind to check/change the
# SQL view that lists reports in index page:
# - db/views/datatables_reports_v01.sql
# - check the model app/models/views/datatables/datatables_report.rb
# - check visible_by method in Project model
can :manage_reports do |user, team|
user.is_normal_user_or_admin_of_team?(team)
end
end
Canaid::Permissions.register_for(Protocol) do
# protocol in repository: read, export, read step, read/download step asset
can :read_protocol_in_repository do |user, protocol|
user.is_member_of_team?(protocol.team) &&
(protocol.in_repository_public? ||
protocol.in_repository_private? && user == protocol.added_by)
end
# protocol in repository: update, create/update/delete/reorder step,
# toggle private/public visibility, archive
can :manage_protocol_in_repository do |user, protocol|
protocol.in_repository_active? &&
user.is_normal_user_or_admin_of_team?(protocol.team) &&
user == protocol.added_by
end
# protocol in repository: restore
can :restore_protocol_in_repository do |user, protocol|
protocol.in_repository_archived? &&
user.is_normal_user_or_admin_of_team?(protocol.team) &&
user == protocol.added_by
end
# protocol in repository: copy
can :clone_protocol_in_repository do |user, protocol|
can_read_protocol_in_repository?(user, protocol) &&
can_create_protocols_in_repository?(user, protocol.team)
end
end
Canaid::Permissions.register_for(Sample) do
# sample: update, delete
can :manage_sample do |user, sample|
can_create_samples?(user, sample.team)
end
end
Canaid::Permissions.register_for(CustomField) do
# sample: update/delete field
can :manage_sample_column do |user, custom_field|
can_create_sample_columns?(user, custom_field.team)
end
end