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
1f72c387
Commit
1f72c387
authored
May 10, 2015
by
Douwe Maan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve Git access error messages.
parent
bd8ff93c
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
44 additions
and
45 deletions
+44
-45
lib/api/internal.rb
lib/api/internal.rb
+7
-19
lib/gitlab/git_access.rb
lib/gitlab/git_access.rb
+36
-25
lib/gitlab/git_access_wiki.rb
lib/gitlab/git_access_wiki.rb
+1
-1
No files found.
lib/api/internal.rb
View file @
1f72c387
...
...
@@ -24,10 +24,6 @@ module API
User
.
find_by
(
id:
params
[
:user_id
])
end
unless
actor
return
Gitlab
::
GitAccessStatus
.
new
(
false
,
'No such user or key'
)
end
project_path
=
params
[
:project
]
# Check for *.wiki repositories.
...
...
@@ -39,7 +35,6 @@ module API
project
=
Project
.
find_with_namespace
(
project_path
)
if
project
access
=
if
wiki
Gitlab
::
GitAccessWiki
.
new
(
actor
,
project
)
...
...
@@ -47,14 +42,7 @@ module API
Gitlab
::
GitAccess
.
new
(
actor
,
project
)
end
status
=
access
.
check
(
params
[
:action
],
params
[
:changes
])
end
if
project
&&
access
.
can_read_project?
status
else
Gitlab
::
GitAccessStatus
.
new
(
false
,
'No such project'
)
end
access
.
check
(
params
[
:action
],
params
[
:changes
])
end
#
...
...
lib/gitlab/git_access.rb
View file @
1f72c387
...
...
@@ -31,8 +31,7 @@ module Gitlab
def
can_push_to_branch?
(
ref
)
return
false
unless
user
if
project
.
protected_branch?
(
ref
)
&&
!
(
project
.
developers_can_push_to_protected_branch?
(
ref
)
&&
project
.
team
.
developer?
(
user
))
if
project
.
protected_branch?
(
ref
)
&&
!
project
.
developers_can_push_to_protected_branch?
(
ref
)
user
.
can?
(
:push_code_to_protected_branches
,
project
)
else
user
.
can?
(
:push_code
,
project
)
...
...
@@ -50,13 +49,25 @@ module Gitlab
end
def
check
(
cmd
,
changes
=
nil
)
unless
actor
return
build_status_object
(
false
,
"No user or key was provided."
)
end
if
user
&&
!
user_allowed?
return
build_status_object
(
false
,
"Your account has been blocked."
)
end
unless
project
&&
can_read_project?
return
build_status_object
(
false
,
'The project you were looking for could not be found.'
)
end
case
cmd
when
*
DOWNLOAD_COMMANDS
download_access_check
when
*
PUSH_COMMANDS
push_access_check
(
changes
)
else
build_status_object
(
false
,
"
Wrong command
"
)
build_status_object
(
false
,
"
The command you're trying to execute is not allowed.
"
)
end
end
...
...
@@ -64,7 +75,7 @@ module Gitlab
if
user
user_download_access_check
elsif
deploy_key
deploy_key_download_access_check
build_status_object
(
true
)
else
raise
'Wrong actor'
end
...
...
@@ -74,39 +85,27 @@ module Gitlab
if
user
user_push_access_check
(
changes
)
elsif
deploy_key
build_status_object
(
false
,
"Deploy key
not allowed to push
"
)
build_status_object
(
false
,
"Deploy key
s are not allowed to push code.
"
)
else
raise
'Wrong actor'
end
end
def
user_download_access_check
if
user
&&
user_allowed?
&&
user
.
can?
(
:download_code
,
project
)
build_status_object
(
true
)
else
build_status_object
(
false
,
"You don't have access"
)
end
unless
user
.
can?
(
:download_code
,
project
)
return
build_status_object
(
false
,
"You are not allowed to download code from this project."
)
end
def
deploy_key_download_access_check
if
can_read_project?
build_status_object
(
true
)
else
build_status_object
(
false
,
"Deploy key not allowed to access this project"
)
end
end
def
user_push_access_check
(
changes
)
unless
user
&&
user_allowed?
return
build_status_object
(
false
,
"You don't have access"
)
end
if
changes
.
blank?
return
build_status_object
(
true
)
end
unless
project
.
repository
.
exists?
return
build_status_object
(
false
,
"
Repository does not exist
"
)
return
build_status_object
(
false
,
"
A repository for this project does not exist yet.
"
)
end
changes
=
changes
.
lines
if
changes
.
kind_of?
(
String
)
...
...
@@ -136,11 +135,23 @@ module Gitlab
:push_code
end
if
user
.
can?
(
action
,
project
)
build_status_object
(
true
)
else
build_status_object
(
false
,
"You don't have permission"
)
unless
user
.
can?
(
action
,
project
)
return
case
action
when
:force_push_code_to_protected_branches
build_status_object
(
false
,
"You are not allowed to force push code to a protected branch on this project."
)
when
:remove_protected_branches
build_status_object
(
false
,
"You are not allowed to deleted protected branches from this project."
)
when
:push_code_to_protected_branches
build_status_object
(
false
,
"You are not allowed to push code to protected branches on this project."
)
when
:admin_project
build_status_object
(
false
,
"You are not allowed to change existing tags on this project."
)
else
# :push_code
build_status_object
(
false
,
"You are not allowed to push code to this project."
)
end
end
build_status_object
(
true
)
end
def
forced_push?
(
oldrev
,
newrev
)
...
...
lib/gitlab/git_access_wiki.rb
View file @
1f72c387
...
...
@@ -4,7 +4,7 @@ module Gitlab
if
user
.
can?
(
:write_wiki
,
project
)
build_status_object
(
true
)
else
build_status_object
(
false
,
"You
don't have access
"
)
build_status_object
(
false
,
"You
are not allowed to write to this project's wiki.
"
)
end
end
end
...
...
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