Fred
0.1.1
OTRS GmbH
http://otrs.org/
GNU GENERAL PUBLIC LICENSE Version 2, June 1991
Improved output.
First version especially for testing and as proof of concept.
A tool to support the developer by his development.
Ein Entwicklertool welches dem Entwickler zur Laufzeit bei der Entwicklung unterstützen soll.
2.2.x
2007-02-28 15:36:01
opms.otrs.com
# --
# Kernel/Output/HTML/OutputFilterFred.pm
# Copyright (C) 2003-2007 OTRS GmbH, http://otrs.com/
# --
# $Id: OutputFilterFred.pm,v 1.3 2007/02/28 14:22:43 martin Exp $
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (GPL). If you
# did not receive this file, see http://www.gnu.org/licenses/gpl.txt.
# --

package Kernel::Output::HTML::OutputFilterFred;

use strict;

use vars qw($VERSION);
$VERSION = '$Revision: 1.3 $';
$VERSION =~ s/^\$.*:\W(.*)\W.+?$/$1/;

sub new {
    my $Type = shift;
    my %Param = @_;

    # allocate new hash for object
    my $Self = {};
    bless ($Self, $Type);

    # get needed objects
    foreach (qw(ConfigObject LogObject)) {
        $Self->{$_} = $Param{$_} || die "Got no $_!";
    }

    return $Self;
}

sub Run {
    my $Self = shift;
    my %Param = @_;
    my $Text = '';
    my $Home = $Self->{ConfigObject}->Get('Home');

    # do noting on redirects
    if (${$Param{Data}} =~ /^Status: 302 Moved/mi && ${$Param{Data}} =~ /^location:/mi && length(${$Param{Data}}) < 800 ) {
        # do nothing
        return 1;
    }

    # Check the HTML-Output with HTML::Lint
    if ($Self->{ConfigObject}->Get('Fred::HTMLCheck')) {
        use HTML::Lint;
        my $HTMLText = '';
        my $HTMLLintObject = HTML::Lint->new( only_types => HTML::Lint::Error::STRUCTURE );
        $HTMLLintObject->parse (${$Param{Data}});

        my $ErrorCounter = $HTMLLintObject->errors;
        foreach my $Error ($HTMLLintObject->errors) {
            my $String .= $Error->as_string;
            if ($String !~ /Invalid character .+ should be written as /) {
                $HTMLText .=  $String . "\n";
            }
        }
        if ($HTMLText) {
            $Text .= $Self->_HTMLQuote(
                Text => $HTMLText,
                Title => "HTML-Checker",
            );
        }
    }

    # Search for stderr messages
    if ($Self->{ConfigObject}->Get('Fred::STDERRLog')) {
        if (open (OUTPUT, "< ".$Self->{ConfigObject}->Get('Home')."/var/fred.log")) {
            my $ErrorLogText = '';
            my @Row = <OUTPUT>;
            my @ReverseRow = reverse(@Row);
            foreach (@ReverseRow) {
                if ($_ =~ /FRED/) {
                    last;
                }
                $ErrorLogText .= $_;
            }

            print STDERR "FRED\n";

            close (OUTPUT);

            if ($ErrorLogText) {
                $Text .= $Self->_HTMLQuote(
                    Text => $ErrorLogText,
                    Title => "STDERR",
                );
            }
        }
    }
    # Search for apache errorlog warning
    if ($Self->{ConfigObject}->Get('Fred::ApacheErrorlogWarnings')) {
        if (open (OUTPUT, "< /var/log/apache2/error_log")) {
            my $ErrorLogText = '';
            my @Row = <OUTPUT>;
            my @ReverseRow = reverse(@Row);
            foreach (@ReverseRow) {
                if ($_ =~ /FRED/) {
                    last;
                }
                $ErrorLogText .= $_;
            }

            print STDERR "FRED\n";

            close (OUTPUT);

            if ($ErrorLogText) {
                $Text .= $Self->_HTMLQuote(
                    Text => $ErrorLogText,
                    Title => "Apache2 error_log",
                );
            }
        }
    }
    # use the cvs checks
    if ($Self->{ConfigObject}->Get('Fred::CVSFilter')) {
        my $PathToCVSFilter = $Self->{ConfigObject}->Get('Fred::PathToCVSFilter');
        if (${$Param{Data}} =~ /Notify.+?Action.+?value="(.+?)">.*?$/mxs) {
            my $Action = $1;
            my $FilterText = '';
            if (-e "$Home/Kernel/Modules/$Action.pm") {
                if (open (OUTPUT, "perl $PathToCVSFilter/filter-extended.pl $Home/Kernel/Modules $Home/Kernel/Modules/$Action.pm |")) {
                    my $Merge = 0;
                    while (<OUTPUT>) {
                        if ($_!~ /^NOTICE/) {
                            $FilterText .= $_;
                            $Merge = 1;
                        }
                    }
                    close (OUTPUT);
                    if ($Merge) {
                        $FilterText = $Action . ".pm\n" . $FilterText;
                    }
                }
            }

            my $SystemModule = '';
            if ($Action =~ /(Agent|Admin|Customer|Public)(.+)$/) {
                $SystemModule = $2;
            }

            if (-e "$Home/Kernel/System/$SystemModule.pm") {
                if (open (OUTPUT, "perl $PathToCVSFilter/filter-extended.pl $Home/Kernel/System $Home/Kernel/System/$SystemModule.pm |")) {
                    my $Merge = 0;
                    while (<OUTPUT>) {
                        if ($_!~ /^NOTICE/) {
                            $FilterText .= $_;
                            $Merge = 1;
                        }
                    }
                    close (OUTPUT);
                    if ($Merge) {
                        $FilterText = $SystemModule . ".pm\n" . $FilterText;
                    }
                }
            }
            if ($FilterText) {
                $Text .= $Self->_HTMLQuote(
                    Text => $FilterText,
                    Title => "filter-extended.pl",
                );
            }
        }
    }
    #-----------------------------------------

    if ($Text) {
        if (${$Param{Data}} =~ s/(\<body(|.+?)\>)/$1\n$Text\n\n\n\n/mx) {
        }
    }

    return 1;
}

sub _HTMLQuote {
    my $Self = shift;
    my %Param = @_;
    my $Output = '';
    $Param{Text} =~ s/&/&amp;/g;
    $Param{Text} =~ s/</&lt;/g;
    $Param{Text} =~ s/>/&gt;/g;
    $Param{Text} =~ s/\n/\n\<br\>/g;
    # shown message
    $Output .= "<table bgcolor=\"#000000\" cellspacing=\"3\" cellpadding=\"0\" width=\"100%\">\n";
    $Output .= "<tr>\n";
    $Output .= "<td bgcolor=\"ba0f0f\">\n";
    $Output .= "<table bgcolor=\"#ffffff\" cellspacing=\"0\" cellpadding=\"2\" width=\"100%\">\n";
    $Output .= "<tr>\n";
    $Output .= "<td bgcolor=\"ba0f0f\">\n";
    $Output .= "<b><font color=\"#ffffff\">Fred: $Param{Title}</font></b>\n";
    $Output .= "</td>\n";
    $Output .= "</tr>\n";
    $Output .= "<tr>\n";
    $Output .= "<td>\n";
    $Output .= "<font size=\"-2\">" . $Param{Text} ."</font>";
    $Output .= "</td>\n";
    $Output .= "</tr>\n";
    $Output .= "</table>\n";
    $Output .= "</td>\n";
    $Output .= "</tr>\n";
    $Output .= "</table>\n";
    # just a small space
    $Output .= "<table cellspacing=\"1\" cellpadding=\"0\" width=\"100%\">\n";
    $Output .= "<tr>\n";
    $Output .= "<td>\n";
    $Output .= "</td>\n";
    $Output .= "</tr>\n";
    $Output .= "</table>\n";
    return $Output;
}

1;

PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSIgPz4KPG90cnNfY29uZmlnIHZlcnNpb249IjEuMCIgaW5pdD0iQXBwbGljYXRpb24iPgogICAgPENWUz4kSWQ6IEZyZWQueG1sLHYgMS4yIDIwMDcvMDIvMjcgMjA6NDg6MzggbWFydGluIEV4cCAkPC9DVlM+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJGcm9udGVuZDo6T3V0cHV0OjpGaWx0ZXJDb250ZW50IyMjRnJlZCIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlN1YnNjcmliZSB0aGUgb3V0cHV0IGZpbHRlciBhdCB0aGUgc3lzdGVtLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5NZWxkZXQgZGVuIE91dHB1dEZpbHRlckZyZWQgYW0gU3lzdGVtIGFuLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyZWQ8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPEhhc2g+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9Ik1vZHVsZSI+S2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok91dHB1dEZpbHRlckZyZWQ8L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IkRlYnVnIj4wPC9JdGVtPgogICAgICAgICAgICA8L0hhc2g+CiAgICAgICAgPC9TZXR0aW5nPgogICAgPC9Db25maWdJdGVtPgogICAgPCEtLQogICAgICAgICRTZWxmLT57J0Zyb250ZW5kOjpPdXRwdXQ6OkZpbHRlckNvbnRlbnQnfS0+eydGcmVkJ30gPSB7CiAgICAgICAgICAgIE1vZHVsZSA9PiAnS2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok91dHB1dEZpbHRlckZyZWQnLAogICAgICAgICAgICBEZWJ1ZyA9PiAwLAogICAgICAgIH07CiAgICAtLT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OkhUTUxDaGVjayIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgYW4gcmVhbHRpbWUgSFRNTC1jaGVja2VyLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5IaWVyIGFrdGl2aWVyZW4gd2VubiB6dXIgTGF1ZnplaXQgZWluIEhUTUwtQ2hlY2tlciBhdXNnZWb8aHJ0IHdlcmRlbiBzb2xsLiBXSUNIVElHOiBEYXMgQ3Bhbi1Nb2R1bCBIVE1MOjpsaW50IGlzdCBoaWVyZvxyIG5vdHdlbmRpZyE8L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMCI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OlNUREVSUkxvZyIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgYW4gcmVhbHRpbWUgSFRNTC1jaGVja2VyLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5IaWVyIGFrdGl2aWVyZW4gd2VubiB6dXIgTGF1ZnplaXQgZWluIEhUTUwtQ2hlY2tlciBhdXNnZWb8aHJ0IHdlcmRlbiBzb2xsLiBXSUNIVElHOiBEYXMgQ3Bhbi1Nb2R1bCBIVE1MOjpsaW50IGlzdCBoaWVyZvxyIG5vdHdlbmRpZyE8L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMSI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OkFwYWNoZUVycm9ybG9nV2FybmluZ3MiIFJlcXVpcmVkPSIwIiBWYWxpZD0iMSI+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImVuIj5UdXJuIG9uIGlmIHlvdSB3YW50IHRvIHNlZSB0aGUgQXBhY2hlIGVycm9ycy48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+SGllciBha3RpdmllcmVuIHdlbm4gbWFuIHp1ciBMYXVmemVpdCBkaWUgQXBhY2hlIEVycm9ycyBzZWhlbiB3aWxsLiBXSUNIVElHOiBEZXIgT1RSUy1TeXN0ZW1iZW51dGVyIGJyYXVjaHQgTGVzZXJlY2h0ZSBhdWYgZGFzIEFwYWNoZSBFcnJvcl9sb2chISE8L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMCI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OkNWU0ZpbHRlciIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgdG8gYWxsb3cgdGhlIENWU0ZpbHRlciByZWFsdGltZS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+SGllciBha3RpdmllcmVuIHVtIHp1ciBMYXVmemVpdCBiZXJlaXRzIGRpZSBDVlMtRmlsdGVyIHp1IHRlc3Rlbi48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMCI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OlBhdGhUb0NWU0ZpbHRlciIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlBhdGggdG8gdGhlIGN2cyBmaWx0ZXIuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPlBmYWQgenVtIENWUy1GaWx0ZXIuIEJlaW0gQ1ZTLUZpbHRlciBoYW5kZWx0IGVzIHNpY2ggdW0gZGllIGZpbHRlci1leHRlbmRlZC5wbCBkZXMgQ1ZTUk9PVC1SZXBvc2l0aW9yeSBkZXMgaW50ZXJuZW4gQ1ZTLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyZWQ8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPFN0cmluZyBSZWdleD0iIj4vaG9tZS90ci9zcmMvQ1ZTUk9PVC1pbnQ8L1N0cmluZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+Cjwvb3Ryc19jb25maWc+Cg==
IyAtLQojIEFBQUZyZWQucG0gLSB0aGUgY29uZmlnIHRvIGJpbmQgU1RERVJSIHRvIGFuIGxvZyBmaWxlIHVzYWJsZSBmb3IgZnJlZAojIENvcHlyaWdodCAoQykgMjAwMy0yMDA3IE9UUlMgR21iSCwgaHR0cDovL290cnMuY29tLwojIC0tCiMgJElkOiBBQUFGcmVkLnBtLHYgMS4xIDIwMDcvMDIvMjcgMjA6NDg6MzggbWFydGluIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvZ3BsLnR4dC4KIyAtLQoKICAgIGlmICgkRU5We0hUVFBfVVNFUl9BR0VOVH0pIHsKICAgICAgICAjIGNoZWNrIGxvZyBmaWxlIHNpemUKICAgICAgICBteSAkU2l6ZSA9IC1zICRTZWxmLT57SG9tZX0uIi92YXIvZnJlZC5sb2ciOwogICAgICAgIGlmICgkU2l6ZSA+IDIwKjEwMjQqMTAyNCkgewogICAgICAgICAgICB1bmxpbmsgJFNlbGYtPntIb21lfS4iL3Zhci9mcmVkLmxvZyI7CiAgICAgICAgfQogICAgICAgICMgY3JlYXRlIHRtcCBmaWxlIGhhbmRsZQogICAgICAgIG9wZW4oT0xET1VULCAiPiZTVERFUlIiKTsKICAgICAgICAjIG1vdmUgU1RET1VUIHRvIHRtcCBmaWxlCiAgICAgICAgaWYgKCFvcGVuKFNUREVSUiwgIj4+ICIuJFNlbGYtPntIb21lfS4iL3Zhci9mcmVkLmxvZyIpKSB7CiAgICAgICAgICAgIHByaW50IFNUREVSUiAiRVJST1I6IENhbid0IHdyaXRlICRTZWxmLT57SG9tZX0vdmFyL2ZyZWQubG9nOiAkISI7CiAgICAgICAgfQogICAgICAgICMgcmVzdG9yZSBTVERPVVQgZmlsZSBoYW5kbGUKIyAgICAgICBvcGVuKFNURE9VVCwgIj4mT0xET1VUIik7CiAgICAgICAgY2xvc2UoT0xET1VUKTsKICAgIH0KCjE7Cg==