Commit 1c62ec09b0fe8d51e9b375714c560eded1b35d51
1 parent
dac7c44a
Exists in
master
and in
4 other branches
4 roles permission system
Showing
18 changed files
with
66 additions
and
111 deletions
Show diff stats
app/controllers/projects_controller.rb
@@ -28,7 +28,7 @@ class ProjectsController < ApplicationController | @@ -28,7 +28,7 @@ class ProjectsController < ApplicationController | ||
28 | 28 | ||
29 | Project.transaction do | 29 | Project.transaction do |
30 | @project.save! | 30 | @project.save! |
31 | - @project.users_projects.create!(:repo_access => Repository::REPO_RW , :project_access => Project::PROJECT_RWA, :user => current_user) | 31 | + @project.users_projects.create!(:project_access => UsersProject::MASTER, :user => current_user) |
32 | 32 | ||
33 | # when project saved no team member exist so | 33 | # when project saved no team member exist so |
34 | # project repository should be updated after first user add | 34 | # project repository should be updated after first user add |
app/models/project.rb
1 | require "grit" | 1 | require "grit" |
2 | 2 | ||
3 | class Project < ActiveRecord::Base | 3 | class Project < ActiveRecord::Base |
4 | - PROJECT_N = 0 | ||
5 | - PROJECT_R = 1 | ||
6 | - PROJECT_RW = 2 | ||
7 | - PROJECT_RWA = 3 | ||
8 | - | ||
9 | belongs_to :owner, :class_name => "User" | 4 | belongs_to :owner, :class_name => "User" |
10 | 5 | ||
11 | has_many :merge_requests, :dependent => :destroy | 6 | has_many :merge_requests, :dependent => :destroy |
@@ -61,12 +56,7 @@ class Project < ActiveRecord::Base | @@ -61,12 +56,7 @@ class Project < ActiveRecord::Base | ||
61 | end | 56 | end |
62 | 57 | ||
63 | def self.access_options | 58 | def self.access_options |
64 | - { | ||
65 | - "Denied" => PROJECT_N, | ||
66 | - "Read" => PROJECT_R, | ||
67 | - "Report" => PROJECT_RW, | ||
68 | - "Admin" => PROJECT_RWA | ||
69 | - } | 59 | + UsersProject.access_roles |
70 | end | 60 | end |
71 | 61 | ||
72 | def repository | 62 | def repository |
@@ -193,11 +183,11 @@ class Project < ActiveRecord::Base | @@ -193,11 +183,11 @@ class Project < ActiveRecord::Base | ||
193 | # Should be rewrited for new access rights | 183 | # Should be rewrited for new access rights |
194 | def add_access(user, *access) | 184 | def add_access(user, *access) |
195 | access = if access.include?(:admin) | 185 | access = if access.include?(:admin) |
196 | - { :project_access => PROJECT_RWA } | 186 | + { :project_access => UsersProject::MASTER } |
197 | elsif access.include?(:write) | 187 | elsif access.include?(:write) |
198 | - { :project_access => PROJECT_RW } | 188 | + { :project_access => UsersProject::DEVELOPER } |
199 | else | 189 | else |
200 | - { :project_access => PROJECT_R } | 190 | + { :project_access => UsersProject::GUEST } |
201 | end | 191 | end |
202 | opts = { :user => user } | 192 | opts = { :user => user } |
203 | opts.merge!(access) | 193 | opts.merge!(access) |
@@ -210,48 +200,48 @@ class Project < ActiveRecord::Base | @@ -210,48 +200,48 @@ class Project < ActiveRecord::Base | ||
210 | 200 | ||
211 | def repository_readers | 201 | def repository_readers |
212 | keys = Key.joins({:user => :users_projects}). | 202 | keys = Key.joins({:user => :users_projects}). |
213 | - where("users_projects.project_id = ? AND users_projects.repo_access = ?", id, Repository::REPO_R) | 203 | + where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::REPORTER) |
214 | keys.map(&:identifier) + deploy_keys.map(&:identifier) | 204 | keys.map(&:identifier) + deploy_keys.map(&:identifier) |
215 | end | 205 | end |
216 | 206 | ||
217 | def repository_writers | 207 | def repository_writers |
218 | keys = Key.joins({:user => :users_projects}). | 208 | keys = Key.joins({:user => :users_projects}). |
219 | - where("users_projects.project_id = ? AND users_projects.repo_access = ?", id, Repository::REPO_RW) | 209 | + where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::DEVELOPER) |
220 | keys.map(&:identifier) | 210 | keys.map(&:identifier) |
221 | end | 211 | end |
222 | 212 | ||
223 | def repository_masters | 213 | def repository_masters |
224 | keys = Key.joins({:user => :users_projects}). | 214 | keys = Key.joins({:user => :users_projects}). |
225 | - where("users_projects.project_id = ? AND users_projects.repo_access = ?", id, Repository::REPO_MASTER) | 215 | + where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::MASTER) |
226 | keys.map(&:identifier) | 216 | keys.map(&:identifier) |
227 | end | 217 | end |
228 | 218 | ||
229 | def readers | 219 | def readers |
230 | - @readers ||= users_projects.includes(:user).where(:project_access => [PROJECT_R, PROJECT_RW, PROJECT_RWA]).map(&:user) | 220 | + @readers ||= users_projects.includes(:user).map(&:user) |
231 | end | 221 | end |
232 | 222 | ||
233 | def writers | 223 | def writers |
234 | - @writers ||= users_projects.includes(:user).where(:project_access => [PROJECT_RW, PROJECT_RWA]).map(&:user) | 224 | + @writers ||= users_projects.includes(:user).map(&:user) |
235 | end | 225 | end |
236 | 226 | ||
237 | def admins | 227 | def admins |
238 | - @admins ||= users_projects.includes(:user).where(:project_access => PROJECT_RWA).map(&:user) | 228 | + @admins ||= users_projects.includes(:user).where(:project_access => UsersProject::MASTER).map(&:user) |
239 | end | 229 | end |
240 | 230 | ||
241 | def allow_read_for?(user) | 231 | def allow_read_for?(user) |
242 | - !users_projects.where(:user_id => user.id, :project_access => [PROJECT_R, PROJECT_RW, PROJECT_RWA]).empty? | 232 | + !users_projects.where(:user_id => user.id).empty? |
243 | end | 233 | end |
244 | 234 | ||
245 | def allow_write_for?(user) | 235 | def allow_write_for?(user) |
246 | - !users_projects.where(:user_id => user.id, :project_access => [PROJECT_RW, PROJECT_RWA]).empty? | 236 | + !users_projects.where(:user_id => user.id).empty? |
247 | end | 237 | end |
248 | 238 | ||
249 | def allow_admin_for?(user) | 239 | def allow_admin_for?(user) |
250 | - !users_projects.where(:user_id => user.id, :project_access => [PROJECT_RWA]).empty? || owner_id == user.id | 240 | + !users_projects.where(:user_id => user.id, :project_access => [UsersProject::MASTER]).empty? || owner_id == user.id |
251 | end | 241 | end |
252 | 242 | ||
253 | def allow_pull_for?(user) | 243 | def allow_pull_for?(user) |
254 | - !users_projects.where(:user_id => user.id, :repo_access => [Repository::REPO_R, Repository::REPO_RW, Repository::REPO_MASTER]).empty? | 244 | + !users_projects.where(:user_id => user.id, :project_access => [UsersProject::REPORTER, UsersProject::DEVELOPER, UsersProject::MASTER]).empty? |
255 | end | 245 | end |
256 | 246 | ||
257 | def root_ref | 247 | def root_ref |
app/models/repository.rb
1 | require File.join(Rails.root, "lib", "gitlabhq", "git_host") | 1 | require File.join(Rails.root, "lib", "gitlabhq", "git_host") |
2 | 2 | ||
3 | class Repository | 3 | class Repository |
4 | - REPO_N = 0 | ||
5 | - REPO_R = 1 | ||
6 | - REPO_RW = 2 | ||
7 | - REPO_MASTER = 3 | ||
8 | - | ||
9 | attr_accessor :project | 4 | attr_accessor :project |
10 | 5 | ||
11 | def self.default_ref | 6 | def self.default_ref |
@@ -13,12 +8,7 @@ class Repository | @@ -13,12 +8,7 @@ class Repository | ||
13 | end | 8 | end |
14 | 9 | ||
15 | def self.access_options | 10 | def self.access_options |
16 | - { | ||
17 | - "Denied" => REPO_N, | ||
18 | - "Pull" => REPO_R, | ||
19 | - "Pull & Push" => REPO_RW, | ||
20 | - "Master" => REPO_MASTER | ||
21 | - } | 11 | + {} |
22 | end | 12 | end |
23 | 13 | ||
24 | def initialize(project) | 14 | def initialize(project) |
app/models/users_project.rb
1 | class UsersProject < ActiveRecord::Base | 1 | class UsersProject < ActiveRecord::Base |
2 | - REPORTER = 21 | ||
3 | - DEVELOPER = 22 | ||
4 | - MASTER = 33 | 2 | + GUEST = 10 |
3 | + REPORTER = 20 | ||
4 | + DEVELOPER = 30 | ||
5 | + MASTER = 40 | ||
5 | 6 | ||
6 | belongs_to :user | 7 | belongs_to :user |
7 | belongs_to :project | 8 | belongs_to :project |
@@ -21,7 +22,6 @@ class UsersProject < ActiveRecord::Base | @@ -21,7 +22,6 @@ class UsersProject < ActiveRecord::Base | ||
21 | UsersProject.transaction do | 22 | UsersProject.transaction do |
22 | user_ids.each do |user_id| | 23 | user_ids.each do |user_id| |
23 | users_project = UsersProject.new( | 24 | users_project = UsersProject.new( |
24 | - :repo_access => repo_access, | ||
25 | :project_access => project_access, | 25 | :project_access => project_access, |
26 | :user_id => user_id | 26 | :user_id => user_id |
27 | ) | 27 | ) |
@@ -35,7 +35,6 @@ class UsersProject < ActiveRecord::Base | @@ -35,7 +35,6 @@ class UsersProject < ActiveRecord::Base | ||
35 | UsersProject.transaction do | 35 | UsersProject.transaction do |
36 | project_ids.each do |project_id| | 36 | project_ids.each do |project_id| |
37 | users_project = UsersProject.new( | 37 | users_project = UsersProject.new( |
38 | - :repo_access => repo_access, | ||
39 | :project_access => project_access, | 38 | :project_access => project_access, |
40 | ) | 39 | ) |
41 | users_project.project_id = project_id | 40 | users_project.project_id = project_id |
@@ -47,6 +46,7 @@ class UsersProject < ActiveRecord::Base | @@ -47,6 +46,7 @@ class UsersProject < ActiveRecord::Base | ||
47 | 46 | ||
48 | def self.access_roles | 47 | def self.access_roles |
49 | { | 48 | { |
49 | + "Guest" => GUEST, | ||
50 | "Reporter" => REPORTER, | 50 | "Reporter" => REPORTER, |
51 | "Developer" => DEVELOPER, | 51 | "Developer" => DEVELOPER, |
52 | "Master" => MASTER | 52 | "Master" => MASTER |
@@ -54,7 +54,7 @@ class UsersProject < ActiveRecord::Base | @@ -54,7 +54,7 @@ class UsersProject < ActiveRecord::Base | ||
54 | end | 54 | end |
55 | 55 | ||
56 | def role_access | 56 | def role_access |
57 | - "#{project_access}#{repo_access}" | 57 | + project_access |
58 | end | 58 | end |
59 | 59 | ||
60 | def update_repository | 60 | def update_repository |
@@ -68,7 +68,7 @@ class UsersProject < ActiveRecord::Base | @@ -68,7 +68,7 @@ class UsersProject < ActiveRecord::Base | ||
68 | end | 68 | end |
69 | 69 | ||
70 | def repo_access_human | 70 | def repo_access_human |
71 | - Repository.access_options.key(self.repo_access) | 71 | + "" |
72 | end | 72 | end |
73 | end | 73 | end |
74 | # == Schema Information | 74 | # == Schema Information |
app/views/admin/projects/show.html.haml
@@ -53,7 +53,6 @@ | @@ -53,7 +53,6 @@ | ||
53 | %td | 53 | %td |
54 | = link_to tm.user_name, admin_users_path(tm.user) | 54 | = link_to tm.user_name, admin_users_path(tm.user) |
55 | %td= select_tag :tm_project_access, options_for_select(Project.access_options, tm.project_access), :class => "medium project-access-select", :disabled => :disabled | 55 | %td= select_tag :tm_project_access, options_for_select(Project.access_options, tm.project_access), :class => "medium project-access-select", :disabled => :disabled |
56 | - %td= select_tag :tm_repo_access, options_for_select(Repository.access_options, tm.repo_access), :class => "medium repo-access-select", :disabled => :disabled | ||
57 | %td= link_to 'Edit Access', edit_admin_team_member_path(tm), :class => "btn small" | 56 | %td= link_to 'Edit Access', edit_admin_team_member_path(tm), :class => "btn small" |
58 | %td= link_to 'Remove from team', admin_team_member_path(tm), :confirm => 'Are you sure?', :method => :delete, :class => "btn danger small" | 57 | %td= link_to 'Remove from team', admin_team_member_path(tm), :confirm => 'Are you sure?', :method => :delete, :class => "btn danger small" |
59 | 58 | ||
@@ -68,7 +67,6 @@ | @@ -68,7 +67,6 @@ | ||
68 | %tr | 67 | %tr |
69 | %td= select_tag :user_ids, options_from_collection_for_select(@users , :id, :name), :multiple => true | 68 | %td= select_tag :user_ids, options_from_collection_for_select(@users , :id, :name), :multiple => true |
70 | %td= select_tag :project_access, options_for_select(Project.access_options), :class => "project-access-select" | 69 | %td= select_tag :project_access, options_for_select(Project.access_options), :class => "project-access-select" |
71 | - %td= select_tag :repo_access, options_for_select(Repository.access_options), :class => "repo-access-select" | ||
72 | 70 | ||
73 | .actions | 71 | .actions |
74 | = submit_tag 'Add', :class => "btn primary" | 72 | = submit_tag 'Add', :class => "btn primary" |
app/views/admin/team_members/_form.html.haml
@@ -10,10 +10,6 @@ | @@ -10,10 +10,6 @@ | ||
10 | .input | 10 | .input |
11 | = f.select :project_access, options_for_select(Project.access_options, @admin_team_member.project_access), {}, :class => "project-access-select" | 11 | = f.select :project_access, options_for_select(Project.access_options, @admin_team_member.project_access), {}, :class => "project-access-select" |
12 | 12 | ||
13 | - .clearfix | ||
14 | - %label Repository Access: | ||
15 | - .input | ||
16 | - = f.select :repo_access, options_for_select(Repository.access_options, @admin_team_member.repo_access), {}, :class => "repo-access-select" | ||
17 | %br | 13 | %br |
18 | .actions | 14 | .actions |
19 | = f.submit 'Save', :class => "btn primary" | 15 | = f.submit 'Save', :class => "btn primary" |
app/views/admin/users/show.html.haml
@@ -61,7 +61,6 @@ | @@ -61,7 +61,6 @@ | ||
61 | %tr | 61 | %tr |
62 | %td= link_to project.name, admin_project_path(project) | 62 | %td= link_to project.name, admin_project_path(project) |
63 | %td= select_tag :tm_project_access, options_for_select(Project.access_options, tm.project_access), :class => "medium project-access-select", :disabled => :disabled | 63 | %td= select_tag :tm_project_access, options_for_select(Project.access_options, tm.project_access), :class => "medium project-access-select", :disabled => :disabled |
64 | - %td= select_tag :tm_repo_access, options_for_select(Repository.access_options, tm.repo_access), :class => "medium repo-access-select", :disabled => :disabled | ||
65 | %td= link_to 'Edit Access', edit_admin_team_member_path(tm), :class => "btn small" | 64 | %td= link_to 'Edit Access', edit_admin_team_member_path(tm), :class => "btn small" |
66 | %td= link_to 'Remove from team', admin_team_member_path(tm), :confirm => 'Are you sure?', :method => :delete, :class => "btn small danger" | 65 | %td= link_to 'Remove from team', admin_team_member_path(tm), :confirm => 'Are you sure?', :method => :delete, :class => "btn small danger" |
67 | 66 | ||
@@ -76,7 +75,6 @@ | @@ -76,7 +75,6 @@ | ||
76 | %tr | 75 | %tr |
77 | %td= select_tag :project_ids, options_from_collection_for_select(@projects , :id, :name), :multiple => true | 76 | %td= select_tag :project_ids, options_from_collection_for_select(@projects , :id, :name), :multiple => true |
78 | %td= select_tag :project_access, options_for_select(Project.access_options), :class => "project-access-select" | 77 | %td= select_tag :project_access, options_for_select(Project.access_options), :class => "project-access-select" |
79 | - %td= select_tag :repo_access, options_for_select(Repository.access_options), :class => "repo-access-select" | ||
80 | 78 | ||
81 | .actions | 79 | .actions |
82 | = submit_tag 'Add', :class => "btn primary" | 80 | = submit_tag 'Add', :class => "btn primary" |
app/views/help/permissions.html.haml
@@ -3,6 +3,12 @@ | @@ -3,6 +3,12 @@ | ||
3 | 3 | ||
4 | %h4 Reporter | 4 | %h4 Reporter |
5 | %ul | 5 | %ul |
6 | + %li Create new issue | ||
7 | + %li Create new merge request | ||
8 | + %li Write on project wall | ||
9 | + | ||
10 | +%h4 Reporter | ||
11 | +%ul | ||
6 | %li Pull project code | 12 | %li Pull project code |
7 | %li Create new issue | 13 | %li Create new issue |
8 | %li Create new merge request | 14 | %li Create new merge request |
app/views/team_members/_form.html.haml
@@ -14,18 +14,9 @@ | @@ -14,18 +14,9 @@ | ||
14 | 14 | ||
15 | .clearfix | 15 | .clearfix |
16 | = f.label :project_access, "Project Access" | 16 | = f.label :project_access, "Project Access" |
17 | - .input= f.select :_project_access, options_for_select(UsersProject.access_roles, @team_member.role_access), {}, :class => "project-access-select" | ||
18 | - | 17 | + .input= f.select :project_access, options_for_select(Project.access_options, @team_member.project_access), {}, :class => "project-access-select" |
19 | 18 | ||
20 | 19 | ||
21 | - -#.clearfix | ||
22 | - -#= f.label :project_access, "Project Access" | ||
23 | - -#.input= f.select :project_access, options_for_select(Project.access_options, @team_member.project_access), {}, :class => "project-access-select" | ||
24 | - | ||
25 | - -#.clearfix | ||
26 | - -#= f.label :repo_access, "Repository Access" | ||
27 | - -#.input= f.select :repo_access, options_for_select(Repository.access_options, @team_member.repo_access), {}, :class => "repo-access-select" | ||
28 | - | ||
29 | .actions | 20 | .actions |
30 | = f.submit 'Save', :class => "btn primary" | 21 | = f.submit 'Save', :class => "btn primary" |
31 | = link_to "Cancel", team_project_path(@project), :class => "btn" | 22 | = link_to "Cancel", team_project_path(@project), :class => "btn" |
@@ -37,6 +28,6 @@ | @@ -37,6 +28,6 @@ | ||
37 | 28 | ||
38 | :javascript | 29 | :javascript |
39 | $('select#team_member_user_id').chosen(); | 30 | $('select#team_member_user_id').chosen(); |
40 | - $('select#team_member__project_access').chosen(); | 31 | + $('select#team_member_project_access').chosen(); |
41 | //$('select#team_member_repo_access').chosen(); | 32 | //$('select#team_member_repo_access').chosen(); |
42 | //$('select#team_member_project_access').chosen(); | 33 | //$('select#team_member_project_access').chosen(); |
app/views/team_members/_show.html.haml
@@ -11,9 +11,6 @@ | @@ -11,9 +11,6 @@ | ||
11 | 11 | ||
12 | .span3 | 12 | .span3 |
13 | = form_for(member, :as => :team_member, :url => project_team_member_path(@project, member)) do |f| | 13 | = form_for(member, :as => :team_member, :url => project_team_member_path(@project, member)) do |f| |
14 | - = f.select :_project_access, options_for_select(UsersProject.access_roles, member.role_access), {}, :class => "medium project-access-select", :disabled => !allow_admin | ||
15 | - -#.span3 | ||
16 | - -#= form_for(member, :as => :team_member, :url => project_team_member_path(@project, member)) do |f| | ||
17 | - -#= f.select :repo_access, options_for_select(Repository.access_options, member.repo_access), {}, :class => "medium repo-access-select", :disabled => !allow_admin | 14 | + = f.select :project_access, options_for_select(UsersProject.access_roles, member.project_access), {}, :class => "medium project-access-select", :disabled => !allow_admin |
18 | - if @project.owner == user | 15 | - if @project.owner == user |
19 | %span.label Project Owner | 16 | %span.label Project Owner |
app/views/team_members/show.html.haml
@@ -28,13 +28,6 @@ | @@ -28,13 +28,6 @@ | ||
28 | = form_for(@team_member, :as => :team_member, :url => project_team_member_path(@project, @team_member)) do |f| | 28 | = form_for(@team_member, :as => :team_member, :url => project_team_member_path(@project, @team_member)) do |f| |
29 | = f.select :project_access, options_for_select(Project.access_options, @team_member.project_access), {}, :class => "project-access-select", :disabled => !allow_admin | 29 | = f.select :project_access, options_for_select(Project.access_options, @team_member.project_access), {}, :class => "project-access-select", :disabled => !allow_admin |
30 | 30 | ||
31 | - %tr | ||
32 | - %td Repository Access | ||
33 | - %td | ||
34 | - = form_for(@team_member, :as => :team_member, :url => project_team_member_path(@project, @team_member)) do |f| | ||
35 | - = f.select :repo_access, options_for_select(Repository.access_options, @team_member.repo_access), {}, :class => "repo-access-select", :disabled => !allow_admin | ||
36 | - | ||
37 | - | ||
38 | - unless user.skype.empty? | 31 | - unless user.skype.empty? |
39 | %tr | 32 | %tr |
40 | %td Skype: | 33 | %td Skype: |
app/views/widgets/_project_member.html.haml
@@ -13,7 +13,6 @@ | @@ -13,7 +13,6 @@ | ||
13 | 13 | ||
14 | .span3 | 14 | .span3 |
15 | %span.label= member.project_access_human | 15 | %span.label= member.project_access_human |
16 | - %span.label= member.repo_access_human | ||
17 | 16 | ||
18 | - if can? current_user, :write_project, @project | 17 | - if can? current_user, :write_project, @project |
19 | - if @project.issues_enabled && @project.merge_requests_enabled | 18 | - if @project.issues_enabled && @project.merge_requests_enabled |
@@ -0,0 +1,18 @@ | @@ -0,0 +1,18 @@ | ||
1 | +class MoveToRolesPermissions < ActiveRecord::Migration | ||
2 | + def up | ||
3 | + repo_n = 0 | ||
4 | + repo_r = 1 | ||
5 | + repo_rw = 2 | ||
6 | + project_rwa = 3 | ||
7 | + | ||
8 | + UsersProject.update_all ["project_access = ?", UsersProject::MASTER], ["project_access = ?", project_rwa] | ||
9 | + UsersProject.update_all ["project_access = ?", UsersProject::DEVELOPER], ["repo_access = ?", repo_rw] | ||
10 | + UsersProject.update_all ["project_access = ?", UsersProject::REPORTER], ["repo_access = ?", repo_r] | ||
11 | + UsersProject.update_all ["project_access = ?", UsersProject::GUEST], ["repo_access = ?", repo_n] | ||
12 | + | ||
13 | + remove_column :users_projects, :repo_access | ||
14 | + end | ||
15 | + | ||
16 | + def down | ||
17 | + end | ||
18 | +end |
db/schema.rb
@@ -11,19 +11,7 @@ | @@ -11,19 +11,7 @@ | ||
11 | # | 11 | # |
12 | # It's strongly recommended to check this file into your version control system. | 12 | # It's strongly recommended to check this file into your version control system. |
13 | 13 | ||
14 | -ActiveRecord::Schema.define(:version => 20120215182305) do | ||
15 | - | ||
16 | - create_table "features", :force => true do |t| | ||
17 | - t.string "name" | ||
18 | - t.string "branch_name" | ||
19 | - t.integer "assignee_id" | ||
20 | - t.integer "author_id" | ||
21 | - t.integer "project_id" | ||
22 | - t.datetime "created_at" | ||
23 | - t.datetime "updated_at" | ||
24 | - t.string "version" | ||
25 | - t.integer "status", :default => 0, :null => false | ||
26 | - end | 14 | +ActiveRecord::Schema.define(:version => 20120216085842) do |
27 | 15 | ||
28 | create_table "issues", :force => true do |t| | 16 | create_table "issues", :force => true do |t| |
29 | t.string "title" | 17 | t.string "title" |
@@ -160,7 +148,6 @@ ActiveRecord::Schema.define(:version => 20120215182305) do | @@ -160,7 +148,6 @@ ActiveRecord::Schema.define(:version => 20120215182305) do | ||
160 | t.integer "project_id", :null => false | 148 | t.integer "project_id", :null => false |
161 | t.datetime "created_at" | 149 | t.datetime "created_at" |
162 | t.datetime "updated_at" | 150 | t.datetime "updated_at" |
163 | - t.integer "repo_access", :default => 0, :null => false | ||
164 | t.integer "project_access", :default => 0, :null => false | 151 | t.integer "project_access", :default => 0, :null => false |
165 | end | 152 | end |
166 | 153 |
spec/models/note_spec.rb
@@ -64,9 +64,8 @@ describe Note do | @@ -64,9 +64,8 @@ describe Note do | ||
64 | 64 | ||
65 | describe :read do | 65 | describe :read do |
66 | before do | 66 | before do |
67 | - @p1.users_projects.create(:user => @u1, :project_access => Project::PROJECT_N) | ||
68 | - @p1.users_projects.create(:user => @u2, :project_access => Project::PROJECT_R) | ||
69 | - @p2.users_projects.create(:user => @u3, :project_access => Project::PROJECT_R) | 67 | + @p1.users_projects.create(:user => @u2, :project_access => UsersProject::GUEST) |
68 | + @p2.users_projects.create(:user => @u3, :project_access => UsersProject::GUEST) | ||
70 | end | 69 | end |
71 | 70 | ||
72 | it { @abilities.allowed?(@u1, :read_note, @p1).should be_false } | 71 | it { @abilities.allowed?(@u1, :read_note, @p1).should be_false } |
@@ -76,9 +75,8 @@ describe Note do | @@ -76,9 +75,8 @@ describe Note do | ||
76 | 75 | ||
77 | describe :write do | 76 | describe :write do |
78 | before do | 77 | before do |
79 | - @p1.users_projects.create(:user => @u1, :project_access => Project::PROJECT_R) | ||
80 | - @p1.users_projects.create(:user => @u2, :project_access => Project::PROJECT_RW) | ||
81 | - @p2.users_projects.create(:user => @u3, :project_access => Project::PROJECT_RW) | 78 | + @p1.users_projects.create(:user => @u2, :project_access => UsersProject::DEVELOPER) |
79 | + @p2.users_projects.create(:user => @u3, :project_access => UsersProject::DEVELOPER) | ||
82 | end | 80 | end |
83 | 81 | ||
84 | it { @abilities.allowed?(@u1, :write_note, @p1).should be_false } | 82 | it { @abilities.allowed?(@u1, :write_note, @p1).should be_false } |
@@ -88,9 +86,9 @@ describe Note do | @@ -88,9 +86,9 @@ describe Note do | ||
88 | 86 | ||
89 | describe :admin do | 87 | describe :admin do |
90 | before do | 88 | before do |
91 | - @p1.users_projects.create(:user => @u1, :project_access => Project::PROJECT_R) | ||
92 | - @p1.users_projects.create(:user => @u2, :project_access => Project::PROJECT_RWA) | ||
93 | - @p2.users_projects.create(:user => @u3, :project_access => Project::PROJECT_RWA) | 89 | + @p1.users_projects.create(:user => @u1, :project_access => UsersProject::REPORTER) |
90 | + @p1.users_projects.create(:user => @u2, :project_access => UsersProject::MASTER) | ||
91 | + @p2.users_projects.create(:user => @u3, :project_access => UsersProject::MASTER) | ||
94 | end | 92 | end |
95 | 93 | ||
96 | it { @abilities.allowed?(@u1, :admin_note, @p1).should be_false } | 94 | it { @abilities.allowed?(@u1, :admin_note, @p1).should be_false } |
spec/models/project_security_spec.rb
@@ -12,8 +12,7 @@ describe Project do | @@ -12,8 +12,7 @@ describe Project do | ||
12 | 12 | ||
13 | describe "read access" do | 13 | describe "read access" do |
14 | before do | 14 | before do |
15 | - @p1.users_projects.create(:project => @p1, :user => @u1, :project_access => Project::PROJECT_N) | ||
16 | - @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => Project::PROJECT_R) | 15 | + @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => UsersProject::REPORTER) |
17 | end | 16 | end |
18 | 17 | ||
19 | it { @abilities.allowed?(@u1, :read_project, @p1).should be_false } | 18 | it { @abilities.allowed?(@u1, :read_project, @p1).should be_false } |
@@ -22,8 +21,7 @@ describe Project do | @@ -22,8 +21,7 @@ describe Project do | ||
22 | 21 | ||
23 | describe "write access" do | 22 | describe "write access" do |
24 | before do | 23 | before do |
25 | - @p1.users_projects.create(:project => @p1, :user => @u1, :project_access => Project::PROJECT_R) | ||
26 | - @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => Project::PROJECT_RW) | 24 | + @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => UsersProject::DEVELOPER) |
27 | end | 25 | end |
28 | 26 | ||
29 | it { @abilities.allowed?(@u1, :write_project, @p1).should be_false } | 27 | it { @abilities.allowed?(@u1, :write_project, @p1).should be_false } |
@@ -32,8 +30,8 @@ describe Project do | @@ -32,8 +30,8 @@ describe Project do | ||
32 | 30 | ||
33 | describe "admin access" do | 31 | describe "admin access" do |
34 | before do | 32 | before do |
35 | - @p1.users_projects.create(:project => @p1, :user => @u1, :project_access => Project::PROJECT_RW) | ||
36 | - @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => Project::PROJECT_RWA) | 33 | + @p1.users_projects.create(:project => @p1, :user => @u1, :project_access => UsersProject::DEVELOPER) |
34 | + @p1.users_projects.create(:project => @p1, :user => @u2, :project_access => UsersProject::MASTER) | ||
37 | end | 35 | end |
38 | 36 | ||
39 | it { @abilities.allowed?(@u1, :admin_project, @p1).should be_false } | 37 | it { @abilities.allowed?(@u1, :admin_project, @p1).should be_false } |
spec/requests/projects_security_spec.rb
@@ -20,11 +20,9 @@ describe "Projects" do | @@ -20,11 +20,9 @@ describe "Projects" do | ||
20 | @u2 = Factory :user | 20 | @u2 = Factory :user |
21 | @u3 = Factory :user | 21 | @u3 = Factory :user |
22 | # full access | 22 | # full access |
23 | - @project.users_projects.create(:user => @u1, :project_access => Project::PROJECT_RWA) | ||
24 | - # no access | ||
25 | - @project.users_projects.create(:user => @u2, :project_access => Project::PROJECT_N) | 23 | + @project.users_projects.create(:user => @u1, :project_access => UsersProject::MASTER) |
26 | # readonly | 24 | # readonly |
27 | - @project.users_projects.create(:user => @u3, :project_access => Project::PROJECT_R) | 25 | + @project.users_projects.create(:user => @u3, :project_access => UsersProject::REPORTER) |
28 | end | 26 | end |
29 | 27 | ||
30 | describe "GET /project_code" do | 28 | describe "GET /project_code" do |
spec/requests/team_members_spec.rb
@@ -31,8 +31,7 @@ describe "TeamMembers" do | @@ -31,8 +31,7 @@ describe "TeamMembers" do | ||
31 | before do | 31 | before do |
32 | within "#new_team_member" do | 32 | within "#new_team_member" do |
33 | select @user_1.name, :from => "team_member_user_id" | 33 | select @user_1.name, :from => "team_member_user_id" |
34 | - select "Report", :from => "team_member_project_access" | ||
35 | - select "Pull", :from => "team_member_repo_access" | 34 | + select "Reporter", :from => "team_member_project_access" |
36 | end | 35 | end |
37 | end | 36 | end |
38 | 37 | ||
@@ -45,8 +44,7 @@ describe "TeamMembers" do | @@ -45,8 +44,7 @@ describe "TeamMembers" do | ||
45 | page.should have_content @user_1.name | 44 | page.should have_content @user_1.name |
46 | 45 | ||
47 | @member.reload | 46 | @member.reload |
48 | - @member.project_access.should == Project::PROJECT_RW | ||
49 | - @member.repo_access.should == Repository::REPO_R | 47 | + @member.project_access.should == UsersProject::REPORTER |
50 | end | 48 | end |
51 | end | 49 | end |
52 | end | 50 | end |