GeneralCatalog
0.1.5
OTRS GmbH
http://otrs.org/
GNU GENERAL PUBLIC LICENSE Version 2, June 1991
Small improvements and code cleanup.
Small improvements and code cleanup.
Add option Valid to ItemList().
Add missing files to SOPM file.
Init release.
The general catalog package.
Das Allgemeiner Katalog Paket.
2.2.x
2007-03-28 20:29:26
opms.otrs.com
IyAtLQojIENIQU5HRVMuR2VuZXJhbENhdGFsb2cgLSBjaGFuZ2UgbG9nIG9mIEdlbmVyYWxDYXRhbG9nIHBhY2thZ2UKIyBDb3B5cmlnaHQgKEMpIDIwMDMtMjAwNyBPVFJTIEdtYkgsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojICRJZDogQ0hBTkdFUy5HZW5lcmFsQ2F0YWxvZyx2IDEuMSAyMDA3LzAzLzIwIDEwOjM2OjEwIG1oIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvZ3BsLnR4dC4KIyAtLQoKMC45LjEgQkVUQTEgKDIwMDcvPz8vPz8pCiAtICgyMDA3Lz8/Lz8/KSBmaXJzdCBiZXRhIHJlbGVhc2UKCkVPRgo=
PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSIgPz4KPG90cnNfY29uZmlnIHZlcnNpb249IjEuMCIgaW5pdD0iQ29uZmlnIj4KICAgIDxDVlM+JElkOiBHZW5lcmFsQ2F0YWxvZy54bWwsdiAxLjIgMjAwNy8wMi8yNCAxMTozNToyOCBtaCBFeHAgJDwvQ1ZTPgogICAgPENvbmZpZ0l0ZW0gTmFtZT0iRnJvbnRlbmQ6Ok1vZHVsZSMjI0FkbWluR2VuZXJhbENhdGFsb2ciIFJlcXVpcmVkPSIwIiBWYWxpZD0iMSI+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImVuIj5Gcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImRlIj5Gcm9udGVuZG1vZHVsLVJlZ2lzdHJhdGlvbiBkZXIgQWRtaW5HZW5lcmFsQ2F0YWxvZyBLb25maWd1cmF0aW9uIGltIEFkbWluLUJlcmVpY2guPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+RnJhbWV3b3JrPC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+RnJvbnRlbmQ6OkFkbWluOjpNb2R1bGVSZWdpc3RyYXRpb248L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8RnJvbnRlbmRNb2R1bGVSZWc+CiAgICAgICAgICAgICAgICA8R3JvdXA+YWRtaW48L0dyb3VwPgogICAgICAgICAgICAgICAgPERlc2NyaXB0aW9uPkFkbWluPC9EZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgIDxUaXRsZT5HZW5lcmFsIENhdGFsb2c8L1RpdGxlPgogICAgICAgICAgICAgICAgPE5hdkJhck5hbWU+QWRtaW48L05hdkJhck5hbWU+CiAgICAgICAgICAgICAgICA8TmF2QmFyTW9kdWxlPgogICAgICAgICAgICAgICAgICAgIDxNb2R1bGU+S2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok5hdkJhck1vZHVsZUFkbWluPC9Nb2R1bGU+CiAgICAgICAgICAgICAgICAgICAgPE5hbWU+R2VuZXJhbCBDYXRhbG9nPC9OYW1lPgogICAgICAgICAgICAgICAgICAgIDxCbG9jaz5CbG9jazM8L0Jsb2NrPgogICAgICAgICAgICAgICAgICAgIDxQcmlvPjQxMDwvUHJpbz4KICAgICAgICAgICAgICAgIDwvTmF2QmFyTW9kdWxlPgogICAgICAgICAgICA8L0Zyb250ZW5kTW9kdWxlUmVnPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KPC9vdHJzX2NvbmZpZz4=
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9kZV9HZW5lcmFsQ2F0YWxvZy5wbSAtIHRoZSBnZXJtYW4gdHJhbnNsYXRpb24gb2YgR2VuZXJhbENhdGFsb2cKIyBDb3B5cmlnaHQgKEMpIDIwMDMtMjAwNyBPVFJTIEdtYkgsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojICRJZDogZGVfR2VuZXJhbENhdGFsb2cucG0sdiAxLjEuMS4xIDIwMDcvMDIvMjMgMTU6Mzk6MDAgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9ncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmRlX0dlbmVyYWxDYXRhbG9nOwoKdXNlIHN0cmljdDsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnQWxsZ2VtZWluZXIgS2F0YWxvZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0FsbGdlbWVpbmVyIEthdGFsb2cgVmVyd2FsdHVuZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnS2F0YWxvZyBLbGFzc2UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmt0aW9uYWxpdOR0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBuZXcgaXRlbSBmYWlsZWQhIFNlZSBTeXN0ZW0gTG9nIGZvciBkZXRhaWxzLid9ID0gJ0hpbnp1ZvxnZW4gZGVzIG5ldWVuIEVpbnRyYWdzIGZlaGxnZXNjaGxhZ2VuISBJbSBTeXN0ZW0gTG9nIGZpbmRlbiBTaWUgd2VpdGVyZSBJbmZvcm1hdGlvbmVuLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydVcGRhdGUgaXRlbSBmYWlsZCEgU2VlIFN5c3RlbSBMb2cgZm9yIGRldGFpbHMuJ30gPSAnVXBkYXRlbiBkZXMgRWludHJhZ3MgZmVobGdlc2NobGFnZW4hIEltIFN5c3RlbSBMb2cgZmluZGVuIFNpZSB3ZWl0ZXJlIEluZm9ybWF0aW9uZW4uJzsKfQoKMTs=
# --
# Kernel/Modules/AdminGeneralCatalog.pm - admin frontend of general catalog management
# Copyright (C) 2003-2007 OTRS GmbH, http://otrs.com/
# --
# $Id: AdminGeneralCatalog.pm,v 1.3 2007/03/20 10:37:19 mh 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::Modules::AdminGeneralCatalog;

