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
d3be0812
Commit
d3be0812
authored
Feb 20, 2019
by
Valery Sizov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Revert JWT scope inforcement
parent
6f550e74
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
0 additions
and
54 deletions
+0
-54
ee/app/controllers/ee/projects/git_http_controller.rb
ee/app/controllers/ee/projects/git_http_controller.rb
+0
-9
ee/spec/requests/git_http_geo_spec.rb
ee/spec/requests/git_http_geo_spec.rb
+0
-45
No files found.
ee/app/controllers/ee/projects/git_http_controller.rb
View file @
d3be0812
...
@@ -48,7 +48,6 @@ module EE
...
@@ -48,7 +48,6 @@ module EE
def
authenticate_user
def
authenticate_user
return
super
unless
geo_request?
return
super
unless
geo_request?
return
render_bad_geo_auth
(
'Bad token'
)
unless
decoded_authorization
return
render_bad_geo_auth
(
'Bad token'
)
unless
decoded_authorization
return
render_bad_geo_auth
(
'Unauthorized scope'
)
unless
jwt_scope_valid?
# grant access
# grant access
@authentication_result
=
::
Gitlab
::
Auth
::
Result
.
new
(
nil
,
project
,
:geo
,
[
:download_code
,
:push_code
])
# rubocop:disable Gitlab/ModuleWithInstanceVariables
@authentication_result
=
::
Gitlab
::
Auth
::
Result
.
new
(
nil
,
project
,
:geo
,
[
:download_code
,
:push_code
])
# rubocop:disable Gitlab/ModuleWithInstanceVariables
...
@@ -58,14 +57,6 @@ module EE
...
@@ -58,14 +57,6 @@ module EE
render_bad_geo_auth
(
"Invalid signature time "
)
render_bad_geo_auth
(
"Invalid signature time "
)
end
end
def
jwt_scope_valid?
decoded_authorization
[
:scope
]
==
::
Gitlab
::
Geo
::
JwtRequestDecoder
.
build_repository_scope
(
repository_type
,
project
.
id
)
end
def
repository_type
wiki?
?
'wiki'
:
'repository'
end
def
decoded_authorization
def
decoded_authorization
strong_memoize
(
:decoded_authorization
)
do
strong_memoize
(
:decoded_authorization
)
do
::
Gitlab
::
Geo
::
JwtRequestDecoder
.
new
(
request
.
headers
[
'Authorization'
]).
decode
::
Gitlab
::
Geo
::
JwtRequestDecoder
.
new
(
request
.
headers
[
'Authorization'
]).
decode
...
...
ee/spec/requests/git_http_geo_spec.rb
View file @
d3be0812
...
@@ -21,7 +21,6 @@ describe "Git HTTP requests (Geo)" do
...
@@ -21,7 +21,6 @@ describe "Git HTTP requests (Geo)" do
let!
(
:key_for_user_without_push_access
)
{
create
(
:key
,
user:
user_without_push_access
)
}
let!
(
:key_for_user_without_push_access
)
{
create
(
:key
,
user:
user_without_push_access
)
}
let
(
:env
)
{
valid_geo_env
}
let
(
:env
)
{
valid_geo_env
}
let
(
:auth_token_with_invalid_scope
)
{
Gitlab
::
Geo
::
BaseRequest
.
new
(
scope:
"invalid-
#{
project
.
id
}
"
).
authorization
}
before
do
before
do
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
...
@@ -347,50 +346,6 @@ describe "Git HTTP requests (Geo)" do
...
@@ -347,50 +346,6 @@ describe "Git HTTP requests (Geo)" do
end
end
end
end
end
end
context
'invalid scope'
do
let
(
:repository_path
)
{
project
.
full_path
}
subject
do
make_request
response
end
def
make_request
get
"/
#{
repository_path
}
.git/info/refs"
,
params:
{
service:
'git-upload-pack'
},
headers:
env
end
shared_examples_for
'unauthorized because of invalid scope'
do
it
{
is_expected
.
to
have_gitlab_http_status
(
:unauthorized
)
}
it
'returns correct error'
do
expect
(
subject
.
parsed_body
).
to
eq
(
'Geo JWT authentication failed: Unauthorized scope'
)
end
end
context
'invalid scope of Geo JWT token'
do
let
(
:env
)
{
geo_env
(
auth_token_with_invalid_scope
)
}
include_examples
'unauthorized because of invalid scope'
end
context
'Geo JWT token scopes for wiki and repository are not interchangeable'
do
context
'wiki scope'
do
let
(
:auth_token_with_valid_wiki_scope
)
{
Gitlab
::
Geo
::
BaseRequest
.
new
(
scope:
"wiki-
#{
project
.
id
}
"
).
authorization
}
let
(
:env
)
{
geo_env
(
auth_token_with_valid_wiki_scope
)
}
include_examples
'unauthorized because of invalid scope'
end
context
'respository scope'
do
let
(
:repository_path
)
{
project
.
wiki
.
full_path
}
let
(
:auth_token_with_valid_repository_scope
)
{
Gitlab
::
Geo
::
BaseRequest
.
new
(
scope:
"repository-
#{
project
.
id
}
"
).
authorization
}
let
(
:env
)
{
geo_env
(
auth_token_with_valid_repository_scope
)
}
include_examples
'unauthorized because of invalid scope'
end
end
end
end
end
def
valid_geo_env
def
valid_geo_env
...
...
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