mirror of
https://github.com/openSUSE/osem.git
synced 2026-04-30 19:53:05 -04:00
146 lines
6.8 KiB
Ruby
146 lines
6.8 KiB
Ruby
class Ability
|
|
include CanCan::Ability
|
|
|
|
def initialize(user)
|
|
# The first argument to `can` is the action you are giving the user permission to do.
|
|
# If you pass :manage it will apply to every action. Other common actions here are
|
|
# :read, :create, :update and :destroy.
|
|
#
|
|
# The second argument is the resource the user can perform the action on. If you pass
|
|
# :all it will apply to every resource. Otherwise pass a Ruby class of the resource.
|
|
#
|
|
# The third argument is an optional hash of conditions to further filter the objects.
|
|
# For example, here the user can only update published articles.
|
|
#
|
|
# can :update, Article, :published => true
|
|
#
|
|
# See the wiki for details: https://github.com/ryanb/cancan/wiki/Defining-Abilities
|
|
|
|
# Order Abilities
|
|
# (Check https://github.com/CanCanCommunity/cancancan/wiki/Ability-Precedence)
|
|
# Check roles of user, using rolify. Role name is *case sensitive*
|
|
# user.is_organizer? or user.has_role? :organizer
|
|
# user.is_cfp_of? Conference or user.has_role? :cfp, Conference
|
|
# user.is_info_desk_of? Conference
|
|
# user.is_volunteer_coordinator_of? Conference
|
|
# user.is_attendee_of? Conference
|
|
# The following is wrong because a user will only have 'cfp' role for a specific conference
|
|
# user.is_cfp? # This is always false
|
|
|
|
user ||= User.new # guest user (not logged in)
|
|
|
|
if user.new_record?
|
|
guest
|
|
else
|
|
roles = Role::ACTIONABLES.map {|i| i.parameterize.underscore}
|
|
if (user.roles.pluck(:name) & roles).empty? && !user.is_admin # User has no roles
|
|
signed_in(user)
|
|
else
|
|
user_with_roles(user)
|
|
end
|
|
end
|
|
end
|
|
|
|
def user_with_roles(user)
|
|
conf_ids_for_organizer = []
|
|
venue_ids_for_organizer = []
|
|
conf_ids_for_cfp = []
|
|
venue_ids_for_cfp = []
|
|
conf_ids_for_info_desk = []
|
|
conf_ids_for_volunteer_coordinator = []
|
|
|
|
# Ids of all the conferences for which the user has an 'organizer' role
|
|
conf_ids_for_organizer =
|
|
Conference.with_role(:organizer, user).pluck(:id) if user.has_role? :organizer, :any
|
|
venue_ids_for_organizer =
|
|
Conference.with_role(:organizer, user).pluck(:venue_id) if user.has_role? :organizer, :any
|
|
conf_ids_for_cfp =
|
|
Conference.with_role(:cfp, user).pluck(:id) if user.has_role? :cfp, :any
|
|
venue_ids_for_cfp =
|
|
Conference.with_role(:cfp, user).pluck(:venue_id) if user.has_role? :cfp, :any
|
|
# Ids of all the conferences for which the user has an 'info_desk' role
|
|
conf_ids_for_info_desk =
|
|
Conference.with_role(:info_desk, user).pluck(:id) if user.has_role? :info_desk, :any
|
|
# Ids of all the conferences for which the user has a 'volunteer_coordinator' role
|
|
conf_ids_for_volunteer_coordinator =
|
|
Conference.with_role(:volunteer_coordinator, user).pluck(:id) if user.has_role? :volunteer_coordinator, :any
|
|
|
|
signed_in(user) # Inherit abilities from signed user
|
|
# User with role
|
|
can :manage, User if user.is_admin # ??? || (user.has_role? :organizer, :any)
|
|
can [:new, :create], Conference if user.is_admin || (user.has_role? :organizer, :any)
|
|
can [:index, :show, :gallery_photos], Conference
|
|
can :manage, Conference, id: conf_ids_for_organizer
|
|
# can :manage, Conference do |conference|
|
|
# conference.id = conf_ids_for_organizer
|
|
# end
|
|
can :manage, Venue, id: venue_ids_for_organizer
|
|
can :index, Venue, id: venue_ids_for_cfp
|
|
can :manage, Registration, conference_id: conf_ids_for_organizer + conf_ids_for_info_desk
|
|
can :manage, Question, conference_id: conf_ids_for_organizer + conf_ids_for_info_desk
|
|
cannot [:edit, :update, :destroy], Question, global: true
|
|
can :manage, Vposition, conference_id: conf_ids_for_organizer + conf_ids_for_volunteer_coordinator
|
|
can :manage, Vday, conference_id: conf_ids_for_organizer + conf_ids_for_volunteer_coordinator
|
|
# The ability to manage an Event means that:
|
|
# the user can also edit the schedule and that
|
|
# the user can also vote
|
|
can :manage, Event, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :create, Event
|
|
can :manage, CallForPapers, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, EventType, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, Track, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, DifficultyLevel, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, EmailSettings, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, Campaign, conference_id: conf_ids_for_organizer
|
|
can :manage, Lodging, venue_id: venue_ids_for_organizer
|
|
can :manage, Photo, conference_id: conf_ids_for_organizer
|
|
can :manage, Room, conference_id: conf_ids_for_organizer + conf_ids_for_cfp
|
|
can :manage, Sponsor, conference_id: conf_ids_for_organizer
|
|
can :manage, SponsorshipLevel, conference_id: conf_ids_for_organizer
|
|
can :manage, Ticket, conference_id: conf_ids_for_organizer
|
|
can :manage, Target, conference_id: conf_ids_for_organizer
|
|
can :index, Commercial, commercialable_type: 'Conference'
|
|
can :manage, Commercial, commercialable_type: 'Conference', commercialable_id: conf_ids_for_organizer
|
|
# Manage commercials for events that belong to a conference of which user is organizer
|
|
can :manage, Commercial, commercialable_type: 'Event', commercialable_id: Event.where(conference_id: conf_ids_for_organizer + conf_ids_for_cfp).pluck(:id)
|
|
can :manage, Contact, conference_id: conf_ids_for_organizer
|
|
can :manage, Campaign, conference_id: conf_ids_for_organizer
|
|
can :manage, Photo, conference_id: conf_ids_for_organizer
|
|
can :manage, RegistrationPeriod, conference_id: conf_ids_for_organizer
|
|
can :manage, Splashpage, conference_id: conf_ids_for_organizer
|
|
end
|
|
|
|
def guest
|
|
## Abilities for everyone, even guests (not logged in users)
|
|
can [:show, :gallery_photos], Conference do |conference|
|
|
conference.splashpage && conference.splashpage.public == true
|
|
end
|
|
|
|
# see commercials too
|
|
|
|
can :show, Event do |event|
|
|
event.state == 'confirmed'
|
|
end
|
|
|
|
can :index, :schedule # show?
|
|
end
|
|
|
|
def signed_in(user)
|
|
guest # Inherits abilities of guest
|
|
|
|
# Conference Registration
|
|
can :manage, Registration, user_id: user.id
|
|
|
|
## Proposals
|
|
# Users can manage their own proposals
|
|
can :manage, Event, id: user.events.pluck(:id)
|
|
|
|
# Submit proposals only for conferences that are not over yet
|
|
can :create, Event, conference_id: Conference.where('end_date >= ?', Date.today).pluck(:id)
|
|
# Users can manage their own commercials
|
|
can :manage, Commercial, commercialable_type: 'Event', commercialable_id: user.events.pluck(:id)
|
|
# View commercials of confirmed events
|
|
can :show, Commercial, commercialable_type: 'Event', commercialable_id: Event.where(state: 'confirmed').pluck(:id)
|
|
end
|
|
end
|