use strict;
use Kernel::System::GeneralCatalog;

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 common opjects
    foreach (keys %Param) {
        $Self->{$_} = $Param{$_};
    }

    # check all needed objects
    foreach (qw(ConfigObject ParamObject LogObject LayoutObject)) {
        if (!$Self->{$_}) {
            $Self->{LayoutObject}->FatalError(Message => "Got no $_!");
        }
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);

    return $Self;
}

sub Run {
    my $Self = shift;
    my %Param = @_;

    # ------------------------------------------------------------ #
    # catalog item list
    # ------------------------------------------------------------ #
    if ($Self->{Subaction} eq 'ItemList') {
        my $Class = $Self->{ParamObject}->GetParam(Param => "Class") || '';
        # check needed Class
        if (!$Class) {
            return $Self->{LayoutObject}->Redirect(OP => "Action=$Self->{Action}");
        }
        # output header and navbar
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # output error notify
        if ($Self->{ParamObject}->GetParam(Param => "ErrorAdd")) {
            $Output .= $Self->{LayoutObject}->Notify(
                Priority => 'Error',
                Data => '$Text{"Add new item failed! See System Log for details."}',
            );
        }
        elsif ($Self->{ParamObject}->GetParam(Param => "ErrorUpdate")) {
            $Output .= $Self->{LayoutObject}->Notify(
                Priority => 'Error',
                Data => '$Text{"Update item faild! See System Log for details."}',
            );
        }
        # get catalog class list
        my $ClassList = $Self->{GeneralCatalogObject}->ClassList();
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'Class',
            Data => $ClassList,
            SelectedID => $Class,
        );
        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                %Param,
                ClassOptionStrg => $ClassOptionStrg,
            },
        );
        $Self->{LayoutObject}->Block(
            Name => 'OverviewItem',
            Data => {
                %Param,
                Class => $Class,
            },
        );
        # get availability list
        my $ValidRef = $Self->{GeneralCatalogObject}->ValidList();
        # get catalog item list
        my $ItemIDList = $Self->{GeneralCatalogObject}->ItemList(
            Class => $Class,
            Valid => 0,
        );

        my $CssClass;
        foreach my $ItemID (sort {$ItemIDList->{$a} cmp $ItemIDList->{$b}} keys %{$ItemIDList}) {
            # get item data
            my $ItemData = $Self->{GeneralCatalogObject}->ItemGet(
                ItemID => $ItemID,
            );
            # set output class
            if ($CssClass && $CssClass eq 'searchactive') {
                $CssClass = 'searchpassive';
            }
            else {
                $CssClass = 'searchactive';
            }
            $Self->{LayoutObject}->Block(
                Name => 'OverviewItemList',
                Data => {
                    %{$ItemData},
                    CssClass => $CssClass,
                    Functionality => $ItemData->{Functionality} || '-',
                    Valid => $ValidRef->{$ItemData->{ValidID}},
                },
            );
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }
    # ------------------------------------------------------------ #
    # catalog item edit
    # ------------------------------------------------------------ #
    elsif ($Self->{Subaction} eq 'ItemEdit') {
        my %ItemData;
        # get params
        $ItemData{ItemID} = $Self->{ParamObject}->GetParam(Param => "ItemID");
        if ($ItemData{ItemID} eq 'NEW') {
            $ItemData{Name} = $Self->{ParamObject}->GetParam(Param => "Name");
            $ItemData{Class} = $Self->{ParamObject}->GetParam(Param => "Class");
            # redirect to overview
            if (!$ItemData{Name} || !$ItemData{Class}) {
                return $Self->{LayoutObject}->Redirect(OP => "Action=$Self->{Action}");
            }
        }
        else {
            my $ItemDataRef = $Self->{GeneralCatalogObject}->ItemGet(
                ItemID => $ItemData{ItemID},
            );
            %ItemData = %{$ItemDataRef};
        }
        # output header
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # get catalog class list
        my $ClassList = $Self->{GeneralCatalogObject}->ClassList();
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'Class',
            Data => $ClassList,
            SelectedID => $ItemData{Class},
        );
        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                %Param,
                ClassOptionStrg => $ClassOptionStrg,
            },
        );
        # generate FunctionalityOptionStrg
        my $FunctionalityRef = $Self->{GeneralCatalogObject}->FunctionalityList(
            Class => $ItemData{Class},
        );
        my $FunctionalityOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'Functionality',
            Data => $FunctionalityRef,
            PossibleNone => 1,
            SelectedID => $ItemData{Functionality} || '',
        );
        # generate ValidOptionStrg
        my $ValidRef = $Self->{GeneralCatalogObject}->ValidList();
        my $ValidDefault = $Self->{GeneralCatalogObject}->ValidLookup(
            Name => 'valid',
        );
        my $ValidOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'ValidID',
            Data => $ValidRef,
            SelectedID => $ItemData{ValidID} || $ValidDefault->{ValidID},
        );
        # output ItemEdit
        $Self->{LayoutObject}->Block(
            Name => 'ItemEdit',
            Data => {
                %ItemData,
                FunctionalityOptionStrg => $FunctionalityOptionStrg,
                ValidOptionStrg => $ValidOptionStrg,
            },
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }
    # ------------------------------------------------------------ #
    # catalog item save
    # ------------------------------------------------------------ #
    elsif ($Self->{Subaction} eq 'ItemSave') {
        my $ErrorNotify = '';
        my %ItemData;
        # get params
        foreach (qw(Class ItemID Name Functionality ValidID Comment)) {
            $ItemData{$_} = $Self->{ParamObject}->GetParam(Param => "$_") || '';
        }
        # save to database
        if ($ItemData{ItemID} eq 'NEW') {
            my $Success = $Self->{GeneralCatalogObject}->ItemAdd(
                %ItemData,
                UserID => $Self->{UserID},
            );
            if (!$Success) {
                $ErrorNotify .= "&ErrorAdd=1";
            }
        }
        else {
            my $Success = $Self->{GeneralCatalogObject}->ItemUpdate(
                %ItemData,
                UserID => $Self->{UserID},
            );
            if (!$Success) {
                $ErrorNotify .= "&ErrorUpdate=1";
            }
        }
        # redirect to overview class list
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=ItemList&Class=$ItemData{Class}$ErrorNotify",
        );
    }
    # ------------------------------------------------------------ #
    # overview
    # ------------------------------------------------------------ #
    else {
        # output header and navbar
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # get catalog class list
        my $ClassList = $Self->{GeneralCatalogObject}->ClassList();
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'Class',
            Data => $ClassList,
        );
        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                %Param,
                ClassOptionStrg => $ClassOptionStrg,
            },
        );
        $Self->{LayoutObject}->Block(
            Name => 'OverviewClass',
            Data => {
                %Param,
            },
        );
        my $CssClass;
        foreach my $Class (@{$ClassList}) {
            # set output class
            if ($CssClass && $CssClass eq 'searchactive') {
                $CssClass = 'searchpassive';
            }
            else {
                $CssClass = 'searchactive';
            }
            $Self->{LayoutObject}->Block(
                Name => 'OverviewClassList',
                Data => {
                    Class => $Class,
                    CssClass => $CssClass,
                },
            );
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }
}

