#!/usr/bin/perl # Copyright 2024 Koha development team # # 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 . use Modern::Perl; use Test::More tests => 1; use File::Slurp; use Data::Dumper; my @files; # OPAC push @files, `git ls-files 'koha-tmpl/opac-tmpl/bootstrap/en/*.tt'`; push @files, `git ls-files 'koha-tmpl/opac-tmpl/bootstrap/en/*.inc'`; # Staff push @files, `git ls-files 'koha-tmpl/intranet-tmpl/prog/en/*.tt'`; push @files, `git ls-files 'koha-tmpl/intranet-tmpl/prog/en/*.inc'`; my @errors; for my $file ( @files ) { chomp $file; my @e = check_csrf_in_forms($file); push @errors, sprintf "%s:%s", $file, join (",", @e) if @e; } is( @errors, 0, "The
in the following files are missing it's corresponding csrf_token include (see bug 22990)" ) or diag(Dumper @errors); sub check_csrf_in_forms { my ( $file ) = @_; my @lines = read_file($file); my @errors; return @errors unless grep { $_ =~ m|