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
c85ab586
Commit
c85ab586
authored
May 26, 2020
by
GitLab Bot
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add latest changes from gitlab-org/security/gitlab@13-0-stable-ee
parent
5bc4a1ef
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
103 additions
and
32 deletions
+103
-32
app/controllers/oauth/authorizations_controller.rb
app/controllers/oauth/authorizations_controller.rb
+11
-0
changelogs/unreleased/security-dblessing-oauth-email-verification.yml
...nreleased/security-dblessing-oauth-email-verification.yml
+5
-0
config/locales/doorkeeper.en.yml
config/locales/doorkeeper.en.yml
+1
-0
spec/controllers/oauth/authorizations_controller_spec.rb
spec/controllers/oauth/authorizations_controller_spec.rb
+46
-32
spec/features/oauth_provider_authorize_spec.rb
spec/features/oauth_provider_authorize_spec.rb
+21
-0
spec/support/shared_examples/features/secure_oauth_authorizations_shared_examples.rb
...s/features/secure_oauth_authorizations_shared_examples.rb
+19
-0
No files found.
app/controllers/oauth/authorizations_controller.rb
View file @
c85ab586
...
@@ -4,6 +4,8 @@ class Oauth::AuthorizationsController < Doorkeeper::AuthorizationsController
...
@@ -4,6 +4,8 @@ class Oauth::AuthorizationsController < Doorkeeper::AuthorizationsController
include
Gitlab
::
Experimentation
::
ControllerConcern
include
Gitlab
::
Experimentation
::
ControllerConcern
include
InitializesCurrentUserMode
include
InitializesCurrentUserMode
before_action
:verify_confirmed_email!
,
only:
[
:new
]
layout
'profile'
layout
'profile'
# Overridden from Doorkeeper::AuthorizationsController to
# Overridden from Doorkeeper::AuthorizationsController to
...
@@ -21,4 +23,13 @@ class Oauth::AuthorizationsController < Doorkeeper::AuthorizationsController
...
@@ -21,4 +23,13 @@ class Oauth::AuthorizationsController < Doorkeeper::AuthorizationsController
render
"doorkeeper/authorizations/error"
render
"doorkeeper/authorizations/error"
end
end
end
end
private
def
verify_confirmed_email!
return
if
current_user
&
.
confirmed?
pre_auth
.
error
=
:unconfirmed_email
render
"doorkeeper/authorizations/error"
end
end
end
changelogs/unreleased/security-dblessing-oauth-email-verification.yml
0 → 100644
View file @
c85ab586
---
title
:
Require confirmed email address for GitLab OAuth authentication
merge_request
:
author
:
type
:
security
config/locales/doorkeeper.en.yml
View file @
c85ab586
...
@@ -36,6 +36,7 @@ en:
...
@@ -36,6 +36,7 @@ en:
access_denied
:
'
The
resource
owner
or
authorization
server
denied
the
request.'
access_denied
:
'
The
resource
owner
or
authorization
server
denied
the
request.'
invalid_scope
:
'
The
requested
scope
is
invalid,
unknown,
or
malformed.'
invalid_scope
:
'
The
requested
scope
is
invalid,
unknown,
or
malformed.'
server_error
:
'
The
authorization
server
encountered
an
unexpected
condition
which
prevented
it
from
fulfilling
the
request.'
server_error
:
'
The
authorization
server
encountered
an
unexpected
condition
which
prevented
it
from
fulfilling
the
request.'
unconfirmed_email
:
'
Verify
the
email
address
in
your
account
profile
before
you
sign
in.'
temporarily_unavailable
:
'
The
authorization
server
is
currently
unable
to
handle
the
request
due
to
a
temporary
overloading
or
maintenance
of
the
server.'
temporarily_unavailable
:
'
The
authorization
server
is
currently
unable
to
handle
the
request
due
to
a
temporary
overloading
or
maintenance
of
the
server.'
#configuration error messages
#configuration error messages
...
...
spec/controllers/oauth/authorizations_controller_spec.rb
View file @
c85ab586
...
@@ -3,7 +3,6 @@
...
@@ -3,7 +3,6 @@
require
'spec_helper'
require
'spec_helper'
describe
Oauth
::
AuthorizationsController
do
describe
Oauth
::
AuthorizationsController
do
let
(
:user
)
{
create
(
:user
)
}
let!
(
:application
)
{
create
(
:oauth_application
,
scopes:
'api read_user'
,
redirect_uri:
'http://example.com'
)
}
let!
(
:application
)
{
create
(
:oauth_application
,
scopes:
'api read_user'
,
redirect_uri:
'http://example.com'
)
}
let
(
:params
)
do
let
(
:params
)
do
{
{
...
@@ -19,53 +18,68 @@ describe Oauth::AuthorizationsController do
...
@@ -19,53 +18,68 @@ describe Oauth::AuthorizationsController do
end
end
describe
'GET #new'
do
describe
'GET #new'
do
context
'without valid params'
do
context
'when the user is confirmed'
do
it
'returns 200 code and renders error view'
do
let
(
:user
)
{
create
(
:user
)
}
get
:new
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
context
'without valid params'
do
expect
(
response
).
to
render_template
(
'doorkeeper/authorizations/error'
)
it
'returns 200 code and renders error view'
do
get
:new
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
render_template
(
'doorkeeper/authorizations/error'
)
end
end
end
end
context
'with valid params'
do
context
'with valid params'
do
render_views
render_views
it
'returns 200 code and renders view'
do
it
'returns 200 code and renders view'
do
get
:new
,
params:
params
get
:new
,
params:
params
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
render_template
(
'doorkeeper/authorizations/new'
)
expect
(
response
).
to
render_template
(
'doorkeeper/authorizations/new'
)
end
end
it
'deletes session.user_return_to and redirects when skip authorization'
do
it
'deletes session.user_return_to and redirects when skip authorization'
do
application
.
update
(
trusted:
true
)
application
.
update
(
trusted:
true
)
request
.
session
[
'user_return_to'
]
=
'http://example.com'
request
.
session
[
'user_return_to'
]
=
'http://example.com'
get
:new
,
params:
params
get
:new
,
params:
params
expect
(
request
.
session
[
'user_return_to'
]).
to
be_nil
expect
(
request
.
session
[
'user_return_to'
]).
to
be_nil
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
end
end
context
'when there is already an access token for the application'
do
context
'when there is already an access token for the application'
do
context
'when the request scope matches any of the created token scopes'
do
context
'when the request scope matches any of the created token scopes'
do
before
do
before
do
scopes
=
Doorkeeper
::
OAuth
::
Scopes
.
from_string
(
'api'
)
scopes
=
Doorkeeper
::
OAuth
::
Scopes
.
from_string
(
'api'
)
allow
(
Doorkeeper
.
configuration
).
to
receive
(
:scopes
).
and_return
(
scopes
)
allow
(
Doorkeeper
.
configuration
).
to
receive
(
:scopes
).
and_return
(
scopes
)
create
:oauth_access_token
,
application:
application
,
resource_owner_id:
user
.
id
,
scopes:
scopes
create
:oauth_access_token
,
application:
application
,
resource_owner_id:
user
.
id
,
scopes:
scopes
end
end
it
'authorizes the request and redirects'
do
it
'authorizes the request and redirects'
do
get
:new
,
params:
params
get
:new
,
params:
params
expect
(
request
.
session
[
'user_return_to'
]).
to
be_nil
expect
(
request
.
session
[
'user_return_to'
]).
to
be_nil
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
expect
(
response
).
to
have_gitlab_http_status
(
:found
)
end
end
end
end
end
end
end
end
end
context
'when the user is unconfirmed'
do
let
(
:user
)
{
create
(
:user
,
confirmed_at:
nil
)
}
it
'returns 200 and renders error view'
do
get
:new
,
params:
params
expect
(
response
).
to
have_gitlab_http_status
(
:ok
)
expect
(
response
).
to
render_template
(
'doorkeeper/authorizations/error'
)
end
end
end
end
end
end
spec/features/oauth_provider_authorize_spec.rb
0 → 100644
View file @
c85ab586
# frozen_string_literal: true
require
'spec_helper'
describe
'OAuth Provider'
do
describe
'Standard OAuth Authorization'
do
let
(
:application
)
{
create
(
:oauth_application
,
scopes:
'read_user'
)
}
before
do
sign_in
(
user
)
visit
oauth_authorization_path
(
client_id:
application
.
uid
,
redirect_uri:
application
.
redirect_uri
.
split
.
first
,
response_type:
'code'
,
state:
'my_state'
,
scope:
'read_user'
)
end
it_behaves_like
'Secure OAuth Authorizations'
end
end
spec/support/shared_examples/features/secure_oauth_authorizations_shared_examples.rb
0 → 100644
View file @
c85ab586
# frozen_string_literal: true
RSpec
.
shared_examples
'Secure OAuth Authorizations'
do
context
'when user is confirmed'
do
let
(
:user
)
{
create
(
:user
)
}
it
'asks the user to authorize the application'
do
expect
(
page
).
to
have_text
"Authorize
#{
application
.
name
}
to use your account?"
end
end
context
'when user is unconfirmed'
do
let
(
:user
)
{
create
(
:user
,
confirmed_at:
nil
)
}
it
'displays an error'
do
expect
(
page
).
to
have_text
I18n
.
t
(
'doorkeeper.errors.messages.unconfirmed_email'
)
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