Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
cb021e58
Commit
cb021e58
authored
Dec 07, 2011
by
Dmitriy Zaporozhets
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
repo & project access separated. critical gitolite bugfix
parent
2ca00bdb
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
106 additions
and
48 deletions
+106
-48
app/controllers/team_members_controller.rb
app/controllers/team_members_controller.rb
+3
-8
app/models/key.rb
app/models/key.rb
+2
-2
app/models/project.rb
app/models/project.rb
+27
-5
app/models/repository.rb
app/models/repository.rb
+13
-1
app/models/users_project.rb
app/models/users_project.rb
+4
-9
app/views/projects/_team.html.haml
app/views/projects/_team.html.haml
+8
-3
app/views/team_members/_show.html.haml
app/views/team_members/_show.html.haml
+9
-10
db/migrate/20111206213842_add_advanced_rights_to_team_member.rb
...rate/20111206213842_add_advanced_rights_to_team_member.rb
+6
-0
db/migrate/20111206222316_migrate_to_new_rights.rb
db/migrate/20111206222316_migrate_to_new_rights.rb
+20
-0
db/schema.rb
db/schema.rb
+3
-4
lib/gitlabhq/gitolite.rb
lib/gitlabhq/gitolite.rb
+7
-2
public/githost_error.html
public/githost_error.html
+4
-4
No files found.
app/controllers/team_members_controller.rb
View file @
cb021e58
...
...
@@ -25,16 +25,11 @@ class TeamMembersController < ApplicationController
@team_member
=
project
.
users_projects
.
find
(
params
[
:id
])
@team_member
.
update_attributes
(
params
[
:team_member
])
respond_to
do
|
format
|
format
.
js
format
.
html
do
unless
@team_member
.
valid?
flash
[
:alert
]
=
"User should have at least one role"
end
redirect_to
team_project_path
(
@project
)
end
end
end
def
destroy
@team_member
=
project
.
users_projects
.
find
(
params
[
:id
])
...
...
app/models/key.rb
View file @
cb021e58
...
...
@@ -23,7 +23,7 @@ class Key < ActiveRecord::Base
c
.
update_keys
(
identifier
,
key
)
projects
.
each
do
|
project
|
c
.
update_project
(
project
.
path
,
project
.
repository_writers
)
c
.
update_project
(
project
.
path
,
project
)
end
end
end
...
...
@@ -33,7 +33,7 @@ class Key < ActiveRecord::Base
c
.
delete_key
(
identifier
)
projects
.
each
do
|
project
|
c
.
update_project
(
project
.
path
,
project
.
repository_writers
)
c
.
update_project
(
project
.
path
,
project
)
end
end
end
...
...
app/models/project.rb
View file @
cb021e58
require
"grit"
class
Project
<
ActiveRecord
::
Base
PROJECT_N
=
0
PROJECT_R
=
1
PROJECT_RW
=
2
PROJECT_RWA
=
3
belongs_to
:owner
,
:class_name
=>
"User"
has_many
:merge_requests
,
:dependent
=>
:destroy
...
...
@@ -47,6 +52,16 @@ class Project < ActiveRecord::Base
scope
:public_only
,
where
(
:private_flag
=>
false
)
def
self
.
access_options
{
"Denied"
=>
PROJECT_N
,
"Read"
=>
PROJECT_R
,
"Report"
=>
PROJECT_RW
,
"Admin"
=>
PROJECT_RWA
}
end
def
repository
@repository
||=
Repository
.
new
(
self
)
end
...
...
@@ -109,21 +124,28 @@ class Project < ActiveRecord::Base
users_projects
.
where
(
:project_id
=>
self
.
id
,
:user_id
=>
user
.
id
).
destroy
if
self
.
id
end
def
writers
@writers
||=
users_projects
.
includes
(
:user
).
where
(
:write
=>
true
).
map
(
&
:user
)
def
repository_readers
keys
=
Key
.
joins
({
:user
=>
:users_projects
}).
where
(
"users_projects.project_id = ? AND users_projects.repo_access = ?"
,
id
,
Repository
::
REPO_R
)
keys
.
map
(
&
:identifier
)
end
def
repository_writers
keys
=
Key
.
joins
({
:user
=>
:users_projects
}).
where
(
"users_projects.project_id = ? AND users_projects.write = ?"
,
id
,
true
)
keys
=
Key
.
joins
({
:user
=>
:users_projects
}).
where
(
"users_projects.project_id = ? AND users_projects.repo_access = ?"
,
id
,
Repository
::
REPO_RW
)
keys
.
map
(
&
:identifier
)
end
def
readers
@readers
||=
users_projects
.
includes
(
:user
).
where
(
:read
=>
true
).
map
(
&
:user
)
@readers
||=
users_projects
.
includes
(
:user
).
where
(
:project_access
=>
[
PROJECT_R
,
PROJECT_RW
,
PROJECT_RWA
]).
map
(
&
:user
)
end
def
writers
@writers
||=
users_projects
.
includes
(
:user
).
where
(
:project_access
=>
[
PROJECT_RW
,
PROJECT_RWA
]).
map
(
&
:user
)
end
def
admins
@admins
||=
users_projects
.
includes
(
:user
).
where
(
:admin
=>
true
).
map
(
&
:user
)
@admins
||=
users_projects
.
includes
(
:user
).
where
(
:project_access
=>
PROJECT_RWA
).
map
(
&
:user
)
end
def
root_ref
...
...
app/models/repository.rb
View file @
cb021e58
require
File
.
join
(
Rails
.
root
,
"lib"
,
"gitlabhq"
,
"git_host"
)
class
Repository
REPO_N
=
0
REPO_R
=
1
REPO_RW
=
2
attr_accessor
:project
def
self
.
default_ref
"master"
end
def
self
.
access_options
{
"Denied"
=>
REPO_N
,
"Pull"
=>
REPO_R
,
"Pull & Push"
=>
REPO_RW
}
end
def
initialize
(
project
)
@project
=
project
end
...
...
@@ -33,7 +45,7 @@ class Repository
def
update_repository
Gitlabhq
::
GitHost
.
system
.
new
.
configure
do
|
c
|
c
.
update_project
(
path
,
project
.
repository_writers
)
c
.
update_project
(
path
,
project
)
end
end
...
...
app/models/users_project.rb
View file @
cb021e58
...
...
@@ -4,25 +4,20 @@ class UsersProject < ActiveRecord::Base
attr_protected
:project_id
,
:project
after_commit
:update_repository
after_save
:update_repository
after_destroy
:update_repository
validates_uniqueness_of
:user_id
,
:scope
=>
[
:project_id
]
validates_presence_of
:user_id
validates_presence_of
:project_id
validate
:user_has_a_role_selected
delegate
:name
,
:email
,
:to
=>
:user
,
:prefix
=>
true
def
update_repository
Git
osis
.
new
.
configure
do
|
c
|
c
.
update_project
(
project
.
path
,
project
.
repository
)
Git
labhq
::
GitHost
.
system
.
new
.
configure
do
|
c
|
c
.
update_project
(
project
.
path
,
project
)
end
end
def
user_has_a_role_selected
errors
.
add
(
:base
,
"Please choose at least one Role in the Access list"
)
unless
read
||
write
||
admin
end
end
# == Schema Information
#
...
...
app/views/projects/_team.html.haml
View file @
cb021e58
...
...
@@ -5,14 +5,19 @@
%table
.round-borders
#team-table
%thead
%th
Name
%th
Web
%th
Git
%th
Admin
%th
Project
%th
Repository
-
if
can?
current_user
,
:admin_team_member
,
@project
%th
Actions
-
@project
.
users_projects
.
each
do
|
up
|
=
render
(
:partial
=>
'team_members/show'
,
:locals
=>
{
:member
=>
up
})
:javascript
$
(
function
(){
$
(
'
.repo-access-select, .project-access-select
'
).
live
(
"
change
"
,
function
()
{
$
(
this
.
form
).
submit
();
});
})
$
(
'
.delete-team-member
'
).
live
(
'
ajax:success
'
,
function
()
{
$
(
this
).
closest
(
'
tr
'
).
fadeOut
();
});
app/views/team_members/_show.html.haml
View file @
cb021e58
-
user
=
member
.
user
-
allow_admin
=
can?
current_user
,
:admin_project
,
@project
%tr
{
:id
=>
dom_id
(
member
)}
%td
=
link_to
image_tag
(
gravatar_icon
(
user
.
email
),
:class
=>
"left"
,
:width
=>
40
,
:style
=>
"padding:0 5px;"
),
project_team_member_path
(
@project
,
member
)
...
...
@@ -6,15 +7,13 @@
=
link_to
truncate
(
user
.
name
,
:lenght
=>
24
),
project_team_member_path
(
@project
,
member
)
%br
.cgray
{
:style
=>
"padding-top:10px;"
}=
truncate
user
.
email
,
:lenght
=>
24
-
if
can?
current_user
,
:admin_project
,
@project
%td
=
form_for
(
member
,
:as
=>
:team_member
,
:url
=>
project_team_member_path
(
@project
,
member
))
do
|
f
|
=
f
.
select
:project_access
,
options_for_select
(
Project
.
access_options
,
member
.
project_access
),
{},
:class
=>
"project-access-select"
,
:disabled
=>
!
allow_admin
%td
=
form_for
(
member
,
:as
=>
:team_member
,
:url
=>
project_team_member_path
(
@project
,
member
))
do
|
f
|
%td
=
f
.
check_box
:read
,
:onclick
=>
"$(this.form).submit();"
%td
=
f
.
check_box
:write
,
:onclick
=>
"$(this.form).submit();"
%td
=
f
.
check_box
:admin
,
:onclick
=>
"$(this.form).submit();"
-
else
%td
=
check_box_tag
"read"
,
1
,
member
.
read
,
:disabled
=>
:disabled
%td
=
check_box_tag
"commit"
,
1
,
member
.
write
,
:disabled
=>
:disabled
%td
=
check_box_tag
"admin"
,
1
,
member
.
admin
,
:disabled
=>
:disabled
-
if
can?
current_user
,
:admin_team_member
,
@project
=
f
.
select
:repo_access
,
options_for_select
(
Repository
.
access_options
,
member
.
repo_access
),
{},
:class
=>
"repo-access-select"
,
:disabled
=>
!
allow_admin
-
if
allow_admin
%td
=
link_to
'Cancel'
,
project_team_member_path
(
:project_id
=>
@project
,
:id
=>
member
.
id
),
:confirm
=>
'Are you sure?'
,
:method
=>
:delete
,
:class
=>
"grey-button negative delete-team-member"
,
:remote
=>
true
db/migrate/20111206213842_add_advanced_rights_to_team_member.rb
0 → 100644
View file @
cb021e58
class
AddAdvancedRightsToTeamMember
<
ActiveRecord
::
Migration
def
change
add_column
:users_projects
,
:repo_access
,
:integer
,
:default
=>
0
,
:null
=>
false
add_column
:users_projects
,
:project_access
,
:integer
,
:default
=>
0
,
:null
=>
false
end
end
db/migrate/20111206222316_migrate_to_new_rights.rb
0 → 100644
View file @
cb021e58
class
MigrateToNewRights
<
ActiveRecord
::
Migration
def
up
# Repository access
UsersProject
.
update_all
(
"repo_access = 2"
,
:write
=>
true
)
UsersProject
.
update_all
(
"repo_access = 1"
,
:read
=>
true
,
:write
=>
false
)
# Project access
UsersProject
.
update_all
(
"project_access = 1"
,
:read
=>
true
,
:write
=>
false
,
:admin
=>
false
)
UsersProject
.
update_all
(
"project_access = 2"
,
:read
=>
true
,
:write
=>
true
,
:admin
=>
false
)
UsersProject
.
update_all
(
"project_access = 3"
,
:read
=>
true
,
:write
=>
true
,
:admin
=>
true
)
# Remove old fields
remove_column
:users_projects
,
:read
remove_column
:users_projects
,
:write
remove_column
:users_projects
,
:admin
end
def
down
end
end
db/schema.rb
View file @
cb021e58
...
...
@@ -11,7 +11,7 @@
#
# It's strongly recommended to check this file into your version control system.
ActiveRecord
::
Schema
.
define
(
:version
=>
20111
127155345
)
do
ActiveRecord
::
Schema
.
define
(
:version
=>
20111
206222316
)
do
create_table
"features"
,
:force
=>
true
do
|
t
|
t
.
string
"name"
...
...
@@ -137,11 +137,10 @@ ActiveRecord::Schema.define(:version => 20111127155345) do
create_table
"users_projects"
,
:force
=>
true
do
|
t
|
t
.
integer
"user_id"
,
:null
=>
false
t
.
integer
"project_id"
,
:null
=>
false
t
.
boolean
"read"
,
:default
=>
false
t
.
boolean
"write"
,
:default
=>
false
t
.
boolean
"admin"
,
:default
=>
false
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
integer
"repo_access"
,
:default
=>
0
,
:null
=>
false
t
.
integer
"project_access"
,
:default
=>
0
,
:null
=>
false
end
end
lib/gitlabhq/gitolite.rb
View file @
cb021e58
...
...
@@ -61,7 +61,7 @@ module Gitlabhq
end
# update or create
def
update_project
(
repo_name
,
name_writers
)
def
update_project
(
repo_name
,
project
)
ga_repo
=
::
Gitolite
::
GitoliteAdmin
.
new
(
File
.
join
(
@local_dir
,
'gitolite'
))
conf
=
ga_repo
.
config
...
...
@@ -71,8 +71,13 @@ module Gitlabhq
::
Gitolite
::
Config
::
Repo
.
new
(
repo_name
)
end
name_readers
=
project
.
repository_readers
name_writers
=
project
.
repository_writers
repo
.
clean_permissions
repo
.
add_permission
(
"R"
,
""
,
name_readers
)
unless
name_readers
.
blank?
repo
.
add_permission
(
"RW+"
,
""
,
name_writers
)
unless
name_writers
.
blank?
conf
.
add_repo
(
repo
)
conf
.
add_repo
(
repo
,
true
)
ga_repo
.
save
end
...
...
public/git
osis
_error.html
→
public/git
host
_error.html
View file @
cb021e58
...
...
@@ -17,10 +17,10 @@
<body>
<!-- This file lives in public/500.html -->
<div
class=
"dialog"
>
<h1>
Gito
sis
Error
</h1>
<h2>
We're sorry, but we cant get access to your gito
sis
.
</h2>
<h3>
1. Check 'config/git
osis
.yml' for correct settings.
</h3>
<h3>
2. Be sure web server user has access to gito
sis
.
</h3>
<h1>
Gito
lite
Error
</h1>
<h2>
We're sorry, but we cant get access to your gito
lite system
.
</h2>
<h3>
1. Check 'config/git
lab
.yml' for correct settings.
</h3>
<h3>
2. Be sure web server user has access to gito
lite
.
</h3>
</div>
</body>
</html>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment