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
6b69a163
Commit
6b69a163
authored
Dec 02, 2016
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix LfsRequest, Projects::GitHttpController, and IssuablesHelper
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
e2e2d682
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
36 additions
and
77 deletions
+36
-77
app/controllers/concerns/lfs_request.rb
app/controllers/concerns/lfs_request.rb
+35
-56
app/controllers/projects/git_http_controller.rb
app/controllers/projects/git_http_controller.rb
+1
-8
app/helpers/issuables_helper.rb
app/helpers/issuables_helper.rb
+0
-13
No files found.
app/controllers/concerns/lfs_request.rb
View file @
6b69a163
...
...
@@ -33,59 +33,15 @@ module LfsRequest
return
if
download_request?
&&
lfs_download_access?
return
if
upload_request?
&&
lfs_upload_access?
<<<<<<<
HEAD
:app
/
helpers
/
lfs_helper
.
rb
if
project
.
public?
||
(
user
&&
user
.
can?
(
:read_project
,
project
))
if
project
.
above_size_limit?
||
objects_exceed_repo_limit?
render_size_error
else
render_lfs_forbidden
end
=======
if
project
.
public?
||
can?
(
user
,
:read_project
,
project
)
lfs_forbidden!
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
:app
/
controllers
/
concerns
/
lfs_request
.
rb
else
render_lfs_not_found
end
end
<<<<<<<
HEAD
:app
/
helpers
/
lfs_helper
.
rb
def
lfs_download_access?
return
false
unless
project
.
lfs_enabled?
ci?
||
lfs_deploy_token?
||
user_can_download_code?
||
build_can_download_code?
end
def
objects
@objects
||=
(
params
[
:objects
]
||
[]).
to_a
end
def
user_can_download_code?
has_authentication_ability?
(
:download_code
)
&&
can?
(
user
,
:download_code
,
project
)
end
def
build_can_download_code?
has_authentication_ability?
(
:build_download_code
)
&&
can?
(
user
,
:build_download_code
,
project
)
end
def
lfs_upload_access?
return
false
unless
project
.
lfs_enabled?
return
false
if
project
.
above_size_limit?
||
objects_exceed_repo_limit?
has_authentication_ability?
(
:push_code
)
&&
can?
(
user
,
:push_code
,
project
)
=======
def
lfs_forbidden!
render_lfs_forbidden
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
:app
/
controllers
/
concerns
/
lfs_request
.
rb
end
def
objects_exceed_repo_limit?
return
false
unless
project
.
size_limit_enabled?
return
@limit_exceeded
if
defined?
(
@limit_exceeded
)
size_of_objects
=
objects
.
sum
{
|
o
|
o
[
:size
]
}
@limit_exceeded
=
(
project
.
repository_and_lfs_size
+
size_of_objects
.
to_mb
)
>
project
.
actual_size_limit
end
def
render_lfs_forbidden
...
...
@@ -110,17 +66,6 @@ module LfsRequest
)
end
<<<<<<<
HEAD
:app
/
helpers
/
lfs_helper
.
rb
def
render_size_error
render
(
json:
{
message:
Gitlab
::
RepositorySizeError
.
new
(
project
).
push_error
,
documentation_url:
help_url
,
},
content_type:
"application/vnd.git-lfs+json"
,
status:
406
)
=======
def
lfs_download_access?
return
false
unless
project
.
lfs_enabled?
...
...
@@ -129,6 +74,7 @@ module LfsRequest
def
lfs_upload_access?
return
false
unless
project
.
lfs_enabled?
return
false
if
project
.
above_size_limit?
||
objects_exceed_repo_limit?
has_authentication_ability?
(
:push_code
)
&&
can?
(
user
,
:push_code
,
project
)
end
...
...
@@ -143,7 +89,6 @@ module LfsRequest
def
build_can_download_code?
has_authentication_ability?
(
:build_download_code
)
&&
can?
(
user
,
:build_download_code
,
project
)
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
:app
/
controllers
/
concerns
/
lfs_request
.
rb
end
def
storage_project
...
...
@@ -162,4 +107,38 @@ module LfsRequest
def
objects
@objects
||=
(
params
[
:objects
]
||
[]).
to_a
end
module
EE
def
lfs_forbidden!
raise
NotImplementedError
unless
defined?
(
super
)
if
project
.
above_size_limit?
||
objects_exceed_repo_limit?
render_size_error
else
super
end
end
def
render_size_error
render
(
json:
{
message:
Gitlab
::
RepositorySizeError
.
new
(
project
).
push_error
,
documentation_url:
help_url
,
},
content_type:
"application/vnd.git-lfs+json"
,
status:
406
)
end
def
objects_exceed_repo_limit?
return
false
unless
project
.
size_limit_enabled?
return
@limit_exceeded
if
defined?
(
@limit_exceeded
)
size_of_objects
=
objects
.
sum
{
|
o
|
o
[
:size
]
}
@limit_exceeded
=
(
project
.
repository_and_lfs_size
+
size_of_objects
.
to_mb
)
>
project
.
actual_size_limit
end
end
prepend
EE
end
app/controllers/projects/git_http_controller.rb
View file @
6b69a163
...
...
@@ -67,15 +67,8 @@ class Projects::GitHttpController < Projects::GitHttpClientController
end
def
render_denied
<<<<<<<
HEAD
if
user
&&
user
.
can?
(
:read_project
,
project
)
message
=
project
.
above_size_limit?
?
access_check
.
message
:
'Access denied'
render
plain:
message
,
status: :forbidden
=======
if
user
&&
can?
(
user
,
:read_project
,
project
)
render
plain:
access_denied_message
,
status: :forbidden
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
else
# Do not leak information about project existence
render_not_found
...
...
@@ -83,7 +76,7 @@ class Projects::GitHttpController < Projects::GitHttpClientController
end
def
access_denied_message
'Access denied'
project
.
above_size_limit?
?
access_check
.
message
:
'Access denied'
end
def
upload_pack_allowed?
...
...
app/helpers/issuables_helper.rb
View file @
6b69a163
...
...
@@ -158,12 +158,8 @@ module IssuablesHelper
:author_id
,
:assignee_id
,
:milestone_title
,
<<<<<<<
HEAD
:label_name
,
:weight
=======
:label_name
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
]
end
...
...
@@ -194,18 +190,9 @@ module IssuablesHelper
end
def
issuables_count_for_state
(
issuable_type
,
state
)
<<<<<<<
HEAD
issuables_finder
=
public_send
(
"
#{
issuable_type
}
_finder"
)
params
=
issuables_finder
.
params
.
merge
(
state:
state
)
finder
=
issuables_finder
.
class
.
new
(
issuables_finder
.
current_user
,
params
)
finder
.
execute
.
page
(
1
).
total_count
=======
@counts
||=
{}
@counts
[
issuable_type
]
||=
public_send
(
"
#{
issuable_type
}
_finder"
).
count_by_state
@counts
[
issuable_type
][
state
]
>>>>>>>
14046
b9c734e5e6506d63276f39f3f9d770c3699
end
IRRELEVANT_PARAMS_FOR_CACHE_KEY
=
%i[utf8 sort page]
...
...
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