Bug 21757: (folow-up) Restore patron brief detail page
[koha.git] / Koha / ClassSplitRule.pm
blob72f467399d698295ade81317385da63a782dffad
1 package Koha::ClassSplitRule;
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it under the
6 # terms of the GNU General Public License as published by the Free Software
7 # Foundation; either version 3 of the License, or (at your option) any later
8 # version.
10 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
11 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
14 # You should have received a copy of the GNU General Public License along
15 # with Koha; if not, write to the Free Software Foundation, Inc.,
16 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 use Modern::Perl;
20 use JSON qw(to_json from_json);
22 use Koha::Database;
24 use base qw(Koha::Object);
26 =head1 NAME
28 Koha::ClassSplitRule Koha Classfication Spliting Rule Object class
30 =head1 API
32 =head2 Class Methods
34 =cut
36 =head3 new
38 Accept 'regexs' as a valid attribute.
39 It should be an arrayref that will be serialized in JSON before stored in DB.
41 =cut
43 sub new {
44 my ($class, $attributes) = @_;
46 if ( exists $attributes->{regexs} ) {
47 $attributes->{split_regex} = to_json($attributes->{regexs});
48 delete $attributes->{regexs};
50 return $class->SUPER::new($attributes);
53 =head3 regexs
55 my $regexs = $rule->regexs
57 $rule->regex(\@regexs);
59 Getter or setter for split_regex
61 =cut
63 sub regexs {
64 my ( $self, $regexs ) = @_;
65 return $regexs
66 ? $self->split_regex( to_json($regexs) )
67 : from_json( $self->split_regex || '[]' );
70 =head3 type
72 =cut
74 sub _type {
75 return 'ClassSplitRule';