Security Advisories (1)
CVE-2026-5090 (2026-05-19)

Template::Plugin::HTML versions through 3.102 for Perl allows HTML and JavaScript to be injected. The html_filter function did not escape single quotes. HTML attributes inside of single quotes could be have code injected. For example, the variable "var" in <a id='ref' title='[% var | html %]'> would not be properly escaped. An attacker could insert some limited HTML and JavaScript, for example, var = " ' onclick='while (true) { alert(1) }'" Note that arbitrary HTML and JavaScript would be difficult to inject, because angle brackets, ampersands and double-quotes would still be escaped.

NAME

Template::Plugin - Base class for plugin objects.

SYNOPSIS

    package MyOrg::Template::MyPlugin;
    use base qw( Template::Plugin );

    sub new {
        my ($class, $context, @params) = @_;
	bless {
            ...whatever...
        }, $class;
    }

    sub method1 { }
    sub method1 { }

DESCRIPTION

The Template::Plugin module defines a base class from which other plugin modules can be derived.

AUTHOR

Andy Wardley <cre.canon.co.uk>

REVISION

$Revision: 1.6 $

COPYRIGHT

Copyright (C) 1996-1999 Andy Wardley. All Rights Reserved. Copyright (C) 1998-1999 Canon Research Centre Europe Ltd.

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

Template