2020-05-07 02:14:54 -06:00
|
|
|
<%= if get_flash(@conn, :info) do %>
|
|
|
|
<p class="alert alert-info" role="alert"><%= get_flash(@conn, :info) %></p>
|
|
|
|
<% end %>
|
|
|
|
<%= if get_flash(@conn, :error) do %>
|
|
|
|
<p class="alert alert-danger" role="alert"><%= get_flash(@conn, :error) %></p>
|
|
|
|
<% end %>
|
|
|
|
|
2022-02-28 09:07:28 -07:00
|
|
|
<h2><%= Gettext.dpgettext("static_pages", "mfa auth page title", "Two-factor authentication") %></h2>
|
2020-05-07 02:14:54 -06:00
|
|
|
|
2021-05-18 16:11:25 -06:00
|
|
|
<%= form_for @conn, Routes.mfa_verify_path(@conn, :verify), [as: "mfa"], fn f -> %>
|
2020-05-07 02:14:54 -06:00
|
|
|
<div class="input">
|
2022-02-28 09:07:28 -07:00
|
|
|
<%= label f, :code, Gettext.dpgettext("static_pages", "mfa auth code prompt", "Authentication code") %>
|
2022-01-22 02:00:43 -07:00
|
|
|
<%= text_input f, :code, [autocomplete: "one-time-code", autocorrect: "off", autocapitalize: "off", autofocus: true, pattern: "[0-9]*", spellcheck: false] %>
|
2020-05-07 02:14:54 -06:00
|
|
|
<%= hidden_input f, :mfa_token, value: @mfa_token %>
|
|
|
|
<%= hidden_input f, :state, value: @state %>
|
|
|
|
<%= hidden_input f, :redirect_uri, value: @redirect_uri %>
|
|
|
|
<%= hidden_input f, :challenge_type, value: "totp" %>
|
|
|
|
</div>
|
|
|
|
|
2022-02-28 09:07:28 -07:00
|
|
|
<%= submit Gettext.dpgettext("static_pages", "mfa auth verify code button", "Verify") %>
|
2020-05-07 02:14:54 -06:00
|
|
|
<% end %>
|
2021-05-18 16:11:25 -06:00
|
|
|
<a href="<%= Routes.mfa_path(@conn, :show, %{challenge_type: "recovery", mfa_token: @mfa_token, state: @state, redirect_uri: @redirect_uri}) %>">
|
2022-02-28 09:07:28 -07:00
|
|
|
<%= Gettext.dpgettext("static_pages", "mfa auth page use recovery code link", "Enter a two-factor recovery code") %>
|
2020-05-07 02:14:54 -06:00
|
|
|
</a>
|