Abilities refactoring
This commit is contained in:
parent
7a9fc48080
commit
ccc9bed893
7 changed files with 83 additions and 8 deletions
|
@ -5,8 +5,18 @@ class SnippetsController < ApplicationController
|
|||
|
||||
# Authorize
|
||||
before_filter :add_project_abilities
|
||||
|
||||
# Allow read any snippet
|
||||
before_filter :authorize_read_snippet!
|
||||
before_filter :authorize_write_snippet!, :only => [:new, :create, :close, :edit, :update, :sort]
|
||||
|
||||
# Allow write(create) snippet
|
||||
before_filter :authorize_write_snippet!, :only => [:new, :create]
|
||||
|
||||
# Allow modify snippet
|
||||
before_filter :authorize_modify_snippet!, :only => [:edit, :update]
|
||||
|
||||
# Allow destroy snippet
|
||||
before_filter :authorize_admin_snippet!, :only => [:destroy]
|
||||
|
||||
respond_to :html
|
||||
|
||||
|
@ -60,4 +70,14 @@ class SnippetsController < ApplicationController
|
|||
|
||||
redirect_to project_snippets_path(@project)
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
def authorize_modify_snippet!
|
||||
can?(current_user, :modify_snippet, @snippet)
|
||||
end
|
||||
|
||||
def authorize_admin_snippet!
|
||||
can?(current_user, :admin_snippet, @snippet)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue