Fred
0.1.4
OTRS GmbH
http://otrs.org/
GNU GENERAL PUBLIC LICENSE Version 2, June 1991
Added Database::SlowLog feature.
Improved the config description.
No longer crashes if HTML::Lint is not installed but HTML-checker is active.
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-07-02 14:19:05
opms.otrs.com
# --
# Kernel/Output/HTML/OutputFilterFred.pm
# Copyright (C) 2003-2007 OTRS GmbH, http://otrs.com/
# --
# $Id: OutputFilterFred.pm,v 1.4 2007/04/16 15:51:52 ot 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.4 $';
$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(MainObject 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')) {
        my $HTMLText = '';
        if ($Self->{MainObject}->Require('HTML::Lint')) {
            HTML::Lint->import();
            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";
                }
            }
        } else {
            $HTMLText = 'The HTML-checker of Fred requires HTML::Lint to be installed!'
                . 'Please install HTML::Lint or deactivate the HTML-checker via SysConfig.';
        }

        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",
                );
            }
        }
    }
    # 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;

PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSIgPz4KPG90cnNfY29uZmlnIHZlcnNpb249IjEuMCIgaW5pdD0iQXBwbGljYXRpb24iPgogICAgPENWUz4kSWQ6IEZyZWQueG1sLHYgMS41IDIwMDcvMDYvMjcgMDk6MTA6MDUgbWFydGluIEV4cCAkPC9DVlM+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJGcm9udGVuZDo6T3V0cHV0OjpGaWx0ZXJDb250ZW50IyMjRnJlZCIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlN1YnNjcmliZSB0aGUgb3V0cHV0IGZpbHRlciBhdCB0aGUgc3lzdGVtLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5NZWxkZXQgZGVuIE91dHB1dEZpbHRlckZyZWQgYW0gU3lzdGVtIGFuLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyZWQ8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPEhhc2g+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9Ik1vZHVsZSI+S2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok91dHB1dEZpbHRlckZyZWQ8L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IkRlYnVnIj4wPC9JdGVtPgogICAgICAgICAgICA8L0hhc2g+CiAgICAgICAgPC9TZXR0aW5nPgogICAgPC9Db25maWdJdGVtPgogICAgPCEtLQogICAgICAgICRTZWxmLT57J0Zyb250ZW5kOjpPdXRwdXQ6OkZpbHRlckNvbnRlbnQnfS0+eydGcmVkJ30gPSB7CiAgICAgICAgICAgIE1vZHVsZSA9PiAnS2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok91dHB1dEZpbHRlckZyZWQnLAogICAgICAgICAgICBEZWJ1ZyA9PiAwLAogICAgICAgIH07CiAgICAtLT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OkhUTUxDaGVjayIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgYW4gcmVhbHRpbWUgSFRNTC1jaGVja2VyLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5IaWVyIGFrdGl2aWVyZW4gd2VubiB6dXIgTGF1ZnplaXQgZWluIEhUTUwtQ2hlY2tlciBhdXNnZWZocnQgd2VyZGVuIHNvbGwuIFdJQ0hUSUc6IERhcyBDcGFuLU1vZHVsIEhUTUw6OmxpbnQgaXN0IGhpZXJmdWVyIG5vdHdlbmRpZy48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMCI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OlNUREVSUkxvZyIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgdG8gc2VlIHRoZSBTVERFUlJMb2cuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPkhpZXIgYWt0aXZpZXJlbiB3ZW5uIG1hbiB6dXIgTGF1ZnplaXQgZGFzIFNUREVSUkxvZyBzZWhlbiB3aWxsLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyZWQ8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPE9wdGlvbiBTZWxlY3RlZElEPSIxIj4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iMCI+Tm88L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjEiPlllczwvSXRlbT4KICAgICAgICAgICAgPC9PcHRpb24+CiAgICAgICAgPC9TZXR0aW5nPgogICAgPC9Db25maWdJdGVtPgo8IS0tICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OkNWU0ZpbHRlciIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlR1cm4gb24gaWYgeW91IHdhbnQgdG8gYWxsb3cgdGhlIENWU0ZpbHRlciByZWFsdGltZS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+SGllciBha3RpdmllcmVuIHVtIHp1ciBMYXVmemVpdCBiZXJlaXRzIGRpZSBDVlMtRmlsdGVyIHp1IHRlc3Rlbi48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMCI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkZyZWQ6OlBhdGhUb0NWU0ZpbHRlciIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlBhdGggdG8gdGhlIGN2cyBmaWx0ZXIuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPlBmYWQgenVtIENWUy1GaWx0ZXIuIEJlaW0gQ1ZTLUZpbHRlciBoYW5kZWx0IGVzIHNpY2ggdW0gZGllIGZpbHRlci1leHRlbmRlZC5wbCBkZXMgQ1ZTUk9PVC1SZXBvc2l0aW9yeSBkZXMgaW50ZXJuZW4gQ1ZTLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyZWQ8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPFN0cmluZyBSZWdleD0iIj4vaG9tZS90ci9zcmMvQ1ZTUk9PVC1pbnQ8L1N0cmluZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+LS0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJEYXRhYmFzZTo6U2xvd0xvZyIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPlRvIGVuYWJsZSBzbG93IHNxbCBsb2cgKHRvIGxvZyBhbGwgc3FsIHF1ZXJpZXMgd2hpY2ggdGFrZSBsb25nZXIgdGhlIDQgc2VjLikuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPlVtIFNsb3cgU1FMIHp1IGFrdGl2aWVyZW4gKG1pdHNjaG5laWRlciBhbGxlciBTUUwtQWJmcmFnZW4gd2VsY2hlIGxhZW5nZXIgNCBTZWsuIGJyYXVjaGVuKS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmVkPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxPcHRpb24gU2VsZWN0ZWRJRD0iMSI+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IjAiPk5vPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSIxIj5ZZXM8L0l0ZW0+CiAgICAgICAgICAgIDwvT3B0aW9uPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KPC9vdHJzX2NvbmZpZz4K
IyAtLQojIEFBQUZyZWQucG0gLSB0aGUgY29uZmlnIHRvIGJpbmQgU1RERVJSIHRvIGFuIGxvZyBmaWxlIHVzYWJsZSBmb3IgZnJlZAojIENvcHlyaWdodCAoQykgMjAwMy0yMDA3IE9UUlMgR21iSCwgaHR0cDovL290cnMuY29tLwojIC0tCiMgJElkOiBBQUFGcmVkLnBtLHYgMS4xIDIwMDcvMDIvMjcgMjA6NDg6MzggbWFydGluIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvZ3BsLnR4dC4KIyAtLQoKICAgIGlmICgkRU5We0hUVFBfVVNFUl9BR0VOVH0pIHsKICAgICAgICAjIGNoZWNrIGxvZyBmaWxlIHNpemUKICAgICAgICBteSAkU2l6ZSA9IC1zICRTZWxmLT57SG9tZX0uIi92YXIvZnJlZC5sb2ciOwogICAgICAgIGlmICgkU2l6ZSA+IDIwKjEwMjQqMTAyNCkgewogICAgICAgICAgICB1bmxpbmsgJFNlbGYtPntIb21lfS4iL3Zhci9mcmVkLmxvZyI7CiAgICAgICAgfQogICAgICAgICMgY3JlYXRlIHRtcCBmaWxlIGhhbmRsZQogICAgICAgIG9wZW4oT0xET1VULCAiPiZTVERFUlIiKTsKICAgICAgICAjIG1vdmUgU1RET1VUIHRvIHRtcCBmaWxlCiAgICAgICAgaWYgKCFvcGVuKFNUREVSUiwgIj4+ICIuJFNlbGYtPntIb21lfS4iL3Zhci9mcmVkLmxvZyIpKSB7CiAgICAgICAgICAgIHByaW50IFNUREVSUiAiRVJST1I6IENhbid0IHdyaXRlICRTZWxmLT57SG9tZX0vdmFyL2ZyZWQubG9nOiAkISI7CiAgICAgICAgfQogICAgICAgICMgcmVzdG9yZSBTVERPVVQgZmlsZSBoYW5kbGUKIyAgICAgICBvcGVuKFNURE9VVCwgIj4mT0xET1VUIik7CiAgICAgICAgY2xvc2UoT0xET1VUKTsKICAgIH0KCjE7Cg==