class Decidim::Meetings::Permissions
def permissions
def permissions return permission_action unless user # Delegate the admin permission checks to the admin permissions class return Decidim::Meetings::Admin::Permissions.new(user, permission_action, context).permissions if permission_action.scope == :admin return permission_action if permission_action.scope != :public return permission_action if permission_action.subject != :meeting case permission_action.action when :join toggle_allow(can_join_meeting?) when :leave toggle_allow(can_leave_meeting?) when :decline_invitation toggle_allow(can_decline_invitation?) when :create toggle_allow(can_create_meetings?) when :update toggle_allow(can_update_meeting?) when :register toggle_allow(can_register_invitation_meeting?) end permission_action end