Bug 21221: Shortcut memberentry scripts if patron does not exist
[koha.git] / members / apikeys.pl
index 7893ad3..9d1a4f1 100755 (executable)
-#!/usr/bin/env perl
+#!/usr/bin/perl
 
-# Copyright 2015 BibLibre
-#
 # This file is part of Koha.
 #
-# Koha is free software; you can redistribute it and/or modify it under the
-# terms of the GNU General Public License as published by the Free Software
-# Foundation; either version 2 of the License, or (at your option) any later
-# version.
+# Copyright 2015 BibLibre
+#
+# Koha is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
 #
-# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
-# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
-# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
+# Koha is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
 #
-# You should have received a copy of the GNU General Public License along
-# with Koha; if not, write to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
 
 use Modern::Perl;
 
 use CGI;
-use String::Random;
 
 use C4::Auth;
-use C4::Members;
 use C4::Output;
+
 use Koha::ApiKeys;
-use Koha::ApiKey;
+use Koha::Patrons;
+use Koha::Token;
 
 my $cgi = new CGI;
 
-my ($template, $loggedinuser, $cookie) = get_template_and_user({
-    template_name => 'members/apikeys.tt',
-    query => $cgi,
-    type => 'intranet',
-    authnotrequired => 0,
-    flagsrequired => {borrowers => 1},
-});
+my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
+    {   template_name   => 'members/apikeys.tt',
+        query           => $cgi,
+        type            => 'intranet',
+        authnotrequired => 0,
+        flagsrequired   => { borrowers => 'edit_borrowers' },
+    }
+);
+
+my $patron;
+my $patron_id = $cgi->param('patron_id') // '';
+my $api_key   = $cgi->param('key')       // '';
 
-my $borrowernumber = $cgi->param('borrowernumber');
-my $borrower = C4::Members::GetMember(borrowernumber => $borrowernumber);
-my $op = $cgi->param('op');
+$patron = Koha::Patrons->find($patron_id) if $patron_id;
+
+if ( not defined $patron or
+     not C4::Context->preference('RESTOAuth2ClientCredentials') ) {
+
+    # patron_id invalid -> exit
+    print $cgi->redirect("/cgi-bin/koha/errors/404.pl"); # escape early
+    exit;
+}
+
+my $op = $cgi->param('op') // '';
+
+if ( $op eq 'generate' or
+     $op eq 'delete' or
+     $op eq 'revoke' or
+     $op eq 'activate' ) {
+
+    die "Wrong CSRF token"
+    unless Koha::Token->new->check_csrf({
+        session_id => scalar $cgi->cookie('CGISESSID'),
+        token      => scalar $cgi->param('csrf_token'),
+    });
+}
 
 if ($op) {
-    if ($op eq 'generate') {
-        my $apikey = new Koha::ApiKey;
-        $apikey->borrowernumber($borrowernumber);
-        $apikey->api_key(String::Random->new->randregex('[a-zA-Z0-9]{32}'));
-        $apikey->store;
-        print $cgi->redirect('/cgi-bin/koha/members/apikeys.pl?borrowernumber=' . $borrowernumber);
+    if ( $op eq 'generate' ) {
+        my $description = $cgi->param('description') // '';
+        my $api_key = Koha::ApiKey->new(
+            {   patron_id   => $patron_id,
+                description => $description
+            }
+        );
+        $api_key->store;
+        print $cgi->redirect( '/cgi-bin/koha/members/apikeys.pl?patron_id=' . $patron_id );
         exit;
     }
 
-    if ($op eq 'delete') {
-        my $key = $cgi->param('key');
-        my $api_key = Koha::ApiKeys->find({borrowernumber => $borrowernumber, api_key => $key});
-        if ($api_key) {
-            $api_key->delete;
+    if ( $op eq 'delete' ) {
+        my $api_key_id = $cgi->param('key');
+        my $key = Koha::ApiKeys->find({ patron_id => $patron_id, client_id => $api_key_id });
+        if ($key) {
+            $key->delete;
         }
-        print $cgi->redirect('/cgi-bin/koha/members/apikeys.pl?borrowernumber=' . $borrowernumber);
+        print $cgi->redirect( '/cgi-bin/koha/members/apikeys.pl?patron_id=' . $patron_id );
         exit;
     }
 
-    if ($op eq 'revoke') {
-        my $key = $cgi->param('key');
-        my $api_key = Koha::ApiKeys->find({borrowernumber => $borrowernumber, api_key => $key});
-        if ($api_key) {
-            $api_key->active(0);
-            $api_key->store;
+    if ( $op eq 'revoke' ) {
+        my $api_key_id = $cgi->param('key');
+        my $key = Koha::ApiKeys->find({ patron_id => $patron_id, client_id => $api_key_id });
+        if ($key) {
+            $key->active(0);
+            $key->store;
         }
-        print $cgi->redirect('/cgi-bin/koha/members/apikeys.pl?borrowernumber=' . $borrowernumber);
+        print $cgi->redirect( '/cgi-bin/koha/members/apikeys.pl?patron_id=' . $patron_id );
         exit;
     }
 
-    if ($op eq 'activate') {
-        my $key = $cgi->param('key');
-        my $api_key = Koha::ApiKeys->find({borrowernumber => $borrowernumber, api_key => $key});
-        if ($api_key) {
-            $api_key->active(1);
-            $api_key->store;
+    if ( $op eq 'activate' ) {
+        my $api_key_id = $cgi->param('key');
+        my $key = Koha::ApiKeys->find({ patron_id => $patron_id, client_id => $api_key_id });
+        if ($key) {
+            $key->active(1);
+            $key->store;
         }
-        print $cgi->redirect('/cgi-bin/koha/members/apikeys.pl?borrowernumber=' . $borrowernumber);
+        print $cgi->redirect( '/cgi-bin/koha/members/apikeys.pl?patron_id=' . $patron_id );
         exit;
     }
 }
 
-my @api_keys = Koha::ApiKeys->search({borrowernumber => $borrowernumber});
+my @api_keys = Koha::ApiKeys->search({ patron_id => $patron_id });
 
 $template->param(
-    api_keys => \@api_keys,
-    borrower => $borrower,
-    borrowernumber => $borrowernumber,
+    api_keys   => \@api_keys,
+    csrf_token => Koha::Token->new->generate_csrf({ session_id => scalar $cgi->cookie('CGISESSID') }),
+    patron     => $patron
 );
 
 output_html_with_http_headers $cgi, $cookie, $template->output;