1;
# --
# AdminGeneralCatalog.dtl - provides HTML form for AdminGeneralCatalog
# Copyright (C) 2003-2007 OTRS GmbH, http://otrs.com/
# --
# $Id: AdminGeneralCatalog.dtl,v 1.1.1.1 2007/02/23 15:39:00 mh 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.
# --

<!-- dtl:block:Overview -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
  <tr>
    <td colspan="2" class="mainhead">
      $Env{"Box0"}$Text{"General Catalog Management"}$Env{"Box1"}
    </td>
  </tr>
  <tr>
    <td width="30%" class="mainbody">
      <form action="$Env{"CGIHandle"}" method="get">
        <input type="hidden" name="Action" value="$Env{"Action"}">
        <input type="hidden" name="Subaction" value="ItemEdit">
        <input type="hidden" name="ItemID" value="NEW">
        <table width="100%" cellspacing="0" cellpadding="4">
          <tr>
            <td class="contenthead">$Text{"Add"}:</td>
          </tr>
          <tr>
            <td class="contentbody">
              <table>
                <tr>
                  <td class="contentkey">$Text{"Name"}:</td>
                  <td class="contentvalue"><input type="text" name="Name" size="25" maxlength="100"></td>
                </tr>
                <tr>
                  <td class="contentkey">$Text{"Catalog Class"}:</td>
                  <td class="contentvalue">$Data{"ClassOptionStrg"}</td>
                </tr>
              </table>
            </td>
          </tr>
          <tr>
            <td class="contentfooter">
              <input class="button" type="submit" value="$Text{"Add"}">
            </td>
          </tr>
        </table>
      </form>
    </td>
    <td width="70%" class="mainbody">
