1 package Koha
::Illrequest
::Config
;
3 # Copyright 2013,2014 PTFS Europe Ltd
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 3 of the License, or (at your option) any later
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License along
17 # with Koha; if not, write to the Free Software Foundation, Inc.,
18 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 use File
::Basename qw
/basename/;
28 Koha::Illrequest::Config - Koha ILL Configuration Object
32 Object-oriented class that giving access to the illconfig data derived
37 Config object providing abstract representation of the expected XML
40 In particular the config object uses a YAML file, whose path is
41 defined by <illconfig> in koha-conf.xml. That YAML file provides the
42 data structure exposed in this object.
44 By default the configured data structure complies with fields used by
45 the British Library Interlibrary Loan DSS API.
47 The config file also provides mappings for Record Object accessors.
55 my $config = Koha::Illrequest::Config->new();
57 Create a new Koha::Illrequest::Config object, with mapping data loaded from the
58 ILL configuration file.
66 $self->{configuration
} = _load_configuration
(
67 C4
::Context
->config("interlibrary_loans")
77 $backend = $config->backend($name);
78 $backend = $config->backend;
80 Standard setter/accessor for our backend.
85 my ( $self, $new ) = @_;
86 $self->{configuration
}->{backend
} = $new if $new;
87 return $self->{configuration
}->{backend
};
92 $backend_dir = $config->backend_dir($new_path);
93 $backend_dir = $config->backend_dir;
95 Standard setter/accessor for our backend_directory.
100 my ( $self, $new ) = @_;
101 $self->{configuration
}->{backend_directory
} = $new if $new;
102 return $self->{configuration
}->{backend_directory
};
105 =head3 available_backends
107 $backends = $config->available_backends;
108 $backends = $config->abailable_backends($reduced);
110 Return a list of available backends, if passed a | delimited list it
111 will filter those backends down to only those present in the list.
115 sub available_backends
{
116 my ( $self, $reduce ) = @_;
117 my $backend_dir = $self->backend_dir;
119 @backends = glob "$backend_dir/*" if ( $backend_dir );
120 @backends = map { basename
($_) } @backends;
121 @backends = grep { $_ =~ /$reduce/ } @backends if $reduce;
127 Return whether a 'branch' block is defined
133 return $self->{configuration
}->{raw_config
}->{branch
};
138 $partner_code = $config->partner_code($new_code);
139 $partner_code = $config->partner_code;
141 Standard setter/accessor for our partner_code.
146 my ( $self, $new ) = @_;
147 $self->{configuration
}->{partner_code
} = $new if $new;
148 return $self->{configuration
}->{partner_code
};
153 $limits = $config->limits($limitshash);
154 $limits = $config->limits;
156 Standard setter/accessor for our limits. No parsing is performed on
157 $LIMITSHASH, so caution should be exercised when using this setter.
162 my ( $self, $new ) = @_;
163 $self->{configuration
}->{limits
} = $new if $new;
164 return $self->{configuration
}->{limits
};
169 my $prefixes = $config->getPrefixes();
171 Return the branch prefix for ILLs defined by our config.
177 return $self->{configuration
}->{prefixes
}->{branch
};
182 my $rules = $config->getLimitRules('brw_cat' | 'branch')
184 Return the hash of ILL limit rules defined by our config.
189 my ( $self, $type ) = @_;
190 die "Unexpected type." unless ( $type eq 'brw_cat' || $type eq 'branch' );
191 my $values = $self->{configuration
}->{limits
}->{$type};
192 $values->{default} = $self->{configuration
}->{limits
}->{default};
196 =head3 getDigitalRecipients
198 my $recipient_rules= $config->getDigitalRecipients('brw_cat' | 'branch');
200 Return the hash of digital_recipient settings defined by our config.
204 sub getDigitalRecipients
{
205 my ( $self, $type ) = @_;
206 die "Unexpected type." unless ( $type eq 'brw_cat' || $type eq 'branch' );
207 my $values = $self->{configuration
}->{digital_recipients
}->{$type};
209 $self->{configuration
}->{digital_recipients
}->{default};
215 my $censoredValues = $config->censorship($hash);
216 my $censoredValues = $config->censorship;
218 Standard setter/accessor for our limits. No parsing is performed on $HASH, so
219 caution should be exercised when using this setter.
221 Return our censorship values for the OPAC as loaded from the koha-conf.xml, or
222 the fallback value (no censorship).
227 my ( $self, $new ) = @_;
228 $self->{configuration
}->{censorship
} = $new if $new;
229 return $self->{configuration
}->{censorship
};
232 =head3 _load_configuration
234 my $configuration = $config->_load_configuration($config_from_xml);
236 Read the configuration values passed as the parameter, and populate a hashref
237 suitable for use with these.
239 A key task performed here is the parsing of the input in the configuration
240 file to ensure we have only valid input there.
244 sub _load_configuration
{
245 my ( $xml_config ) = @_;
246 my $xml_backend_dir = $xml_config->{backend_directory
};
248 # Default data structure to be returned
249 my $configuration = {
250 backend_directory
=> $xml_backend_dir,
252 censor_notes_staff
=> 0,
253 censor_reply_date
=> 0,
256 digital_recipients
=> {},
258 partner_code
=> 'ILLLIBS',
259 raw_config
=> $xml_config,
262 # Per Branch Configuration
263 my $branches = $xml_config->{branch
};
264 if ( ref($branches) eq "ARRAY" ) {
265 # Multiple branch overrides defined
270 config
=> $configuration,
274 } elsif ( ref($branches) eq "HASH" ) {
275 # Single branch override defined
278 id
=> $branches->{code
},
279 config
=> $configuration,
284 # Per Borrower Category Configuration
285 my $brw_cats = $xml_config->{borrower_category
};
286 if ( ref($brw_cats) eq "ARRAY" ) {
287 # Multiple borrower category overrides defined
292 config
=> $configuration,
296 } elsif ( ref($brw_cats) eq "HASH" ) {
297 # Single branch override defined
300 id
=> $brw_cats->{code
},
301 config
=> $configuration,
306 # Default Configuration
310 config
=> $configuration
314 my $staff_comments = $xml_config->{staff_request_comments
} || 0;
315 $configuration->{censorship
}->{censor_notes_staff
} = 1
316 if ( $staff_comments && 'hide' eq $staff_comments );
317 my $reply_date = $xml_config->{reply_date
} || 0;
318 $configuration->{censorship
}->{censor_reply_date
} = 1
319 if ( $reply_date && 'hide' eq $reply_date );
322 $configuration->{partner_code
} = $xml_config->{partner_code
} || 'ILLLIBS';
324 return $configuration;
327 =head3 _load_unit_config
329 my $configuration->{part} = _load_unit_config($params);
331 $PARAMS is a hashref with the following elements:
332 - unit: the part of the configuration we are parsing.
333 - id: the name within which we will store the parsed unit in config.
334 - config: the configuration we are augmenting.
335 - type: the type of config unit we are parsing. Assumed to be 'default'.
337 Read `unit', and augment `config' with these under `id'.
339 This is a helper for _load_configuration.
341 A key task performed here is the parsing of the input in the configuration
342 file to ensure we have only valid input there.
346 sub _load_unit_config
{
348 my $unit = $params->{unit
};
349 my $id = $params->{id
};
350 my $config = $params->{config
};
351 my $type = $params->{type
};
352 die "TYPE should be either 'branch' or 'brw_cat' if ID is not 'default'."
353 if ( $id ne 'default' && ( $type ne 'branch' && $type ne 'brw_cat') );
354 return $config unless $id;
356 if ( $unit->{api_key
} && $unit->{api_auth
} ) {
357 $config->{credentials
}->{api_keys
}->{$id} = {
358 api_key
=> $unit->{api_key
},
359 api_auth
=> $unit->{api_auth
},
362 # Add request_limit rules.
363 # METHOD := 'annual' || 'active'
365 if ( ref $unit->{request_limit
} eq 'HASH' ) {
366 my $method = $unit->{request_limit
}->{method
};
367 my $count = $unit->{request_limit
}->{count
};
368 if ( 'default' eq $id ) {
369 $config->{limits
}->{$id}->{method
} = $method
370 if ( $method && ( 'annual' eq $method || 'active' eq $method ) );
371 $config->{limits
}->{$id}->{count
} = $count
372 if ( $count && ( -1 <= $count ) );
374 $config->{limits
}->{$type}->{$id}->{method
} = $method
375 if ( $method && ( 'annual' eq $method || 'active' eq $method ) );
376 $config->{limits
}->{$type}->{$id}->{count
} = $count
377 if ( $count && ( -1 <= $count ) );
383 if ( $unit->{prefix
} ) {
384 if ( 'default' eq $id ) {
385 $config->{prefixes
}->{$id} = $unit->{prefix
};
387 $config->{prefixes
}->{$type}->{$id} = $unit->{prefix
};
391 # Add digital_recipient rules.
392 # DIGITAL_RECIPIENT := borrower || branch (defaults to borrower)
393 if ( $unit->{digital_recipient
} ) {
394 if ( 'default' eq $id ) {
395 $config->{digital_recipients
}->{$id} = $unit->{digital_recipient
};
397 $config->{digital_recipients
}->{$type}->{$id} =
398 $unit->{digital_recipient
};
407 Alex Sassmannshausen <alex.sassmannshausen@ptfs-europe.com>