Commit a7d5526b authored by Paul Slaughter's avatar Paul Slaughter

Merge branch 'consolidate-u2f-authenticate-haml' into 'master'

Deduplicate U2F authentication views for users and admin mode

See merge request gitlab-org/gitlab!33212
parents a0316ac9 869eb352
...@@ -40,10 +40,10 @@ export default class U2FAuthenticate { ...@@ -40,10 +40,10 @@ export default class U2FAuthenticate {
this.signRequests = u2fParams.sign_requests.map(request => omit(request, 'challenge')); this.signRequests = u2fParams.sign_requests.map(request => omit(request, 'challenge'));
this.templates = { this.templates = {
setup: '#js-authenticate-u2f-setup', setup: '#js-authenticate-token-2fa-setup',
inProgress: '#js-authenticate-u2f-in-progress', inProgress: '#js-authenticate-token-2fa-in-progress',
error: '#js-authenticate-u2f-error', error: '#js-authenticate-token-2fa-error',
authenticated: '#js-authenticate-u2f-authenticated', authenticated: '#js-authenticate-token-2fa-authenticated',
}; };
} }
...@@ -88,7 +88,7 @@ export default class U2FAuthenticate { ...@@ -88,7 +88,7 @@ export default class U2FAuthenticate {
error_message: error.message(), error_message: error.message(),
error_code: error.errorCode, error_code: error.errorCode,
}); });
return this.container.find('#js-u2f-try-again').on('click', this.renderInProgress); return this.container.find('#js-token-2fa-try-again').on('click', this.renderInProgress);
} }
renderAuthenticated(deviceResponse) { renderAuthenticated(deviceResponse) {
......
...@@ -5,8 +5,8 @@ export default () => { ...@@ -5,8 +5,8 @@ export default () => {
if (!gon.u2f) return; if (!gon.u2f) return;
const u2fAuthenticate = new U2FAuthenticate( const u2fAuthenticate = new U2FAuthenticate(
$('#js-authenticate-u2f'), $('#js-authenticate-token-2fa'),
'#js-login-u2f-form', '#js-login-token-2fa-form',
gon.u2f, gon.u2f,
document.querySelector('#js-login-2fa-device'), document.querySelector('#js-login-2fa-device'),
document.querySelector('.js-2fa-form'), document.querySelector('.js-2fa-form'),
......
...@@ -78,7 +78,7 @@ export default class U2FRegister { ...@@ -78,7 +78,7 @@ export default class U2FRegister {
error_message: error.message(), error_message: error.message(),
error_code: error.errorCode, error_code: error.errorCode,
}); });
return this.container.find('#js-u2f-try-again').on('click', this.renderSetup); return this.container.find('#js-token-2fa-try-again').on('click', this.renderSetup);
} }
renderRegistered(deviceResponse) { renderRegistered(deviceResponse) {
......
#js-authenticate-u2f
%a.btn.btn-block.btn-info#js-login-2fa-device{ href: '#' }= _("Sign in via 2FA code")
%script#js-authenticate-u2f-in-progress{ type: "text/template" }
%p= _("Trying to communicate with your device. Plug it in (if you haven't already) and press the button on the device now.")
-# haml-lint:disable NoPlainNodes
%script#js-authenticate-u2f-error{ type: "text/template" }
%div
%p <%= error_message %> (#{_("error code:")} <%= error_code %>)
%a.btn.btn-block.btn-warning#js-u2f-try-again= _("Try again?")
%script#js-authenticate-u2f-authenticated{ type: "text/template" }
%div
%p= _("We heard back from your U2F device. You have been authenticated.")
= form_tag(admin_session_path, method: :post, id: 'js-login-u2f-form') do |f|
= hidden_field_tag 'user[device_response]', nil, class: 'form-control', required: true, id: "js-device-response"
...@@ -12,4 +12,4 @@ ...@@ -12,4 +12,4 @@
- if current_user.two_factor_otp_enabled? - if current_user.two_factor_otp_enabled?
= render 'admin/sessions/two_factor_otp' = render 'admin/sessions/two_factor_otp'
- if current_user.two_factor_u2f_enabled? - if current_user.two_factor_u2f_enabled?
= render 'admin/sessions/two_factor_u2f' = render 'u2f/authenticate', render_remember_me: false, target_path: admin_session_path
...@@ -14,4 +14,4 @@ ...@@ -14,4 +14,4 @@
= f.submit "Verify code", class: "btn btn-success" = f.submit "Verify code", class: "btn btn-success"
- if @user.two_factor_u2f_enabled? - if @user.two_factor_u2f_enabled?
= render "u2f/authenticate", locals: { params: params, resource: resource, resource_name: resource_name } = render "u2f/authenticate", params: params, resource: resource, resource_name: resource_name, render_remember_me: true, target_path: new_user_session_path
#js-authenticate-u2f #js-authenticate-token-2fa
%a.btn.btn-block.btn-info#js-login-2fa-device{ href: '#' }= _("Sign in via 2FA code") %a.btn.btn-block.btn-info#js-login-2fa-device{ href: '#' }= _("Sign in via 2FA code")
%script#js-authenticate-u2f-in-progress{ type: "text/template" } %script#js-authenticate-token-2fa-in-progress{ type: "text/template" }
%p= _("Trying to communicate with your device. Plug it in (if you haven't already) and press the button on the device now.") %p= _("Trying to communicate with your device. Plug it in (if you haven't already) and press the button on the device now.")
%script#js-authenticate-u2f-error{ type: "text/template" } %script#js-authenticate-token-2fa-error{ type: "text/template" }
%div %div
%p <%= error_message %> (#{_("error code:")} <%= error_code %>) %p <%= error_message %> (#{_("error code:")} <%= error_code %>)
%a.btn.btn-block.btn-warning#js-u2f-try-again= _("Try again?") %a.btn.btn-block.btn-warning#js-token-2fa-try-again= _("Try again?")
%script#js-authenticate-u2f-authenticated{ type: "text/template" } %script#js-authenticate-token-2fa-authenticated{ type: "text/template" }
%div %div
%p= _("We heard back from your U2F device. You have been authenticated.") %p= _("We heard back from your device. You have been authenticated.")
= form_tag(new_user_session_path, method: :post, id: 'js-login-u2f-form') do |f| = form_tag(target_path, method: :post, id: 'js-login-token-2fa-form') do |f|
- resource_params = params[resource_name].presence || params - if render_remember_me
= hidden_field_tag 'user[remember_me]', resource_params.fetch(:remember_me, 0) - resource_params = params[resource_name].presence || params
= hidden_field_tag 'user[remember_me]', resource_params.fetch(:remember_me, 0)
= hidden_field_tag 'user[device_response]', nil, class: 'form-control', required: true, id: "js-device-response" = hidden_field_tag 'user[device_response]', nil, class: 'form-control', required: true, id: "js-device-response"
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
%div %div
%p %p
%span <%= error_message %> (#{_("error code:")} <%= error_code %>) %span <%= error_message %> (#{_("error code:")} <%= error_code %>)
%a.btn.btn-warning#js-u2f-try-again= _("Try again?") %a.btn.btn-warning#js-token-2fa-try-again= _("Try again?")
%script#js-register-u2f-registered{ type: "text/template" } %script#js-register-u2f-registered{ type: "text/template" }
.row.append-bottom-10 .row.append-bottom-10
......
...@@ -24830,7 +24830,7 @@ msgstr "" ...@@ -24830,7 +24830,7 @@ msgstr ""
msgid "We have found the following errors:" msgid "We have found the following errors:"
msgstr "" msgstr ""
msgid "We heard back from your U2F device. You have been authenticated." msgid "We heard back from your device. You have been authenticated."
msgstr "" msgstr ""
msgid "We recommend that you buy more Pipeline minutes to avoid any interruption of service." msgid "We recommend that you buy more Pipeline minutes to avoid any interruption of service."
......
...@@ -257,7 +257,7 @@ describe 'Using U2F (Universal 2nd Factor) Devices for Authentication', :js do ...@@ -257,7 +257,7 @@ describe 'Using U2F (Universal 2nd Factor) Devices for Authentication', :js do
expect(page).to have_button('Verify code') expect(page).to have_button('Verify code')
expect(page).to have_css('#user_otp_attempt') expect(page).to have_css('#user_otp_attempt')
expect(page).not_to have_link('Sign in via 2FA code') expect(page).not_to have_link('Sign in via 2FA code')
expect(page).not_to have_css('#js-authenticate-u2f') expect(page).not_to have_css('#js-authenticate-token-2fa')
end end
before do before do
......
...@@ -13,10 +13,10 @@ describe('U2FAuthenticate', () => { ...@@ -13,10 +13,10 @@ describe('U2FAuthenticate', () => {
beforeEach(() => { beforeEach(() => {
loadFixtures('u2f/authenticate.html'); loadFixtures('u2f/authenticate.html');
u2fDevice = new MockU2FDevice(); u2fDevice = new MockU2FDevice();
container = $('#js-authenticate-u2f'); container = $('#js-authenticate-token-2fa');
component = new U2FAuthenticate( component = new U2FAuthenticate(
container, container,
'#js-login-u2f-form', '#js-login-token-2fa-form',
{ {
sign_requests: [], sign_requests: [],
}, },
...@@ -92,7 +92,7 @@ describe('U2FAuthenticate', () => { ...@@ -92,7 +92,7 @@ describe('U2FAuthenticate', () => {
u2fDevice.respondToAuthenticateRequest({ u2fDevice.respondToAuthenticateRequest({
errorCode: 'error!', errorCode: 'error!',
}); });
const retryButton = container.find('#js-u2f-try-again'); const retryButton = container.find('#js-token-2fa-try-again');
retryButton.trigger('click'); retryButton.trigger('click');
setupButton = container.find('#js-login-u2f-device'); setupButton = container.find('#js-login-u2f-device');
setupButton.trigger('click'); setupButton.trigger('click');
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment