5 [% INCLUDE 'doc-head-open.inc' %]
6 <title>Two-factor authentication › Patrons › Koha</title>
7 [% INCLUDE 'doc-head-close.inc' %]
9 <body id="pat_two_factor_auth" class="pat">
10 [% WRAPPER 'header.inc' %]
11 [% INCLUDE 'patron-search-header.inc' %]
13 [% PROCESS 'auth-two-factor.inc' %]
15 [% WRAPPER 'sub-header.inc' %]
16 <nav id="breadcrumbs" aria-label="Breadcrumb" class="breadcrumb">
19 <a href="/cgi-bin/koha/mainpage.pl">Home</a>
22 <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
25 <a href="#" aria-current="page">
26 Manage two-factor authentication
33 <div class="main container-fluid">
35 <div class="col-sm-10 col-sm-push-2">
38 [% INCLUDE 'members-toolbar.inc' %]
40 <h1>Manage two-factor authentication</h1>
42 [% IF ( missing_key ) %]
43 <div id="error_message" class="dialog message">
45 Operation cannot proceed, please define an encryption key in your configuration.
49 [% PROCESS registration_form %]
51 <div id="registration-status">
52 [% IF patron.auth_method == "two-factor" %]
53 <div id="registration-status-enabled">
55 <div id="registration-status-enabled" style="display: none;">
57 <div class="two-factor-status">Status: Enabled</div>
59 <form id="two-factor-auth" action="/cgi-bin/koha/members/two_factor_auth.pl" method="post">
60 <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
61 <input type="hidden" name="op" value="disable-2FA" />
62 <input type="submit" value="Disable two-factor authentication" />
66 [% IF patron.auth_method == "password" %]
67 <div id="registration-status-disabled">
69 <div id="registration-status-disabled" style="display: none;">
71 <div class="two-factor-status">Status: Disabled</div>
72 [% IF Koha.Preference('TwoFactorAuthentication') == 'enforced' %]
73 <div>Two-factor authentication is mandatory to login. If you do not enable now it will be asked at your next login.</div>
76 <input id="enable-2FA" type="submit" value="Enable two-factor authentication" />
81 </div> <!-- /.col-sm-10.col-sm-push-2 -->
83 <div class="col-sm-2 col-sm-pull-10">
85 [% INCLUDE 'circ-menu.inc' %]
87 </div> <!-- /.col-sm-2.col-sm-pull-10 -->
91 [% MACRO jsinclude BLOCK %]
92 [% INCLUDE 'str/members-menu.inc' %]
93 [% Asset.js("js/members-menu.js") | $raw %]
95 $(document).ready(function(){
96 $("#enable-2FA").on("click", function(e){
101 url: '/api/v1/auth/two-factor/registration',
102 success: function (data) {
103 $("#qr_code").attr('src', data.qr_code);
104 $("#secret32").val(data.secret32);
105 $("#issuer").html(data.issuer);
106 $("#key_id").html(data.key_id);
107 $("#registration-form").show();
108 $("#registration-status").hide();
110 error: function (data) {
116 $("#register-2FA").on("click", function(e){
119 secret32: $("#secret32").val(),
120 pin_code: $("#pin_code").val(),
122 if (!data.pin_code) return;
127 url: '/api/v1/auth/two-factor/registration/verification',
128 success: function (data) {
129 window.location = "/cgi-bin/koha/members/two_factor_auth.pl";
131 error: function (data) {
132 const error = data.responseJSON.error;
133 if ( error == 'Invalid pin' ) {
134 $("#errors").html(_("Invalid PIN code")).show();
146 [% INCLUDE 'intranet-bottom.inc' %]