<!-- dtl:block:OverviewClass -->
      <table width="100%" cellspacing="0" cellpadding="4">
        <tr>
          <td class="contenthead">$Text{"List"}:</td>
        </tr>
        <tr>
          <td class="contentbody">
            <table width="100%" border="0" cellspacing="0" cellpadding="3">
              <tr>
                <td class="contentkey" width="60%">$Text{"Catalog Class"}</td>
              </tr>
<!-- dtl:block:OverviewClassList -->
              <tr>
                <td class="$QData{"CssClass"}">
                  <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=ItemList&Class=$LQData{"Class"}">
                  $QData{"Class"}
                  </a>
                </td>
              </tr>
<!-- dtl:block:OverviewClassList -->
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentfooter">
            &nbsp;
          </td>
        </tr>
      </table>
<!-- dtl:block:OverviewClass -->
<!-- dtl:block:OverviewItem -->
      <table width="100%" cellspacing="0" cellpadding="4">
        <tr>
          <td class="contenthead">$Text{"List"}:</td>
        </tr>
        <tr>
          <td class="contentbody">
            <table width="100%" border="0" cellspacing="0" cellpadding="3">
              <tr>
                <td class="contentkey" width="60%">$QData{"Class"}</td>
                <td class="contentkey" align="center">$Text{"Functionality"}</td>
                <td class="contentkey" align="center">$Text{"Valid"}</td>
              </tr>
<!-- dtl:block:OverviewItemList -->
              <tr>
                <td class="$QData{"CssClass"}">
                  <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=ItemEdit&ItemID=$QData{"ItemID"}">
                  $QData{"Name"}
                  </a>
                </td>
                <td class="$QData{"CssClass"}" align="center">
                  $QData{"Functionality"}
                </td>
                <td class="$QData{"CssClass"}" align="center">
                  $Text{"$QData{"Valid"}"}
                </td>
              </tr>
<!-- dtl:block:OverviewItemList -->
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentfooter">
            &nbsp;
          </td>
        </tr>
      </table>
