Commit 7534154b44f920005e6732bbcc9e9af391b81546
Committed by
 Dmitriy Zaporozhets
 Dmitriy Zaporozhets
1 parent
dcea5220
Exists in
master
and in
4 other branches
Add access control in public section to users teams
Showing
3 changed files
with
11 additions
and
1 deletions
 
Show diff stats
app/controllers/teams/application_controller.rb
| 1 | class Teams::ApplicationController < ApplicationController | 1 | class Teams::ApplicationController < ApplicationController | 
| 2 | + | ||
| 3 | + before_filter :authorize_manage_user_team! | ||
| 4 | + | ||
| 2 | protected | 5 | protected | 
| 3 | 6 | ||
| 4 | def user_team | 7 | def user_team | 
| 5 | @user_team ||= UserTeam.find_by_path(params[:team_id]) | 8 | @user_team ||= UserTeam.find_by_path(params[:team_id]) | 
| 6 | end | 9 | end | 
| 7 | 10 | ||
| 11 | + def authorize_manage_user_team! | ||
| 12 | + return access_denied! unless can?(current_user, :manage_user_team, user_team) | ||
| 13 | + end | ||
| 14 | + | ||
| 8 | end | 15 | end | 
app/controllers/teams/members_controller.rb
| 1 | class Teams::MembersController < Teams::ApplicationController | 1 | class Teams::MembersController < Teams::ApplicationController | 
| 2 | # Authorize | 2 | # Authorize | 
| 3 | - before_filter :authorize_manage_user_team!, only: [:new, :edit] | 3 | + skip_before_filter :authorize_manage_user_team!, only: [:index] | 
| 4 | 4 | ||
| 5 | def index | 5 | def index | 
| 6 | @members = @user_team.members | 6 | @members = @user_team.members | 
app/controllers/teams/projects_controller.rb
| 1 | class Teams::ProjectsController < Teams::ApplicationController | 1 | class Teams::ProjectsController < Teams::ApplicationController | 
| 2 | + | ||
| 3 | + skip_before_filter :authorize_manage_user_team!, only: [:index] | ||
| 4 | + | ||
| 2 | def index | 5 | def index | 
| 3 | @projects = user_team.projects | 6 | @projects = user_team.projects | 
| 4 | @avaliable_projects = current_user.admin? ? Project.without_team(user_team) : (Project.personal(current_user) + current_user.projects).uniq | 7 | @avaliable_projects = current_user.admin? ? Project.without_team(user_team) : (Project.personal(current_user) + current_user.projects).uniq |