-
Notifications
You must be signed in to change notification settings - Fork 265
/
Copy pathkoha-svc.pl
executable file
·166 lines (122 loc) · 4.57 KB
/
koha-svc.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#!/usr/bin/perl
# Copyright 2011 - Dobrica Pavlinusic
#
# 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 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.
#
# You should have received a copy of the GNU General Public License
# along with Koha; if not, see <http://www.gnu.org/licenses>.
use warnings;
use strict;
use LWP::UserAgent;
use File::Slurp qw( read_file write_file );
if ( $#ARGV >= 3 && !caller ) { # process command-line params only if not called as module!
my ( $url, $user, $password, $biblionumber, $file ) = @ARGV;
my $svc = Koha::SVC->new(
url => $url,
user => $user,
password => $password,
debug => 0,
);
if ( !$file ) {
my $marcxml = $svc->get($biblionumber);
my $file = "bib-$biblionumber.xml";
write_file $file , $marcxml;
print "saved $file ", -s $file, " bytes\n";
print $marcxml;
} else {
print "update $biblionumber from $file\n";
$svc->post( $biblionumber, scalar read_file($file) );
}
exit 0;
}
package Koha::SVC;
use warnings;
use strict;
=head1 NAME
Koha::SVC
=head1 DESCRIPTION
Call Koha's C</svc/> API to fetch/update records
This script can be used from other scripts as C<Koha::SVC> module or run
directly using syntax:
koha-svc.pl http://koha-dev:8080/cgi-bin/koha/svc svc-user svc-password $biblionumber [bib-42.xml]
If called without last argument (MARCXML filename) it will fetch C<$biblionumber> from Koha and create
C<bib-$biblionumber.xml> file from it. When called with xml filename, it will update record in Koha.
This script is intentionally separate from Koha itself and dependencies which Koha has under
assumption that you might want to run it on another machine (or create custom script which mungles
Koha's records from other machine without bringing all Koha dependencies with it).
=head1 USAGE
This same script can be used as module (as it defines T<Koha::SVC> package) using
require "koha-svc.pl"
at beginning of script. Rest of API is described below. Example of its usage is at beginning of this script.
=head2 new
my $svc = Koha::SVC->new(
url => 'http://koha-dev:8080/cgi-bin/koha/svc',
user => 'svc-user',
password => 'svc-password',
);
URL must point to Koha's B<intranet> address and port.
Specified user must have C<editcatalogue> permission.
=cut
sub new {
my $class = shift;
my $self = {@_};
bless $self, $class;
my $url = $self->{url} || die "no url found";
my $user = $self->{user} || die "no user specified";
my $password = $self->{password} || die "no password";
my $ua = LWP::UserAgent->new();
$ua->cookie_jar( {} );
my $get_resp = $ua->get("$url/authentication");
my $csrf_token = $get_resp->header('CSRF-TOKEN');
my $resp = $ua->post(
"$url/authentication",
'Csrf-Token' => $csrf_token,
'Content' => { login_userid => $user, login_password => $password }
);
die $resp->status_line unless $resp->is_success;
#NOTE: A successful authentication means we have a new CGISESSID and a new CSRF Token
$csrf_token = $resp->header('CSRF-TOKEN');
$self->{csrf_token} = $csrf_token;
warn "# $user $url = ", $resp->decoded_content, "\n" if $self->{debug};
$self->{ua} = $ua;
return $self;
}
=head2 get
my $marcxml = $svc->get( $biblionumber );
=cut
sub get {
my ( $self, $biblionumber ) = @_;
my $url = $self->{url};
warn "# get $url/bib/$biblionumber\n" if $self->{debug};
my $resp = $self->{ua}->get("$url/bib/$biblionumber");
die $resp->status_line unless $resp->is_success;
return $resp->decoded_content;
}
=head2 post
my $marcxml = $svc->post( $biblionumber, $marcxml );
=cut
sub post {
my ( $self, $biblionumber, $marcxml ) = @_;
my $url = $self->{url};
warn "# post $url/bib/$biblionumber\n" if $self->{debug};
my $csrf_token = $self->{csrf_token};
my $resp = $self->{ua}->post(
"$url/bib/$biblionumber",
'Content_type' => 'text/xml',
'Csrf_Token' => $csrf_token,
'Content' => $marcxml,
);
die $resp->status_line unless $resp->is_success;
return $resp->decoded_content;
}
1;