Bug 36328: (QA follow-up) Expand tests and reorder elements to clarify differences
[koha.git] / C4 / Scrubber.pm
1 package C4::Scrubber;
2
3 # Copyright Liblime 2008
4 # Parts copyright sys-tech.net 2011
5 # Copyright PTFS Europe 2011
6 #
7 # This file is part of Koha.
8 #
9 # Koha is free software; you can redistribute it and/or modify it
10 # under the terms of the GNU General Public License as published by
11 # the Free Software Foundation; either version 3 of the License, or
12 # (at your option) any later version.
13 #
14 # Koha is distributed in the hope that it will be useful, but
15 # WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
18 #
19 # You should have received a copy of the GNU General Public License
20 # along with Koha; if not, see <http://www.gnu.org/licenses>.
21
22 use strict;
23 use warnings;
24 use Carp qw( croak );
25 use HTML::Scrubber;
26
27 use C4::Context;
28
29 my %scrubbertypes = (
30     default => {},    # place holder, default settings are below as fallbacks in call to constructor
31     tag     => {},    # uses defaults
32     comment => { allow => [qw( br b i em big small strong )], },
33     note    => { allow => [qw[ br b i em big small strong u hr span div p ]] },
34     staff   => {
35         default => [ 1 => { '*' => 1 } ],
36         comment => 1,
37     },
38 );
39
40
41 sub new {
42     shift; # ignore our class we are wrapper
43     my $type = (@_) ? shift : 'default';
44     if ( !exists $scrubbertypes{$type} ) {
45         croak "New called with unrecognized type '$type'";
46     }
47     my $settings = $scrubbertypes{$type};
48     my $scrubber = HTML::Scrubber->new(
49         allow   => exists $settings->{allow}   ? $settings->{allow}   : [],
50         rules   => exists $settings->{rules}   ? $settings->{rules}   : [],
51         default => exists $settings->{default} ? $settings->{default} : [ 0 => { '*' => 0 } ],
52         comment => exists $settings->{comment} ? $settings->{comment} : 0,
53         note    => exists $settings->{note}    ? $settings->{note}    : 0,
54         process => 0,
55     );
56     return $scrubber;
57 }
58
59
60 1;
61 __END__
62
63 =head1 C4::Sanitize
64
65 Standardized wrapper with settings for building HTML::Scrubber tailored to various koha inputs.
66
67 The default is to scrub everything, leaving no markup at all.  This is compatible with the expectations
68 for Tags.
69
70 =head2 TODO: Add real perldoc
71
72 =cut
73