<!-- dtl:block:OverviewItem -->
<!-- dtl:block:ItemEdit -->
      <form action="$Env{"CGIHandle"}" method="get">
        <input type="hidden" name="Action" value="$Env{"Action"}">
        <input type="hidden" name="Subaction" value="ItemSave">
        <input type="hidden" name="Class" value="$QData{"Class"}">
        <input type="hidden" name="ItemID" value="$QData{"ItemID"}">
        <table width="100%" cellspacing="0" cellpadding="4">
          <tr>
            <td class="contenthead">$Text{"Item"} $Text{"Edit"}:</td>
          </tr>
          <tr>
            <td class="contentbody">
              <table border="0" cellspacing="0" cellpadding="3">
                <tr>
                  <td class="contentkey">$Text{"Catalog Class"}: </td>
                  <td class="contentvalue">$QData{"Class"}</td>
                </tr>
                <tr>
                  <td class="contentkey">$Text{"Name"}: </td>
                  <td class="contentvalue">
                    <input type="text" name="Name" value="$QData{"Name"}" size="45" maxlength="100">
                  </td>
                </tr>
                <tr>
                  <td class="contentkey">$Text{"Functionality"}: </td>
                  <td class="contentvalue">$Data{"FunctionalityOptionStrg"}</td>
                </tr>
                <tr>
                  <td class="contentkey">$Text{"Valid"}: </td>
                  <td class="contentvalue">$Data{"ValidOptionStrg"}</td>
                </tr>
                <tr>
                  <td class="contentkey">$Text{"Comment"}: </td>
                  <td class="contentvalue">
                    <input type="text" name="Comment" value="$QData{"Comment"}" size="50" maxlength="200">
                  </td>
                </tr>
              </table>
            </td>
          </tr>
          <tr>
            <td class="contentfooter">
              <input class="button" type="submit" value="$Text{"Submit"}">
            </td>
          </tr>
        </table>
      </form>
<!-- dtl:block:ItemEdit -->
    </td>
  </tr>
</table>
<!-- dtl:block:Overview -->

# --
# Kernel/System/GeneralCatalog.pm - all general catalog functions
# Copyright (C) 2003-2007 OTRS GmbH, http://otrs.com/
# --
# $Id: GeneralCatalog.pm,v 1.3 2007/02/27 20:09:00 mh 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::System::GeneralCatalog;

use strict;

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

=head1 NAME

Kernel::System::GeneralCatalog - general catalog lib

=head1 SYNOPSIS

All general catalog functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create a object

    use Kernel::Config;
    use Kernel::System::Log;
    use Kernel::System::DB;

    my $ConfigObject = Kernel::Config->new();
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        LogObject => $LogObject,
    );
    my $GeneralCatalogObject = Kernel::System::GeneralCatalog->new(
        ConfigObject => $ConfigObject,
        LogObject => $LogObject,
        DBObject => $DBObject,
    );

=cut

sub new {
    my $Type = shift;
    my %Param = @_;
    # allocate new hash for object
    my $Self = {};
    bless ($Self, $Type);
    # check needed objects
    foreach (qw(DBObject ConfigObject LogObject)) {
        $Self->{$_} = $Param{$_} || die "Got no $_!";
    }

    return $Self;
}

=item ClassList()

return an array reference of all general catalog classes

    my $ListRef = $GeneralCatalogObject->ClassList();

=cut

sub ClassList {
    my $Self = shift;
    my %Param = @_;
    my @ClassList;
    # ask database
    $Self->{DBObject}->Prepare(
        SQL => "SELECT DISTINCT(class) FROM general_catalog ORDER BY class",
    );
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        push(@ClassList, $Row[0]);
    }
    return \@ClassList;
}

=item ItemList()

return a list as hash reference of one general catalog class

    my $ListRef = $GeneralCatalogObject->ItemList(
        Class => 'ITSM::Service::Type',
        Valid => 0,
    );

=cut

sub ItemList {
    my $Self = shift;
    my %Param = @_;
    # check needed stuff
    foreach (qw(Class)) {
        if (!$Param{$_}) {
            $Self->{LogObject}->Log(Priority => 'error', Message => "Need $_!");
            return;
        }
    }
    if (!defined($Param{Valid})) {
        $Param{Valid} = 1;
    }

    # ask database
    my %Data = ();
    my $SQL = "SELECT id, name FROM general_catalog WHERE class = '$Param{Class}' ";
    if ($Param{Valid}) {
        $SQL .= "AND valid_id = 1";
    }
    $Self->{DBObject}->Prepare(SQL => $SQL);
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        $Data{$Row[0]} = $Row[1];
    }
    return \%Data;
}

=item FunctionalityList()

return an hash reference of all functionalities of a general catalog class

    my $ListRef = $GeneralCatalogObject->FunctionalityList(
        Class => 'ITSM::Service::Type',
    );

