1 package Koha::REST::V1::TwoFactorAuth;
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Mojo::Base 'Mojolicious::Controller';
23 use C4::Letters qw( GetPreparedLetter );
27 Koha::REST::V1::TwoFactorAuth
35 Will send an email with the OTP token needed to complete the second authentication step.
42 my $c = shift->openapi->valid_input or return;
44 my $patron = Koha::Patrons->find( $c->stash('koha.user')->borrowernumber );
48 my $letter = C4::Letters::GetPreparedLetter(
50 letter_code => '2FA_OTP_TOKEN',
51 branchcode => $patron->branchcode,
53 borrowers => $patron->unblessed,
56 my $message_id = C4::Letters::EnqueueLetter(
59 borrowernumber => $patron->borrowernumber,
60 message_transport_type => 'email'
63 C4::Letters::SendQueuedMessages({message_id => $message_id});
65 my $message = C4::Letters::GetMessage($message_id);
67 if ( $message->{status} eq 'sent' ) {
68 return $c->render(status => 200, openapi => {});
69 } elsif ( $message->{status} eq 'failed' ) {
70 return $c->render(status => 400, openapi => { error => 'email_not_sent'});
74 $c->unhandled_exception($_);