=cut

sub FunctionalityList {
    my $Self = shift;
    my %Param = @_;
    my %FunctionalityList;
    # check needed stuff
    foreach (qw(Class)) {
        if (!$Param{$_}) {
            $Self->{LogObject}->Log(Priority => 'error', Message => "Need $_!");
            return;
        }
    }
    # ask database
    $Self->{DBObject}->Prepare(
        SQL => "SELECT DISTINCT(functionality) FROM general_catalog WHERE class = '$Param{Class}' ORDER BY functionality",
    );
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        $FunctionalityList{$Row[0]} = $Row[0];
    }
    delete($FunctionalityList{''});

    return \%FunctionalityList;
}

=item ItemGet()

get a general catalog item

Return
    $ItemData{ItemID}
    $ItemData{Class}
    $ItemData{Name}
    $ItemData{Functionality}
    $ItemData{ValidID}
    $ItemData{Comment}
    $ItemData{CreateTime}
    $ItemData{CreateBy}
    $ItemData{ChangeTime}
    $ItemData{ChangeBy}

    my $ItemDataRef = $GeneralCatalogObject->ItemGet(
        ItemID => 3,
    );

=cut

sub ItemGet {
    my $Self = shift;
    my %Param = @_;
    # check needed stuff
    foreach (qw(ItemID)) {
        if (!$Param{$_}) {
            $Self->{LogObject}->Log(Priority => 'error', Message => "Need $_!");
            return;
        }
    }
    # ask database
    my %ItemData = ();
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, class, name, functionality, valid_id, comments, ".
            "create_time, create_by, change_time, change_by FROM general_catalog WHERE id = $Param{ItemID}",
        Limit => 1,
    );
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        $ItemData{ItemID} = $Row[0];
        $ItemData{Class} = $Row[1];
        $ItemData{Name} = $Row[2];
        $ItemData{Functionality} = $Row[3] || '';
        $ItemData{ValidID} = $Row[4];
        $ItemData{Comment} = $Row[5] || '';
        $ItemData{CreateTime} = $Row[6];
        $ItemData{CreateBy} = $Row[7];
        $ItemData{ChangeTime} = $Row[8];
        $ItemData{ChangeBy} = $Row[9];
    }
    return \%ItemData;
}

=item ItemAdd()

add a new general catalog item

    my $True = $GeneralCatalogObject->ItemAdd(
        Class => 'ITSM::Service::Type',
        Name => 'Item Name',
        Functionality => 'Func3',       # (optional)
        ValidID => 1,
        Comment => 'Comment',           # (optional)
        UserID => 1,
    );

=cut

sub ItemAdd {
    my $Self = shift;
    my %Param = @_;
    # check needed stuff
    foreach (qw(Class Name ValidID UserID)) {
        if (!$Param{$_}) {
            $Self->{LogObject}->Log(Priority => 'error', Message => "Need $_!");
            return;
        }
    }
    # quote
    foreach (qw(Class Name Functionality Comment)) {
        $Param{$_} = $Self->{DBObject}->Quote($Param{$_});
    }
    foreach (qw(ValidID UserID)) {
        $Param{$_} = $Self->{DBObject}->Quote($Param{$_}, 'Integer');
    }
    # find exiting item with same name
    my $NoAdd;
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM general_catalog WHERE name = '$Param{Name}' AND class = '$Param{Class}'",
        Limit => 1,
    );
    while ($Self->{DBObject}->FetchrowArray()) {
        $NoAdd = 1;
    }
    # add item
    my $Return;
    if (!$NoAdd) {
        $Self->{DBObject}->Do(
            SQL =>"INSERT INTO general_catalog ".
                "(class, name, functionality, valid_id, comments, ".
                "create_time, create_by, change_time, change_by) VALUES ".
                "('$Param{Class}', '$Param{Name}', '$Param{Functionality}', $Param{ValidID}, '$Param{Comment}', ".
                "current_timestamp, $Param{UserID}, current_timestamp, $Param{UserID})",
        );
        $Return = 1;
    }
    else {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message => "Can't add new item! General catalog item with same name already exists in this class.",
        );
    }
    return $Return;
}

=item ItemUpdate()

update a existing general catalog item

    my $True = $GeneralCatalogObject->ItemUpdate(
        ItemID => 123,
        Name => 'Item Name',
        Functionality => 'Func3',  # (optional)
        ValidID => 1,
        Comment => 'Comment',      # (optional)
        UserID => 1,
    );

=cut

sub ItemUpdate {
    my $Self = shift;
    my %Param = @_;
    # check needed stuff
    foreach (qw(ItemID Name ValidID UserID)) {
        if (!$Param{$_}) {
            $Self->{LogObject}->Log(Priority => 'error', Message => "Need $_!");
            return;
        }
    }
    # quote
    foreach (qw(Name Functionality Comment)) {
        $Param{$_} = $Self->{DBObject}->Quote($Param{$_});
    }
    foreach (qw(ItemID ValidID UserID)) {
        $Param{$_} = $Self->{DBObject}->Quote($Param{$_}, 'Integer');
    }
    # get class of item
    my $Class;
    my $OldFunctionality;
    $Self->{DBObject}->Prepare(
        SQL => "SELECT class, functionality FROM general_catalog WHERE id = $Param{ItemID}",
        Limit => 1,
    );
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        $Class = $Row[0] || '';
        $OldFunctionality = $Row[1] || '';
    }
    # find exiting item with same name
    my $Update;
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM general_catalog WHERE name = '$Param{Name}' AND class = '$Class'",
        Limit => 1,
    );
    while (my @Row = $Self->{DBObject}->FetchrowArray()) {
        if ($Param{ItemID} eq $Row[0]) {
            $Update = 1;
        }
    }
    # count functionality
    if ($OldFunctionality) {
        $Self->{DBObject}->Prepare(
            SQL => "SELECT COUNT(functionality) FROM general_catalog ".
                "WHERE class = '$Class' AND functionality = '$OldFunctionality'",
            Limit => 1,
        );
        my $LastFunctionality = 1;
        while (my @Row = $Self->{DBObject}->FetchrowArray()) {
            if ($Row[0] > 1 || $Param{Functionality} eq $OldFunctionality) {
                $LastFunctionality = 0;
            }
        }
        if ($LastFunctionality) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message => "Can't update item! The functionality of this item is the last in this class.",
            );
            return;
        }
    }
    # update item
    if ($Update && $Class) {
        $Self->{DBObject}->Do(
            SQL => "UPDATE general_catalog SET name = '$Param{Name}', functionality = '$Param{Functionality}',".
                "valid_id = $Param{ValidID}, comments = '$Param{Comment}', ".
                "change_time = current_timestamp, change_by = $Param{UserID} WHERE id = $Param{ItemID}",
        );
        return 1;
    }
    else {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message => "Can't update item! General catalog item with same name already exists in this class.",
        );
        return;
    }
}

=item ValidLookup()

return a hash reference of all general catalog availabilities

Return
    $Valid{ValidID}
    $Valid{Name}

    my $ValidRef = $GeneralCatalogObject->ValidLookup(
        ValidID => 1,
    );

    or

    my $ValidRef = $GeneralCatalogObject->ValidLookup(
        Name => 'valid',
    );

=cut

sub ValidLookup {
    my $Self = shift;
    my %Param = @_;
    my %Valid;
    if (!$Param{ValidID} && !$Param{Name}) {
        $Self->{LogObject}->Log(Priority => 'error', Message => "Need ValidID or Name!");
        return;
    }
    # get valid list
    my $ValidListRef = $Self->ValidList();
    if ($Param{ValidID}) {
        $Valid{ValidID} = $Param{ValidID};
        $Valid{Name} = $ValidListRef->{ValidID};
    }
    elsif ($Param{Name}) {
        my %ValidReverse = reverse(%{$ValidListRef});
        $Valid{ValidID} = $ValidReverse{$Param{Name}};
        $Valid{Name} = $Param{Name};
    }
    return \%Valid;
}

=item ValidList()

return a hash reference of all general catalog availabilities

    my $ListRef = $GeneralCatalogObject->ValidList();

=cut

sub ValidList {
    my $Self = shift;
    my %Param = @_;
    my %ValidList;

    $ValidList{'1'} = 'valid';
    $ValidList{'2'} = 'invalid';
    $ValidList{'3'} = 'invalid-temporarily';

    return \%ValidList;
}

1;

=back

=head1 TERMS AND CONDITIONS

This Software is part of the OTRS project (http://otrs.org/).

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.

=cut

=head1 VERSION

$Revision: 1.3 $ $Date: 2007/02/27 20:09:00 $

=cut