ITSMConfigurationManagement
3.3.11
OTRS AG
http://otrs.org/
GNU AFFERO GENERAL PUBLIC LICENSE Version 3, November 2007
Build for OTRS::ITSM 3.3.11.
Build for OTRS::ITSM 3.3.10.
Build for OTRS::ITSM 3.3.9.
Build for OTRS::ITSM 3.3.8.
Build for OTRS::ITSM 3.3.7.
Build for OTRS::ITSM 3.3.6.
Build for OTRS::ITSM 3.3.5.
Build for OTRS::ITSM 3.3.4.
Build for OTRS::ITSM 3.3.3.
Build for OTRS::ITSM 3.3.2.
Build for OTRS::ITSM 3.3.1.
Build for OTRS::ITSM 3.3.0 rc1.
Build for OTRS::ITSM 3.3.0 beta5.
Build for OTRS::ITSM 3.3.0 beta4.
Build for OTRS::ITSM 3.3.0 beta3.
Build for OTRS::ITSM 3.3.0 beta2.
Build for OTRS::ITSM 3.3.0 beta1.
The OTRS ITSM Configuration Management package.
Das OTRS ITSM Configuration Management Paket.
El paquete OTRS ITSM Configuration Management.
3.3.x
<br/>
<strong>WELCOME</strong>
<br/>
<br/>
You are about to install the OTRS package ITSMConfigurationManagement.<br/>
<br/>
<br/>
<strong>REQUIRED OTRS PACKAGES</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>WILLKOMMEN</strong>
<br/>
<br/>
Sie sind im Begriff das OTRS-Paket ITSMConfigurationManagement zu installieren.<br/>
<br/>
<br/>
<strong>BENÖTIGTE OTRS-PAKETE</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>BIENVENIDO</strong>
<br/>
<br/>
Usted está punto de instalar el paquete ITSMConfigurationManagement de OTRS.<br/>
<br/>
<br/>
<strong>PAQUETES OTRS REQUERIDOS</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>NOTICE</strong>
<br/>
<br/>
In order to grant users access to the config item menu, you need to add them as member to the group 'itsm-configitem'.
<br/>
<br/>
The menu items that were added by this package will be visible after you log-in to the system again.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>HINWEIS</strong>
<br/>
<br/>
Um Benutzern Zugriff auf das ConfigItem-Menü zu gewähren, müssen diese Mitglied der neuen Gruppe 'itsm-configitem' sein.
<br/>
<br/>
Die von diesem Paket hinzugefügten Menü-Punkte sind erst nach einem erneuten Anmeldevorgang im System sichtbar.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>ATENCIÓN</strong>
<br/>
<br/>
Para permitirles a los usuarios el acceso al menú de los elementos de configuración, es necesario que se den de
alta como miembros del grupo 'itsm-configitem'.
<br/>
<br/>
Los elementos del menú que se agregaron por este paquete, serpan visibles después reiniciar la sesión al sistema.
<br/>
<br/>
((enjoy))
<br/>
<br/>
<br/>
<strong>ATTENTION</strong>
<br/>
<br/>
If you uninstall this package, all database tables that were created during installation will be deleted.
All data from these tables will be irrevocably lost!
<br/>
<br/>
The group 'itsm-configitem' that was created during package installation will be deactivated.
You can activate this group again in the admin area.
<br/>
<br/>
All links to config item objects will be irrevocably deleted!
<br/>
<br/>
The statistics that are associated with this package, will no longer be available if the package is uninstalled.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>ACHTUNG</strong>
<br/>
<br/>
Bei der Deinstallation werden die von diesem Paket angelegten Datenbank-Tabellen gelöscht.
Alle darin enthaltenen Daten gehen unwiderruflich verloren!
<br/>
<br/>
Die von diesem Paket angelegte Gruppe 'itsm-configitem' wird deaktiviert.
Sie kann jederzeit im Admin-Bereich wieder aktiviert werden.
<br/>
<br/>
Alle Verknüpfungen zu ConfigItem-Objekten werden unwiderruflich gelöscht!
<br/>
<br/>
Nach der Deinstallation sind die zu diesem Paket zugehörigen Statistiken nicht mehr verfügbar.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>ATENCIÓN</strong>
<br/>
<br/>
Si usted desinstala este paquete, todas las tablas de la base de datos que fueron creadas durante su instalación se eliminarán.
¡Todos los datos de dichas tablas se perderán irrevocablemente!
<br/>
<br/>
El grupo 'itsm-configitem' que se creó durante la instalación de este paquete se desactivará.
Es posible reactivar este grupo en el área de administración.
<br/>
<br/>
¡Todos los vínculos a objetos de elementos de configuración serán eliminados permanentemente!
<br/>
<br/>
Si usted desinstala este paquete, las estadísticas que están asociadas a él ya no estarán disponibles.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>WELCOME</strong>
<br/>
<br/>
You are about to upgrade the OTRS package ITSMConfigurationManagement.<br/>
<br/>
<br/>
<strong>REQUIRED OTRS PACKAGES</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>WILLKOMMEN</strong>
<br/>
<br/>
Sie sind im Begriff das OTRS-Paket ITSMConfigurationManagement zu aktualisieren.<br/>
<br/>
<br/>
<strong>BENÖTIGTE OTRS-PAKETE</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>BIENVENIDO</strong>
<br/>
<br/>
Usted está a punto de actualizar el paquete ITSMConfigurationManagement de OTRS.<br/>
<br/>
<br/>
<strong>PAQUETES OTRS REQUERIDOS</strong>
<ul>
<li>ITSMCore 3.3.11</li>
</ul>
<br/>
((enjoy))<br/>
<br/>
ITSMCore
# define function name
my $FunctionName = 'CodeInstall';
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
# load the module
if ( $Self->{MainObject}->Require($CodeModule) ) {
# create new instance
my $CodeObject = $CodeModule->new( %{$Self} );
if ($CodeObject) {
# start methode
if ( !$CodeObject->$FunctionName(%{$Self}) ) {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method $FunctionName() on $CodeModule.pm."
);
}
}
# error handling
else {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method new() on $CodeModule.pm."
);
}
}
# uninstall Feature AddOn OTRSCIColumns that has been integrated in OTRS ITSM 3.2.91 (OTRS ITSM 3.3.0 Beta 1)
$Self->_PackageUninstallMerged(
Name => 'OTRSCIColumns',
);
# uninstall Feature AddOn OTRSCIAttributeSyntaxCheck that has been integrated in OTRS ITSM 3.2.91 (OTRS ITSM 3.3.0 Beta 1)
$Self->_PackageUninstallMerged(
Name => 'OTRSCIAttributeSyntaxCheck',
);
# define function name
my $FunctionName = 'CodeUpgrade';
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
# The code module has just recently been copied to it's location in the file system.
# In a persistent Perl environment an old version of the module might still be loaded,
# as watchdogs like Apache2::Reload haven't had a chance to reload it.
# So we need to make sure that the new version is being loaded.
# Kernel::System::Main::Require() checks the relative file path, so we need to remove that from %INC.
# This is only needed in persistent Perl environment, but does no harm in a CGI environment.
my $CodeModulePath = $CodeModule;
$CodeModulePath =~ s/::/\//g;
$CodeModulePath .= '.pm';
delete $INC{$CodeModulePath};
# load the module
if ( $Self->{MainObject}->Require($CodeModule) ) {
# create new instance
my $CodeObject = $CodeModule->new( %{$Self} );
if ($CodeObject) {
# start methode
if ( !$CodeObject->$FunctionName(%{$Self}) ) {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method $FunctionName() on $CodeModule.pm."
);
}
}
# error handling
else {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method new() on $CodeModule.pm."
);
}
}
# define function name
my $FunctionName = 'CodeUninstall';
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
# load the module
if ( $Self->{MainObject}->Require($CodeModule) ) {
# create new instance
my $CodeObject = $CodeModule->new( %{$Self} );
if ($CodeObject) {
# start methode
if ( !$CodeObject->$FunctionName(%{$Self}) ) {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method $FunctionName() on $CodeModule.pm."
);
}
}
# error handling
else {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method new() on $CodeModule.pm."
);
}
}
# cleanup stats list
{
# load required modules
$Self->{MainObject}->Require('Kernel::System::CSV');
$Self->{MainObject}->Require('Kernel::System::Group');
$Self->{MainObject}->Require('Kernel::System::User');
$Self->{MainObject}->Require('Kernel::System::Stats');
# create needed objects
$Self->{CSVObject} = Kernel::System::CSV->new( %{$Self} );
$Self->{GroupObject} = Kernel::System::Group->new( %{$Self} );
$Self->{UserObject} = Kernel::System::User->new( %{$Self} );
$Self->{StatsObject} = Kernel::System::Stats->new(
%{$Self},
UserID => 1,
);
# cleanup stats list
$Self->{StatsObject}->StatsCleanUp();
}
# define function name
my $FunctionName = 'CodeReinstall';
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
# load the module
if ( $Self->{MainObject}->Require($CodeModule) ) {
# create new instance
my $CodeObject = $CodeModule->new( %{$Self} );
if ($CodeObject) {
# start methode
if ( !$CodeObject->$FunctionName(%{$Self}) ) {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method $FunctionName() on $CodeModule.pm."
);
}
}
# error handling
else {
$Self->{LogObject}->Log(
Priority => 'error',
Message => "Could not call method new() on $CodeModule.pm."
);
}
}
2014-12-11 18:59:14
opms.otrs.com
#!/usr/bin/perl
# --
# bin/otrs.ITSMConfigItemDelete.pl - to delete config items
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU AFFERO General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# any later version.
#
# This program 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 Affero General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
# or see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;

# use ../ as lib location
use File::Basename;
use FindBin qw($RealBin);
use lib dirname($RealBin);

use Getopt::Long;
use Kernel::Config;
use Kernel::System::Encode;
use Kernel::System::Log;
use Kernel::System::Main;
use Kernel::System::Time;
use Kernel::System::DB;
use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;

# common objects
my %CommonObject = ();
$CommonObject{ConfigObject} = Kernel::Config->new();
$CommonObject{EncodeObject} = Kernel::System::Encode->new(%CommonObject);
$CommonObject{LogObject}    = Kernel::System::Log->new(
    LogPrefix => 'OTRS-ConfigItemDelete.pl',
    %CommonObject,
);
$CommonObject{MainObject}           = Kernel::System::Main->new(%CommonObject);
$CommonObject{TimeObject}           = Kernel::System::Time->new(%CommonObject);
$CommonObject{DBObject}             = Kernel::System::DB->new(%CommonObject);
$CommonObject{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%CommonObject);
$CommonObject{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%CommonObject);

print "otrs.ITSMConfigItemDelete.pl";
print "delete config items (all, by class (and deployment state) or by number).\n";
print "Copyright (C) 2001-2014 OTRS AG, http://otrs.com/\n";

my $Help              = '';
my $All               = '';
my $Class             = '';
my $DeploymentState   = '';
my @ConfigItemNumbers = ();

GetOptions(
    'help'                  => \$Help,
    'all'                   => \$All,
    'class=s'               => \$Class,
    'deploymentstate=s'     => \$DeploymentState,
    'ConfigItemNumber=s{,}' => \@ConfigItemNumbers,
);

# delete all config items
if ($All) {

    # get all config items ids
    my @ConfigItemsIDs = @{ $CommonObject{ConfigItemObject}->ConfigItemSearch() };

    # get number of config items
    my $CICount = scalar @ConfigItemsIDs;

    # if there are any CI to delete
    if ($CICount) {

        print "Are you sure that you want to delete ALL $CICount config items? ";
        print "This is irrevocable. [y/n] ";
        chomp( my $Confirmation = lc <STDIN> );

        # if the user confirms the deletion
        if ( $Confirmation eq 'y' ) {

            # delete config items
            print "Deleting all config items...\n";
            DeleteConfigItems( ConfigItemsIDs => \@ConfigItemsIDs );
        }
        else {
            exit 1;
        }
    }
    else {
        print "There are NO config items to delete.\n";
    }
}

# delete listed config items
elsif (@ConfigItemNumbers) {

    my @ConfigItemsIDs;

    for my $ConfigItemNumber (@ConfigItemNumbers) {

        # checks the validity of the config item id
        my $ID = $CommonObject{ConfigItemObject}->ConfigItemLookup(
            ConfigItemNumber => $ConfigItemNumber,
        );

        if ($ID) {
            push @ConfigItemsIDs, $ID;
        }
        else {
            print "Unable to find config item $ConfigItemNumber.\n";
        }
    }

    # delete config items (if any valid number was given)
    if (@ConfigItemsIDs) {
        print "Deleting specified config items...\n";
        DeleteConfigItems( ConfigItemsIDs => \@ConfigItemsIDs );
    }
}

# delete config items that belong to the class
elsif ($Class) {

    my @ConfigItemsIDs;

    # get class list
    my $ClassList = $CommonObject{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
        Valid => 0,
    );

    # invert the hash to have the classes names as keys
    my %ClassName2ID = reverse %{$ClassList};

    if ( $ClassName2ID{$Class} ) {
        my $ID = $ClassName2ID{$Class};

        # define the search param for the class search
        my %SearchParam = (
            ClassIDs => [$ID],
        );

        # also a deployment state is given
        if ($DeploymentState) {

            # get deployment state list
            my $DeploymentStateList = $CommonObject{GeneralCatalogObject}->ItemList(
                Class => 'ITSM::ConfigItem::DeploymentState',
            );

            # invert the hash to have the deployment state names as keys
            my %DeploymentState2ID = reverse %{$DeploymentStateList};

            # if the deployment state is valid
            if ( $DeploymentState2ID{$DeploymentState} ) {

                # get the deployment state id
                my $ID = $DeploymentState2ID{$DeploymentState};

                # add search parameter
                $SearchParam{DeplStateIDs} = [$ID];
            }
            else {
                print "Unable to find deployment state $DeploymentState.\n";
                exit 1;
            }
        }

        # get ids of this class (and maybe deployment state) config items
        @ConfigItemsIDs
            = @{ $CommonObject{ConfigItemObject}->ConfigItemSearch(%SearchParam) };
    }
    else {
        print "Unable to find class name $Class.\n";
    }

    # delete config items (if any valid number was given)
    if (@ConfigItemsIDs) {
        print "Deleting config items that belong to the class $Class...\n";
        DeleteConfigItems( ConfigItemsIDs => \@ConfigItemsIDs );
    }
    else {
        print "There are no config items that belong to the class $Class...\n";
    }
}

# show usage
else {
    print "Usage: $0 [options] \n";
    print "  Options are as follows:\n";
    print "  --help                             display this option help\n";
    print "  --all                              delete all config items\n";
    print "  --class name                       delete all config items of this class\n";
    print
        "  --deploymentstate name             delete all config items with this deployment state (ONLY TOGETHER with the --class parameter)\n";
    print "  --ConfigItemNumber no1 no2 no3     delete listed config items\n";
    exit 1;
}

1;

sub DeleteConfigItems {

    # get parameters
    my (%Param) = @_;

    my $DeletedCI;

    # delete specified config items
    for my $ConfigItemID ( @{ $Param{ConfigItemsIDs} } ) {
        my $True = $CommonObject{ConfigItemObject}->ConfigItemDelete(
            ConfigItemID => $ConfigItemID,
            UserID       => 1,
        );
        if ( !$True ) {
            print "Unable to delete config item with id $ConfigItemID\n";
        }
        else {
            $DeletedCI++;
        }
    }
    print "Deletd $DeletedCI config item(s).\n\n";

    return 1;
}

#!/usr/bin/perl
# --
# bin/otrs.ITSMConfigItemListDuplicates.pl - list configitems with duplicate names
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU AFFERO General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# any later version.
#
# This program 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 Affero General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
# or see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;

# use ../ as lib location
use File::Basename;
use FindBin qw($RealBin);
use lib dirname($RealBin);
use lib dirname($RealBin) . '/Custom';

use Getopt::Long;
use Kernel::Config;
use Kernel::System::Encode;
use Kernel::System::Log;
use Kernel::System::Main;
use Kernel::System::Time;
use Kernel::System::DB;
use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;
use Kernel::System::VariableCheck qw(IsArrayRefWithData);

# common objects
my %CommonObject = ();
$CommonObject{ConfigObject} = Kernel::Config->new();
$CommonObject{EncodeObject} = Kernel::System::Encode->new(%CommonObject);
$CommonObject{LogObject}    = Kernel::System::Log->new(
    LogPrefix => 'otrs.ITSMConfigItemListDuplicates.pl',
    %CommonObject,
);
$CommonObject{MainObject}           = Kernel::System::Main->new(%CommonObject);
$CommonObject{TimeObject}           = Kernel::System::Time->new(%CommonObject);
$CommonObject{DBObject}             = Kernel::System::DB->new(%CommonObject);
$CommonObject{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%CommonObject);
$CommonObject{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%CommonObject);

print "otrs.ITSMConfigItemListDuplicates.pl";
print "(List ConfigItems which have a non-unique name).\n";
print "Copyright (C) 2001-2014 OTRS AG, http://otrs.com/\n\n";

my $Help      = '';
my $Class     = '';
my $Scope     = '';
my $AllStates = '';

GetOptions(
    'help'      => \$Help,
    'class=s'   => \$Class,
    'scope=s'   => \$Scope,
    'allstates' => \$AllStates,
);

# make sure, the supplied 'scope' is valid
if ( $Scope && $Scope ne 'class' && $Scope ne 'global' ) {
    print "The provided scope is not valid, please use 'class' or 'global'\n";
    exit 1;
}

my %SearchCriteria;

if ($Class) {

    # get class list
    my $ClassList = $CommonObject{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # invert the hash to have the classes' names as keys
    my %ClassName2ID = reverse %{$ClassList};

    # check, whether this class exists
    if ( $ClassName2ID{$Class} ) {
        my $ID = $ClassName2ID{$Class};

        # get ids of this class' config items
        $SearchCriteria{ClassIDs} = [$ID];
    }
    else {
        print "Unable to find class name $Class.\n";
    }
}

if ( !$AllStates ) {

    my $StateList = $CommonObject{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::ConfigItem::DeploymentState',
        Preferences => {
            Functionality => [ 'preproductive', 'productive' ],
        },
    );

    my $DeploymentStateIDs = [ keys %{$StateList} ];

    $SearchCriteria{DeplStateIDs} = [ keys %{$StateList} ];
}

# get all config items ids
my @ConfigItemIDs = @{ $CommonObject{ConfigItemObject}->ConfigItemSearch(%SearchCriteria) };

# get number of config items
my $CICount = scalar @ConfigItemIDs;

# if there are any CI to check
if ($CICount) {

    # if the scope was explicitely defined, set it, otherwise this script will fall back to the
    # value set in SysConfig
    if ($Scope) {
        $CommonObject{ConfigObject}->Set(
            Key   => 'UniqueCIName::UniquenessCheckScope',
            Value => $Scope,
        );
    }

    if ($Class) {
        print "Checking config items of class $Class...\n";
    }
    else {
        print "Checking all config items...\n";
    }

    my $DuplicatesFound = 0;

    # check config items
    CONFIGITEMID:
    for my $ConfigItemID (@ConfigItemIDs) {

        # get the attributes of this config item
        my $ConfigItem = $CommonObject{ConfigItemObject}->ConfigItemGet(
            ConfigItemID => $ConfigItemID,
        );

        next CONFIGITEMID if !$ConfigItem->{LastVersionID};

        # get the latest version of this config item
        my $Version = $CommonObject{ConfigItemObject}->VersionGet(
            VersionID  => $ConfigItem->{LastVersionID},
            XMLDataGet => 1,
        );

        next CONFIGITEMID if !$Version;

        if ( !$Version->{Name} ) {
            print "Skipping ConfigItem $ConfigItemID as it doesn't have a name\n";
            next CONFIGITEMID;
        }

        my $Duplicates = $CommonObject{ConfigItemObject}->UniqueNameCheck(
            ConfigItemID => $ConfigItemID,
            ClassID      => $ConfigItem->{ClassID},
            Name         => $Version->{Name}
        );

        if ( IsArrayRefWithData($Duplicates) ) {

            $DuplicatesFound = 1;

            my @DuplicateData;

            for my $DuplicateID ( @{$Duplicates} ) {

                # get the # of the duplicate
                my $DuplicateConfigItem = $CommonObject{ConfigItemObject}->ConfigItemGet(
                    ConfigItemID => $DuplicateID,
                );

                my $DuplicateVersion = $CommonObject{ConfigItemObject}->VersionGet(
                    VersionID => $DuplicateConfigItem->{LastVersionID},
                );

                push @DuplicateData, $DuplicateVersion;
            }

            print "ConfigItem $Version->{Number} (Name: $Version->{Name}, ConfigItemID: "
                . "$Version->{ConfigItemID}) has the following duplicates:\n";

            # list all the details of the duplicates
            for my $DuplicateVersion (@DuplicateData) {
                print "\t$DuplicateVersion->{Number} (ConfigItemID: "
                    . "$DuplicateVersion->{ConfigItemID})\n";
            }
        }
    }

    if ($DuplicatesFound) {
        print "Finished checking for duplicate names\n";
    }
    else {
        print "No duplicate names found\n";
    }
}
else {
    print "There are NO config items to check.\n";
}

print "\n";

# show usage
if ($Help) {
    print "Usage: $0 [options] \n";
    print "  Options are as follows:\n";
    print "  --help                             display this option help\n";
    print "  --class name                       check only config items of this class\n";
    print "  --scope (global|class)             define the scope for the uniqueness check\n";
    print
        "  --allstates                        also check config items in non-productive states\n\n";
    exit 1;
}

1;

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LQEAAAAAAKCZmNAUAIAmKykpEQTBz89PqVTauy0AAACAPRFaAgCgyUpKSkRR9PHxIbQEAAAAJ0doCQCAJvP39zcYDMSVAAAAAIUoivZuAwAAAAAAANolspYAAA6urKzMYDD4+Pi4ubnZuy0AAACAoyG0BABwcLdv366trfXw8CC0BAAAAFidi70bAACAben1ekEQXFz4k3vDmrcAACAASURBVAcAAABYH/fZAAAHZzAYBEJLAAAAgG1wnw0AcGSiKEovrOBtbgAAAIAtEFoCADgyaTScQNYSAAAAYBvcZwMAHBmj4QAAAACb4lYbAODIpNASo+EAAAAAG3G1dwMAALAhW7weTq1Wl5WVBQQEdOrUyYrVAgAAAO0RWUsAAEdmiwFxUp0KhcKKdQIAAADtFFlLAABHZrvQEvM3AQCs7qmnnjp+/Li9W4F2ac6cOX/605/s3Qo4KUJLAABHJg2Is+5cS4SWAAA2kpeX98477zzwwAP2bgjamffee6+srMzerYDzIrQEAHBktggtiaIoEFoCANhGaGho165d7d0KtDO+vr72bgKcGrfFAABHxoA4AAAAwKa4LQYAODLbDYhjGm8AAABAILQEAHBszLUEAEDLteSBSnt8GNMe2wzYEbfFAABHxoA4AAAalZKS4u7u7ubmFhkZOXbsWHs3x1YUCgUxI8AWuC0GADgyq2ctiaLINN4AAAczderUjRs3arXanJycXbt2ma8g/e1rnvq2DQ8Pb3ad1m1JS9Y01vpHBLQR3BYDAByZLUJL0gdCSwAAh6HVaidOnNjKO83Pz294BY1G0zotsZZGjwhwVNwWAwAcljRyTbBqaEmew5uMegBAq8nIyJg8ebJKpfLw8Bg+fPj+/ft79uwpL7148eKECRMiIiIiIiImTZqUkZEhL5L+YFVUVEyYMMHd3d3d3T0lJcW45piYGOkvmuI3I0eONF7hypUr9f3V27JlS48ePby9vX//+99XVVWZr1bftt27dzfZqck6GzdujIiI6Nixo7e395gxY06dOmV8OH//+999fHzS0tIWL17s5eVlckSNys7OHjFihKurq/nZaKDN0phBhULh5+c3adKkgwcP3n333ZYfUQPXSDC6r9izZ88999zTs2fPHTt21Feb9LVHjx5NOmrApggtAQAclpSyZN0wEK+HAwC0sosXL44dO3bs2LEXLlwo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r73OD2Bd7Xu2CACNiouLW758eWVlZVZW1osvviiXP/XUU+np6VqtVjDKTnrppZdeeOGFixcv1tbW/vrrr9OmTauzzjq3Nfboo49u3rzZvPzpp59+4403cnNzc3Nz/+u//st40ebNmx999NHmHuX/GTBgQGpq6unTpx988MHPPvushbWh/bLRREsC03gDAFpds9O6LTF16tSNGzeWlJSYxJWEZkVe6mRej/Twr05VVVVW2Wmd+7VkUbPrbHbllq/fwHkD7I6bY8DB/fd///fOnTsDAwNHjhw5duxYufzxxx+fNGmSn5/fu+++K48Xe/XVVx977LFJkyb5+vr+7ne/e+qpp+qss85tjU2ePPno0aOXL182KX/nnXe6du3ar1+/2NjYhx9+WC7PyMg4fvz4xIkTW3q0giAIwr333rt169apU6dapTa0RzZ6PZw0mZdg9uJFAABsxzjrXBCEmpqa119/PSQkJCwsbN26dT179pTKtVrt3Llze/Xq1bNnz9mzZ9fW1krlCoVCoVCsWrUqMjLS3d09JSVFKo+JiVEoFFqtdtKkSdI68i5SU1NNSgRBqKqqeuGFF1QqVWxsbEZGhvkK5uqsJyAgoKKiQvEbuVytVg8aNMjLyyskJOSVV16RYkzSOitWrPDx8UlLS1u7dq2Pj498CE3ab2Vl5fTp0729vQcMGHD+/HmTTeLj4y1Pn79x48aQIUNUKpXx+5Tr228D563O9eu7XvWdN6CNILQEOLi77777yJEj1dXV169ff+mll+QHI9OmTbt06VJ1dfXp06dHjhwpFbq4uLz66qsXL16sqak5d+7c448/LpWbPE6pc1tjnp6eb7755htvvGGyeYcOHf7xj3+UlJTcunVr1qxZcvmbb7755ptvenh4WPHAeUOcM7NR1pL8E0vWEgDAXt5+++3a2trz589fu3bNy8urpKREKp83b15ERERGRsbly5cjIiLmzZsnlUt/vPLy8tLT0zdu3Cg/e8vOzpYWib+Rd5GYmGieSjNnzpyAgICCgoJDhw7t2rVLsCDdps56pAab73TWrFnLly+vra29evXqqFGjZs2aJe9Cr9f/85//HD9+/Pnz5//5z382+viwvvaHhYWVlJTs3bv3xx9/NFlq0piGrVu3bvPmzVevXvX29p49e3aj+63vvNW5fn3Xq77zBrQRDOwEADiaoqKi0tJS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8XUAAC+YTKYhrisRQlyuF2kwGIYmE1/xqxUwGYOaVcC9R34CpSUAAPALd+7cIbgbDmBwLFmypKKighCiVquVSuXSpUu5+6ekpFRXV7e1tVksFna7SqWKj48PDw9vbm7esmULe1dISIhSqTSZTIcOHZozZw53HA4O43iKe1z311rKysratGmTyWRqb2/fuHEj0z4E1wFg2GtpaVm8eLFYLB47duysWbOOHj3KLANHCDl37tyzzz6rUCgUCkV6enpLSwuzi74FTKfTPfvsswKBQCAQ0IusMSZOnEjfI8YsfDZ79mx2h4sXLzq7j2zv3r3333+/SCRaunSpXq+37+bs2J/97Gc2g9r0qa2tVSgUY8aMEYlE8+bNY6YP0z23bt1KLxtXUlIiFAptzsilK1euPPXUU6NGjbK/Ghw50/cMUhQ1bty49PT048eP//znP3f/jDjeI8K6U6++vv6RRx6JiYk5ePCgs2j0y/vvv9/lmXJk5TIy85WzePFioVD4wAMP7N69mx3c2XsEbrECAADwzWKxXLx48cKFCwaDge9chjlCSGxsLN9ZDIqHH3543LhxfGfhpby8vNLSUq8Pz8nJqaysZLdIpVL2S51O98orr0RFRUVFRb3wwgvt7e10u7OPhf39/SUlJffee++4cePmzp3L5LZ3796JEyeOHTs2JSXl3Llz7KP27t0bEhIiFArT09MvXLjAHYeDwzgOU7Xftv40XYt73NjY2Pj4eDeuq1Wn02VnZwuFwmnTpn333XfMKENwHWAgOjo6hEKh+/2ffvrpffv2DV4+YLVaS0tL8/LymJfNzc333nvv73//e5VKZTQar1279u///u8RERHM3oSEhMuXL9Mvf/jhh+nTp58/f545nBDy8ssvnzhxwmKx0N909iO6/FXXvsPJkycffPDB//mf/+nr6zt58iS9LJqbx3K3Hzt2LDU19e9//7ter+/p6fnyyy8ff/zx06dPM0e98cYbu3fvjoyMfPPNN3fv3u3wjDhOZN68eX/72984robD3EJCQvbu3Wu1Ws1mc1dX1x//+MeoqCg3z8jle0Qf++GHH/7mN79RqVQWi2XJkiV0++eff/7ss8+ye+r1+kmTJqnVardO2HlWLiMTQt55551Dhw7duXPnypUrTz755JEjR+hd3O8RTSqVtra2ciTmssMwhtISAADwr7e398KFC8wHFBg8KC35J5+XlgBGMpSW/JBNaWnRokU7d+501nnhwoV1dXXslrq6ul/84hfMS0LIrl272C/tg3hRWpo3b94XX3zBvNyzZ4+vSktPPvnkDz/8wG75/vvv58yZwxx169YteuP27dvuJG8z6LfffutFbmFhYYcOHaKH5gjusN3le0QfW19fz7zs7+9ntmfMmPHXv/6Vebl58+a33nqLIw03s3IZmRDy3//938zLU6dOJSUl0dvc7xENpSUOuCEOAAD4h2fDAQAAjBzHjx9PSUnh2Pv444+zWxITE48dO8Zuee6553ye1d/+9jf2uE899ZSvIp86deq+++5j37E1bdq0xsZGpkN4eDi9ERYW5kX8Rx55xIujvvnmm/Ly8qioqIkTJ86fP3/JkiXur2HkzntECElOTma2g4ODme0NGzasWbOG3jYYDL/73e/eeustL07BnsvIs2bNYranTZt26tQpetvlewTcUFoCAAD++W1pqaur6/r16yaTie9EAAAAhg+z2exwqSOGlfM22IAzduxYmxkxVqu1t7eX36wefPDBo0ePGgyGK1euHDx4cPfu3StWrHD/8IG8R//8z/8cHBx89OhRQkhNTc38+fNlMpn7Q/swskAgoDf88z0KICgtAQAAz8xmM/0wDj98PJxOp9PpdAH9cRbA38hkMsqOr36pAICA8MQTT3z++efO9s6ePfubb75ht5w8eTIpKWmws4qPjz99+jTz8siRIwMMyDxrbP78+f/1X/81wGhDoK6ujrsDc0YDf482bNjw9ttvG43GDz/8sKioyNNUHWblTmT2RKTvv/8+Li6O3g6U98hvobQEAAA8o58NJxAIRo0axXcutlBUAvC5zs5O+zUaOjs7+c4LAIZOSUnJr3/9a3oF5Tt37rS0tFRXVy9fvpzeu3HjxrVr1zY2Nvb39/f39zc2Nq5bt479lMZB8u6777711lsXLlwwmUyNjY1fffWVpxHoZ0QSQq5fv15ZWTljxgy6vbS0tKqq6v333//xxx9NJpNGo/nzn/88f/58H5+Ah6Kiovbt29fd3U2/bGxsDAkJsenj7IwG/h7Fx8ePHz8+IyNjzpw50dHRHmXuLCt3Il++fLm+vt5gMFy7dq2wsPCdd96h2/3zPQogKC0BAADP6MnGfng3HIN70j4AAAB4JDExUalUbty4USwWR0dHP//88319fb/7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l8lkcrncV/F4ri+pmYyMjA8//HDr1q1arXbXrl0OZ71aayk/P//VV1+VSCTbtm1LS0vjrpyenr5nz5733nvPYDAUFBT0LnhCJBKVlJQsXLjw9OnTOTk558+f70trAEMO1lrqE4vFUlJSQtP0b3/725dffvnRRx8NCQkRCARBQUGxsbFz5sxZv379MM4r2Wy2I0eOWK3WKVOmvPrqq7/+9a9HjRolFArJPutPP/30+vXrkVcCAAAAABiZlEqlQwmPxyNjhZgDiqJ2795dW1srl8uTk5NfeeUV6pfjichc8h77IpesXLlyyZIl8fHxer1+x44d3P3u2LGjoaEhPDx81qxZixYt6jFOpsThK0VRZOkluVxeUFBQWFjo2eMBGD7wIXmfXLt2raura/To0c8884zLCoGBgUuWLHEub21tLS8vr66u7ujoEAqFarV6+vTpZEsCBjMv7Keffvr73/+u1Wr5fP7o0aNnz54dGRnZ6wb/9Kc/Xb169X//93+bm5stFsuf/vQniqI0Gs21a9fu3bvX2trK4/FkMtmECRNmzZrF/en6P//5z7a2tsjIyJSUFJfDTcVi8QsvvMC89KQXZh4ce0Icc9y7OImampry8vKampru7u6goKDRo0fPnDkzJibGodrt27cvXrxYX19P03R4eHhiYmJiYiLm6IF/GQwGrVYbERGB1XkAAABgCGlsbHQocZkkkkgkBw8ePHjwoMs6V69e9aQv5iqX45tc9hscHJyfn5+fn2+xWE6cOPHYY49x12cXOlRITU311VQ+gKEIqaU+uX37NkVRU6dO9eqq6urqoqIi5keP1Wq9e/fu3bt3f/Ob3zz77LMOlb/77rtLly6xe7x///6//du/MTOZvW3wm2+++fHHHx0K8/Pz2S+bm5ubm5srKip+//vfc7yVrayspChqxowZHq4U2LtefNLClStXSktLmV8Aer2+oqLi559/XrhwYWJiIlPthx9+IHtDEHV1dXV1dc57pgIMMJ1OZzabu7q6kFoCAAAA8KF33nln+/btYrE4JSXl7Nmz/g4HYKhCaqlPSNIhNjbW80s6Ojq++uors9n8xBNPzJw5MywsrLu7+8aNG+fOnTt//nxCQsKYMWPY9f/+978nJSU9+eSTUqm0oaHh+PHjLS0tFy5cYEYDedvg1atXZ86cOXnyZIVCwaSEHnnkkcTExNGjR0ulUrPZXFdXd/bsWY1Gc+HChfnz57u7l/r6eoqiHNrn4EkvW7du5Rgi1Ls4GxoaysrKaJp+8sknZ82aNWrUqLa2tgsXLly7dq20tDQ2NpaM1G1oaDh58iRFUVOnTp05c2ZoaGhHR0d5eblXe1IA9Ae1Wt3a2uqXdRMAAAAAhrFt27Zt27bN31EADHlILfWJwWCgKMp5v3DntAhT8sMPP5hMpl//+tepqamkRCwWz5w5UyAQlJWVXb582SFTk5SUxMy2Gz169IIFCz777LN79+4xFbxtcOrUqfPmzXMIb+XKlcxxUFBQQkJCeHj4nj17bt26xZGy6erqoigqJCTEXQWf9NL3Fv7+97/b7fbx48c///zzpCQsLOyFF17Q6/VVVVU//PDD4sWLKYq6fPmy3W5/7LHHFixYQKrJ5fIFCxZ0dXVVVFR4eI8A/UEgEISHh/s7CgAAAAAAABeQWhpoVVVVFEVNnz7dofzxxx8vKyurqalxKHdYBjs6OpqiqM7Ozl43OGXKFOeoyPCcO3futLX9P/buPc6p8k78+HNynUkmk0lmMvcBQQUUtRWBqoVqRaXg6iqieCuLsO22vkRaXgVR0ddPFxEXrK3sbusK1b66qy9a25Fa0WqrrVSs1GtFFAVUmMx9ksxMkklOkpPfH6fGmJlkMteTZD7vP+aVPOc5z/M9J+Kc+ea5+JInCXd3d2dxTdkaeS/Da+HTTz8VQsybNy+lfP78+YcPH07k6dQX5557bkq1c845h9QSAAAAAAADIrU0IhaLpaenp7e3N2WiyoBLUKu8Xq8QQt3bsv86cOo4oGRlZWXJb81msxAiFosNu8H+c2o6Ojp+9rOf9fX19b/AaDTavzDBarV2d3f3v/wBDbuXkbfQ09MjhHC5XCnl6jy4RJ5OrZa8iJWK0SLIfYqiZLnkGQAAAACMLlJLI1JTU9PT0/Ppp59mvwaKmvFRFGXAo8k5I1Xyvpuj0qDRaEwp+cMf/tDX11dXV7dgwYKqqqri4mKdTheNRjdt2pS565qamu7u7iwvf9i9jGILQEHq7u72eDyVlZVWq1XrWJCtaDTa2dkZjUb771MJAAAA5BdSSyMyffr0Q4cOvfbaa2eccUaWQwbsdntXV9fq1av7j44ZnpE3qE4EW7p0aXKGqKura9ATp0+f/sEHH/z1r3/N5vKH3cvIWygtLfV4PB0dHZMmTUoub29vF0lrRanVurq6Uv7S6+zszD5IYPx1d3dHo9Hm5mabzeZyufR6vdYRYXA6nc7v98fj8Ugk0j/jDwAAAOQRJlCMyBlnnFFaWtrS0rJnz55044ZSTJs2TQjxyiuvjFYMI29QHdlkMHwhz7hv375BTzzjjDPKyspaW1vTXb4sy0899dRQe1HrhMPh0YpTXci8/y36y1/+IoQ44YQT1Lfqi/4Nvvrqq4N2AWiooaHB6XRKktTb2/vJJ5/4fD6tI8LgdDqdOsFZ3Q4CAAAAyF+klkbEYDBcddVVer3+9ddf/5//+Z8333yzq6srEokoihIMBo8ePbp79+6UU84991yLxfLmm28+8cQTR44c6e3tVRQlFAo1Nzfv27fv4YcfHmoMI2+wqqpKCLF79+6Ojo5IJNLe3r579+533nln0BP1ev3SpUsNBsPrr7++Y8eOv//9793d3bFYLBwOt7S0/PnPf/7xj3/89ttvD7UXu90uhHjrrbeSF+oeSZxf+cpXdDrdoUOHnn76aY/HE4vFPB7P7t27P/roI71en1gBfe7cuTqd7uDBg3v27PF6vbFYzOv17tmzhzW8keMkSSovL29oaCgqKlIUpaOjo6mpKeWfD3KQxWIRpJYAAPiMJEmDLgYydl1nODTyqLS6LmDcMCFupBoaGlasWPHkk0+2trb+9re/7V/BZrMtXrw4+e111123a9euQ4cOHTp0aOQBjLzB888///HHHz98+LC62Zxq7ty5+/fvH/Tc+vr6FStW/OpXv2pubv7Nb36TctRkMl1++eVD7eXUU0/du3fvc88999xzz6kl6lLow46zurp60aJFe/bseeONN954441EuSRJixcvVjNWarWLLrro97///f79+5PbnD179uuvv84kI+Q4s9lcX1/v9Xo9Hk9fX9/x48fLy8tT9gFATrFarR6Ph9QSAKCA1dTUtLS0ZFk5Ho9rlYJJ3g2p/6GRR5Wh/RQ2my15N3AgXzBqaRQ0NDSsXr36sssumz59emlpqcFgMBqNdrv9lFNOufzyy9esWXPKKack16+vr7/pppsWLFhQX19fVFSk0+mKiorq6urOP//8m266aRgBjLDBk08++brrrmtoaDAYDCaTqa6u7rLLLktOhw3a++rVqy+99NJp06apl282m2tqas4777w1a9Z8+ctfHmov55133rx585xOZ0o2ZyRxzpkz58YbbzzllFOsVqtOp7NaraeccsrKlSvPOuus5GrnnHPO9ddff8IJJ5hMJpPJVFtbe+mlly5YsEB8tjcfkMskSXI6nZMmTSouLk4MX4pEIlrHhYEVFRXp9Xp1nKnWsQAAMCZaW1uT34ZCoTVr1lRVVdXU1Dz22GPqyh6ZrV69evr06Var9aKLLnrppZfUwsbGRpPJJElSaWnpvHnzEu2kK89gz549/cclBQKBFStWlJSUnHnmmQcOHEg5Ze7cuXPnzh205QztqyXbt2+vr683mUyNjY1qudPp9Pv90mey7ALIBVL2CVRgYjpy5MgvfvGLhoaGVatWaR0LkK3u7u7Ozk5FUXQ6ncvlKi0t1ToiDKClpcXv95eXlzudznHrdN68eXfeeefChQvHrcdxY7fb/X5//61RAWDiqK6ufvjhhzXZfjQej8+ZM8fv9ydvWStJX/h7c+3atX19fffcc09JScnvfve77373uykb5qTUF0L4/f6SkpJIJPLyyy9ffvnl6ogem8120UUX/fKXv5Rl+fnnn//2t7+d2J9nwPJBpfR7880322y2u+++u6en55FHHrn99tuTj86ZM0cI8be//S37m9P/uiRJ2rBhw2233fbHP/5x2bJliaUM+tdE/tqyZYvb7d6+fbvWgYwHJsQBmcTj8b179wohpk6dqnUswBDY7Xar1dra2trX19fW1tbb21tVVZWyCj40Z7FY/H5/MBgcz9QSAKCATZ48ee3atVpHIerq6pqbm9XX6uib2tpat9v9xBNPvPfee+pvvauuuuqqq67K3M5HH320du3affv2hcPhWbNm+f1+tfzxxx+/8sorjUZjRUWFy+V65plnMpcPlboKh8lkqqio+Pa3v3377bcnHx1SUimD++67TwhxxRVXMMYcBYA/M4DP/exnPzvrrLPq6ursdruiKM3NzS+//PInn3xiMplmzZqldXTA0BgMhvr6ep/P19nZGQwGP/3008rKSpvNpnVc+Jy6kncoFFLHl2kdDgAg77322mtadR2PxxO/y9xut/oiZQxONBodUptXX331Nddcs3PnTqfT2dnZWVNTo5ZfeumlsiwHAgGPx/O///u/F198sdfrzVA+EhpujSLLsslk0qp3YEh4kAU+d+zYscbGxv/8z/+8995777vvvp///Ocff/yxXq//53/+Z3XfOiDv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eOKJzzzzzIwZM4QQBw8enDlzpvoP/5RTTnnqqaemT58uhGhra/vKV77yySefCCEkSWppaamurhZCBIPBioqKYDCYuf4nn3wyefLk/l339PTMnDnz+PHjYrBNIk4++eTGxsbTTjstXYUsmxqw2oknnvj000+feuqpQogDBw5cfvnlhw8fznBnkhUXF3d1dVksFvVtos2TTjrpt7/9baLN008/PXFuIBBwuVzqTRshv9+/dOnS3//+9+pbk1sSZ20AACAASURBVMlksViS91X5+OOP+d84kGAymcLhsNZRAMBEFE/aIU7rWICcMKF2iCO1BBS+4uJin8+nzqUKhULFxcXqP3yLxZL8Jb9Op1M37ZbSbOyaob6iKInZyK+//vqtt9761ltveb1eIYRer1d3A8mcWiouLvZ6vSljYbJsatBqyY2HQiGHw6FeSLo7k2zq1KnPP//8SSedlHI3UtpMPvejjz76xje+ceTIkUyfylC8+OKLt91228GDB4PBoNVqbWlp0fChLRQKNTc3x2Ixk8lUV1dnMDD6dZT19va2trYajcYTTjhhLNqfN2/enXfeuXDhwrFoHAAwYZFaSlFVVdV/kcrKysq2tjZN4sH4m1CpJZbxBgpfbW3txx9/rL4+evRoonzSpEnqmBeVmifKIEP95CX6rrnmmn/5l385fPhwNBrt6uoatFlVQ0ODOpIoWbqmUtZHHLTH2traxIUfPny4rq4uUT7gnUk2e/bsV155pX95XV1d4pSULNIrr7wywv0vUlxwwQWvvfba008/fdZZZ/X29v7kJz8ZxcaHqqioqL6+3mAwyLLsdruz/HyRPavVarfbq6qqtA4EAAAMX1tbW//1aMgroVCRWgIK37XXXrt27drm5ubm5ua1a9cmyr/73e9+61vfev/992VZfvfdd6+55prM7WRZPxAIlJaWWq3WTz/99Nvf/naWQa5YsWL16tVHjx71er3f//73MzdVUVHx/vvvZ9/jtddeu2bNmqampqampjVr1lx77bWJ8gHvTLJLL730ySef7F9+3XXXff/733e73W63+3vf+17yoSeffDJl85FRcf755+/fv/9Pf/rT/v37R2W23bCZTKaGhgaj0SjL8vHjx9UxYhgtOp2usrKyuLhY60AAAACArJBaAgrfxo0bGxoaTjvttDPPPPOrX/2q0WhUy1evXn3ZZZctWbKktLT0+uuvTyRc0smy/s6dOzds2GCz2b7+9a+fd955WQa5bt26c88997zzzjvxxBMnTZqUuakNGzace+65ibFLg/a4cePGU045Zfbs2bNnz545c+Ydd9yR+c4ku/LKK//6179++OGHKeV33HHH1KlTTz/99FmzZl188cWJ8kOHDu3fv/+KK67I8sKH6rzzzvvlL385YKjjyWAw1NfXG43GSCTS1NREdgkAAACYsFhrCZhY/v73v19++eXpJn9NZBnuzH333feXv/zlmWeeyaadSy65ZP78+Rs2bBjtAHNRNBptamqKRCJGo1GdJad1RBgcay0BAMYCay0BKVhrCUCh+f73v9/a2vrpp5+uXbv28ssv1zqcHJLNnbntttuyzCsJIZ555pkJklcSn41dMhgMjF0CAAAAJixSS8CEcMIJJ8yZM2fu3LlTp07dtGmThpFIA9Ewnty5M3kqObvkdrvJLgEAAM1p9Xip7WMtoCEmLwATwpo1a9asWaN1FEIIkWuTcHPnzuQvo9FYW1vrdrtlWW5paamrq9Pp+N4CAACImpqalpaWLCsHg0GLxTIq/Wr1wJl9vzabrbe3d0yDAcYTT/8AgJEym811dXV6vT4UCrW0tORaAhEAAGiitbU18TpluHry246Ojjlz5lit1qqqqptvvjmxE65awefzrVq1ymazrVu3Ti1vbGw0mUySJJWWls6bN2/atGmJXvbs2dN/UHwkEtmwYcP06dOnTZu2fv16WZaT29++fXt9fb3JZGpsbEw+a+7cuXPnzs3ySgfsN137TqfT7/fnwvh9YLSQWgIAjAKz2VxbW6vT6YLBoMfj0TocAACQW+Lx+Nlnn71v3z717b59+8455xz166h169Zt27ZNluUjR44sWLAgkUJSjy5ZsmT+/Plut/sb3/iGWr58+fJ/+qd/ikQira2tP/jBD3w+X6KXxYsX9/+Ka+PGjXV1dYcOHfrwww/r6uo2btyY3H5zc/PBgwd37dq1bNmylICz/7ZswH7Tta8+KcU/k2UXQC5jhzgAwKgJBAI+n6+mpoY5caOip6fH6/WWlZXZ7fbRapMd4gAAYyF5h7i6urrm5ubko+rc+eeff37r1q0vvPCCEOKiiy5av379RRddJIQoLy9P/l7K5XK1t7erryVJ6u3tLSkpSW7t6aefvvLKKyORSEVFhcvl+vnPfz5n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8YYNGxRFWbVq1Wuvvdbb2xsIBPbv3/+v//qviqLceuutDz30UKJy/IsyFPY/pb29/amnnpo6dWpbW9vGjRuT66xfv/69996rq6t79NFHjx8/Hg6HfT7fq6++unnz5jPOOGNIl5N9hEPt9IILLgiFQo8//nhy4f/93/+FQqEFCxZkGd7pp59+zz337N271+PxhMPhd99998ILL+zu7v7e9743pucWHkYtAQAwiI8//jgajTY0NBQVFWkdCwAAKFjHjx8/6aSTZFn+2c9+duONN6YcffTRR1euXGkymY4cOVJfX9//9OThQlkefeWVV+bNm1dZWdnW1pYoLC8v93g8r7766tlnnz2Mq8gQRoZD2XeqNvL4449fd911s2bNeuONNxKHZs2a9dZbbz3xxBPXXnttuo4ya2pqamhoKC4uDgaD43luvmPUEgAAg2C5JQAAMA5++tOfyrK8dOnS/nklIcSNN9545ZVXyrL805/+dLR6/NKXviSE6O7uTi4MBAJCiJNPPnm0esnGUDtdsmSJ0+l888033377bbXkrbfeeuutt5xO5xVXXDHsMNT9W1wu1zifm+9ILQEAMAhSSwAAYBy88MILQohvfetb6Sqoh/7whz+MVo9vvvmmECJlDNSZZ54phFi1atXhw4dHq6NBDbVTs9msLuO9c+dOtUR9ccMNN5jN5mEEEIvFPvzwQ/UO33TTTeN2bmFgQhwAAINobW3t7e2tqKhwOBxaxwIAAAqW0+n0er1dXV1Op3PACp2dnS6Xq7y8vLOzs//RIU2I6+zs3Lt379q1az/55JO77rrr7rvvTtTcu3fvxRdfHAqFhBBTp0798pe/fNppp33ta187//zz1e/bMhvehLjsO0008s4773z5y192OBzNzc1CiJqaGp/P984775xxxhmZb0W6wIQQdXV169evv+WWW7I8cYTnFgxSSwAADKKjo8Pn8zkcjoqKCq1jAQAABctoNEaj0f/f3t0GRVW2ARw/C4cFFNR4CcdQBJFRaHxJ1DGFRgd1fJl0RNKlQc2ssNGsMc1whkpHJfvilFnqqIkjU2pAkKYIigxmCjhomoYhogGJ8rqLwCzseT7s85xnZ5c9LIuxov/fB2f3frnu69x8ca895169Xm98tMqSXq9Xq9WiKOr1esteW0pLljQazcGDB11cXEwbb968uXXr1vT0dK1WKzf6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
<?xml version="1.0" encoding="utf-8" ?>
<otrs_config version="1.0" init="Config">
    <ConfigItem Name="Frontend::Module###AdminITSMConfigItem" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Admin::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>admin</Group>
                <Description>Admin</Description>
                <Title>Config Item</Title>
                <NavBarName>Admin</NavBarName>
                <NavBarModule>
                    <Module>Kernel::Output::HTML::NavBarModuleAdmin</Module>
                    <Name Translatable="1">Config Items</Name>
                    <Description Translatable="1">Create and manage the definitions for Configuration Items.</Description>
                    <Block>Ticket</Block>
                    <Prio>495</Prio>
                </NavBarModule>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItem" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <GroupRo>itsm-configitem</GroupRo>
                <Description>ITSM Config Item Overview</Description>
                <NavBarName>Config Item</NavBarName>
                <Title>Config Item</Title>
                <NavBar>
                    <Description>Configuration Management Database</Description>
                    <Name>CMDB</Name>
                    <Type>Menu</Type>
                    <Block>ItemArea</Block>
                    <Link>Action=AgentITSMConfigItem</Link>
                    <NavBar>Config Item</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>3200</Prio>
                </NavBar>
                <NavBar>
                    <Description>Overview</Description>
                    <Name>Overview</Name>
                    <Link>Action=AgentITSMConfigItem</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>Config Item</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>100</Prio>
                </NavBar>
                <Loader>
                    <CSS>ITSM.Agent.Default.css</CSS>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemZoom" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <GroupRo>itsm-configitem</GroupRo>
                <Description>Config Item Zoom</Description>
                <Title>Zoom</Title>
                <NavBarName>Config Item</NavBarName>
                <Loader>
                    <CSS>ITSM.Agent.Detail.css</CSS>
                    <CSS>ITSM.Agent.Default.css</CSS>
                    <CSS>ITSM.Print.css</CSS>
                    <CSS_IE7>ITSM.Agent.Detail.IE7.css</CSS_IE7>
                    <JavaScript>thirdparty/jquery-tablesorter-2.0.5/jquery.tablesorter.js</JavaScript>
                    <JavaScript>Core.UI.Table.Sort.js</JavaScript>
                    <JavaScript>ITSM.Agent.Zoom.js</JavaScript>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemEdit" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>itsm-configitem</Group>
                <Description>Config Item Edit</Description>
                <Title>Edit</Title>
                <NavBarName>Config Item</NavBarName>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemPrint" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <GroupRo>itsm-configitem</GroupRo>
                <Description>Config Item Print</Description>
                <Title>Print</Title>
                <NavBarName>Config Item</NavBarName>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemAdd" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <Group>itsm-configitem</Group>
                <Description>Config Item Add</Description>
                <Title>Add</Title>
                <NavBarName>Config Item</NavBarName>
                <NavBar>
                    <Description>New</Description>
                    <Name>New</Name>
                    <Link>Action=AgentITSMConfigItemAdd</Link>
                    <Type></Type>
                    <Block></Block>
                    <NavBar>Config Item</NavBar>
                    <AccessKey></AccessKey>
                    <Prio>200</Prio>
                </NavBar>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemSearch" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <GroupRo>itsm-configitem</GroupRo>
                <Description>Search Config Items</Description>
                <Title>Search</Title>
                <NavBarName>Config Item</NavBarName>
                <NavBar>
                    <Description>Search Config Items</Description>
                    <Name>Search</Name>
                    <Link>Action=AgentITSMConfigItemSearch</Link>
                    <LinkOption>onclick="ITSM.Agent.ConfigItem.Search.OpenSearchDialog('AgentITSMConfigItemSearch'); if (event.stopPropagation) { event.stopPropagation(); } else { window.event.cancelBubble = true; } return false;"</LinkOption>
                    <NavBar>Config Item</NavBar>
                    <Type></Type>
                    <Block></Block>
                    <AccessKey></AccessKey>
                    <Prio>300</Prio>
                </NavBar>
                <Loader>
                    <CSS>ITSM.Agent.Detail.css</CSS>
                    <CSS>ITSM.Table.css</CSS>
                    <CSS>ITSM.Print.css</CSS>
                    <CSS_IE7>ITSM.Agent.Detail.IE7.css</CSS_IE7>
                    <JavaScript>thirdparty/jquery-tablesorter-2.0.5/jquery.tablesorter.js</JavaScript>
                    <JavaScript>Core.UI.Table.Sort.js</JavaScript>
                    <JavaScript>ITSM.Agent.Zoom.js</JavaScript>
                </Loader>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###000-Back" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">Back</Item>
                <Item Key="Description">Back</Item>
                <Item Key="Action"></Item>
                <Item Key="Link">Action=AgentITSMConfigItem;ClassID=$QData{"ClassID"}</Item>
                <Item Key="Target">Back</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###200-History" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">History</Item>
                <Item Key="Description">History</Item>
                <Item Key="Action">AgentITSMConfigItemEdit</Item>
                <Item Key="Link">Action=AgentITSMConfigItemHistory;ConfigItemID=$QData{"ConfigItemID"};VersionID=$QData{"VersionID"}</Item>
                <Item Key="Target">PopUp</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###300-Edit" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">Edit</Item>
                <Item Key="Description">Edit</Item>
                <Item Key="Action">AgentITSMConfigItemEdit</Item>
                <Item Key="Link">Action=AgentITSMConfigItemEdit;ConfigItemID=$QData{"ConfigItemID"}</Item>
                <Item Key="Target">PopUp</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###400-Print" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">Print</Item>
                <Item Key="Description">Print</Item>
                <Item Key="Action">AgentITSMConfigItemPrint</Item>
                <Item Key="Link">Action=AgentITSMConfigItemPrint;ConfigItemID=$QData{"ConfigItemID"};VersionID=$QData{"VersionID"}</Item>
                <Item Key="LinkParam">target="print"</Item>
                <Item Key="Target">PopUp</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###500-Link" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">Link</Item>
                <Item Key="Description">Link</Item>
                <Item Key="Action">AgentLinkObject</Item>
                <Item Key="Link">Action=AgentLinkObject;SourceObject=ITSMConfigItem;SourceKey=$QData{"ConfigItemID"}</Item>
                <Item Key="Target">PopUp</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::MenuModule###600-Duplicate" Required="0" Valid="1">
        <Description Translatable="1">Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::MenuModule</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemMenuGeneric</Item>
                <Item Key="Name">Duplicate</Item>
                <Item Key="Description">Duplicate</Item>
                <Item Key="Action">AgentITSMConfigItemEdit</Item>
                <Item Key="Link">Action=AgentITSMConfigItemEdit;DuplicateID=$QData{"ConfigItemID"};VersionID=$QData{"VersionID"}</Item>
                <Item Key="Target">PopUp</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::NumberGenerator" Required="1" Valid="1">
        <Description Translatable="1">Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Option Location="Kernel/System/ITSMConfigItem/Number/*.pm" SelectedID="Kernel::System::ITSMConfigItem::Number::AutoIncrement"></Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::CINameRegex" Required="0" Valid="0">
        <Description Translatable="1">Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Computer::CINameRegex">^ABC.*</Item>
                <Item Key="Computer::CINameRegexErrorMessage">A computer name must start with ABC!</Item>
                <Item Key="Hardware::CINameRegex">.*\d\d$</Item>
                <Item Key="Hardware::CINameRegexErrorMessage">A hardware name must end with two digits!</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="LinkObject::DefaultSubObject###ITSMConfigItem" Required="1" Valid="1">
        <Description Translatable="1">Defines the default subobject of the class 'ITSMConfigItem'.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::LinkObject</SubGroup>
        <Setting>
            <String Regex="">Computer</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="LinkObject::ITSMConfigItem::ShowColumnsByClass" Required="0" Valid="0">
        <Description Translatable="1">Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::LinkObject</SubGroup>
        <Setting>
            <Array>
                <Item>Computer::Name</Item>
                <Item>Computer::CurDeplState</Item>
                <Item>Computer::HardDisk::1</Item>
                <Item>Computer::HardDisk::1::Capacity::1</Item>
                <Item>Computer::HardDisk::2</Item>
                <Item>Computer::HardDisk::2::Capacity::1</Item>
                <Item>Computer::HardDisk::3</Item>
                <Item>Computer::HardDisk::3::Capacity::1</Item>
                <Item>Computer::WarrantyExpirationDate::1</Item>
                <Item>Computer::CreateTime</Item>
                <Item>Location::Type::1</Item>
                <Item>Location::Address::1</Item>
            </Array>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Stats::DynamicObjectRegistration###ITSMConfigItem" Required="0" Valid="1">
        <Description Translatable="1">Module to generate ITSM config item statistics.</Description>
        <Group>Framework</Group>
        <SubGroup>Core::Stats</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::Stats::Dynamic::ITSMConfigItem</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ImportExport::ObjectBackendRegistration###ITSMConfigItem" Required="0" Valid="1">
        <Description Translatable="1">Object backend module registration for the import/export module.</Description>
        <Group>ImportExport</Group>
        <SubGroup>ObjectBackend::ModuleRegistration</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem</Item>
                <Item Key="Name">Config Item</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::EventModulePost###100-History" Required="0" Valid="1">
        <Description Translatable="1">Config item event module that enables logging to history in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::ITSMConfigItem::Event::DoHistory</Item>
                <Item Key="Event">(ConfigItemCreate|VersionCreate|DeploymentStateUpdate|IncidentStateUpdate|ConfigItemDelete|LinkAdd|LinkDelete|DefinitionUpdate|NameUpdate|ValueUpdate|DefinitionCreate|VersionDelete|AttachmentAddPost|AttachmentDeletePost)</Item>
                <Item Key="Transaction">0</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::HistoryOrder" Required="1" Valid="1">
        <Description Translatable="1">Shows the config item history (reverse ordered) in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::ViewHistory</SubGroup>
        <Setting>
            <Option SelectedID="normal">
                <Item Key="reverse">reverse</Item>
                <Item Key="normal">normal</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Module###AgentITSMConfigItemHistory" Required="0" Valid="1">
        <Description Translatable="1">Frontend module registration for the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ModuleRegistration</SubGroup>
        <Setting>
            <FrontendModuleReg>
                <GroupRo>itsm-configitem</GroupRo>
                <Description>Config Item History</Description>
                <Title>History</Title>
                <NavBarName>Config Item</NavBarName>
            </FrontendModuleReg>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="GeneralCatalogPreferences###DeploymentStates" Required="0" Valid="1">
        <Description Translatable="1">Parameters for the deployment states in the preferences view of the agent interface.</Description>
        <Group>GeneralCatalog</Group>
        <SubGroup>GeneralCatalog::Preferences</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::GeneralCatalogPreferencesGeneric</Item>
                <Item Key="Class">ITSM::ConfigItem::DeploymentState</Item>
                <Item Key="Label">Deployment State Type</Item>
                <Item Key="Desc">Deployment State Type.</Item>
                <Item Key="Data">
                    <Hash>
                        <Item Key="postproductive">postproductive</Item>
                        <Item Key="preproductive">preproductive</Item>
                        <Item Key="productive">productive</Item>
                    </Hash>
                </Item>
                <Item Key="PrefKey">Functionality</Item>
                <Item Key="Block">Option</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Permission::Class###010-ClassGroupCheck" Required="0" Valid="1">
        <Description Translatable="1">Module to check the group responsible for a class.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::ITSMConfigItem::Permission::ClassGroupCheck</Item>
                <Item Key="Required">0</Item>
                <Item Key="Granted">1</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Permission::Item###010-ItemClassGroupCheck" Required="0" Valid="1">
        <Description Translatable="1">Module to check the group responsible for a configuration item.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::System::ITSMConfigItem::Permission::ItemClassGroupCheck</Item>
                <Item Key="Required">0</Item>
                <Item Key="Granted">1</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItem###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the ITSM configuration item screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">ro</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemEdit###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the edit ITSM configuration item screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">rw</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemAdd###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the add ITSM configuration item screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">rw</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemHistory###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the history ITSM configuration item screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">ro</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemPrint###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the print ITSM configuration item screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">ro</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemZoom###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the ITSM configuration item zoom screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">ro</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemSearch###Permission" Required="1" Valid="1">
        <Description Translatable="1">Required permissions to use the ITSM configuration item search screen in the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItem::Permission</SubGroup>
        <Setting>
            <String Regex="">ro</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AdminITSMConfigItem###EditorRows" Required="1" Valid="1">
        <Description Translatable="1">Defines the number of rows for the CI definition editor in the admin interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Admin::ViewConfigItemDefinition</SubGroup>
        <Setting>
            <String Regex="">30</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="GeneralCatalogPreferences###Permissions" Required="0" Valid="1">
        <Description Translatable="1">Parameters for the example permission groups of the general catalog attributes.</Description>
        <Group>GeneralCatalog</Group>
        <SubGroup>GeneralCatalog::Preferences</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::GeneralCatalogPreferencesGeneric</Item>
                <Item Key="Label">Permission</Item>
                <Item Key="Desc">Define the group with permissions.</Item>
                <Item Key="Block">Permission</Item>
                <Item Key="Class">ITSM::ConfigItem::Class</Item>
                <Item Key="PrefKey">Permission</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Frontend::Search###ConfigItem" Required="0" Valid="1">
        <Description Translatable="1">Configuration item search backend router of the agent interface.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::SearchRouter</SubGroup>
        <Setting>
            <Hash>
                <Item Key="^(?:Agent|Admin)ITSMConfigItem">Action=AgentITSMConfigItemSearch;Subaction=AJAX</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="Loader::Agent::CommonJS###100-ConfigurationManagement" Required="1" Valid="1">
        <Description Translatable="1">List of JS files to always be loaded for the agent interface.</Description>
        <Group>Framework</Group>
        <SubGroup>Core::Web</SubGroup>
        <Setting>
            <Array>
                <Item>ITSM.Agent.ConfigItem.Search.js</Item>
            </Array>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="PreferencesGroups###ConfigItemOverviewSmallPageShown" Required="0" Valid="1">
        <Description Translatable="1">Parameters for the pages (in which the configuration items are shown).</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::Preferences</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::PreferencesGeneric</Item>
                <Item Key="Column">Other Settings</Item>
                <Item Key="Label" Translatable="1">Configuration Item Limit</Item>
                <Item Key="Key" Translatable="1">Configuration Item limit per page</Item>
                <Item Key="Data">
                    <Hash>
                        <Item Key="10">10</Item>
                        <Item Key="15">15</Item>
                        <Item Key="20">20</Item>
                        <Item Key="25">25</Item>
                        <Item Key="30">30</Item>
                        <Item Key="35">35</Item>
                    </Hash>
                </Item>
                <Item Key="DataSelected">25</Item>
                <Item Key="PrefKey">UserConfigItemOverviewSmallPageShown</Item>
                <Item Key="Prio">8000</Item>
                <Item Key="Active">0</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::Overview###Small" Required="0" Valid="1">
        <Description Translatable="1">Defines an overview module to show the small view of a configuration item list.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ITSMConfigItemOverview</SubGroup>
        <Setting>
            <Hash>
                <Item Key="Module">Kernel::Output::HTML::ITSMConfigItemOverviewSmall</Item>
                <Item Key="Name">Small</Item>
                <Item Key="PageShown">25</Item>
                <Item Key="Image">overviewsmall.png</Item>
                <Item Key="ImageSelected">overviewsmall-selected.png</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Hook" Required="1" Valid="1">
        <Description Translatable="1">The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <String Regex="">ConfigItem#</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemSearch###SearchLimit" Required="1" Valid="1">
        <Description Translatable="1">Defines the search limit for the AgentITSMConfigItemSearch screen.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItemSearch</SubGroup>
        <Setting>
            <String Regex="">10000</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemSearch###ShowColumns" Required="1" Valid="1">
        <Description Translatable="1">Defines the shown columns in the config item search. This option has no effect on the position of the column.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItemSearch</SubGroup>
        <Setting>
            <Hash>
                <Item Key="CurInciSignal">1</Item>
                <Item Key="Number">1</Item>
                <Item Key="Name">1</Item>
                <Item Key="Class">0</Item>
                <Item Key="CurDeplState">1</Item>
                <Item Key="CurDeplStateType">0</Item>
                <Item Key="CurInciState">1</Item>
                <Item Key="CurInciStateType">0</Item>
                <Item Key="LastChanged">1</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemSearch###ShowColumnsByClass" Required="0" Valid="0">
        <Description Translatable="1">Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItemSearch</SubGroup>
        <Setting>
            <Array>
                <Item>Computer::Name</Item>
                <Item>Computer::Number</Item>
                <Item>Computer::CurInciSignal</Item>
                <Item>Computer::CurDeplState</Item>
                <Item>Computer::HardDisk::1</Item>
                <Item>Computer::HardDisk::1::Capacity::1</Item>
                <Item>Computer::HardDisk::2</Item>
                <Item>Computer::HardDisk::2::Capacity::1</Item>
                <Item>Computer::HardDisk::3</Item>
                <Item>Computer::HardDisk::3::Capacity::1</Item>
                <Item>Computer::WarrantyExpirationDate::1</Item>
                <Item>Computer::CreateTime</Item>
                <Item>Location::CurInciSignal</Item>
                <Item>Location::Number</Item>
                <Item>Location::Type::1</Item>
                <Item>Location::Name</Item>
                <Item>Location::Address::1</Item>
                <Item>Location::LastChanged</Item>
            </Array>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItemSearch###SearchCSVData" Required="1" Valid="1">
        <Description Translatable="1">Data used to export the search result in CSV format.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItemSearch</SubGroup>
        <Setting>
            <Array>
                <Item>Class</Item>
                <Item>Incident State</Item>
                <Item>Name</Item>
                <Item>ConfigItemNumber</Item>
                <Item>ChangeState</Item>
                <Item>Version</Item>
                <Item>Create Time</Item>
            </Array>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItem###SearchLimit" Required="1" Valid="1">
        <Description Translatable="1">Defines the search limit for the AgentITSMConfigItem screen.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItem</SubGroup>
        <Setting>
            <String Regex="">10000</String>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns" Required="1" Valid="1">
        <Description Translatable="1">Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter 'All' is selected.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItem</SubGroup>
        <Setting>
            <Hash>
                <Item Key="CurInciSignal">1</Item>
                <Item Key="Number">1</Item>
                <Item Key="Name">1</Item>
                <Item Key="Class">0</Item>
                <Item Key="CurDeplState">1</Item>
                <Item Key="CurDeplStateType">0</Item>
                <Item Key="CurInciState">1</Item>
                <Item Key="CurInciStateType">0</Item>
                <Item Key="LastChanged">1</Item>
            </Hash>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumnsByClass" Required="0" Valid="0">
        <Description Translatable="1">Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Frontend::Agent::ViewConfigItem</SubGroup>
        <Setting>
            <Array>
                <Item>Computer::Name</Item>
                <Item>Computer::Number</Item>
                <Item>Computer::CurInciSignal</Item>
                <Item>Computer::CurDeplState</Item>
                <Item>Computer::HardDisk::1</Item>
                <Item>Computer::HardDisk::1::Capacity::1</Item>
                <Item>Computer::HardDisk::2</Item>
                <Item>Computer::HardDisk::2::Capacity::1</Item>
                <Item>Computer::HardDisk::3</Item>
                <Item>Computer::HardDisk::3::Capacity::1</Item>
                <Item>Computer::WarrantyExpirationDate::1</Item>
                <Item>Computer::CreateTime</Item>
                <Item>Location::CurInciSignal</Item>
                <Item>Location::Number</Item>
                <Item>Location::Type::1</Item>
                <Item>Location::Name</Item>
                <Item>Location::Address::1</Item>
                <Item>Location::LastChanged</Item>
            </Array>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="UniqueCIName::EnableUniquenessCheck" Required="0" Valid="1">
        <Description Translatable="1">Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Option SelectedID="0">
                <Item Key="1">Enabled</Item>
                <Item Key="0">Disabled</Item>
            </Option>
        </Setting>
    </ConfigItem>
    <ConfigItem Name="UniqueCIName::UniquenessCheckScope" Required="0" Valid="1">
        <Description Translatable="1">Check for a unique name only within the same ConfigItem class ('class') or globally ('global'), which means every existing ConfigItem is taken into account when looking for duplicates.</Description>
        <Group>ITSM Configuration Management</Group>
        <SubGroup>Core::ITSMConfigItem</SubGroup>
        <Setting>
            <Option SelectedID="global">
                <Item Key="global">global</Item>
                <Item Key="class">class</Item>
            </Option>
        </Setting>
    </ConfigItem>
</otrs_config>

# --
# Kernel/Language/bg_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::bg_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = 'Административнен инструмент';
    $Self->{Translation}->{'Backup Device'} = 'Архивиращо у-во';
    $Self->{Translation}->{'Beamer'} = 'Бимер';
    $Self->{Translation}->{'Building'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'Процесор';
    $Self->{Translation}->{'Camera'} = 'Камера';
    $Self->{Translation}->{'Capacity'} = 'Капацитет';
    $Self->{Translation}->{'Change Definition'} = 'Промяна на дефиницията';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Промяната на дефинициите е неуспешна! Виж системния журнал за детайли.';
    $Self->{Translation}->{'Client Application'} = 'Потребителски приложения';
    $Self->{Translation}->{'Client OS'} = 'Потребителска Опер.с-ма';
    $Self->{Translation}->{'Concurrent Users'} = 'Конкурентни потребители';
    $Self->{Translation}->{'Config Item-Area'} = '';
    $Self->{Translation}->{'Config Items available'} = 'Достъпни конфигур.единици';
    $Self->{Translation}->{'Config Items shown'} = 'Показани конфигур.единици';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Демо';
    $Self->{Translation}->{'Desktop'} = 'Настолен';
    $Self->{Translation}->{'Developer Licence'} = 'Лиценз за разработчици';
    $Self->{Translation}->{'Docking Station'} = 'Докинг станция';
    $Self->{Translation}->{'Duplicate'} = 'Направи копие';
    $Self->{Translation}->{'Embedded'} = 'Вградена';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Ентърпрайс лиценз';
    $Self->{Translation}->{'Expiration Date'} = 'Дата на изтичане';
    $Self->{Translation}->{'Expired'} = 'Изтекли';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = 'Безплатно разпространяван';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Гейт преход';
    $Self->{Translation}->{'Graphic Adapter'} = 'Графична карта';
    $Self->{Translation}->{'Hard Disk'} = 'Твърд диск';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Твърд диск::капацитет';
    $Self->{Translation}->{'Hide Versions'} = 'Скрий Версиите';
    $Self->{Translation}->{'IP Address'} = 'IP адрес';
    $Self->{Translation}->{'IP over DHCP'} = 'IP от DHCP';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = 'Неактивни';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = 'Дата на инсталация';
    $Self->{Translation}->{'Keybord'} = 'Клавиатура';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Преносим';
    $Self->{Translation}->{'Last Change'} = 'Последна промяна';
    $Self->{Translation}->{'Licence Key'} = 'Лицензен ключ';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Лицензен ключ::Дата на изтичане';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Лицензен ключ::Количество';
    $Self->{Translation}->{'Licence Type'} = 'Тип на лиценза';
    $Self->{Translation}->{'Maintenance'} = 'Поддръжка';
    $Self->{Translation}->{'Maximum number of one element'} = '';
    $Self->{Translation}->{'Media'} = 'Медия';
    $Self->{Translation}->{'Middleware'} = 'Средно ниво';
    $Self->{Translation}->{'Model'} = 'Модел';
    $Self->{Translation}->{'Modem'} = 'Модем';
    $Self->{Translation}->{'Monitor'} = 'Монитор';
    $Self->{Translation}->{'Mouse'} = 'Мишка';
    $Self->{Translation}->{'Network Adapter'} = 'Мрежов адаптер';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Мрежов адаптер::IP Адрес';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Мрежов адаптер::IP от DHCP';
    $Self->{Translation}->{'Network Address'} = 'Мрежов адрес';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Мрежов адрес::Гейт преход';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Мрежов адрес::Маска на подмрежата';
    $Self->{Translation}->{'Open Source'} = 'Софтуер с отворен код';
    $Self->{Translation}->{'Operating System'} = 'Операционна система';
    $Self->{Translation}->{'Operational'} = '';
    $Self->{Translation}->{'Other'} = 'Други';
    $Self->{Translation}->{'Other Equipment'} = 'Друго оборудване';
    $Self->{Translation}->{'Outlet'} = '';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA карта';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Лицензиране на точка';
    $Self->{Translation}->{'Per Processor'} = 'Лицензиране за процесор';
    $Self->{Translation}->{'Per Server'} = 'Лицензиране за сървър';
    $Self->{Translation}->{'Per User'} = 'Лицензиране за потребител';
    $Self->{Translation}->{'Phone 1'} = '';
    $Self->{Translation}->{'Phone 2'} = '';
    $Self->{Translation}->{'Pilot'} = 'Пилот-водач';
    $Self->{Translation}->{'Planned'} = 'Планиран';
    $Self->{Translation}->{'Printer'} = 'Принтер';
    $Self->{Translation}->{'Production'} = 'Продуктивен';
    $Self->{Translation}->{'Quantity'} = 'Количество';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = 'Памет';
    $Self->{Translation}->{'Repair'} = 'Ремонт/Възстановяване';
    $Self->{Translation}->{'Retired'} = 'Излязъл от употреба';
    $Self->{Translation}->{'Review'} = 'Преглеждан';
    $Self->{Translation}->{'Room'} = '';
    $Self->{Translation}->{'Router'} = 'Рутер';
    $Self->{Translation}->{'Scanner'} = 'Скенер';
    $Self->{Translation}->{'Search Config Items'} = '';
    $Self->{Translation}->{'Security Device'} = 'У-во за сигурност';
    $Self->{Translation}->{'Serial Number'} = 'Сериен Номер';
    $Self->{Translation}->{'Server'} = 'Сървър';
    $Self->{Translation}->{'Server Application'} = 'Сървърно приложение';
    $Self->{Translation}->{'Server OS'} = 'сървърна Опер.с-ма';
    $Self->{Translation}->{'Show Versions'} = 'Покажи Версиите';
    $Self->{Translation}->{'Single Licence'} = 'Единичен лиценз';
    $Self->{Translation}->{'Subnet Mask'} = 'Маска на подмрежата';
    $Self->{Translation}->{'Switch'} = 'Концентратор';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Тест/Качествен контрол';
    $Self->{Translation}->{'The deployment state of this config item'} = '';
    $Self->{Translation}->{'The incident state of this config item'} = '';
    $Self->{Translation}->{'Time Restricted'} = 'Лиценз, ограничен по време';
    $Self->{Translation}->{'USB Device'} = 'USB Устройство';
    $Self->{Translation}->{'Unlimited'} = 'Неограничен лиценз';
    $Self->{Translation}->{'User Tool'} = 'Клиентски инструмент';
    $Self->{Translation}->{'Volume Licence'} = 'Специални обемни програми';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN точка за достъп';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Дата на изтичане на гаранцията';
    $Self->{Translation}->{'Workplace'} = '';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Управление на конфигурационните единици CI';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = '';
    $Self->{Translation}->{'Class'} = 'Клас';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = '';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = '';
    $Self->{Translation}->{'Incident State'} = '';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = '';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Последна промяна';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = '';
    $Self->{Translation}->{'Last changed by'} = 'Последно променен от';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Да търси и в предишните версии?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/cs_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::cs_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adresa';
    $Self->{Translation}->{'Admin Tool'} = 'Administrační nástroj';
    $Self->{Translation}->{'Backup Device'} = 'Zálohovácí Zařízení';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Budova';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'Procesor';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Kapacita';
    $Self->{Translation}->{'Change Definition'} = 'Změna Definice';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Změna definice neúspěšná! Viz Systémový Log pro podrobnosti.';
    $Self->{Translation}->{'Client Application'} = 'Uživatelské Aplikace';
    $Self->{Translation}->{'Client OS'} = 'Uživatelský Operační Systém';
    $Self->{Translation}->{'Concurrent Users'} = 'Konkurenční Uživatelé';
    $Self->{Translation}->{'Config Item-Area'} = 'Konfig. Položka-Struktura';
    $Self->{Translation}->{'Config Items available'} = 'Dostupné Konfig. Položky';
    $Self->{Translation}->{'Config Items shown'} = 'Zobrazené Konfig. Položky';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Stolní';
    $Self->{Translation}->{'Developer Licence'} = 'Licence Vývojáře';
    $Self->{Translation}->{'Docking Station'} = 'Dok Stanice';
    $Self->{Translation}->{'Duplicate'} = 'Duplikace';
    $Self->{Translation}->{'Embedded'} = 'Vestavěný';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Podniková Licence ';
    $Self->{Translation}->{'Expiration Date'} = 'Konec Platnosti';
    $Self->{Translation}->{'Expired'} = 'Propadnuté';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'podlaží';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Grafická Karta';
    $Self->{Translation}->{'Hard Disk'} = 'Pevný Disk';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Pevný Disk::Kapacita';
    $Self->{Translation}->{'Hide Versions'} = 'Skrýt Verze';
    $Self->{Translation}->{'IP Address'} = 'IP Adresa';
    $Self->{Translation}->{'IP over DHCP'} = 'IP z DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT Příslušenství';
    $Self->{Translation}->{'Inactive'} = 'Neaktivní';
    $Self->{Translation}->{'Incident'} = 'Incident';
    $Self->{Translation}->{'Install Date'} = 'Datum Instalace';
    $Self->{Translation}->{'Keybord'} = 'Klávesnice';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Mobilní';
    $Self->{Translation}->{'Last Change'} = 'Poslední změna';
    $Self->{Translation}->{'Licence Key'} = 'Licenční Klíč';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Licenční Klíč::Konec Platnosti';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Licenční Klíč::Množství';
    $Self->{Translation}->{'Licence Type'} = 'Druh licence';
    $Self->{Translation}->{'Maintenance'} = 'Údržba';
    $Self->{Translation}->{'Maximum number of one element'} = 'Max počet jedné Položky';
    $Self->{Translation}->{'Media'} = 'Médium';
    $Self->{Translation}->{'Middleware'} = 'Střední úroveň';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Myš';
    $Self->{Translation}->{'Network Adapter'} = 'Síťový Adapter';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Síťový Adapter::IP adresa';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Síťový Adapter::IP z DHCP';
    $Self->{Translation}->{'Network Address'} = 'Síťová Adresa';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Síťová Adresa::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Síťová Adresa::Maska Podsítě';
    $Self->{Translation}->{'Open Source'} = 'Software s Otevřeným Kódem';
    $Self->{Translation}->{'Operating System'} = 'Operační Systém';
    $Self->{Translation}->{'Operational'} = 'Operační';
    $Self->{Translation}->{'Other'} = 'Jiné';
    $Self->{Translation}->{'Other Equipment'} = 'Jiné Vybavení';
    $Self->{Translation}->{'Outlet'} = 'Filiálka';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA karta';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'na Uzel';
    $Self->{Translation}->{'Per Processor'} = 'na Procesor';
    $Self->{Translation}->{'Per Server'} = 'na Server';
    $Self->{Translation}->{'Per User'} = 'na Uživatele';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Řídící';
    $Self->{Translation}->{'Planned'} = 'Naplánováno';
    $Self->{Translation}->{'Printer'} = 'Tiskárna';
    $Self->{Translation}->{'Production'} = 'Produkční';
    $Self->{Translation}->{'Quantity'} = 'Množství';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'Oprava/Obnovení';
    $Self->{Translation}->{'Retired'} = 'Mimo provoz';
    $Self->{Translation}->{'Review'} = 'Přehled';
    $Self->{Translation}->{'Room'} = 'Místnost';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Skener';
    $Self->{Translation}->{'Search Config Items'} = 'Vyhledat Konfig. Položky';
    $Self->{Translation}->{'Security Device'} = 'Bezpečnostní Zařízení';
    $Self->{Translation}->{'Serial Number'} = 'Sériové Číslo';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Serverová Aplikace';
    $Self->{Translation}->{'Server OS'} = 'Serverový Operační Systém';
    $Self->{Translation}->{'Show Versions'} = 'Ukázat Verze';
    $Self->{Translation}->{'Single Licence'} = 'Jednoduchá Licence';
    $Self->{Translation}->{'Subnet Mask'} = 'Maska Podsítě';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/Kontrola kvality';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Stav Nasazení této Konfig. Položky';
    $Self->{Translation}->{'The incident state of this config item'} = 'Stav Incidentu této Konfig. Položky';
    $Self->{Translation}->{'Time Restricted'} = 'Časově omezená Licence';
    $Self->{Translation}->{'USB Device'} = 'USB Zařízení';
    $Self->{Translation}->{'Unlimited'} = 'Neomezená';
    $Self->{Translation}->{'User Tool'} = 'Uživatelský Nástroj';
    $Self->{Translation}->{'Volume Licence'} = 'Svazková Licence';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'Přístupový Bod WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Konec platnosti záruky';
    $Self->{Translation}->{'Workplace'} = 'Pracoviště';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Správa Konfiguračních Položek';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Konfig. Položka';
    $Self->{Translation}->{'Class'} = 'Třída';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Jméno této Konfig. Položky';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Stav Nasazení';
    $Self->{Translation}->{'Incident State'} = 'Stav Incidentu';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Aktuální Stav Incidentu';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Poslední změna';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Aktuální Stav Nasazení';
    $Self->{Translation}->{'Last changed by'} = 'Poslední změna od';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Hledat také v předchozích verzích?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/ct_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ct_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = 'Eina d\'administració';
    $Self->{Translation}->{'Backup Device'} = 'Dispositiu de còpies de seguretat';
    $Self->{Translation}->{'Beamer'} = 'Projector';
    $Self->{Translation}->{'Building'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Càmera';
    $Self->{Translation}->{'Capacity'} = 'Capacitat';
    $Self->{Translation}->{'Change Definition'} = 'Canviar definició';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Canvi de definició ha fallat! Veure el registre del sistema per a més detalls.';
    $Self->{Translation}->{'Client Application'} = 'Aplicació client';
    $Self->{Translation}->{'Client OS'} = 'Sistema Operatiu client';
    $Self->{Translation}->{'Concurrent Users'} = 'Usuaris concurrents';
    $Self->{Translation}->{'Config Item-Area'} = 'Àrea-Element de configuració';
    $Self->{Translation}->{'Config Items available'} = 'Elements de configuració disponibles';
    $Self->{Translation}->{'Config Items shown'} = 'Elements de configuració mostrats';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Ordinador';
    $Self->{Translation}->{'Developer Licence'} = 'Llicència de desenvolupament';
    $Self->{Translation}->{'Docking Station'} = 'Unitat d\'expansió';
    $Self->{Translation}->{'Duplicate'} = 'Duplicar';
    $Self->{Translation}->{'Embedded'} = 'Integrat';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Llicència corporativa';
    $Self->{Translation}->{'Expiration Date'} = 'Data d\'expiració';
    $Self->{Translation}->{'Expired'} = 'Expirat';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Porta d\'enllaç';
    $Self->{Translation}->{'Graphic Adapter'} = 'Adaptador gràfic';
    $Self->{Translation}->{'Hard Disk'} = 'Disc dur';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disc dur::Capacitat';
    $Self->{Translation}->{'Hide Versions'} = 'Ocultar versions';
    $Self->{Translation}->{'IP Address'} = 'Direcció IP';
    $Self->{Translation}->{'IP over DHCP'} = 'IP per DHCP';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = 'Inactiu';
    $Self->{Translation}->{'Install Date'} = 'Data d\'instal·lació';
    $Self->{Translation}->{'Keybord'} = 'Teclat';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Portàtil';
    $Self->{Translation}->{'Last Change'} = 'Últim canvi';
    $Self->{Translation}->{'Licence Key'} = 'Clau de llicència';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Clau de llicència::Data d\'expiració';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Clau de llicència::Cuantitat';
    $Self->{Translation}->{'Licence Type'} = 'Tipus de llicència';
    $Self->{Translation}->{'Maintenance'} = 'Manteniment';
    $Self->{Translation}->{'Maximum number of one element'} = 'Nombre màxim d\'un element';
    $Self->{Translation}->{'Media'} = 'Medi';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Mòdem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Ratolí';
    $Self->{Translation}->{'Network Adapter'} = 'Adaptador de xarxa';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adaptador de xarxa::Direcció IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adaptador de xarxa::IP per DHCP';
    $Self->{Translation}->{'Network Address'} = 'Direcció de xarxa';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Direcció de xarxa::Porta d\'enllaç';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Direcció de xarxa::Màscara de subxarxa';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'Sistema Operatiu';
    $Self->{Translation}->{'Operational'} = 'Operatiu';
    $Self->{Translation}->{'Other'} = 'Altres';
    $Self->{Translation}->{'Other Equipment'} = 'Alter equipament';
    $Self->{Translation}->{'Outlet'} = '';
    $Self->{Translation}->{'PCMCIA Card'} = 'Targeta PCMCIA';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Per Node';
    $Self->{Translation}->{'Per Processor'} = 'Per Processador';
    $Self->{Translation}->{'Per Server'} = 'Per Servidor';
    $Self->{Translation}->{'Per User'} = 'Per Usuari';
    $Self->{Translation}->{'Phone 1'} = '';
    $Self->{Translation}->{'Phone 2'} = '';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Planificat';
    $Self->{Translation}->{'Printer'} = 'Impressora';
    $Self->{Translation}->{'Production'} = 'Producció';
    $Self->{Translation}->{'Quantity'} = 'Cuantitat';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = 'Ram';
    $Self->{Translation}->{'Repair'} = 'Reparar';
    $Self->{Translation}->{'Retired'} = 'Retirat';
    $Self->{Translation}->{'Review'} = 'Revisar';
    $Self->{Translation}->{'Room'} = '';
    $Self->{Translation}->{'Router'} = 'Encaminador';
    $Self->{Translation}->{'Scanner'} = 'Escàner';
    $Self->{Translation}->{'Search Config Items'} = 'Cercar elements de configuració';
    $Self->{Translation}->{'Security Device'} = 'Dispositiu de seguretat';
    $Self->{Translation}->{'Serial Number'} = 'Nombre de sèrie';
    $Self->{Translation}->{'Server'} = 'Servidor';
    $Self->{Translation}->{'Server Application'} = 'Aplicació servidor';
    $Self->{Translation}->{'Server OS'} = 'Sistema Operatiu servidor';
    $Self->{Translation}->{'Show Versions'} = 'Mostrar versions';
    $Self->{Translation}->{'Single Licence'} = 'Llicència Individual';
    $Self->{Translation}->{'Subnet Mask'} = 'Màscara de subxarxa';
    $Self->{Translation}->{'Switch'} = 'Commutador';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Provar/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'L\'estat del desplegament d\aquest element de configuració';
    $Self->{Translation}->{'The incident state of this config item'} = 'L\'estat de l\'incident d\'aquest element de configuració';
    $Self->{Translation}->{'Time Restricted'} = 'Restricció de temps';
    $Self->{Translation}->{'USB Device'} = 'Dispositiu USB';
    $Self->{Translation}->{'Unlimited'} = 'Il·limitat';
    $Self->{Translation}->{'User Tool'} = 'Eina d\'usuari';
    $Self->{Translation}->{'Volume Licence'} = 'Llicència per volum';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'Punt d\'accés WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Data de fi de la garantia';
    $Self->{Translation}->{'Workplace'} = '';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gestió d\'elements de configuració';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Element de configuració';
    $Self->{Translation}->{'Class'} = 'Classe';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'El nom d\'aquest element de configuració';
    $Self->{Translation}->{'Deployment State'} = 'Estat del desplegament';
    $Self->{Translation}->{'Incident State'} = 'Estat de l\'incident';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Estat actual de l\'incident';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last Changed'} = '';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Estat actual del desplegament';
    $Self->{Translation}->{'Last changed'} = 'Últim canvi';
    $Self->{Translation}->{'Last changed by'} = 'Últim canvi per';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Search-Template'} = '';
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Cercar també en versions anteriors?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Linked Objects'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Created By'} = '';
    $Self->{Translation}->{'Changed On'} = '';
    $Self->{Translation}->{'Resize'} = '';
    $Self->{Translation}->{'Show or hide the content.'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} = '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} = '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} = '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} = '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} = '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} = '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} = '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/da_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::da_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adresse';
    $Self->{Translation}->{'Admin Tool'} = 'Admin værktøjer';
    $Self->{Translation}->{'Backup Device'} = 'Backup enhed';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Bygning';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Kapacitet';
    $Self->{Translation}->{'Change Definition'} = 'Ændre definition';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Ændring af definition fejlede! Se System Log for detaljer.';
    $Self->{Translation}->{'Client Application'} = 'Klient aplikation';
    $Self->{Translation}->{'Client OS'} = 'Klient OS';
    $Self->{Translation}->{'Concurrent Users'} = 'Samtidige brugere';
    $Self->{Translation}->{'Config Item-Area'} = 'Config Item-område';
    $Self->{Translation}->{'Config Items available'} = 'Tilgængelige Config Items';
    $Self->{Translation}->{'Config Items shown'} = 'Vis Config Items';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Udvikler licens';
    $Self->{Translation}->{'Docking Station'} = 'Docking Station';
    $Self->{Translation}->{'Duplicate'} = 'Dupliker';
    $Self->{Translation}->{'Embedded'} = 'Embedded';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterprise licens';
    $Self->{Translation}->{'Expiration Date'} = 'Udløbsdato';
    $Self->{Translation}->{'Expired'} = 'Udløbet';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Etage';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Grafikkort';
    $Self->{Translation}->{'Hard Disk'} = 'Harddisk';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Harddisk::Kapacitet';
    $Self->{Translation}->{'Hide Versions'} = 'Skjul versioner';
    $Self->{Translation}->{'IP Address'} = 'IP adresse';
    $Self->{Translation}->{'IP over DHCP'} = 'IP via DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT facilitet';
    $Self->{Translation}->{'Inactive'} = 'Inaktiv';
    $Self->{Translation}->{'Incident'} = 'Incident';
    $Self->{Translation}->{'Install Date'} = 'Installationsdato';
    $Self->{Translation}->{'Keybord'} = 'Tastatur';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Sidst ændret';
    $Self->{Translation}->{'Licence Key'} = 'Licensnøgle';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Licensnøgle::Udløbsdato';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Licensnøgle::Mængde';
    $Self->{Translation}->{'Licence Type'} = 'Licenstype';
    $Self->{Translation}->{'Maintenance'} = 'Vedligeholdelse';
    $Self->{Translation}->{'Maximum number of one element'} = 'Maximum antal af et element';
    $Self->{Translation}->{'Media'} = 'Medie';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Mus';
    $Self->{Translation}->{'Network Adapter'} = 'Netkort';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Netkort::IP adresse';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Netkort::IP via DHCP';
    $Self->{Translation}->{'Network Address'} = 'Netværksadresse';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Netværksadresse::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Netværksadresse::Subnet maske';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'OS';
    $Self->{Translation}->{'Operational'} = 'Operationel';
    $Self->{Translation}->{'Other'} = 'Andet';
    $Self->{Translation}->{'Other Equipment'} = 'Andet udstyr';
    $Self->{Translation}->{'Outlet'} = 'Stikkontakt';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA kort';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Pr node';
    $Self->{Translation}->{'Per Processor'} = 'Pr processor';
    $Self->{Translation}->{'Per Server'} = 'Pr server';
    $Self->{Translation}->{'Per User'} = 'Pr bruger';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Planlagt';
    $Self->{Translation}->{'Printer'} = 'Printer';
    $Self->{Translation}->{'Production'} = 'Produktion';
    $Self->{Translation}->{'Quantity'} = 'Mængde';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'Reperation';
    $Self->{Translation}->{'Retired'} = 'Persioneret';
    $Self->{Translation}->{'Review'} = 'Anmeldelse';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Skanner';
    $Self->{Translation}->{'Search Config Items'} = 'Søg Config Item';
    $Self->{Translation}->{'Security Device'} = 'Sikkerhedsenhed';
    $Self->{Translation}->{'Serial Number'} = 'Serienummer';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Server aplikation';
    $Self->{Translation}->{'Server OS'} = 'Server OS';
    $Self->{Translation}->{'Show Versions'} = 'Vis versioner';
    $Self->{Translation}->{'Single Licence'} = 'Enkeltlicens';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnet maske';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Deployment tilstand for denne Config item';
    $Self->{Translation}->{'The incident state of this config item'} = 'Incident tilstand for denne Config Item';
    $Self->{Translation}->{'Time Restricted'} = 'Tidsbegrænset';
    $Self->{Translation}->{'USB Device'} = 'USB enhed';
    $Self->{Translation}->{'Unlimited'} = 'Unbegrænset';
    $Self->{Translation}->{'User Tool'} = 'Bruger værktøjer';
    $Self->{Translation}->{'Volume Licence'} = 'Volumen Licens';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN Access Point';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Udløbsdato for garanti';
    $Self->{Translation}->{'Workplace'} = 'Arbejdsplads';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Config Item styring';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Config Item';
    $Self->{Translation}->{'Class'} = 'Klasse';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Navnet på denne Config Item';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Deployment tilstand';
    $Self->{Translation}->{'Incident State'} = 'Incident tilstand';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Nuværende Incident tilstand';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Sidst ændret';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Nuværende deployment status';
    $Self->{Translation}->{'Last changed by'} = 'Sidst ændret af';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Søg også i tidligere versioner?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/de_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::de_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adresse';
    $Self->{Translation}->{'Admin Tool'} = 'Admin Tool';
    $Self->{Translation}->{'Backup Device'} = 'Backup Gerät';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Gebäude';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Neues ConfigItem (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'ConfigItem (ID=%s) gelöscht';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Definition des ConfigItems aktualisiert (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Verwendungsstatus geändert (neu=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Vorfallsstatus geändert (neu=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Link auf %s (Typ=%s) hinzugefügt';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Link auf %s (Typ=%s) gelöscht';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Name geändert (neu=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Attribut %s von "%s" auf "%s" geändert';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Neue Version erzeugt (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Version %s gelöscht';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = 'Anhang (%s) hinzugefügt';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = 'Anhang (%s) gelöscht';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Kapazität';
    $Self->{Translation}->{'Change Definition'} = 'Definition ändern';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Ändern der Definition fehlgeschlagen! Im System Log finden Sie weitere Informationen.';
    $Self->{Translation}->{'Client Application'} = 'Client Anwendung';
    $Self->{Translation}->{'Client OS'} = 'Client Betriebssystem';
    $Self->{Translation}->{'Concurrent Users'} = 'Gleichzeitige User';
    $Self->{Translation}->{'Config Item-Area'} = 'Config Item-Bereich';
    $Self->{Translation}->{'Config Items available'} = 'Config Items verfügbar';
    $Self->{Translation}->{'Config Items shown'} = 'Config Items angezeigt';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Entwickler Lizenz';
    $Self->{Translation}->{'Docking Station'} = 'Docking Station';
    $Self->{Translation}->{'Duplicate'} = 'Duplizieren';
    $Self->{Translation}->{'Embedded'} = 'Embedded';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Leere Felder belassen den aktuellen Wert';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterprise Lizenz';
    $Self->{Translation}->{'Expiration Date'} = 'Ablaufdatum';
    $Self->{Translation}->{'Expired'} = 'Abgelaufen';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Etage';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Grafik Adapter';
    $Self->{Translation}->{'Hard Disk'} = 'Festplatte';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Festplatte::Kapazität';
    $Self->{Translation}->{'Hide Versions'} = 'Versionen ausblenden';
    $Self->{Translation}->{'IP Address'} = 'IP Addresse';
    $Self->{Translation}->{'IP over DHCP'} = 'IP über DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT Einrichtung';
    $Self->{Translation}->{'Inactive'} = 'Inaktiv';
    $Self->{Translation}->{'Incident'} = 'Vorfall';
    $Self->{Translation}->{'Install Date'} = 'Installationsdatum';
    $Self->{Translation}->{'Keybord'} = 'Tastatur';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Letzte Änderung';
    $Self->{Translation}->{'Licence Key'} = 'Lizenzschlüssel';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Lizenzschlüssel::Ablaufdatum';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Lizenzschlüssel::Menge';
    $Self->{Translation}->{'Licence Type'} = 'Lizenztyp';
    $Self->{Translation}->{'Maintenance'} = 'In Wartung';
    $Self->{Translation}->{'Maximum number of one element'} = 'Maximale Anzahl eines Elements';
    $Self->{Translation}->{'Media'} = 'Medium';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Maus';
    $Self->{Translation}->{'Network Adapter'} = 'Netzwerk Adapter';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Netzwerk Adapter::IP Addresse';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Netzwerk Adapter::IP über DHCP';
    $Self->{Translation}->{'Network Address'} = 'Netzwerk Addresse';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Netzwerk Addresse::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Netzwerk Addresse::Subnetz Maske';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'Betriebssystem';
    $Self->{Translation}->{'Operational'} = 'Operativ';
    $Self->{Translation}->{'Other'} = 'Sonstiges';
    $Self->{Translation}->{'Other Equipment'} = 'Sonstige Ausstattung';
    $Self->{Translation}->{'Outlet'} = 'Anschlussdose';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA Karte';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Pro Knoten';
    $Self->{Translation}->{'Per Processor'} = 'Pro Prozessor';
    $Self->{Translation}->{'Per Server'} = 'Pro Server';
    $Self->{Translation}->{'Per User'} = 'Pro Benutzer';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilotbetrieb';
    $Self->{Translation}->{'Planned'} = 'Geplant';
    $Self->{Translation}->{'Printer'} = 'Drucker';
    $Self->{Translation}->{'Production'} = 'Produktiv';
    $Self->{Translation}->{'Quantity'} = 'Menge';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'Arbeitsspeicher';
    $Self->{Translation}->{'Repair'} = 'In Reparatur';
    $Self->{Translation}->{'Retired'} = 'Außer Dienst';
    $Self->{Translation}->{'Review'} = 'Unter Review';
    $Self->{Translation}->{'Room'} = 'Raum';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Scanner';
    $Self->{Translation}->{'Search Config Items'} = 'Config Item Suche';
    $Self->{Translation}->{'Security Device'} = 'Sichertheitsgerät';
    $Self->{Translation}->{'Serial Number'} = 'Seriennummer';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Server Anwendung';
    $Self->{Translation}->{'Server OS'} = 'Server Betriebssystem';
    $Self->{Translation}->{'Show Versions'} = 'Versionen einblenden';
    $Self->{Translation}->{'Single Licence'} = 'Einzellizenz';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnetz Maske';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telko';
    $Self->{Translation}->{'Test/QA'} = 'Test/QS';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Der Verwendungsstatus dieses Config Items';
    $Self->{Translation}->{'The incident state of this config item'} = 'Der Vorfallsstatus dieses Config Items';
    $Self->{Translation}->{'Time Restricted'} = 'Zeitlich begrenzt';
    $Self->{Translation}->{'USB Device'} = 'USB Gerät';
    $Self->{Translation}->{'Unlimited'} = 'Unlimitiert';
    $Self->{Translation}->{'User Tool'} = 'User Tool';
    $Self->{Translation}->{'Volume Licence'} = 'Volumen Lizenz';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN Access Point';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Garantie Ablaufdatum';
    $Self->{Translation}->{'Workplace'} = 'Arbeitsplatz';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Config Item Verwaltung';
    $Self->{Translation}->{'Change class definition'} = 'Klassen-Definition ändern';
    $Self->{Translation}->{'Config Item'} = 'Config Item';
    $Self->{Translation}->{'Class'} = 'Klasse';
    $Self->{Translation}->{'Definition'} = 'Definition';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filter für Klassen';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Wählen Sie eine Klasse aus der Liste aus um ein neues Config Item zu erstellen.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Der Name dieses Config Items';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        'Name wird bereits von den ConfigItems mit den folgenden Nummern verwendet: %s';
    $Self->{Translation}->{'Deployment State'} = 'Verwendungsstatus';
    $Self->{Translation}->{'Incident State'} = 'Vorfallsstatus';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Kontext-Eintstellungen';
    $Self->{Translation}->{'Config Items per page'} = 'Config Items pro Seite';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Verwendungsstatus-Typ';
    $Self->{Translation}->{'Current Incident State'} = 'Aktueller Vorfallsstatus';
    $Self->{Translation}->{'Current Incident State Type'} = 'Aktueller Vorfallsstatus-Typ';
    $Self->{Translation}->{'Last changed'} = 'Zuletzt geändert';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'ConfigItem';
    $Self->{Translation}->{'ConfigItem-Info'} = 'ConfigItem-Info';
    $Self->{Translation}->{'Current Deployment State'} = 'Aktueller Verwendungsstatus';
    $Self->{Translation}->{'Last changed by'} = 'Zuletzt geändert von';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Auch in früheren Versionen suchen?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Erstellzeit';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Configuration Item';
    $Self->{Translation}->{'Configuration Item Information'} = 'Configuration Item Information';
    $Self->{Translation}->{'Show one version'} = 'Zeige nur eine Version';
    $Self->{Translation}->{'Show all versions'} = 'Zeige alle Versionen';
    $Self->{Translation}->{'Version Incident State'} = 'Versions-Vorfallstatus';
    $Self->{Translation}->{'Version Number'} = 'Versionsnummer';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Configuration Item Versions-Details';
    $Self->{Translation}->{'Property'} = 'Eigenschaft';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        'Prüfe Namen auf Eindeutigkeit innerhalb der selben ConfigItem-Klasse oder global, d.h. es werden alle ConfigItems jeglicher ConfigItem-Klasse bei der Prüfung auf einen eindeutigen Namen berücksichtigt.';
    $Self->{Translation}->{'Config Items'} = 'Config Items';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Configuration Item Limit';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Configuration Item Limit pro Seite';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        'Definiert das Standard-Subobject der Klasse';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '(De-)Aktiviert die Funktionalität um ConfigItems auf eindeutige Namen zu überprüfen. Bevor Sie diese Option aktivieren, sollten Sie Ihr System auf bereits vorhandene ConfigItems mit gleichem Namen überprüfen. Sie können dies mit Hilfe des scripts bin/otrs.ITSMConfigItemListDuplicates.pl tun.';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        'Objekt-Backend Modul Registration des Import/Export Moduls.';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9lbl9JVFNNQ29uZmlnSXRlbS5wbSAtIHRoZSBlbmdsaXNoIHRyYW5zbGF0aW9uIG9mIElUU01Db25maWdJdGVtCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Okxhbmd1YWdlOjplbl9JVFNNQ29uZmlnSXRlbTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgbXkgJExhbmcgPSAkU2VsZi0+e1RyYW5zbGF0aW9ufTsKCiAgICByZXR1cm4gaWYgcmVmICRMYW5nIG5lICdIQVNIJzsKCiAgICAkTGFuZy0+eydDSUhpc3Rvcnk6OkNvbmZpZ0l0ZW1DcmVhdGUnfSAgICAgICAgICAgID0gJ05ldyBDb25maWdJdGVtIChJRD0lcyknOwogICAgJExhbmctPnsnQ0lIaXN0b3J5OjpWZXJzaW9uQ3JlYXRlJ30gICAgICAgICAgICAgICA9ICdOZXcgdmVyc2lvbiAoSUQ9JXMpJzsKICAgICRMYW5nLT57J0NJSGlzdG9yeTo6RGVwbG95bWVudFN0YXRlVXBkYXRlJ30gICAgICAgPSAnRGVwbG95bWVudCBzdGF0ZSB1cGRhdGVkIChuZXc9JXM7IG9sZD0lcyknOwogICAgJExhbmctPnsnQ0lIaXN0b3J5OjpJbmNpZGVudFN0YXRlVXBkYXRlJ30gICAgICAgICA9ICdJbmNpZGVudCBzdGF0ZSB1cGRhdGVkIChuZXc9JXM7IG9sZD0lcyknOwogICAgJExhbmctPnsnQ0lIaXN0b3J5OjpDb25maWdJdGVtRGVsZXRlJ30gICAgICAgICAgICA9ICdDb25maWdJdGVtIChJRD0lcykgZGVsZXRlZCc7CiAgICAkTGFuZy0+eydDSUhpc3Rvcnk6OkxpbmtBZGQnfSAgICAgICAgICAgICAgICAgICAgID0gJ0xpbmsgdG8gJXMgKHR5cGU9JXMpIGFkZGVkJzsKICAgICRMYW5nLT57J0NJSGlzdG9yeTo6TGlua0RlbGV0ZSd9ICAgICAgICAgICAgICAgICAgPSAnTGluayB0byAlcyAodHlwZT0lcykgZGVsZXRlZCc7CiAgICAkTGFuZy0+eydDSUhpc3Rvcnk6OkRlZmluaXRpb25VcGRhdGUnfSAgICAgICAgICAgID0gJ0NvbmZpZ0l0ZW1zXCcgZGVmaW5pdGlvbiB1cGRhdGVkIChJRD0lcyknOwogICAgJExhbmctPnsnQ0lIaXN0b3J5OjpOYW1lVXBkYXRlJ30gICAgICAgICAgICAgICAgICA9ICdOYW1lIHVwZGF0ZWQgKG5ldz0lczsgb2xkPSVzKSc7CiAgICAkTGFuZy0+eydDSUhpc3Rvcnk6OlZhbHVlVXBkYXRlJ30gICAgICAgICAgICAgICAgID0gJ0F0dHJpYnV0ZSAlcyB1cGRhdGVkIGZyb20gIiVzIiB0byAiJXMiJzsKICAgICRMYW5nLT57J0NJSGlzdG9yeTo6VmVyc2lvbkRlbGV0ZSd9ICAgICAgICAgICAgICAgPSAnVmVyc2lvbiAlcyBkZWxldGVkJzsKCiAgICAkTGFuZy0+eydEZXZlbG9wZXIgTGljZW5jZSd9ICAgICAgICAgICAgICAgICAgICAgID0gJ0RldmVsb3BlciBMaWNlbnNlJzsKICAgICRMYW5nLT57J0VudGVycHJpc2UgTGljZW5jZSd9ICAgICAgICAgICAgICAgICAgICAgPSAnRW50ZXJwcmlzZSBMaWNlbnNlJzsKICAgICRMYW5nLT57J1NpbmdsZSBMaWNlbmNlJ30gICAgICAgICAgICAgICAgICAgICAgICAgPSAnU2luZ2xlIExpY2Vuc2UnOwogICAgJExhbmctPnsnVm9sdW1lIExpY2VuY2UnfSAgICAgICAgICAgICAgICAgICAgICAgICA9ICdWb2x1bWUgTGljZW5zZSc7CiAgICAkTGFuZy0+eydMaWNlbmNlIFR5cGUnfSAgICAgICAgICAgICAgICAgICAgICAgICAgID0gJ0xpY2Vuc2UgVHlwZSc7CiAgICAkTGFuZy0+eydMaWNlbmNlIEtleSd9ICAgICAgICAgICAgICAgICAgICAgICAgICAgID0gJ0xpY2Vuc2UgS2V5JzsKICAgICRMYW5nLT57J0xpY2VuY2UgS2V5OjpRdWFudGl0eSd9ICAgICAgICAgICAgICAgICAgPSAnTGljZW5zZSBLZXk6OlF1YW50aXR5JzsKICAgICRMYW5nLT57J0xpY2VuY2UgS2V5OjpFeHBpcmF0aW9uIERhdGUnfSAgICAgICAgICAgPSAnTGljZW5zZSBLZXk6OkV4cGlyYXRpb24gRGF0ZSc7CgogICAgcmV0dXJuIDE7Cn0KCjE7Cg==
# --
# Kernel/Language/en_CA_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::en_CA_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = '';
    $Self->{Translation}->{'Backup Device'} = '';
    $Self->{Translation}->{'Beamer'} = '';
    $Self->{Translation}->{'Building'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'New ConfigItem (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'ConfigItem (ID=%s) deleted';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'ConfigItems\' definition updated (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Deployment state updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Incident state updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Link to %s (type=%s) added';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Link to %s (type=%s) deleted';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Name updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Attribute %s updated from "%s" to "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'New version (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Version %s deleted';
    $Self->{Translation}->{'CPU'} = '';
    $Self->{Translation}->{'Camera'} = '';
    $Self->{Translation}->{'Capacity'} = '';
    $Self->{Translation}->{'Change Definition'} = '';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = '';
    $Self->{Translation}->{'Client Application'} = '';
    $Self->{Translation}->{'Client OS'} = '';
    $Self->{Translation}->{'Concurrent Users'} = '';
    $Self->{Translation}->{'Config Item-Area'} = '';
    $Self->{Translation}->{'Config Items available'} = '';
    $Self->{Translation}->{'Config Items shown'} = '';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = '';
    $Self->{Translation}->{'Desktop'} = '';
    $Self->{Translation}->{'Developer Licence'} = 'Developer License';
    $Self->{Translation}->{'Docking Station'} = '';
    $Self->{Translation}->{'Duplicate'} = '';
    $Self->{Translation}->{'Embedded'} = '';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterprise License';
    $Self->{Translation}->{'Expiration Date'} = '';
    $Self->{Translation}->{'Expired'} = '';
    $Self->{Translation}->{'FQDN'} = '';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = '';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '';
    $Self->{Translation}->{'Graphic Adapter'} = '';
    $Self->{Translation}->{'Hard Disk'} = '';
    $Self->{Translation}->{'Hard Disk::Capacity'} = '';
    $Self->{Translation}->{'Hide Versions'} = '';
    $Self->{Translation}->{'IP Address'} = '';
    $Self->{Translation}->{'IP over DHCP'} = '';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = '';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = '';
    $Self->{Translation}->{'Keybord'} = '';
    $Self->{Translation}->{'LAN'} = '';
    $Self->{Translation}->{'Laptop'} = '';
    $Self->{Translation}->{'Last Change'} = '';
    $Self->{Translation}->{'Licence Key'} = 'License Key';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'License Key::Expiration Date';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'License Key::Quantity';
    $Self->{Translation}->{'Licence Type'} = 'License Type';
    $Self->{Translation}->{'Maintenance'} = '';
    $Self->{Translation}->{'Maximum number of one element'} = '';
    $Self->{Translation}->{'Media'} = '';
    $Self->{Translation}->{'Middleware'} = '';
    $Self->{Translation}->{'Model'} = '';
    $Self->{Translation}->{'Modem'} = '';
    $Self->{Translation}->{'Monitor'} = '';
    $Self->{Translation}->{'Mouse'} = '';
    $Self->{Translation}->{'Network Adapter'} = '';
    $Self->{Translation}->{'Network Adapter::IP Address'} = '';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = '';
    $Self->{Translation}->{'Network Address'} = '';
    $Self->{Translation}->{'Network Address::Gateway'} = '';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = '';
    $Self->{Translation}->{'Open Source'} = '';
    $Self->{Translation}->{'Operating System'} = '';
    $Self->{Translation}->{'Operational'} = '';
    $Self->{Translation}->{'Other'} = '';
    $Self->{Translation}->{'Other Equipment'} = '';
    $Self->{Translation}->{'Outlet'} = '';
    $Self->{Translation}->{'PCMCIA Card'} = '';
    $Self->{Translation}->{'PDA'} = '';
    $Self->{Translation}->{'Per Node'} = '';
    $Self->{Translation}->{'Per Processor'} = '';
    $Self->{Translation}->{'Per Server'} = '';
    $Self->{Translation}->{'Per User'} = '';
    $Self->{Translation}->{'Phone 1'} = '';
    $Self->{Translation}->{'Phone 2'} = '';
    $Self->{Translation}->{'Pilot'} = '';
    $Self->{Translation}->{'Planned'} = '';
    $Self->{Translation}->{'Printer'} = '';
    $Self->{Translation}->{'Production'} = '';
    $Self->{Translation}->{'Quantity'} = '';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = '';
    $Self->{Translation}->{'Repair'} = '';
    $Self->{Translation}->{'Retired'} = '';
    $Self->{Translation}->{'Review'} = '';
    $Self->{Translation}->{'Room'} = '';
    $Self->{Translation}->{'Router'} = '';
    $Self->{Translation}->{'Scanner'} = '';
    $Self->{Translation}->{'Search Config Items'} = '';
    $Self->{Translation}->{'Security Device'} = '';
    $Self->{Translation}->{'Serial Number'} = '';
    $Self->{Translation}->{'Server'} = '';
    $Self->{Translation}->{'Server Application'} = '';
    $Self->{Translation}->{'Server OS'} = '';
    $Self->{Translation}->{'Show Versions'} = '';
    $Self->{Translation}->{'Single Licence'} = 'Single License';
    $Self->{Translation}->{'Subnet Mask'} = '';
    $Self->{Translation}->{'Switch'} = '';
    $Self->{Translation}->{'Telco'} = '';
    $Self->{Translation}->{'Test/QA'} = '';
    $Self->{Translation}->{'The deployment state of this config item'} = '';
    $Self->{Translation}->{'The incident state of this config item'} = '';
    $Self->{Translation}->{'Time Restricted'} = '';
    $Self->{Translation}->{'USB Device'} = '';
    $Self->{Translation}->{'Unlimited'} = '';
    $Self->{Translation}->{'User Tool'} = '';
    $Self->{Translation}->{'Volume Licence'} = 'Volume License';
    $Self->{Translation}->{'WLAN'} = '';
    $Self->{Translation}->{'WLAN Access Point'} = '';
    $Self->{Translation}->{'Warranty Expiration Date'} = '';
    $Self->{Translation}->{'Workplace'} = '';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = '';
    $Self->{Translation}->{'Actions'} = '';
    $Self->{Translation}->{'Add'} = '';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Go to overview'} = '';
    $Self->{Translation}->{'List'} = '';
    $Self->{Translation}->{'Config Item'} = '';
    $Self->{Translation}->{'Class'} = '';
    $Self->{Translation}->{'Version'} = '';
    $Self->{Translation}->{'Created by'} = '';
    $Self->{Translation}->{'Created'} = '';
    $Self->{Translation}->{'View'} = '';
    $Self->{Translation}->{'Definition'} = '';
    $Self->{Translation}->{'Change'} = '';
    $Self->{Translation}->{'Submit'} = '';
    $Self->{Translation}->{'or'} = '';
    $Self->{Translation}->{'Cancel'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Hint'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';
    $Self->{Translation}->{'No matches found.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'Edit'} = '';
    $Self->{Translation}->{'Cancel & close window'} = '';
    $Self->{Translation}->{'Name'} = '';
    $Self->{Translation}->{'The name of this config item'} = '';
    $Self->{Translation}->{'This field is required.'} = '';
    $Self->{Translation}->{'Deployment State'} = '';
    $Self->{Translation}->{'Incident State'} = '';
    $Self->{Translation}->{'Delete'} = '';
    $Self->{Translation}->{'Save'} = '';

    # Template: AgentITSMConfigItemHistory
    $Self->{Translation}->{'History of'} = '';
    $Self->{Translation}->{'History Content'} = '';
    $Self->{Translation}->{'Action'} = '';
    $Self->{Translation}->{'Comment'} = '';
    $Self->{Translation}->{'Zoom'} = '';
    $Self->{Translation}->{'User'} = '';
    $Self->{Translation}->{'Createtime'} = '';
    $Self->{Translation}->{'Zoom view'} = '';

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Change search options'} = '';
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';
    $Self->{Translation}->{'Settings'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'State'} = '';
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = '';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last Changed'} = '';
    $Self->{Translation}->{'No data found.'} = '';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = '';
    $Self->{Translation}->{'Last changed'} = '';
    $Self->{Translation}->{'Last changed by'} = '';
    $Self->{Translation}->{'Linked-Object'} = '';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Search-Template'} = '';
    $Self->{Translation}->{'Create New'} = '';
    $Self->{Translation}->{'Create Template'} = '';
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Search template'} = '';
    $Self->{Translation}->{'Save changes in template'} = '';
    $Self->{Translation}->{'Add another attribute'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = '';
    $Self->{Translation}->{'Output'} = '';
    $Self->{Translation}->{'Number'} = '';
    $Self->{Translation}->{'(e. g. 10*5155 or 105658*)'} = '';
    $Self->{Translation}->{'Remove this entry'} = '';
    $Self->{Translation}->{'Remove'} = '';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'Search'} = '';
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Linked Objects'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Created By'} = '';
    $Self->{Translation}->{'Changed On'} = '';
    $Self->{Translation}->{'Resize'} = '';
    $Self->{Translation}->{'Show or hide the content.'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';
    $Self->{Translation}->{'Value'} = '';

    # SysConfig
    $Self->{Translation}->{'ACL module that allows closing parent tickets only if all its children are already closed ("State" shows which states are not available for the parent ticket until all child tickets are closed).'} = '';
    $Self->{Translation}->{'Activates TypeAhead for the autocomplete feature, that enables users to type in whatever speed they desire, without losing any information. Often this means that keystrokes entered will not be displayed on the screen immediately.'} = '';
    $Self->{Translation}->{'Activates a blinking mechanism of the queue that contains the oldest ticket.'} = '';
    $Self->{Translation}->{'Activates lost password feature for agents, in the agent interface.'} = '';
    $Self->{Translation}->{'Activates lost password feature for customers.'} = '';
    $Self->{Translation}->{'Activates support for customer groups.'} = '';
    $Self->{Translation}->{'Activates the article filter in the zoom view to specify which articles should be shown.'} = '';
    $Self->{Translation}->{'Activates the available themes on the system. Value 1 means active, 0 means inactive.'} = '';
    $Self->{Translation}->{'Activates the ticket archive system to have a faster system by moving some tickets out of the daily scope. To search for these tickets, the archive flag has to be enabled in the ticket search.'} = '';
    $Self->{Translation}->{'Activates time accounting.'} = '';
    $Self->{Translation}->{'Add a note to this ticket!'} = '';
    $Self->{Translation}->{'Adds a suffix with the actual year and month to the OTRS log file. A logfile for every month will be created.'} = '';
    $Self->{Translation}->{'Adds customers email addresses to recipients in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 1. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 2. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 3. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 4. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 5. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 6. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 7. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 8. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 9. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 1. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 2. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 3. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 4. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 5. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 6. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 7. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 8. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 9. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Admin'} = '';
    $Self->{Translation}->{'Admin Notification'} = '';
    $Self->{Translation}->{'Agent Notifications'} = '';
    $Self->{Translation}->{'Agent interface article notification module to check PGP.'} = '';
    $Self->{Translation}->{'Agent interface article notification module to check S/MIME.'} = '';
    $Self->{Translation}->{'Agent interface module to access fulltext search via nav bar.'} = '';
    $Self->{Translation}->{'Agent interface module to access search profiles via nav bar.'} = '';
    $Self->{Translation}->{'Agent interface module to check incoming emails in the Ticket-Zoom-View if the S/MIME-key is available and true.'} = '';
    $Self->{Translation}->{'Agent interface notification module to check the used charset.'} = '';
    $Self->{Translation}->{'Agent interface notification module to see the number of tickets an agent is responsible for.'} = '';
    $Self->{Translation}->{'Agent interface notification module to see the number of watched tickets.'} = '';
    $Self->{Translation}->{'Agents'} = '';
    $Self->{Translation}->{'Agents <-> Groups'} = '';
    $Self->{Translation}->{'Agents <-> Roles'} = '';
    $Self->{Translation}->{'Allows adding notes in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows agents to exchange the axis of a stat if they generate one.'} = '';
    $Self->{Translation}->{'Allows agents to generate individual-related stats.'} = '';
    $Self->{Translation}->{'Allows choosing between showing the attachments of a ticket in the browser (inline) or just make them downloadable (attachment).'} = '';
    $Self->{Translation}->{'Allows choosing the next compose state for customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to change the ticket priority in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket SLA in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket priority in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket queue in the customer interface. If this is set to \'No\', QueueDefault should be configured.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket service in the customer interface.'} = '';
    $Self->{Translation}->{'Allows defining new types for ticket (if ticket type feature is enabled).'} = '';
    $Self->{Translation}->{'Allows defining services and SLAs for tickets (e. g. email, desktop, network, ...), and escalation attributes for SLAs (if ticket service/SLA feature is enabled).'} = '';
    $Self->{Translation}->{'Allows extended search conditions in ticket search of the agent interface. With this feature you can search w. g. with this kind of conditions like "(key1&&key2)" or "(key1||key2)".'} = '';
    $Self->{Translation}->{'Allows extended search conditions in ticket search of the customer interface. With this feature you can search w. g. with this kind of conditions like "(key1&&key2)" or "(key1||key2)".'} = '';
    $Self->{Translation}->{'Allows having a medium format ticket overview (CustomerInfo => 1 - shows also the customer information).'} = '';
    $Self->{Translation}->{'Allows having a small format ticket overview (CustomerInfo => 1 - shows also the customer information).'} = '';
    $Self->{Translation}->{'Allows the administrators to login as other users, via the users administration panel.'} = '';
    $Self->{Translation}->{'Allows to set a new ticket state in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Article free text options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Attachments'} = '';
    $Self->{Translation}->{'Attachments <-> Responses'} = '';
    $Self->{Translation}->{'Auto Responses'} = '';
    $Self->{Translation}->{'Auto Responses <-> Queues'} = '';
    $Self->{Translation}->{'Automated line break in text messages after x number of chars.'} = '';
    $Self->{Translation}->{'Automatically lock and set owner to current Agent after selecting for an Bulk Action.'} = '';
    $Self->{Translation}->{'Automatically sets the owner of a ticket as the responsible for it (if ticket responsible feature is enabled).'} = '';
    $Self->{Translation}->{'Automatically sets the responsible of a ticket (if it is not set yet) after the first owner update.'} = '';
    $Self->{Translation}->{'Back'} = '';
    $Self->{Translation}->{'Balanced white skin by Felix Niklas.'} = '';
    $Self->{Translation}->{'Blocks all the incoming emails that do not have a valid ticket number in subject with From: @example.com address.'} = '';
    $Self->{Translation}->{'Builds an article index right after the article\'s creation.'} = '';
    $Self->{Translation}->{'CMD example setup. Ignores emails where external CMD returns some output on STDOUT (email will be piped into STDIN of some.bin).'} = '';
    $Self->{Translation}->{'CSV Separator'} = '';
    $Self->{Translation}->{'Change password'} = '';
    $Self->{Translation}->{'Change queue!'} = '';
    $Self->{Translation}->{'Change the ticket customer!'} = '';
    $Self->{Translation}->{'Change the ticket free fields!'} = '';
    $Self->{Translation}->{'Change the ticket owner!'} = '';
    $Self->{Translation}->{'Change the ticket priority!'} = '';
    $Self->{Translation}->{'Change the ticket responsible!'} = '';
    $Self->{Translation}->{'Changes the owner of tickets to everyone (useful for ASP). Normally only agent with rw permissions in the queue of the ticket will be shown.'} = '';
    $Self->{Translation}->{'Checks the SystemID in ticket number detection for follow-ups (use "No" if SystemID has been changed after using the system).'} = '';
    $Self->{Translation}->{'Close this ticket!'} = '';
    $Self->{Translation}->{'Comment for new history entries in the customer interface.'} = '';
    $Self->{Translation}->{'Companies'} = '';
    $Self->{Translation}->{'Company Tickets'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} = '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} = '';
    $Self->{Translation}->{'Configure your own log text for PGP.'} = '';
    $Self->{Translation}->{'Configures a default TicketFreeField setting. "Counter" defines the free text field which should be used, "Key" is the TicketFreeKey, "Value" is the TicketFreeText and "Event" defines the trigger event.'} = '';
    $Self->{Translation}->{'Configures a default TicketFreeField setting. "Counter" defines the free text field which should be used, "Key" is the TicketFreeKey, "Value" is the TicketFreeText and "Event" defines the trigger event. Please check the developer manual (http://doc.otrs.org/), chapter "Ticket Event Module".'} = '';
    $Self->{Translation}->{'Configures the full-text index. Execute "bin/otrs.RebuildFulltextIndex.pl" in order to generate a new index.'} = '';
    $Self->{Translation}->{'Controls if customers have the ability to sort their tickets.'} = '';
    $Self->{Translation}->{'Converts HTML mails into text messages.'} = '';
    $Self->{Translation}->{'Create and manage Service Level Agreements (SLAs).'} = '';
    $Self->{Translation}->{'Create and manage agents.'} = '';
    $Self->{Translation}->{'Create and manage attachments.'} = '';
    $Self->{Translation}->{'Create and manage companies.'} = '';
    $Self->{Translation}->{'Create and manage customers.'} = '';
    $Self->{Translation}->{'Create and manage event based notifications.'} = '';
    $Self->{Translation}->{'Create and manage groups.'} = '';
    $Self->{Translation}->{'Create and manage notifications that are sent to agents.'} = '';
    $Self->{Translation}->{'Create and manage queues.'} = '';
    $Self->{Translation}->{'Create and manage response templates.'} = '';
    $Self->{Translation}->{'Create and manage responses that are automatically sent.'} = '';
    $Self->{Translation}->{'Create and manage roles.'} = '';
    $Self->{Translation}->{'Create and manage salutations.'} = '';
    $Self->{Translation}->{'Create and manage services.'} = '';
    $Self->{Translation}->{'Create and manage signatures.'} = '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Create and manage ticket priorities.'} = '';
    $Self->{Translation}->{'Create and manage ticket states.'} = '';
    $Self->{Translation}->{'Create and manage ticket types.'} = '';
    $Self->{Translation}->{'Create new Ticket'} = '';
    $Self->{Translation}->{'Create new email ticket and send this out (outbound)'} = '';
    $Self->{Translation}->{'Create new phone ticket (inbound)'} = '';
    $Self->{Translation}->{'Custom text for the page shown to customers that have no tickets yet.'} = '';
    $Self->{Translation}->{'Customer Companies'} = '';
    $Self->{Translation}->{'Customer item (icon) which shows the open tickets of this customer as info block.'} = '';
    $Self->{Translation}->{'Customers'} = '';
    $Self->{Translation}->{'Customers <-> Groups'} = '';
    $Self->{Translation}->{'Customers <-> Services'} = '';
    $Self->{Translation}->{'Dashboard'} = '';
    $Self->{Translation}->{'Data used to export the search result in CSV format.'} = '';
    $Self->{Translation}->{'Debugs the translation set. If this is set to "Yes" all strings (text) without translations are written to STDERR. This can be helpful when you are creating a new translation file. Otherwise, this option should remain set to "No".'} = '';
    $Self->{Translation}->{'Default ACL values for ticket actions.'} = '';
    $Self->{Translation}->{'Default data to use on attribute for ticket search screen. Example: "TicketCreateTimePointFormat=year;TicketCreateTimePointStart=Last;TicketCreateTimePoint=2;".'} = '';
    $Self->{Translation}->{'Default data to use on attribute for ticket search screen. Example: "TicketCreateTimeStartYear=2010;TicketCreateTimeStartMonth=10;TicketCreateTimeStartDay=4;TicketCreateTimeStopYear=2010;TicketCreateTimeStopMonth=11;TicketCreateTimeStopDay=3;".'} = '';
    $Self->{Translation}->{'Default loop protection module.'} = '';
    $Self->{Translation}->{'Default queue ID used by the system in the agent interface.'} = '';
    $Self->{Translation}->{'Default skin for OTRS 3.0 interface.'} = '';
    $Self->{Translation}->{'Default skin for interface.'} = '';
    $Self->{Translation}->{'Default spelling dictionary'} = '';
    $Self->{Translation}->{'Default ticket ID used by the system in the agent interface.'} = '';
    $Self->{Translation}->{'Default ticket ID used by the system in the customer interface.'} = '';
    $Self->{Translation}->{'Define a filter for html output to add links behind a defined string. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Define the start day of the week for the date picker.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a LinkedIn icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a XING icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a google icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a google maps icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a default list of words, that are ignored by the spell checker.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind CVE numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind MSBulletin numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind a defined string. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind bugtraq numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter to process the text in the articles, in order to highlight predefined keywords.'} = '';
    $Self->{Translation}->{'Defines a regular expression that excludes some addresses from the syntax check (if "CheckEmailAddresses" is set to "Yes"). Please enter a regex in this field for email addresses, that aren\'t syntactically valid, but are necessary for the system (i.e. "root@localhost").'} = '';
    $Self->{Translation}->{'Defines a regular expression that filters all email addresses that should not be used in the application.'} = '';
    $Self->{Translation}->{'Defines a useful module to load specific user options or to display news.'} = '';
    $Self->{Translation}->{'Defines all the X-headers that should be scanned.'} = '';
    $Self->{Translation}->{'Defines all the languages that are available to the application. The Key/Content pair links the front-end display name to the appropriate language PM file. The "Key" value should be the base-name of the PM file (i.e. de.pm is the file, then de is the "Key" value). The "Content" value should be the display name for the front-end. Specify any own-defined language here (see the developer documentation http://doc.otrs.org/ for more infomation). Please remember to use the HTML equivalents for non-ASCII characters (i.e. for the German oe = o umlaut, it is necessary to use the &ouml; symbol).'} = '';
    $Self->{Translation}->{'Defines all the parameters for the RefreshTime object in the customer preferences of the customer interface.'} = '';
    $Self->{Translation}->{'Defines all the parameters for the ShownTickets object in the customer preferences of the customer interface.'} = '';
    $Self->{Translation}->{'Defines all the parameters for this item in the customer preferences.'} = '';
    $Self->{Translation}->{'Defines all the possible stats output formats.'} = '';
    $Self->{Translation}->{'Defines an alternate URL, where the login link refers to.'} = '';
    $Self->{Translation}->{'Defines an alternate URL, where the logout link refers to.'} = '';
    $Self->{Translation}->{'Defines an alternate login URL for the customer panel..'} = '';
    $Self->{Translation}->{'Defines an alternate logout URL for the customer panel.'} = '';
    $Self->{Translation}->{'Defines an external link to the database of the customer (e.g. \'http://yourhost/customer.php?CID=$Data{"CustomerID"}\' or \'\').'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} = '';
    $Self->{Translation}->{'Defines how the From field from the emails (sent from answers and email tickets) should look like.'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the close ticket screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket bounce screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket compose screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket forward screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket free text screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket merge screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket note screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket owner screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket pending screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket phone outbound screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket priority screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket responsible screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required to change the customer of a ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if composed messages have to be spell checked in the agent interface.'} = '';
    $Self->{Translation}->{'Defines if time accounting is mandatory in the agent interface.'} = '';
    $Self->{Translation}->{'Defines if time accounting must be set to all tickets in bulk action.'} = '';
    $Self->{Translation}->{'Defines the =hHeight for the rich text editor component. Enter number (pixels) or percent value (relative).'} = '';
    $Self->{Translation}->{'Defines the IP regular expression for accessing the local repository. You need to enable this to have access to your local repository and the package::RepositoryList is required on the remote host.'} = '';
    $Self->{Translation}->{'Defines the URL CSS path.'} = '';
    $Self->{Translation}->{'Defines the URL base path of icons, CSS and Java Script.'} = '';
    $Self->{Translation}->{'Defines the URL image path of icons for navigation.'} = '';
    $Self->{Translation}->{'Defines the URL java script path.'} = '';
    $Self->{Translation}->{'Defines the URL rich text editor path.'} = '';
    $Self->{Translation}->{'Defines the address of a dedicated DNS server, if necessary, for the "CheckMXRecord" look-ups.'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to agents, about new password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to agents, with token about new requested password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, about new account.'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, about new password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, with token about new requested password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for rejected emails.'} = '';
    $Self->{Translation}->{'Defines the boldness of the line drawed by the graph.'} = '';
    $Self->{Translation}->{'Defines the colors for the graphs.'} = '';
    $Self->{Translation}->{'Defines the column to store the keys for the preferences table.'} = '';
    $Self->{Translation}->{'Defines the config parameters of this item, to be shown in the preferences view.'} = '';
    $Self->{Translation}->{'Defines the config parameters of this item, to be shown in the preferences view. Take care to maintain the dictionaries installed in the system in the data section.'} = '';
    $Self->{Translation}->{'Defines the connections for http/ftp, via a proxy.'} = '';
    $Self->{Translation}->{'Defines the date input format used in forms (option or input fields).'} = '';
    $Self->{Translation}->{'Defines the default CSS used in rich text editors.'} = '';
    $Self->{Translation}->{'Defines the default body of a note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default front-end (HTML) theme to be used by the agents and customers. The default themes are Standard and Lite. If you like, you can add your own theme. Please refer the administrator manual located at http://doc.otrs.org/.'} = '';
    $Self->{Translation}->{'Defines the default front-end language. All the possible values are determined by the available language files on the system (see the next setting).'} = '';
    $Self->{Translation}->{'Defines the default history type in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default maximum number of X-axis attributes for the time scale.'} = '';
    $Self->{Translation}->{'Defines the default maximum number of search results shown on the overview page.'} = '';
    $Self->{Translation}->{'Defines the default next state for a ticket after customer follow up in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after being bounced, in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after being forwarded, in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket if it is composed / answered in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default note body text for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of follow up customer tickets in the ticket zoom screen in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of new tickets.'} = '';
    $Self->{Translation}->{'Defines the default queue for new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for dynamic objects (Form: Common Specification).'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for permissions (Form: Common Specification).'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for stats format (Form: Common Specification). Please insert the format key (see Stats::Format).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 1 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 1 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 10 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 11 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 12 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 13 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 14 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 15 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 16 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 2 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 2 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 3 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 3 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 4 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 5 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 6 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 7 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 8 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 9 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 1 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 1 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 10 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 11 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 12 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 13 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 14 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 15 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 16 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 2 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 2 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 3 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 3 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 4 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 5 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 6 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 7 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 8 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 9 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default sender type for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default sender type for tickets in the ticket zoom screen of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default shown ticket search attribute for ticket search screen.'} = '';
    $Self->{Translation}->{'Defines the default sort criteria for all queues displayed in the queue view, after sort by priority is done.'} = '';
    $Self->{Translation}->{'Defines the default sort order for all queues in the queue view, after priority sort.'} = '';
    $Self->{Translation}->{'Defines the default spell checker dictionary.'} = '';
    $Self->{Translation}->{'Defines the default state of new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default state of new tickets.'} = '';
    $Self->{Translation}->{'Defines the default subject for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default subject of a note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in a ticket search of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the escalation view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the locked ticket view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the responsible view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the status view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the watch view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting of the ticket search result of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket bounced notification for customer/sender in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket next state after adding a phone note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket order (after priority sort) in the escalation view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order (after priority sort) in the status view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the responsible view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the ticket locked view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the ticket search result of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the watch view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order of a search result in the customer interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type for article in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default type of forwarded message in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket zoom screen of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default used Frontend-Module if no Action parameter given in the url on the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default used Frontend-Module if no Action parameter given in the url on the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default value for the action parameter for the public frontend. The action parameter is used in the scripts of the system.'} = '';
    $Self->{Translation}->{'Defines the default viewable sender types of a ticket (default: customer).'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 1\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 2\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 3\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 4\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 5\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 6\'s default value.'} = '';
    $Self->{Translation}->{'Defines the filter that processes the text in the articles, in order to highlight URLs.'} = '';
    $Self->{Translation}->{'Defines the format of responses in the ticket compose screen of the agent interface ($QData{"OrigFrom"} is From 1:1, $QData{"OrigFromName"} is only realname of From).'} = '';
    $Self->{Translation}->{'Defines the free key field number 1 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 1 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 10 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 11 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 12 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 13 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 14 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 15 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 16 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 2 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 2 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 3 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 3 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 4 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 5 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 6 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 7 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 8 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 9 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 1 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 1 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 10 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 11 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 12 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 13 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 14 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 15 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 16 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 2 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 2 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 3 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 3 for ticket to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 4 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 5 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 6 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 7 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 8 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 9 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 1 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 2 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 3 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 4 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 5 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 6 for tickets.'} = '';
    $Self->{Translation}->{'Defines the fully qualified domain name of the system. This setting is used as a variable, OTRS_CONFIG_FQDN which is found in all forms of messaging used by the application, to build links to the tickets within your system.'} = '';
    $Self->{Translation}->{'Defines the groups every customer user will be in (if CustomerGroupSupport is enabled and you don\'t want to manage every user for these groups).'} = '';
    $Self->{Translation}->{'Defines the height of the legend.'} = '';
    $Self->{Translation}->{'Defines the history comment for the close ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the email ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the phone ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket free text screen action, which gets used for ticket history.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket note screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket owner screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket pending screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket phone outbound screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket priority screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket responsible screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket zoom action, which gets used for ticket history in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the close ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the email ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the phone ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket free text screen action, which gets used for ticket history.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket note screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket owner screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket pending screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket phone outbound screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket priority screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket responsible screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket zoom action, which gets used for ticket history in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 1, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 2, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 3, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 4, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 5, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 6, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 7, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 8, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 9, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days to count the working time.'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 1 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 10 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 11 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 12 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 13 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 14 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 15 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 16 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 2 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 3 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 4 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 5 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 6 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 7 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 8 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 9 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the key to be checked with Kernel::Modules::AgentInfo module. If this user preferences key is true, the message is accepted by the system.'} = '';
    $Self->{Translation}->{'Defines the key to check with CustomerAccept. If this user preferences key is true, then the message is accepted by the system.'} = '';
    $Self->{Translation}->{'Defines the link type \'Normal\'. If the source name and the target name contain the same value, the resulting link is a non-directional one; otherwise, the result is a directional link.'} = '';
    $Self->{Translation}->{'Defines the link type \'ParentChild\'. If the source name and the target name contain the same value, the resulting link is a non-directional one; otherwise, the result is a directional link.'} = '';
    $Self->{Translation}->{'Defines the link type groups. The link types of the same group cancel one another. Example: If ticket A is linked per a \'Normal\' link with ticket B, then these tickets could not be additionally linked with link of a \'ParentChild\' relationship.'} = '';
    $Self->{Translation}->{'Defines the list of online repositories. Another installations can be used as repository, for example: Key="http://example.com/otrs/public.pl?Action=PublicRepository;File=" and Content="Some Name".'} = '';
    $Self->{Translation}->{'Defines the location to get online repository list for additional packages. The first available result will be used.'} = '';
    $Self->{Translation}->{'Defines the log module for the system. "File" writes all messages in a given logfile, "SysLog" uses the syslog daemon of the system, e.g. syslogd.'} = '';
    $Self->{Translation}->{'Defines the maximal size (in bytes) for file uploads via the browser.'} = '';
    $Self->{Translation}->{'Defines the maximal valid time (in seconds) for a session id.'} = '';
    $Self->{Translation}->{'Defines the maximum number of pages per PDF file.'} = '';
    $Self->{Translation}->{'Defines the maximum size (in MB) of the log file.'} = '';
    $Self->{Translation}->{'Defines the module that shows all the currently loged in customers in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows all the currently logged in agents in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows the currently loged in agents in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows the currently loged in customers in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module to authenticate customers.'} = '';
    $Self->{Translation}->{'Defines the module to display a notification in the agent interface, if the system is used by the admin user (normally you shouldn\'t work as admin).'} = '';
    $Self->{Translation}->{'Defines the module to generate html refresh headers of html sites, in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module to generate html refresh headers of html sites.'} = '';
    $Self->{Translation}->{'Defines the module to send emails. "Sendmail" directly uses the sendmail binary of your operating system. Any of the "SMTP" mechanisms use a specified (external) mailserver. "DoNotSendEmail" doesn\'t send emails and it is useful for test systems.'} = '';
    $Self->{Translation}->{'Defines the module used to store the session data. With "DB" the frontend server can be splitted from the db server. "FS" is faster.'} = '';
    $Self->{Translation}->{'Defines the name of the application, shown in the web interface, tabs and title bar of the web browser.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 1.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 2.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 3.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 4.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 5.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 6.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 7.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 8.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 9.'} = '';
    $Self->{Translation}->{'Defines the name of the column to store the data in the preferences table.'} = '';
    $Self->{Translation}->{'Defines the name of the column to store the user identifier in the preferences table.'} = '';
    $Self->{Translation}->{'Defines the name of the key for customer sessions.'} = '';
    $Self->{Translation}->{'Defines the name of the session key. E.g. Session, SessionID or OTRS.'} = '';
    $Self->{Translation}->{'Defines the name of the table, where the customer preferences are stored.'} = '';
    $Self->{Translation}->{'Defines the next possible states after composing / answering a ticket in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next possible states after forwarding a ticket in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next possible states for customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after being bounced, in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after being moved to another queue, in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the parameters for the customer preferences table.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTL" indicates the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" defines the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Limit" defines the number of entries displayed by default. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTL" indicates the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Limit" defines the number of entries displayed by default. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" defines the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the password to access the SOAP handle (bin/cgi-bin/rpc.pl).'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold italic monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold italic proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle italic monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle italic proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path of the shown info file, that is located under Kernel/Output/HTML/Standard/CustomerAccept.dtl.'} = '';
    $Self->{Translation}->{'Defines the path to PGP binary.'} = '';
    $Self->{Translation}->{'Defines the path to open ssl binary. It may need a HOME env ($ENV{HOME} = \'/var/lib/wwwrun\';).'} = '';
    $Self->{Translation}->{'Defines the placement of the legend. This should be a two letter key of the form: \'B[LCR]|R[TCB]\'. The first letter indicates the placement (Bottom or Right), and the second letter the alignment (Left, Right, Center, Top, or Bottom).'} = '';
    $Self->{Translation}->{'Defines the postmaster default queue.'} = '';
    $Self->{Translation}->{'Defines the receipent target of the phone ticket and the sender of the email ticket ("Queue" shows all queues, "SystemAddress" displays all system addresses) in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the receipent target of the tickets ("Queue" shows all queues, "SystemAddress" displays all system addresses) in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the search limit for the stats.'} = '';
    $Self->{Translation}->{'Defines the separator between the agents real name and the given queue email address.'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} = '';
    $Self->{Translation}->{'Defines the spacing of the legends.'} = '';
    $Self->{Translation}->{'Defines the standard permissions available for customers within the application. If more permissions are needed, you can enter them here. Permissions must be hard coded to be effective. Please ensure, when adding any of the afore mentioned permissions, that the "rw" permission remains the last entry.'} = '';
    $Self->{Translation}->{'Defines the standard size of PDF pages.'} = '';
    $Self->{Translation}->{'Defines the state of a ticket if it gets a follow-up and the ticket was already closed.'} = '';
    $Self->{Translation}->{'Defines the state of a ticket if it gets a follow-up.'} = '';
    $Self->{Translation}->{'Defines the state type of the reminder for pending tickets.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to agents, about new password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to agents, with token about new requested password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, about new account.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, about new password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, with token about new requested password.'} = '';
    $Self->{Translation}->{'Defines the subject for rejected emails.'} = '';
    $Self->{Translation}->{'Defines the system administrator\'s email address. It will be displayed in the error screens of the application.'} = '';
    $Self->{Translation}->{'Defines the system identifier. Every ticket number and http session string contain this ID. This ensures that only tickets which belong to your system will be processed as follow-ups (useful when communicating between two instances of OTRS).'} = '';
    $Self->{Translation}->{'Defines the target attribute in the link to external customer database. E.g. \'target="cdb"\'.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 1, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 2, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 3, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 4, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 5, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 6, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 7, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 8, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 9, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the type of protocol, used by ther web server, to serve the application. If https protocol will be used instead of plain http, it must be specified it here. Since this has no affect on the web server\'s settings or behavior, it will not change the method of access to the application and, if it is wrong, it will not prevent you from logging into the application. This setting is used as a variable, OTRS_CONFIG_HttpType which is found in all forms of messaging used by the application, to build links to the tickets within your system.'} = '';
    $Self->{Translation}->{'Defines the used character for email quotes in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the user identifier for the customer panel.'} = '';
    $Self->{Translation}->{'Defines the username to access the SOAP handle (bin/cgi-bin/rpc.pl).'} = '';
    $Self->{Translation}->{'Defines the valid state types for a ticket.'} = '';
    $Self->{Translation}->{'Defines the valid states for unlocked tickets. To unlock tickets the script "bin/otrs.UnlockTickets.pl" can be used.'} = '';
    $Self->{Translation}->{'Defines the viewable locks of a ticket. Default: unlock, tmp_lock.'} = '';
    $Self->{Translation}->{'Defines the width for the rich text editor component. Enter number (pixels) or percent value (relative).'} = '';
    $Self->{Translation}->{'Defines the width of the legend.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 1.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 2.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 3.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 4.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 5.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 6.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 1 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 2 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 3 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 4 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 5 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 6 is optional or not.'} = '';
    $Self->{Translation}->{'Defines which states should be set automatically (Content), after the pending time of state (Key) has been reached.'} = '';
    $Self->{Translation}->{'Delay time between autocomplete queries.'} = '';
    $Self->{Translation}->{'Delete this ticket!'} = '';
    $Self->{Translation}->{'Deletes a session if the session id is used with an invalid remote IP address.'} = '';
    $Self->{Translation}->{'Deletes requested sessions if they have timed out.'} = '';
    $Self->{Translation}->{'Determines if the list of possible queues to move to ticket into should be displayed in a dropdown list or in a new window in the agent interface. If "New Window" is set you can add a move note to the ticket.'} = '';
    $Self->{Translation}->{'Determines if the search results container for the autocomplete feature should adjust its width dynamically.'} = '';
    $Self->{Translation}->{'Determines if the statatistics module may generate ticket lists.'} = '';
    $Self->{Translation}->{'Determines the next possible ticket states, after the creation of a new email ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Determines the next possible ticket states, after the creation of a new phone ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Determines the next screen after new customer ticket in the customer interface.'} = '';
    $Self->{Translation}->{'Determines the next screen after the follow up screen of a zoomed ticket in the customer interface.'} = '';
    $Self->{Translation}->{'Determines the possible states for pending tickets that changed state after reaching time limit.'} = '';
    $Self->{Translation}->{'Determines the strings that will be shown as receipent (To:) of the phone ticket and as sender (From:) of the email ticket in the agent interface. For Queue as NewQueueSelectionType "<Queue>" shows the names of the queues and for SystemAddress "<Realname> <<Email>>" shows the name and email of the receipent.'} = '';
    $Self->{Translation}->{'Determines the strings that will be shown as receipent (To:) of the ticket in the customer interface. For Queue as CustomerPanelSelectionType, "<Queue>" shows the names of the queues, and for SystemAddress, "<Realname> <<Email>>" shows the name and email of the receipent.'} = '';
    $Self->{Translation}->{'Determines the way the linked objects are displayed in each zoom mask.'} = '';
    $Self->{Translation}->{'Determines which options will be valid of the recepient (phone ticket) and the sender (email ticket) in the agent interface.'} = '';
    $Self->{Translation}->{'Determines which queues will be valid for ticket\'s recepients in the customer interface.'} = '';
    $Self->{Translation}->{'Disables sending reminder notifications to the responsible agent of a ticket (Ticket::Responsible needs to be activated).'} = '';
    $Self->{Translation}->{'Disables the web installer (http://yourhost.example.com/otrs/installer.pl), to prevent the system from being hijacked. If set to "No", the system can be reinstalled and the current basic configuration will be used to pre-populate the questions within the installer script. If not active, it also disables the GenericAgent, PackageManager and SQL Box (to avoid the use of destructive queries, such as DROP DATABASE, and also to steal user passwords).'} = '';
    $Self->{Translation}->{'Displays the accounted time for an article in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Email Addresses'} = '';
    $Self->{Translation}->{'Enables PDF output. The CPAN module PDF::API2 is required, if not installed, PDF output will be disabled.'} = '';
    $Self->{Translation}->{'Enables PGP support. When PGP support is enabled for signing and securing mail, it is HIGHLY recommended that the web server be run as the OTRS user. Otherwise, there will be problems with the privileges when accessing .gnupg folder.'} = '';
    $Self->{Translation}->{'Enables S/MIME support.'} = '';
    $Self->{Translation}->{'Enables customers to create their own accounts.'} = '';
    $Self->{Translation}->{'Enables file upload in the package manager frontend.'} = '';
    $Self->{Translation}->{'Enables or disable the debug mode over frontend interface.'} = '';
    $Self->{Translation}->{'Enables or disables the autocomplete feature for the customer search in the agent interface.'} = '';
    $Self->{Translation}->{'Enables or disables the ticket watcher feature, to keep track of tickets without being the owner nor the responsible.'} = '';
    $Self->{Translation}->{'Enables performance log (to log the page response time). It will affect the system performance. Frontend::Module###AdminPerformanceLog must be enabled.'} = '';
    $Self->{Translation}->{'Enables spell checker support.'} = '';
    $Self->{Translation}->{'Enables ticket bulk action feature for the agent frontend to work on more than one ticket at a time.'} = '';
    $Self->{Translation}->{'Enables ticket bulk action feature only for the listed groups.'} = '';
    $Self->{Translation}->{'Enables ticket responsible feature, to keep track of a specific ticket.'} = '';
    $Self->{Translation}->{'Enables ticket watcher feature only for the listed groups.'} = '';
    $Self->{Translation}->{'Escalation view'} = '';
    $Self->{Translation}->{'Event module registration. For more performance you can define a trigger event (e. g. Event => TicketCreate). This is only possible if all TicketFreeField elements need the same event.'} = '';
    $Self->{Translation}->{'Example for free text'} = '';
    $Self->{Translation}->{'Execute SQL statements.'} = '';
    $Self->{Translation}->{'Executes follow up checks on In-Reply-To or References headers for mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up mail attachments checks in  mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up mail body checks in mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up plain/raw mail checks in mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Experimental "Slim" skin which tries to save screen space for power users.'} = '';
    $Self->{Translation}->{'Exports the whole article tree in search result (it can affect the system performance).'} = '';
    $Self->{Translation}->{'Fetches packages via proxy. Overwrites "WebUserAgent::Proxy".'} = '';
    $Self->{Translation}->{'File that is displayed in the Kernel::Modules::AgentInfo module, if located under Kernel/Output/HTML/Standard/AgentInfo.dtl.'} = '';
    $Self->{Translation}->{'Filter incoming emails.'} = '';
    $Self->{Translation}->{'Forces encoding of outgoing emails (7bit|8bit|quoted-printable|base64).'} = '';
    $Self->{Translation}->{'Forces to choose a different ticket state (from current) after lock action. Define the current state as key, and the next state after lock action as content.'} = '';
    $Self->{Translation}->{'Forces to unlock tickets after being moved to another queue.'} = '';
    $Self->{Translation}->{'Frontend language'} = '';
    $Self->{Translation}->{'Frontend module registration (disable company link if no company feature is used).'} = '';
    $Self->{Translation}->{'Frontend module registration for the agent interface.'} = '';
    $Self->{Translation}->{'Frontend module registration for the customer interface.'} = '';
    $Self->{Translation}->{'Frontend theme'} = '';
    $Self->{Translation}->{'GenericAgent'} = '';
    $Self->{Translation}->{'Gives end users the possibility to override the separator character for CSV files, defined in the translation files.'} = '';
    $Self->{Translation}->{'Grants access, if the customer ID of the ticket matches the customer user\'s ID and the customer user has group permissions on the queue the ticket is in.'} = '';
    $Self->{Translation}->{'Groups'} = '';
    $Self->{Translation}->{'Helps to extend your articles full-text search (From, To, Cc, Subject and Body search). Runtime will do full-text searches on live data (it works fine for up to 50.000 tickets). StaticDB will strip all articles and will build an index after article creation, increasing fulltext searches about 50%. To create an initial index use "bin/otrs.RebuildFulltextIndex.pl".'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a database driver (normally autodetection is used) can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a password to connect to the customer table can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a username to connect to the customer table can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the DSN for the connection to the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the column name for the CustomerPassword in the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the crypt type of passwords must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the name of the column for the CustomerKey in the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the name of the table where your customer data should be stored must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a column for the identifiers in session table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a column for the values in session table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a table in database where session data will be stored must be specified.'} = '';
    $Self->{Translation}->{'If "FS" was selected for SessionModule, a directory where the session data will be stored must be specified.'} = '';
    $Self->{Translation}->{'If "HTTPBasicAuth" was selected for Customer::AuthModule, you can specify (by using a RegExp) to strip parts of REMOTE_USER (e. g. for to remove trailing domains). RegExp-Note, $1 will be the new Login.'} = '';
    $Self->{Translation}->{'If "HTTPBasicAuth" was selected for Customer::AuthModule, you can specify to strip leading parts of user names (e. g. for domains like example_domain\user to user).'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and if you want to add a suffix to every customer login name, specifiy it here, e. g. you just want to write the username user but in your LDAP directory exists user@domain.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and special paramaters are needed for the Net::LDAP perl module, you can specify them here. See "perldoc Net::LDAP" for more information about the parameters.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and your users have only anonymous access to the LDAP tree, but you want to search through the data, you can do this with a user who has access to the LDAP directory. Specify the password for this special user here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and your users have only anonymous access to the LDAP tree, but you want to search through the data, you can do this with a user who has access to the LDAP directory. Specify the username for this special user here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the BaseDN must be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the LDAP host can be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the user identifier must be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, user attributes can be specified. For LDAP posixGroups use UID, for non LDAP posixGroups use full user DN.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, you can specify access attributes here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, you can specify if the applications will stop if e. g. a connection to a server can\'t be established due to network problems.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::Authmodule, you can check if the user is allowed to authenticate because he is in a posixGroup, e.g. user needs to be in a group xyz to use OTRS. Specify the group, who may access the system.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected, you can add a filter to each LDAP query, e.g. (mail=*), (objectclass=user) or (!objectclass=computer).'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, the password to authenticate to the radius host must be specified.'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, the radius host must be specified.'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, you can specify if the applications will stop if e. g. a connection to a server can\'t be established due to network problems.'} = '';
    $Self->{Translation}->{'If "Sendmail" was selected as SendmailModule, the location of the sendmail binary and the needed options must be specified.'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, a special log facility can be specified.'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, a special log sock can be specified (on solaris you may need to use \'stream\').'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, the charset that should be used for logging can be specified.'} = '';
    $Self->{Translation}->{'If "file" was selected for LogModule, a logfile must be specified. If the file doesn\'t exist, it will be created by the system.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, and authentication to the mail server is needed, a password must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, and authentication to the mail server is needed, an username must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, the mailhost that sends out the mails must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, the port where your mailserver is listening for incoming connections must be specified.'} = '';
    $Self->{Translation}->{'If configured, all emails sent by the application will contain an X-Header with this organization or company name.'} = '';
    $Self->{Translation}->{'If enabled, OTRS will deliver all CSS files in minified form. WARNING: If you turn this off, there will likely be problems in IE 7, because it cannot load more than 32 CSS files.'} = '';
    $Self->{Translation}->{'If enabled, OTRS will deliver all JavaScript files in minified form.'} = '';
    $Self->{Translation}->{'If enabled, TicketPhone and TicketEmail will be open in new windows.'} = '';
    $Self->{Translation}->{'If enabled, the OTRS version tag will be removed from the HTTP headers.'} = '';
    $Self->{Translation}->{'If enabled, the QueueView will automatically refresh after the specified time.'} = '';
    $Self->{Translation}->{'If enabled, the first level of the main menu opens on mouse hover (instead of click only).'} = '';
    $Self->{Translation}->{'If set, this address is used as envelope from header in outgoing notifications. If no address is specified, the envelope from header is empty.'} = '';
    $Self->{Translation}->{'If this regex matches, no message will be send by the autoresponder.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, specify the DSN to this database.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, the password to authenticate to this database can be specified.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, the user to authenticate to this database can be specified.'} = '';
    $Self->{Translation}->{'Ignore article with system sender type for new article feature (e. g. auto responses or email notifications).'} = '';
    $Self->{Translation}->{'Import'} = '';
    $Self->{Translation}->{'Includes article create times in the ticket search of the agent interface.'} = '';
    $Self->{Translation}->{'IndexAccelerator: to choose your backend TicketViewAccelerator module. "RuntimeDB" generates each queue view on the fly from ticket table (no performance problems up to approx. 60.000 tickets in total and 6.000 open tickets in the system). "StaticDB" is the most powerful module, it uses an extra ticket-index table that works like a view (recommended if more than 80.000 and 6.000 open tickets are stored in the system). Use the script "bin/otrs.RebuildTicketIndex.pl" for initial index update.'} = '';
    $Self->{Translation}->{'Install ispell or aspell on the system, if you want to use a spell checker. Please specify the path to the aspell or ispell binary on your operating system.'} = '';
    $Self->{Translation}->{'Interface language'} = '';
    $Self->{Translation}->{'It is possible to configure different skins, for example to distinguish between diferent agents, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid skin on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'It is possible to configure different skins, for example to distinguish between diferent customers, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid skin on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'It is possible to configure different themes, for example to distinguish between agents and customers, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid theme on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'Language'} = '';
    $Self->{Translation}->{'Link agents to groups.'} = '';
    $Self->{Translation}->{'Link agents to roles.'} = '';
    $Self->{Translation}->{'Link attachments to responses templates.'} = '';
    $Self->{Translation}->{'Link customers to groups.'} = '';
    $Self->{Translation}->{'Link customers to services.'} = '';
    $Self->{Translation}->{'Link queues to auto responses.'} = '';
    $Self->{Translation}->{'Link responses to queues.'} = '';
    $Self->{Translation}->{'Link roles to groups.'} = '';
    $Self->{Translation}->{'Link this ticket to other objects!'} = '';
    $Self->{Translation}->{'Links 2 tickets with a "Normal" type link.'} = '';
    $Self->{Translation}->{'Links 2 tickets with a "ParentChild" type link.'} = '';
    $Self->{Translation}->{'List of CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE6-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE7-specific CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of IE7-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE8-specific CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of IE8-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of JS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of JS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'Log file for the ticket counter.'} = '';
    $Self->{Translation}->{'Look into a ticket!'} = '';
    $Self->{Translation}->{'Makes the application check the MX record of email addresses before sending an email or submitting a telephone or email ticket.'} = '';
    $Self->{Translation}->{'Makes the application check the syntax of email addresses.'} = '';
    $Self->{Translation}->{'Makes the picture transparent.'} = '';
    $Self->{Translation}->{'Makes the session management use html cookies. If html cookies are disabled or if the client browser disabled html cookies, then the system will work as usual and append the session id to the links.'} = '';
    $Self->{Translation}->{'Manage PGP keys for email encryption.'} = '';
    $Self->{Translation}->{'Manage POP3 or IMAP accounts to fetch email from.'} = '';
    $Self->{Translation}->{'Manage S/MIME certificates for email encryption.'} = '';
    $Self->{Translation}->{'Manage existing sessions.'} = '';
    $Self->{Translation}->{'Manage periodic tasks.'} = '';
    $Self->{Translation}->{'Mark as Spam!'} = '';
    $Self->{Translation}->{'Max size (in characters) of the customer information table (phone and email) in the compose screen.'} = '';
    $Self->{Translation}->{'Max size of the subjects in an email reply.'} = '';
    $Self->{Translation}->{'Max. displayed tickets'} = '';
    $Self->{Translation}->{'Maximal auto email responses to own email-address a day (Loop-Protection).'} = '';
    $Self->{Translation}->{'Maximal size in KBytes for mails that can be fetched via POP3/POP3S/IMAP/IMAPS (KBytes).'} = '';
    $Self->{Translation}->{'Maximum number of tickets to be displayed in the result of a search in the agent interface.'} = '';
    $Self->{Translation}->{'Maximum number of tickets to be displayed in the result of a search in the customer interface.'} = '';
    $Self->{Translation}->{'Maximum size (in characters) of the customer info table in the queue view.'} = '';
    $Self->{Translation}->{'Maximum size (in characters) of the customer information table in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Merge this ticket!'} = '';
    $Self->{Translation}->{'Module for To-selection in new ticket screen in the customer interface.'} = '';
    $Self->{Translation}->{'Module to check customer permissions.'} = '';
    $Self->{Translation}->{'Module to check if a user is in a special group. Access is granted, if the user is in the specified group and has ro and rw permissions.'} = '';
    $Self->{Translation}->{'Module to check if arrived emails should be marked as email-internal (because of original forwared internal email it college). ArticleType and SenderType define the values for the arrived email/article.'} = '';
    $Self->{Translation}->{'Module to check the agent responsible of a ticket.'} = '';
    $Self->{Translation}->{'Module to check the group permissions for the access to customer tickets.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} = '';
    $Self->{Translation}->{'Module to check the owner of a ticket.'} = '';
    $Self->{Translation}->{'Module to check the watcher agents of a ticket.'} = '';
    $Self->{Translation}->{'Module to compose signed messages (PGP or S/MIME).'} = '';
    $Self->{Translation}->{'Module to crypt composed messages (PGP or S/MIME).'} = '';
    $Self->{Translation}->{'Module to filter and manipulate incoming messages. Block/ignore all spam email with From: noreply@ address.'} = '';
    $Self->{Translation}->{'Module to filter and manipulate incoming messages. Get a 4 digit number to ticket free text, use regex in Match e. g. From => \'(.+?)@.+?\', and use () as [***] in Set =>.'} = '';
    $Self->{Translation}->{'Module to generate accounted time ticket statistics.'} = '';
    $Self->{Translation}->{'Module to generate html OpenSearch profile for short ticket search in the agent interface.'} = '';
    $Self->{Translation}->{'Module to generate html OpenSearch profile for short ticket search in the customer interface.'} = '';
    $Self->{Translation}->{'Module to generate ticket solution and response time statistics.'} = '';
    $Self->{Translation}->{'Module to generate ticket statistics.'} = '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Module to inform agents, via the agent interface, about the used charset. A notification is displayed, if the default charset is not used, e.g. in tickets.'} = '';
    $Self->{Translation}->{'Module to show notifications and escalations (ShownMax: max. shown escalations, EscalationInMinutes: Show ticket which will escalation in, CacheTime: Cache of calculated escalations in seconds).'} = '';
    $Self->{Translation}->{'Module to use database filter storage.'} = '';
    $Self->{Translation}->{'My Queues'} = '';
    $Self->{Translation}->{'My Tickets'} = '';
    $Self->{Translation}->{'Name of custom queue. The custom queue is a queue selection of your preferred queues and can be selected in the preferences settings.'} = '';
    $Self->{Translation}->{'New'} = '';
    $Self->{Translation}->{'New Ticket'} = '';
    $Self->{Translation}->{'New email ticket'} = '';
    $Self->{Translation}->{'New phone ticket'} = '';
    $Self->{Translation}->{'New ticket notification'} = '';
    $Self->{Translation}->{'Next possible ticket states after adding a phone note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Notifications (Event)'} = '';
    $Self->{Translation}->{'Number of displayed tickets'} = '';
    $Self->{Translation}->{'Number of lines (per ticket) that are shown by the search utility in the agent interface.'} = '';
    $Self->{Translation}->{'Number of tickets to be displayed in each page of a search result in the agent interface.'} = '';
    $Self->{Translation}->{'Number of tickets to be displayed in each page of a search result in the customer interface.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} = '';
    $Self->{Translation}->{'Out Of Office Time'} = '';
    $Self->{Translation}->{'Overloads (redefines) existing functions in Kernel::System::Ticket. Used to easily add customizations.'} = '';
    $Self->{Translation}->{'Overview'} = '';
    $Self->{Translation}->{'Overview Escalated Tickets'} = '';
    $Self->{Translation}->{'Overview of all open Tickets'} = '';
    $Self->{Translation}->{'Overview of all open Tickets.'} = '';
    $Self->{Translation}->{'PGP Key'} = '';
    $Self->{Translation}->{'PGP Key Upload'} = '';
    $Self->{Translation}->{'PGP Keys'} = '';
    $Self->{Translation}->{'Package Manager'} = '';
    $Self->{Translation}->{'Parameters for the CreateNextMask object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the CustomQueue object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the FollowUpNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the LockTimeoutNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the MoveNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the NewTicketNotify object in the preferences view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the RefreshTime object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the WatcherNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the new tickets overview of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket calendar of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket escalation overview of the agent interface . "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket pending reminder overview of the agent interface . "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket pending reminder overview of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket stats of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the medium ticket overview.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the small ticket overview.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the ticket preview overview.'} = '';
    $Self->{Translation}->{'Parameters of the example SLA attribute Comment2.'} = '';
    $Self->{Translation}->{'Parameters of the example queue attribute Comment2.'} = '';
    $Self->{Translation}->{'Parameters of the example service attribute Comment2.'} = '';
    $Self->{Translation}->{'Path for the log file (it only applies if "FS" was selected for LoopProtectionModule and it is mandatory).'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the QueueObject object for the agent interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the QueueObject object for the customer interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the TicketObject for the agent interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the TicketObject for the customer interface.'} = '';
    $Self->{Translation}->{'Performance Log'} = '';
    $Self->{Translation}->{'Permitted width for compose email windows.'} = '';
    $Self->{Translation}->{'Permitted width for compose note windows.'} = '';
    $Self->{Translation}->{'PostMaster Filters'} = '';
    $Self->{Translation}->{'PostMaster Mail Accounts'} = '';
    $Self->{Translation}->{'Print this ticket!'} = '';
    $Self->{Translation}->{'Priorities'} = '';
    $Self->{Translation}->{'Protection against CSRF (Cross Site Request Forgery) exploits (for more info see http://en.wikipedia.org/wiki/Cross-site_request_forgery).'} = '';
    $Self->{Translation}->{'Queue view'} = '';
    $Self->{Translation}->{'QueueView Refresh Time'} = '';
    $Self->{Translation}->{'Queues'} = '';
    $Self->{Translation}->{'Refresh QueueView after'} = '';
    $Self->{Translation}->{'Refresh interval'} = '';
    $Self->{Translation}->{'Replaces the original sender with current customer\'s email address on compose answer in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to change the customer of a ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the close ticket screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket bounce screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket compose screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket forward screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket free text screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket merge screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket note screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket phone outbound screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket responsible screen in the agent interface.'} = '';
    $Self->{Translation}->{'Resets and unlocks the owner of a ticket if it was moved to another queue.'} = '';
    $Self->{Translation}->{'Responses'} = '';
    $Self->{Translation}->{'Responses <-> Queues'} = '';
    $Self->{Translation}->{'Restores a ticket from the archive (only if the event is a state change, from closed to any open available state).'} = '';
    $Self->{Translation}->{'Roles'} = '';
    $Self->{Translation}->{'Roles <-> Groups'} = '';
    $Self->{Translation}->{'Runs an initial wildcard search of the existing customer users when accessing the AdminCustomerUser module.'} = '';
    $Self->{Translation}->{'Runs the system in "Demo" mode. If set to "Yes", agents can change preferences, such as selection of language and theme via the agent web interface. These changes are only valid for the current session. It will not be possible for agents to change their passwords.'} = '';
    $Self->{Translation}->{'S/MIME Certificate'} = '';
    $Self->{Translation}->{'S/MIME Certificate Upload'} = '';
    $Self->{Translation}->{'S/MIME Certificates'} = '';
    $Self->{Translation}->{'SQL Box'} = '';
    $Self->{Translation}->{'Salutations'} = '';
    $Self->{Translation}->{'Saves the attachments of articles. "DB" stores all data in the database (not recommended for storing big attachments). "FS" stores the data on the filesystem; this is faster but the webserver should run under the OTRS user. You can switch between the modules even on a system that is already in production without any loss of data.'} = '';
    $Self->{Translation}->{'Saves the login and password on the session table in the database, if "DB" was selected for SessionModule.'} = '';
    $Self->{Translation}->{'Screen after new ticket'} = '';
    $Self->{Translation}->{'Search Tickets'} = '';
    $Self->{Translation}->{'Search backend default router.'} = '';
    $Self->{Translation}->{'Search backend router.'} = '';
    $Self->{Translation}->{'Select the separator character used in CSV files (stats and searches). If you don\'t select a separator here, the default separator for your language will be used.'} = '';
    $Self->{Translation}->{'Select your frontend Theme.'} = '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} = '';
    $Self->{Translation}->{'Selects the module to handle uploads via the web interface. "DB" stores all uploads in the database, "FS" uses the file system.'} = '';
    $Self->{Translation}->{'Selects the ticket number generator module. "AutoIncrement" increments the ticket number, the SystemID and the counter are used with SystemID.counter format (e.g. 1010138, 1010139). With "Date" the ticket numbers will be generated by the current date, the SystemID and the counter. The format looks like Year.Month.Day.SystemID.counter (e.g. 200206231010138, 200206231010139). With "DateChecksum"  the counter will be appended as checksum to the string of date and SystemID. The checksum will be rotated on a daily basis. The format looks like Year.Month.Day.SystemID.Counter.CheckSum (e.g. 2002070110101520, 2002070110101535). "Random" generates randomized ticket numbers in the format "SystemID.Random" (e.g. 100057866352, 103745394596).'} = '';
    $Self->{Translation}->{'Send me a notification if a customer sends a follow up and I\'m the owner of the ticket or the ticket is unlocked and is in one of my subscribed queues.'} = '';
    $Self->{Translation}->{'Send me a notification if a ticket is moved into one of "My Queues".'} = '';
    $Self->{Translation}->{'Send me a notification if a ticket is unlocked by the system.'} = '';
    $Self->{Translation}->{'Send me a notification if there is a new ticket in "My Queues".'} = '';
    $Self->{Translation}->{'Send me the same notifications for my watched tickets that the ticket owners will get.'} = '';
    $Self->{Translation}->{'Send new ticket notifications'} = '';
    $Self->{Translation}->{'Send notifications to users.'} = '';
    $Self->{Translation}->{'Send ticket follow up notifications'} = '';
    $Self->{Translation}->{'Send ticket lock timeout notifications'} = '';
    $Self->{Translation}->{'Send ticket move notifications'} = '';
    $Self->{Translation}->{'Send ticket watch notifications'} = '';
    $Self->{Translation}->{'Sender type for new tickets from the customer inteface.'} = '';
    $Self->{Translation}->{'Sends agent follow-up notification only to the owner, if a ticket is unlocked (the default is to send the notification to all agents).'} = '';
    $Self->{Translation}->{'Sends all outgoing email via bcc to the specified address. Please use this only for backup reasons.'} = '';
    $Self->{Translation}->{'Sends customer notifications just to the mapped customer. Normally, if no customer is mapped, the latest customer sender gets the notification.'} = '';
    $Self->{Translation}->{'Sends reminder notifications of unlocked ticket after reaching the reminder date (only sent to ticket owner).'} = '';
    $Self->{Translation}->{'Sends the notifications which are configured in the admin interface under "Notfication (Event)".'} = '';
    $Self->{Translation}->{'Service Level Agreements'} = '';
    $Self->{Translation}->{'Services'} = '';
    $Self->{Translation}->{'Session Management'} = '';
    $Self->{Translation}->{'Set sender email addresses for this system.'} = '';
    $Self->{Translation}->{'Set the default height (in pixels) of inline HTML articles in AgentTicketZoom.'} = '';
    $Self->{Translation}->{'Set the maximum height (in pixels) of inline HTML articles in AgentTicketZoom.'} = '';
    $Self->{Translation}->{'Set this ticket to pending!'} = '';
    $Self->{Translation}->{'Set this to yes if you trust in all your public and private pgp keys, even if they are not certified with a trusted signature.'} = '';
    $Self->{Translation}->{'Sets if ticket owner must be selected by the agent.'} = '';
    $Self->{Translation}->{'Sets the PendingTime of a ticket to 0 if the state is changed to a non-pending state.'} = '';
    $Self->{Translation}->{'Sets the age in minutes (first level) for highlighting queues that contain untouched tickets.'} = '';
    $Self->{Translation}->{'Sets the age in minutes (second level) for highlighting queues that contain untouched tickets.'} = '';
    $Self->{Translation}->{'Sets the configuration level of the administrator. Depending on the config level, some sysconfig options will be not shown. The config levels are in in ascending order: Expert, Advanced, Beginner. The higher the config level is (e.g. Beginner is the highest), the less likely is it that the user can accidentally configure the system in a way that it is not usable any more.'} = '';
    $Self->{Translation}->{'Sets the default article type for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default article type for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket move screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default charset for the web interface to use (should represent the charset used to create the database or, in some cases, the database management system being used). "utf-8" is a good choice for environments expecting many charsets. You can specify another charset here (i.e. "iso-8859-1"). Please be sure that you will not be receiving foreign emails, or text, otherwise this could lead to problems.'} = '';
    $Self->{Translation}->{'Sets the default link type of splitted tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default next state for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default next ticket state, after the creation of an email ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default note text for new telephone tickets. E.g \'New ticket via call\' in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default priority for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default priority for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default sender type for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default sender type for new phone ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for new email tickets (e.g. \'email Outbound\') in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for new phone tickets (e.g. \'Phone call\') in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket move screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default text for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the display order of the different items in the preferences view.'} = '';
    $Self->{Translation}->{'Sets the inactivity time (in seconds) to pass before a session is killed and a user is loged out.'} = '';
    $Self->{Translation}->{'Sets the minimal ticket counter size (if "AutoIncrement" was selected as TicketNumberGenerator). Default is 5, this means the counter starts from 10000.'} = '';
    $Self->{Translation}->{'Sets the minimum number of characters before autocomplete query is sent.'} = '';
    $Self->{Translation}->{'Sets the number of lines that are displayed in text messages (e.g. ticket lines in the QueueZoom).'} = '';
    $Self->{Translation}->{'Sets the number of lines that are displayed in the preview of messages (e.g. for tickets in the QueueView).'} = '';
    $Self->{Translation}->{'Sets the number of search results to be displayed for the autocomplete feature.'} = '';
    $Self->{Translation}->{'Sets the options for PGP binary.'} = '';
    $Self->{Translation}->{'Sets the order of the different items in the customer preferences view.'} = '';
    $Self->{Translation}->{'Sets the password for private PGP key.'} = '';
    $Self->{Translation}->{'Sets the prefered time units (e.g. work units, hours, minutes).'} = '';
    $Self->{Translation}->{'Sets the prefix to the scripts folder on the server, as configured on the web server. This setting is used as a variable, OTRS_CONFIG_ScriptAlias which is found in all forms of messaging used by the application, to build links to the tickets within the system.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the service in the close ticket screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket free text screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket note screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket owner screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket pending screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket priority screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket responsible screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the size of the statistic graph.'} = '';
    $Self->{Translation}->{'Sets the stats hook.'} = '';
    $Self->{Translation}->{'Sets the system time zone (required a system with UTC as system time). Otherwise this is a diff time to the local time.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket type in the close ticket screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket free text screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket note screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket owner screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket pending screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket priority screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket responsible screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the time type which should be shown.'} = '';
    $Self->{Translation}->{'Sets the timeout (in seconds) for http/ftp downloads.'} = '';
    $Self->{Translation}->{'Sets the timeout (in seconds) for package downloads. Overwrites "WebUserAgent::Timeout".'} = '';
    $Self->{Translation}->{'Sets the user time zone per user (required a system with UTC as system time and UTC under TimeZone). Otherwise this is a diff time to the local time.'} = '';
    $Self->{Translation}->{'Sets the user time zone per user based on java script / browser time zone offset feature at login time.'} = '';
    $Self->{Translation}->{'Show a responsible selection in phone and email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Show article as rich text even if rich text writing is disabled.'} = '';
    $Self->{Translation}->{'Show this screen after I created a new ticket'} = '';
    $Self->{Translation}->{'Shows a count of icons in the ticket zoom, if the article has attachments.'} = '';
    $Self->{Translation}->{'Shows a link in the menu for subscribing / unsubscribing from a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a ticket with another object in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows merging tickets in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a free text field in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a note in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a note to a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to close a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to close a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to delete a ticket in every ticket overview of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to delete a ticket in the ticket zoom view of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to lock / unlock a ticket in the ticket overviews of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to lock/unlock tickets in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to move a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to print a ticket or an article in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the customer who requested the ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the history of a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the owner of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the priority of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the responsible agent of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set a ticket as pending in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set a ticket as spam in every ticket overview of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set the priority of a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to zoom a ticket in the ticket overviews of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to access article attachments via a html online viewer in the zoom view of the article in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to download article attachments in the zoom view of the article in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to see a zoomed email ticket in plain text.'} = '';
    $Self->{Translation}->{'Shows a link to set a ticket as spam in the ticket zoom view of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a preview of the ticket overview (CustomerInfo => 1 - shows also Customer-Info, CustomerInfoMaxSize max. size in characters of Customer-Info).'} = '';
    $Self->{Translation}->{'Shows all both ro and rw queues in the queue view.'} = '';
    $Self->{Translation}->{'Shows all open tickets (even if they are locked) in the escalation view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows all open tickets (even if they are locked) in the status view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows all the articles of the ticket (expanded) in the zoom view.'} = '';
    $Self->{Translation}->{'Shows all the customer identifiers in a multi-select field (not useful if you have a lot of customer identifiers).'} = '';
    $Self->{Translation}->{'Shows an owner selection in phone and email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Shows customer history tickets in AgentTicketPhone, AgentTicketEmail and AgentTicketCustomer.'} = '';
    $Self->{Translation}->{'Shows either the last customer article\'s subject or the ticket title in the small format overview.'} = '';
    $Self->{Translation}->{'Shows existing parent/child queue lists in the system in the form of a tree or a list.'} = '';
    $Self->{Translation}->{'Shows the activated ticket attributes in the customer interface (0 = Disabled and 1 = Enabled).'} = '';
    $Self->{Translation}->{'Shows the articles sorted normally or in reverse, under ticket zoom in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the customer user information (phone and email) in the compose screen.'} = '';
    $Self->{Translation}->{'Shows the customer user\'s info in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Shows the message of the day (MOTD) in the agent dashboard. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually.'} = '';
    $Self->{Translation}->{'Shows the message of the day on login screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket history (reverse ordered) in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket history!'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows time in long format (days, hours, minutes), if set to "Yes"; or in short format (days, hours), if set to "No".'} = '';
    $Self->{Translation}->{'Shows time use complete description (days, hours, minutes), if set to "Yes"; or just first letter (d, h, m), if set to "No".'} = '';
    $Self->{Translation}->{'Signatures'} = '';
    $Self->{Translation}->{'Skin'} = '';
    $Self->{Translation}->{'Sorts the tickets (ascendingly or descendingly) when a single queue is selected in the queue view and after the tickets are sorted by priority. Values: 0 = ascending (oldest on top, default), 1 = descending (youngest on top). Use the QueueID for the key and 0 or 1 for value.'} = '';
    $Self->{Translation}->{'Spam Assassin example setup. Ignores emails that are marked with SpamAssassin.'} = '';
    $Self->{Translation}->{'Spam Assassin example setup. Moves marked mails to spam queue.'} = '';
    $Self->{Translation}->{'Specifies if an agent should receive email notification of his own actions.'} = '';
    $Self->{Translation}->{'Specifies the background color of the chart.'} = '';
    $Self->{Translation}->{'Specifies the background color of the picture.'} = '';
    $Self->{Translation}->{'Specifies the border color of the chart.'} = '';
    $Self->{Translation}->{'Specifies the border color of the legend.'} = '';
    $Self->{Translation}->{'Specifies the bottom margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the different article types that will be used in the system.'} = '';
    $Self->{Translation}->{'Specifies the different note types that will be used in the system.'} = '';
    $Self->{Translation}->{'Specifies the directory to store the data in, if "FS" was selected for TicketStorageModule.'} = '';
    $Self->{Translation}->{'Specifies the directory where SSL certificates are stored.'} = '';
    $Self->{Translation}->{'Specifies the directory where private SSL certificates are stored.'} = '';
    $Self->{Translation}->{'Specifies the email address that should be used by the application when sending notifications. The email address is used to build the complete display name for the notification master (i.e. "OTRS Notification Master" otrs@your.example.com). You can use the OTRS_CONFIG_FQDN variable as set in your configuation, or choose another email address. Notifications are messages such as en::Customer::QueueUpdate or en::Agent::Move.'} = '';
    $Self->{Translation}->{'Specifies the left margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the name that should be used by the application when sending notifications. The sender name is used to build the complete display name for the notification master (i.e. "OTRS Notification Master" otrs@your.example.com). Notifications are messages such as en::Customer::QueueUpdate or en::Agent::Move.'} = '';
    $Self->{Translation}->{'Specifies the path of the file for the logo in the page header (gif|jpg|png, 700 x 100 pixel).'} = '';
    $Self->{Translation}->{'Specifies the path of the file for the performance log.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of Microsoft Excel files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of Microsoft Word files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of PDF documents, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of XML files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the right margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the text color of the chart (e. g. caption).'} = '';
    $Self->{Translation}->{'Specifies the text color of the legend.'} = '';
    $Self->{Translation}->{'Specifies the text that should appear in the log file to denote a CGI script entry.'} = '';
    $Self->{Translation}->{'Specifies the top margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies user id of the postmaster data base.'} = '';
    $Self->{Translation}->{'Spelling Dictionary'} = '';
    $Self->{Translation}->{'Standard available permissions for agents within the application. If more permissions are needed, they can be entered here. Permissions must be defined to be effective. Some other good permissions have also been provided built-in: note, close, pending, customer, freetext, move, compose, responsible, forward, and bounce. Make sure that "rw" is always the last registered permission.'} = '';
    $Self->{Translation}->{'Start number for statistics counting. Every new stat increments this number.'} = '';
    $Self->{Translation}->{'States'} = '';
    $Self->{Translation}->{'Statistics'} = '';
    $Self->{Translation}->{'Status view'} = '';
    $Self->{Translation}->{'Stores cookies after the browser has been closed.'} = '';
    $Self->{Translation}->{'Strips empty lines on the ticket preview in the queue view.'} = '';
    $Self->{Translation}->{'System Log'} = '';
    $Self->{Translation}->{'The "bin/PostMasterMailAccount.pl" will reconnect to POP3/POP3S/IMAP/IMAPS host after the specified count of messages.'} = '';
    $Self->{Translation}->{'The agent skin\'s InternalName which should be used in the agent interface. Please check the available skins in Frontend::Agent::Skins.'} = '';
    $Self->{Translation}->{'The customer skin\'s InternalName which should be used in the customer interface. Please check the available skins in Frontend::Customer::Skins.'} = '';
    $Self->{Translation}->{'The divider between TicketHook and ticket number. E.g \': \'.'} = '';
    $Self->{Translation}->{'The format of the subject. \'Left\' means \'[TicketHook#:12345] Some Subject\', \'Right\' means \'Some Subject [TicketHook#:12345]\', \'None\' means \'Some Subject\' and no ticket number. In the last case you should enable PostmasterFollowupSearchInRaw or PostmasterFollowUpSearchInReferences to recognize followups based on email headers and/or body.'} = '';
    $Self->{Translation}->{'The headline shown in the customer interface.'} = '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} = '';
    $Self->{Translation}->{'The identifier for a ticket, e.g. Ticket#, Call#, MyTicket#. The default is Ticket#.'} = '';
    $Self->{Translation}->{'The logo shown in the header of the agent interface. The URL to the image must be a relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The logo shown in the header of the customer interface. The URL to the image must be a relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The logo shown on top of the login box of the agent interface. The URL to the image must be relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The text at the beginning of the subject in an email reply, e.g. RE, AW, or AS.'} = '';
    $Self->{Translation}->{'The text at the beginning of the subject when an email is forwarded, e.g. FW, Fwd, or WG.'} = '';
    $Self->{Translation}->{'Theme'} = '';
    $Self->{Translation}->{'This module and its PreRun() function will be executed, if defined, for every request. This module is useful to check some user options or to display news about new applications.'} = '';
    $Self->{Translation}->{'Ticket Overview "Medium" Limit'} = '';
    $Self->{Translation}->{'Ticket Overview "Preview" Limit'} = '';
    $Self->{Translation}->{'Ticket Overview "Small" Limit'} = '';
    $Self->{Translation}->{'Ticket follow up notification'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the move ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket forward screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket search of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket search screen in the customer interface. Possible settings: 0 = Disabled and 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the move ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket forward screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket search of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket search screen in the customer interface. Possible settings: 0 = Disabled and 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Medium"'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Preview"'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Small"'} = '';
    $Self->{Translation}->{'Ticket lock timeout notification'} = '';
    $Self->{Translation}->{'Ticket move notification'} = '';
    $Self->{Translation}->{'Ticket overview'} = '';
    $Self->{Translation}->{'Ticket watch notification'} = '';
    $Self->{Translation}->{'Tickets'} = '';
    $Self->{Translation}->{'Time Zone'} = '';
    $Self->{Translation}->{'Time in seconds that gets added to the actual time if setting a pending-state (default: 86400 = 1 day).'} = '';
    $Self->{Translation}->{'Toolbar Item for a shortcut.'} = '';
    $Self->{Translation}->{'Turns on the animations used in the GUI. If you have problems with these animations (e.g. performance issues), you can turn them off here.'} = '';
    $Self->{Translation}->{'Turns on the remote ip address check. It should be set to "No" if the application is used, for example, via a proxy farm or a dialup connection, because the remote ip address is mostly different for the requests.'} = '';
    $Self->{Translation}->{'Types'} = '';
    $Self->{Translation}->{'Update Ticket "Seen" flag if every article got seen or a new Article got created.'} = '';
    $Self->{Translation}->{'Update and extend your system with software packages.'} = '';
    $Self->{Translation}->{'Updates the ticket escalation index after a ticket attribute got updated.'} = '';
    $Self->{Translation}->{'Updates the ticket index accelerator.'} = '';
    $Self->{Translation}->{'Uses Cc recipients in reply Cc list on compose an email answer in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Uses richtext for viewing and editing: articles, salutations, signatures, standard responses, auto responses and notifications.'} = '';
    $Self->{Translation}->{'View performance benchmark results.'} = '';
    $Self->{Translation}->{'View system log messages.'} = '';
    $Self->{Translation}->{'Wear this frontend skin'} = '';
    $Self->{Translation}->{'When tickets are merged, a note will be added automatically to the ticket which is no longer active. In this text area you can define this text (This text cannot be changed by the agent).'} = '';
    $Self->{Translation}->{'When tickets are merged, the customer can be informed per email by setting the check box "Inform Sender". In this text area, you can define a pre-formatted text which can later be modified by the agents.'} = '';
    $Self->{Translation}->{'Your language'} = '';
    $Self->{Translation}->{'Your queue selection of your favourite queues. You also get notified about those queues via email if enabled.'} = '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/en_GB_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::en_GB_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = '';
    $Self->{Translation}->{'Backup Device'} = '';
    $Self->{Translation}->{'Beamer'} = '';
    $Self->{Translation}->{'Building'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'New ConfigItem (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'ConfigItem (ID=%s) deleted';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'ConfigItems\' definition updated (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Deployment state updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Incident state updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Link to %s (type=%s) added';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Link to %s (type=%s) deleted';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Name updated (new=%s; old=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Attribute %s updated from "%s" to "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'New version (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Version %s deleted';
    $Self->{Translation}->{'CPU'} = '';
    $Self->{Translation}->{'Camera'} = '';
    $Self->{Translation}->{'Capacity'} = '';
    $Self->{Translation}->{'Change Definition'} = '';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = '';
    $Self->{Translation}->{'Client Application'} = '';
    $Self->{Translation}->{'Client OS'} = '';
    $Self->{Translation}->{'Concurrent Users'} = '';
    $Self->{Translation}->{'Config Item-Area'} = '';
    $Self->{Translation}->{'Config Items available'} = '';
    $Self->{Translation}->{'Config Items shown'} = '';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = '';
    $Self->{Translation}->{'Desktop'} = '';
    $Self->{Translation}->{'Developer Licence'} = '';
    $Self->{Translation}->{'Docking Station'} = '';
    $Self->{Translation}->{'Duplicate'} = '';
    $Self->{Translation}->{'Embedded'} = '';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = '';
    $Self->{Translation}->{'Expiration Date'} = '';
    $Self->{Translation}->{'Expired'} = '';
    $Self->{Translation}->{'FQDN'} = '';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = '';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '';
    $Self->{Translation}->{'Graphic Adapter'} = '';
    $Self->{Translation}->{'Hard Disk'} = '';
    $Self->{Translation}->{'Hard Disk::Capacity'} = '';
    $Self->{Translation}->{'Hide Versions'} = '';
    $Self->{Translation}->{'IP Address'} = '';
    $Self->{Translation}->{'IP over DHCP'} = '';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = '';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = '';
    $Self->{Translation}->{'Keybord'} = '';
    $Self->{Translation}->{'LAN'} = '';
    $Self->{Translation}->{'Laptop'} = '';
    $Self->{Translation}->{'Last Change'} = '';
    $Self->{Translation}->{'Licence Key'} = '';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = '';
    $Self->{Translation}->{'Licence Key::Quantity'} = '';
    $Self->{Translation}->{'Licence Type'} = '';
    $Self->{Translation}->{'Maintenance'} = '';
    $Self->{Translation}->{'Maximum number of one element'} = '';
    $Self->{Translation}->{'Media'} = '';
    $Self->{Translation}->{'Middleware'} = '';
    $Self->{Translation}->{'Model'} = '';
    $Self->{Translation}->{'Modem'} = '';
    $Self->{Translation}->{'Monitor'} = '';
    $Self->{Translation}->{'Mouse'} = '';
    $Self->{Translation}->{'Network Adapter'} = '';
    $Self->{Translation}->{'Network Adapter::IP Address'} = '';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = '';
    $Self->{Translation}->{'Network Address'} = '';
    $Self->{Translation}->{'Network Address::Gateway'} = '';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = '';
    $Self->{Translation}->{'Open Source'} = '';
    $Self->{Translation}->{'Operating System'} = '';
    $Self->{Translation}->{'Operational'} = '';
    $Self->{Translation}->{'Other'} = '';
    $Self->{Translation}->{'Other Equipment'} = '';
    $Self->{Translation}->{'Outlet'} = '';
    $Self->{Translation}->{'PCMCIA Card'} = '';
    $Self->{Translation}->{'PDA'} = '';
    $Self->{Translation}->{'Per Node'} = '';
    $Self->{Translation}->{'Per Processor'} = '';
    $Self->{Translation}->{'Per Server'} = '';
    $Self->{Translation}->{'Per User'} = '';
    $Self->{Translation}->{'Phone 1'} = '';
    $Self->{Translation}->{'Phone 2'} = '';
    $Self->{Translation}->{'Pilot'} = '';
    $Self->{Translation}->{'Planned'} = '';
    $Self->{Translation}->{'Printer'} = '';
    $Self->{Translation}->{'Production'} = '';
    $Self->{Translation}->{'Quantity'} = '';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = '';
    $Self->{Translation}->{'Repair'} = '';
    $Self->{Translation}->{'Retired'} = '';
    $Self->{Translation}->{'Review'} = '';
    $Self->{Translation}->{'Room'} = '';
    $Self->{Translation}->{'Router'} = '';
    $Self->{Translation}->{'Scanner'} = '';
    $Self->{Translation}->{'Search Config Items'} = '';
    $Self->{Translation}->{'Security Device'} = '';
    $Self->{Translation}->{'Serial Number'} = '';
    $Self->{Translation}->{'Server'} = '';
    $Self->{Translation}->{'Server Application'} = '';
    $Self->{Translation}->{'Server OS'} = '';
    $Self->{Translation}->{'Show Versions'} = '';
    $Self->{Translation}->{'Single Licence'} = '';
    $Self->{Translation}->{'Subnet Mask'} = '';
    $Self->{Translation}->{'Switch'} = '';
    $Self->{Translation}->{'Telco'} = '';
    $Self->{Translation}->{'Test/QA'} = '';
    $Self->{Translation}->{'The deployment state of this config item'} = '';
    $Self->{Translation}->{'The incident state of this config item'} = '';
    $Self->{Translation}->{'Time Restricted'} = '';
    $Self->{Translation}->{'USB Device'} = '';
    $Self->{Translation}->{'Unlimited'} = '';
    $Self->{Translation}->{'User Tool'} = '';
    $Self->{Translation}->{'Volume Licence'} = '';
    $Self->{Translation}->{'WLAN'} = '';
    $Self->{Translation}->{'WLAN Access Point'} = '';
    $Self->{Translation}->{'Warranty Expiration Date'} = '';
    $Self->{Translation}->{'Workplace'} = '';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = '';
    $Self->{Translation}->{'Actions'} = '';
    $Self->{Translation}->{'Add'} = '';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Go to overview'} = '';
    $Self->{Translation}->{'List'} = '';
    $Self->{Translation}->{'Config Item'} = '';
    $Self->{Translation}->{'Class'} = '';
    $Self->{Translation}->{'Version'} = '';
    $Self->{Translation}->{'Created by'} = '';
    $Self->{Translation}->{'Created'} = '';
    $Self->{Translation}->{'View'} = '';
    $Self->{Translation}->{'Definition'} = '';
    $Self->{Translation}->{'Change'} = '';
    $Self->{Translation}->{'Submit'} = '';
    $Self->{Translation}->{'or'} = '';
    $Self->{Translation}->{'Cancel'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Hint'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';
    $Self->{Translation}->{'No matches found.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'Edit'} = '';
    $Self->{Translation}->{'Cancel & close window'} = '';
    $Self->{Translation}->{'Name'} = '';
    $Self->{Translation}->{'The name of this config item'} = '';
    $Self->{Translation}->{'This field is required.'} = '';
    $Self->{Translation}->{'Deployment State'} = '';
    $Self->{Translation}->{'Incident State'} = '';
    $Self->{Translation}->{'Delete'} = '';
    $Self->{Translation}->{'Save'} = '';

    # Template: AgentITSMConfigItemHistory
    $Self->{Translation}->{'History of'} = '';
    $Self->{Translation}->{'History Content'} = '';
    $Self->{Translation}->{'Action'} = '';
    $Self->{Translation}->{'Comment'} = '';
    $Self->{Translation}->{'Zoom'} = '';
    $Self->{Translation}->{'User'} = '';
    $Self->{Translation}->{'Createtime'} = '';
    $Self->{Translation}->{'Zoom view'} = '';

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Change search options'} = '';
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';
    $Self->{Translation}->{'Settings'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'State'} = '';
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = '';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last Changed'} = '';
    $Self->{Translation}->{'No data found.'} = '';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = '';
    $Self->{Translation}->{'Last changed'} = '';
    $Self->{Translation}->{'Last changed by'} = '';
    $Self->{Translation}->{'Linked-Object'} = '';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Search-Template'} = '';
    $Self->{Translation}->{'Create New'} = '';
    $Self->{Translation}->{'Create Template'} = '';
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Search template'} = '';
    $Self->{Translation}->{'Save changes in template'} = '';
    $Self->{Translation}->{'Add another attribute'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = '';
    $Self->{Translation}->{'Output'} = '';
    $Self->{Translation}->{'Number'} = '';
    $Self->{Translation}->{'(e. g. 10*5155 or 105658*)'} = '';
    $Self->{Translation}->{'Remove this entry'} = '';
    $Self->{Translation}->{'Remove'} = '';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'Search'} = '';
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Linked Objects'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Created By'} = '';
    $Self->{Translation}->{'Changed On'} = '';
    $Self->{Translation}->{'Resize'} = '';
    $Self->{Translation}->{'Show or hide the content.'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';
    $Self->{Translation}->{'Value'} = '';

    # SysConfig
    $Self->{Translation}->{'ACL module that allows closing parent tickets only if all its children are already closed ("State" shows which states are not available for the parent ticket until all child tickets are closed).'} = '';
    $Self->{Translation}->{'Activates TypeAhead for the autocomplete feature, that enables users to type in whatever speed they desire, without losing any information. Often this means that keystrokes entered will not be displayed on the screen immediately.'} = '';
    $Self->{Translation}->{'Activates a blinking mechanism of the queue that contains the oldest ticket.'} = '';
    $Self->{Translation}->{'Activates lost password feature for agents, in the agent interface.'} = '';
    $Self->{Translation}->{'Activates lost password feature for customers.'} = '';
    $Self->{Translation}->{'Activates support for customer groups.'} = '';
    $Self->{Translation}->{'Activates the article filter in the zoom view to specify which articles should be shown.'} = '';
    $Self->{Translation}->{'Activates the available themes on the system. Value 1 means active, 0 means inactive.'} = '';
    $Self->{Translation}->{'Activates the ticket archive system to have a faster system by moving some tickets out of the daily scope. To search for these tickets, the archive flag has to be enabled in the ticket search.'} = '';
    $Self->{Translation}->{'Activates time accounting.'} = '';
    $Self->{Translation}->{'Add a note to this ticket!'} = '';
    $Self->{Translation}->{'Adds a suffix with the actual year and month to the OTRS log file. A logfile for every month will be created.'} = '';
    $Self->{Translation}->{'Adds customers email addresses to recipients in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 1. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 2. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 3. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 4. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 5. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 6. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 7. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 8. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days for the calendar number 9. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the one time vacation days. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 1. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 2. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 3. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 4. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 5. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 6. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 7. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 8. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days for the calendar number 9. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Adds the permanent vacation days. Please use single digit pattern for numbers from 1 to 9 (instead of 01 - 09).'} = '';
    $Self->{Translation}->{'Admin'} = '';
    $Self->{Translation}->{'Admin Notification'} = '';
    $Self->{Translation}->{'Agent Notifications'} = '';
    $Self->{Translation}->{'Agent interface article notification module to check PGP.'} = '';
    $Self->{Translation}->{'Agent interface article notification module to check S/MIME.'} = '';
    $Self->{Translation}->{'Agent interface module to access fulltext search via nav bar.'} = '';
    $Self->{Translation}->{'Agent interface module to access search profiles via nav bar.'} = '';
    $Self->{Translation}->{'Agent interface module to check incoming emails in the Ticket-Zoom-View if the S/MIME-key is available and true.'} = '';
    $Self->{Translation}->{'Agent interface notification module to check the used charset.'} = '';
    $Self->{Translation}->{'Agent interface notification module to see the number of tickets an agent is responsible for.'} = '';
    $Self->{Translation}->{'Agent interface notification module to see the number of watched tickets.'} = '';
    $Self->{Translation}->{'Agents'} = '';
    $Self->{Translation}->{'Agents <-> Groups'} = '';
    $Self->{Translation}->{'Agents <-> Roles'} = '';
    $Self->{Translation}->{'Allows adding notes in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Allows adding notes in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Allows agents to exchange the axis of a stat if they generate one.'} = '';
    $Self->{Translation}->{'Allows agents to generate individual-related stats.'} = '';
    $Self->{Translation}->{'Allows choosing between showing the attachments of a ticket in the browser (inline) or just make them downloadable (attachment).'} = '';
    $Self->{Translation}->{'Allows choosing the next compose state for customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to change the ticket priority in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket SLA in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket priority in the customer interface.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket queue in the customer interface. If this is set to \'No\', QueueDefault should be configured.'} = '';
    $Self->{Translation}->{'Allows customers to set the ticket service in the customer interface.'} = '';
    $Self->{Translation}->{'Allows defining new types for ticket (if ticket type feature is enabled).'} = '';
    $Self->{Translation}->{'Allows defining services and SLAs for tickets (e. g. email, desktop, network, ...), and escalation attributes for SLAs (if ticket service/SLA feature is enabled).'} = '';
    $Self->{Translation}->{'Allows extended search conditions in ticket search of the agent interface. With this feature you can search w. g. with this kind of conditions like "(key1&&key2)" or "(key1||key2)".'} = '';
    $Self->{Translation}->{'Allows extended search conditions in ticket search of the customer interface. With this feature you can search w. g. with this kind of conditions like "(key1&&key2)" or "(key1||key2)".'} = '';
    $Self->{Translation}->{'Allows having a medium format ticket overview (CustomerInfo => 1 - shows also the customer information).'} = '';
    $Self->{Translation}->{'Allows having a small format ticket overview (CustomerInfo => 1 - shows also the customer information).'} = '';
    $Self->{Translation}->{'Allows the administrators to login as other users, via the users administration panel.'} = '';
    $Self->{Translation}->{'Allows to set a new ticket state in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Article free text options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Article free text options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Attachments'} = '';
    $Self->{Translation}->{'Attachments <-> Responses'} = '';
    $Self->{Translation}->{'Auto Responses'} = '';
    $Self->{Translation}->{'Auto Responses <-> Queues'} = '';
    $Self->{Translation}->{'Automated line break in text messages after x number of chars.'} = '';
    $Self->{Translation}->{'Automatically lock and set owner to current Agent after selecting for an Bulk Action.'} = '';
    $Self->{Translation}->{'Automatically sets the owner of a ticket as the responsible for it (if ticket responsible feature is enabled).'} = '';
    $Self->{Translation}->{'Automatically sets the responsible of a ticket (if it is not set yet) after the first owner update.'} = '';
    $Self->{Translation}->{'Back'} = '';
    $Self->{Translation}->{'Balanced white skin by Felix Niklas.'} = '';
    $Self->{Translation}->{'Blocks all the incoming emails that do not have a valid ticket number in subject with From: @example.com address.'} = '';
    $Self->{Translation}->{'Builds an article index right after the article\'s creation.'} = '';
    $Self->{Translation}->{'CMD example setup. Ignores emails where external CMD returns some output on STDOUT (email will be piped into STDIN of some.bin).'} = '';
    $Self->{Translation}->{'CSV Separator'} = '';
    $Self->{Translation}->{'Change password'} = '';
    $Self->{Translation}->{'Change queue!'} = '';
    $Self->{Translation}->{'Change the ticket customer!'} = '';
    $Self->{Translation}->{'Change the ticket free fields!'} = '';
    $Self->{Translation}->{'Change the ticket owner!'} = '';
    $Self->{Translation}->{'Change the ticket priority!'} = '';
    $Self->{Translation}->{'Change the ticket responsible!'} = '';
    $Self->{Translation}->{'Changes the owner of tickets to everyone (useful for ASP). Normally only agent with rw permissions in the queue of the ticket will be shown.'} = '';
    $Self->{Translation}->{'Checks the SystemID in ticket number detection for follow-ups (use "No" if SystemID has been changed after using the system).'} = '';
    $Self->{Translation}->{'Close this ticket!'} = '';
    $Self->{Translation}->{'Comment for new history entries in the customer interface.'} = '';
    $Self->{Translation}->{'Companies'} = '';
    $Self->{Translation}->{'Company Tickets'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} = '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} = '';
    $Self->{Translation}->{'Configure your own log text for PGP.'} = '';
    $Self->{Translation}->{'Configures a default TicketFreeField setting. "Counter" defines the free text field which should be used, "Key" is the TicketFreeKey, "Value" is the TicketFreeText and "Event" defines the trigger event.'} = '';
    $Self->{Translation}->{'Configures a default TicketFreeField setting. "Counter" defines the free text field which should be used, "Key" is the TicketFreeKey, "Value" is the TicketFreeText and "Event" defines the trigger event. Please check the developer manual (http://doc.otrs.org/), chapter "Ticket Event Module".'} = '';
    $Self->{Translation}->{'Configures the full-text index. Execute "bin/otrs.RebuildFulltextIndex.pl" in order to generate a new index.'} = '';
    $Self->{Translation}->{'Controls if customers have the ability to sort their tickets.'} = '';
    $Self->{Translation}->{'Converts HTML mails into text messages.'} = '';
    $Self->{Translation}->{'Create and manage Service Level Agreements (SLAs).'} = '';
    $Self->{Translation}->{'Create and manage agents.'} = '';
    $Self->{Translation}->{'Create and manage attachments.'} = '';
    $Self->{Translation}->{'Create and manage companies.'} = '';
    $Self->{Translation}->{'Create and manage customers.'} = '';
    $Self->{Translation}->{'Create and manage event based notifications.'} = '';
    $Self->{Translation}->{'Create and manage groups.'} = '';
    $Self->{Translation}->{'Create and manage notifications that are sent to agents.'} = '';
    $Self->{Translation}->{'Create and manage queues.'} = '';
    $Self->{Translation}->{'Create and manage response templates.'} = '';
    $Self->{Translation}->{'Create and manage responses that are automatically sent.'} = '';
    $Self->{Translation}->{'Create and manage roles.'} = '';
    $Self->{Translation}->{'Create and manage salutations.'} = '';
    $Self->{Translation}->{'Create and manage services.'} = '';
    $Self->{Translation}->{'Create and manage signatures.'} = '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Create and manage ticket priorities.'} = '';
    $Self->{Translation}->{'Create and manage ticket states.'} = '';
    $Self->{Translation}->{'Create and manage ticket types.'} = '';
    $Self->{Translation}->{'Create new Ticket'} = '';
    $Self->{Translation}->{'Create new email ticket and send this out (outbound)'} = '';
    $Self->{Translation}->{'Create new phone ticket (inbound)'} = '';
    $Self->{Translation}->{'Custom text for the page shown to customers that have no tickets yet.'} = '';
    $Self->{Translation}->{'Customer Companies'} = '';
    $Self->{Translation}->{'Customer item (icon) which shows the open tickets of this customer as info block.'} = '';
    $Self->{Translation}->{'Customers'} = '';
    $Self->{Translation}->{'Customers <-> Groups'} = '';
    $Self->{Translation}->{'Customers <-> Services'} = '';
    $Self->{Translation}->{'Dashboard'} = '';
    $Self->{Translation}->{'Data used to export the search result in CSV format.'} = '';
    $Self->{Translation}->{'Debugs the translation set. If this is set to "Yes" all strings (text) without translations are written to STDERR. This can be helpful when you are creating a new translation file. Otherwise, this option should remain set to "No".'} = '';
    $Self->{Translation}->{'Default ACL values for ticket actions.'} = '';
    $Self->{Translation}->{'Default data to use on attribute for ticket search screen. Example: "TicketCreateTimePointFormat=year;TicketCreateTimePointStart=Last;TicketCreateTimePoint=2;".'} = '';
    $Self->{Translation}->{'Default data to use on attribute for ticket search screen. Example: "TicketCreateTimeStartYear=2010;TicketCreateTimeStartMonth=10;TicketCreateTimeStartDay=4;TicketCreateTimeStopYear=2010;TicketCreateTimeStopMonth=11;TicketCreateTimeStopDay=3;".'} = '';
    $Self->{Translation}->{'Default loop protection module.'} = '';
    $Self->{Translation}->{'Default queue ID used by the system in the agent interface.'} = '';
    $Self->{Translation}->{'Default skin for OTRS 3.0 interface.'} = '';
    $Self->{Translation}->{'Default skin for interface.'} = '';
    $Self->{Translation}->{'Default spelling dictionary'} = '';
    $Self->{Translation}->{'Default ticket ID used by the system in the agent interface.'} = '';
    $Self->{Translation}->{'Default ticket ID used by the system in the customer interface.'} = '';
    $Self->{Translation}->{'Define a filter for html output to add links behind a defined string. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Define the start day of the week for the date picker.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a LinkedIn icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a XING icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a google icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a customer item, which generates a google maps icon at the end of a customer info block.'} = '';
    $Self->{Translation}->{'Defines a default list of words, that are ignored by the spell checker.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind CVE numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind MSBulletin numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind a defined string. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter for html output to add links behind bugtraq numbers. The element Image allows two input kinds. At once the name of an image (e.g. faq.png). In this case the OTRS image path will be used. The second possiblity is to insert the link to the image.'} = '';
    $Self->{Translation}->{'Defines a filter to process the text in the articles, in order to highlight predefined keywords.'} = '';
    $Self->{Translation}->{'Defines a regular expression that excludes some addresses from the syntax check (if "CheckEmailAddresses" is set to "Yes"). Please enter a regex in this field for email addresses, that aren\'t syntactically valid, but are necessary for the system (i.e. "root@localhost").'} = '';
    $Self->{Translation}->{'Defines a regular expression that filters all email addresses that should not be used in the application.'} = '';
    $Self->{Translation}->{'Defines a useful module to load specific user options or to display news.'} = '';
    $Self->{Translation}->{'Defines all the X-headers that should be scanned.'} = '';
    $Self->{Translation}->{'Defines all the languages that are available to the application. The Key/Content pair links the front-end display name to the appropriate language PM file. The "Key" value should be the base-name of the PM file (i.e. de.pm is the file, then de is the "Key" value). The "Content" value should be the display name for the front-end. Specify any own-defined language here (see the developer documentation http://doc.otrs.org/ for more infomation). Please remember to use the HTML equivalents for non-ASCII characters (i.e. for the German oe = o umlaut, it is necessary to use the &ouml; symbol).'} = '';
    $Self->{Translation}->{'Defines all the parameters for the RefreshTime object in the customer preferences of the customer interface.'} = '';
    $Self->{Translation}->{'Defines all the parameters for the ShownTickets object in the customer preferences of the customer interface.'} = '';
    $Self->{Translation}->{'Defines all the parameters for this item in the customer preferences.'} = '';
    $Self->{Translation}->{'Defines all the possible stats output formats.'} = '';
    $Self->{Translation}->{'Defines an alternate URL, where the login link refers to.'} = '';
    $Self->{Translation}->{'Defines an alternate URL, where the logout link refers to.'} = '';
    $Self->{Translation}->{'Defines an alternate login URL for the customer panel..'} = '';
    $Self->{Translation}->{'Defines an alternate logout URL for the customer panel.'} = '';
    $Self->{Translation}->{'Defines an external link to the database of the customer (e.g. \'http://yourhost/customer.php?CID=$Data{"CustomerID"}\' or \'\').'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} = '';
    $Self->{Translation}->{'Defines how the From field from the emails (sent from answers and email tickets) should look like.'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the close ticket screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket bounce screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket compose screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket forward screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket free text screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket merge screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket note screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket owner screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket pending screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket phone outbound screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket priority screen of a zoomed ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required in the ticket responsible screen of the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if a ticket lock is required to change the customer of a ticket in the agent interface (if the ticket isn\'t locked yet, the ticket gets locked and the current agent will be set automatically as its owner).'} = '';
    $Self->{Translation}->{'Defines if composed messages have to be spell checked in the agent interface.'} = '';
    $Self->{Translation}->{'Defines if time accounting is mandatory in the agent interface.'} = '';
    $Self->{Translation}->{'Defines if time accounting must be set to all tickets in bulk action.'} = '';
    $Self->{Translation}->{'Defines the =hHeight for the rich text editor component. Enter number (pixels) or percent value (relative).'} = '';
    $Self->{Translation}->{'Defines the IP regular expression for accessing the local repository. You need to enable this to have access to your local repository and the package::RepositoryList is required on the remote host.'} = '';
    $Self->{Translation}->{'Defines the URL CSS path.'} = '';
    $Self->{Translation}->{'Defines the URL base path of icons, CSS and Java Script.'} = '';
    $Self->{Translation}->{'Defines the URL image path of icons for navigation.'} = '';
    $Self->{Translation}->{'Defines the URL java script path.'} = '';
    $Self->{Translation}->{'Defines the URL rich text editor path.'} = '';
    $Self->{Translation}->{'Defines the address of a dedicated DNS server, if necessary, for the "CheckMXRecord" look-ups.'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to agents, about new password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to agents, with token about new requested password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, about new account.'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, about new password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for notification mails sent to customers, with token about new requested password (after using this link the new password will be sent).'} = '';
    $Self->{Translation}->{'Defines the body text for rejected emails.'} = '';
    $Self->{Translation}->{'Defines the boldness of the line drawed by the graph.'} = '';
    $Self->{Translation}->{'Defines the colors for the graphs.'} = '';
    $Self->{Translation}->{'Defines the column to store the keys for the preferences table.'} = '';
    $Self->{Translation}->{'Defines the config parameters of this item, to be shown in the preferences view.'} = '';
    $Self->{Translation}->{'Defines the config parameters of this item, to be shown in the preferences view. Take care to maintain the dictionaries installed in the system in the data section.'} = '';
    $Self->{Translation}->{'Defines the connections for http/ftp, via a proxy.'} = '';
    $Self->{Translation}->{'Defines the date input format used in forms (option or input fields).'} = '';
    $Self->{Translation}->{'Defines the default CSS used in rich text editors.'} = '';
    $Self->{Translation}->{'Defines the default body of a note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default front-end (HTML) theme to be used by the agents and customers. The default themes are Standard and Lite. If you like, you can add your own theme. Please refer the administrator manual located at http://doc.otrs.org/.'} = '';
    $Self->{Translation}->{'Defines the default front-end language. All the possible values are determined by the available language files on the system (see the next setting).'} = '';
    $Self->{Translation}->{'Defines the default history type in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default maximum number of X-axis attributes for the time scale.'} = '';
    $Self->{Translation}->{'Defines the default maximum number of search results shown on the overview page.'} = '';
    $Self->{Translation}->{'Defines the default next state for a ticket after customer follow up in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after adding a note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after being bounced, in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket after being forwarded, in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default next state of a ticket if it is composed / answered in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default note body text for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of follow up customer tickets in the ticket zoom screen in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default priority of new tickets.'} = '';
    $Self->{Translation}->{'Defines the default queue for new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for dynamic objects (Form: Common Specification).'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for permissions (Form: Common Specification).'} = '';
    $Self->{Translation}->{'Defines the default selection at the drop down menu for stats format (Form: Common Specification). Please insert the format key (see Stats::Format).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 1 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 1 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 10 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 11 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 12 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 13 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 14 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 15 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 16 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 2 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 2 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 3 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 3 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 4 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 5 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 6 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 7 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 8 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free key field number 9 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 1 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 1 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 10 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 11 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 12 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 13 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 14 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 15 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 16 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 2 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 2 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 3 for articles (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 3 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 4 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 5 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 6 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 7 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 8 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default selection of the free text field number 9 for tickets (if more than one option is provided).'} = '';
    $Self->{Translation}->{'Defines the default sender type for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default sender type for tickets in the ticket zoom screen of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default shown ticket search attribute for ticket search screen.'} = '';
    $Self->{Translation}->{'Defines the default sort criteria for all queues displayed in the queue view, after sort by priority is done.'} = '';
    $Self->{Translation}->{'Defines the default sort order for all queues in the queue view, after priority sort.'} = '';
    $Self->{Translation}->{'Defines the default spell checker dictionary.'} = '';
    $Self->{Translation}->{'Defines the default state of new customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default state of new tickets.'} = '';
    $Self->{Translation}->{'Defines the default subject for phone tickets in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default subject of a note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in a ticket search of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the escalation view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the locked ticket view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the responsible view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the status view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting in the watch view of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket attribute for ticket sorting of the ticket search result of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket bounced notification for customer/sender in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket next state after adding a phone note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket order (after priority sort) in the escalation view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order (after priority sort) in the status view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the responsible view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the ticket locked view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the ticket search result of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order in the watch view of the agent interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket order of a search result in the customer interface. Up: oldest on top. Down: latest on top.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default ticket priority in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type for article in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default type of forwarded message in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default type of the note in the ticket zoom screen of the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default used Frontend-Module if no Action parameter given in the url on the agent interface.'} = '';
    $Self->{Translation}->{'Defines the default used Frontend-Module if no Action parameter given in the url on the customer interface.'} = '';
    $Self->{Translation}->{'Defines the default value for the action parameter for the public frontend. The action parameter is used in the scripts of the system.'} = '';
    $Self->{Translation}->{'Defines the default viewable sender types of a ticket (default: customer).'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 1\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 2\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 3\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 4\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 5\'s default value.'} = '';
    $Self->{Translation}->{'Defines the difference from now (in seconds) of the free time field number 6\'s default value.'} = '';
    $Self->{Translation}->{'Defines the filter that processes the text in the articles, in order to highlight URLs.'} = '';
    $Self->{Translation}->{'Defines the format of responses in the ticket compose screen of the agent interface ($QData{"OrigFrom"} is From 1:1, $QData{"OrigFromName"} is only realname of From).'} = '';
    $Self->{Translation}->{'Defines the free key field number 1 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 1 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 10 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 11 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 12 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 13 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 14 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 15 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 16 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 2 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 2 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 3 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 3 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 4 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 5 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 6 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 7 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 8 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free key field number 9 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 1 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 1 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 10 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 11 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 12 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 13 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 14 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 15 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 16 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 2 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 2 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 3 for articles to add a new article attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 3 for ticket to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 4 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 5 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 6 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 7 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 8 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free text field number 9 for tickets to add a new ticket attribute.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 1 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 2 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 3 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 4 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 5 for tickets.'} = '';
    $Self->{Translation}->{'Defines the free time key field number 6 for tickets.'} = '';
    $Self->{Translation}->{'Defines the fully qualified domain name of the system. This setting is used as a variable, OTRS_CONFIG_FQDN which is found in all forms of messaging used by the application, to build links to the tickets within your system.'} = '';
    $Self->{Translation}->{'Defines the groups every customer user will be in (if CustomerGroupSupport is enabled and you don\'t want to manage every user for these groups).'} = '';
    $Self->{Translation}->{'Defines the height of the legend.'} = '';
    $Self->{Translation}->{'Defines the history comment for the close ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the email ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the phone ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket free text screen action, which gets used for ticket history.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket note screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket owner screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket pending screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket phone outbound screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket priority screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket responsible screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history comment for the ticket zoom action, which gets used for ticket history in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the close ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the email ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the phone ticket screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket free text screen action, which gets used for ticket history.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket note screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket owner screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket pending screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket phone outbound screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket priority screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket responsible screen action, which gets used for ticket history in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the history type for the ticket zoom action, which gets used for ticket history in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 1, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 2, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 3, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 4, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 5, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 6, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 7, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 8, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days of the calendar number 9, to count the working time.'} = '';
    $Self->{Translation}->{'Defines the hours and week days to count the working time.'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 1 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 10 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 11 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 12 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 13 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 14 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 15 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 16 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 2 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 3 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 4 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 5 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 6 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 7 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 8 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the http link for the free text field number 9 for tickets (it will be used in every ticket view).'} = '';
    $Self->{Translation}->{'Defines the key to be checked with Kernel::Modules::AgentInfo module. If this user preferences key is true, the message is accepted by the system.'} = '';
    $Self->{Translation}->{'Defines the key to check with CustomerAccept. If this user preferences key is true, then the message is accepted by the system.'} = '';
    $Self->{Translation}->{'Defines the link type \'Normal\'. If the source name and the target name contain the same value, the resulting link is a non-directional one; otherwise, the result is a directional link.'} = '';
    $Self->{Translation}->{'Defines the link type \'ParentChild\'. If the source name and the target name contain the same value, the resulting link is a non-directional one; otherwise, the result is a directional link.'} = '';
    $Self->{Translation}->{'Defines the link type groups. The link types of the same group cancel one another. Example: If ticket A is linked per a \'Normal\' link with ticket B, then these tickets could not be additionally linked with link of a \'ParentChild\' relationship.'} = '';
    $Self->{Translation}->{'Defines the list of online repositories. Another installations can be used as repository, for example: Key="http://example.com/otrs/public.pl?Action=PublicRepository;File=" and Content="Some Name".'} = '';
    $Self->{Translation}->{'Defines the location to get online repository list for additional packages. The first available result will be used.'} = '';
    $Self->{Translation}->{'Defines the log module for the system. "File" writes all messages in a given logfile, "SysLog" uses the syslog daemon of the system, e.g. syslogd.'} = '';
    $Self->{Translation}->{'Defines the maximal size (in bytes) for file uploads via the browser.'} = '';
    $Self->{Translation}->{'Defines the maximal valid time (in seconds) for a session id.'} = '';
    $Self->{Translation}->{'Defines the maximum number of pages per PDF file.'} = '';
    $Self->{Translation}->{'Defines the maximum size (in MB) of the log file.'} = '';
    $Self->{Translation}->{'Defines the module that shows all the currently loged in customers in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows all the currently logged in agents in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows the currently loged in agents in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module that shows the currently loged in customers in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module to authenticate customers.'} = '';
    $Self->{Translation}->{'Defines the module to display a notification in the agent interface, if the system is used by the admin user (normally you shouldn\'t work as admin).'} = '';
    $Self->{Translation}->{'Defines the module to generate html refresh headers of html sites, in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the module to generate html refresh headers of html sites.'} = '';
    $Self->{Translation}->{'Defines the module to send emails. "Sendmail" directly uses the sendmail binary of your operating system. Any of the "SMTP" mechanisms use a specified (external) mailserver. "DoNotSendEmail" doesn\'t send emails and it is useful for test systems.'} = '';
    $Self->{Translation}->{'Defines the module used to store the session data. With "DB" the frontend server can be splitted from the db server. "FS" is faster.'} = '';
    $Self->{Translation}->{'Defines the name of the application, shown in the web interface, tabs and title bar of the web browser.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 1.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 2.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 3.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 4.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 5.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 6.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 7.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 8.'} = '';
    $Self->{Translation}->{'Defines the name of the calendar number 9.'} = '';
    $Self->{Translation}->{'Defines the name of the column to store the data in the preferences table.'} = '';
    $Self->{Translation}->{'Defines the name of the column to store the user identifier in the preferences table.'} = '';
    $Self->{Translation}->{'Defines the name of the key for customer sessions.'} = '';
    $Self->{Translation}->{'Defines the name of the session key. E.g. Session, SessionID or OTRS.'} = '';
    $Self->{Translation}->{'Defines the name of the table, where the customer preferences are stored.'} = '';
    $Self->{Translation}->{'Defines the next possible states after composing / answering a ticket in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next possible states after forwarding a ticket in the ticket forward screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next possible states for customer tickets in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after adding a note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after being bounced, in the ticket bounce screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the next state of a ticket after being moved to another queue, in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the parameters for the customer preferences table.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTL" indicates the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" defines the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Limit" defines the number of entries displayed by default. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTL" indicates the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the parameters for the dashboard backend. "Limit" defines the number of entries displayed by default. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" defines the cache expiration period in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Defines the password to access the SOAP handle (bin/cgi-bin/rpc.pl).'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold italic monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold italic proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle bold proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle italic monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle italic proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle monospaced font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path and TTF-File to handle proportional font in PDF documents.'} = '';
    $Self->{Translation}->{'Defines the path of the shown info file, that is located under Kernel/Output/HTML/Standard/CustomerAccept.dtl.'} = '';
    $Self->{Translation}->{'Defines the path to PGP binary.'} = '';
    $Self->{Translation}->{'Defines the path to open ssl binary. It may need a HOME env ($ENV{HOME} = \'/var/lib/wwwrun\';).'} = '';
    $Self->{Translation}->{'Defines the placement of the legend. This should be a two letter key of the form: \'B[LCR]|R[TCB]\'. The first letter indicates the placement (Bottom or Right), and the second letter the alignment (Left, Right, Center, Top, or Bottom).'} = '';
    $Self->{Translation}->{'Defines the postmaster default queue.'} = '';
    $Self->{Translation}->{'Defines the receipent target of the phone ticket and the sender of the email ticket ("Queue" shows all queues, "SystemAddress" displays all system addresses) in the agent interface.'} = '';
    $Self->{Translation}->{'Defines the receipent target of the tickets ("Queue" shows all queues, "SystemAddress" displays all system addresses) in the customer interface.'} = '';
    $Self->{Translation}->{'Defines the search limit for the stats.'} = '';
    $Self->{Translation}->{'Defines the separator between the agents real name and the given queue email address.'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} = '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} = '';
    $Self->{Translation}->{'Defines the spacing of the legends.'} = '';
    $Self->{Translation}->{'Defines the standard permissions available for customers within the application. If more permissions are needed, you can enter them here. Permissions must be hard coded to be effective. Please ensure, when adding any of the afore mentioned permissions, that the "rw" permission remains the last entry.'} = '';
    $Self->{Translation}->{'Defines the standard size of PDF pages.'} = '';
    $Self->{Translation}->{'Defines the state of a ticket if it gets a follow-up and the ticket was already closed.'} = '';
    $Self->{Translation}->{'Defines the state of a ticket if it gets a follow-up.'} = '';
    $Self->{Translation}->{'Defines the state type of the reminder for pending tickets.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to agents, about new password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to agents, with token about new requested password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, about new account.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, about new password.'} = '';
    $Self->{Translation}->{'Defines the subject for notification mails sent to customers, with token about new requested password.'} = '';
    $Self->{Translation}->{'Defines the subject for rejected emails.'} = '';
    $Self->{Translation}->{'Defines the system administrator\'s email address. It will be displayed in the error screens of the application.'} = '';
    $Self->{Translation}->{'Defines the system identifier. Every ticket number and http session string contain this ID. This ensures that only tickets which belong to your system will be processed as follow-ups (useful when communicating between two instances of OTRS).'} = '';
    $Self->{Translation}->{'Defines the target attribute in the link to external customer database. E.g. \'target="cdb"\'.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 1, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 2, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 3, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 4, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 5, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 6, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 7, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 8, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the time zone of the calendar number 9, which can be assigned later to a specific queue.'} = '';
    $Self->{Translation}->{'Defines the type of protocol, used by ther web server, to serve the application. If https protocol will be used instead of plain http, it must be specified it here. Since this has no affect on the web server\'s settings or behavior, it will not change the method of access to the application and, if it is wrong, it will not prevent you from logging into the application. This setting is used as a variable, OTRS_CONFIG_HttpType which is found in all forms of messaging used by the application, to build links to the tickets within your system.'} = '';
    $Self->{Translation}->{'Defines the used character for email quotes in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Defines the user identifier for the customer panel.'} = '';
    $Self->{Translation}->{'Defines the username to access the SOAP handle (bin/cgi-bin/rpc.pl).'} = '';
    $Self->{Translation}->{'Defines the valid state types for a ticket.'} = '';
    $Self->{Translation}->{'Defines the valid states for unlocked tickets. To unlock tickets the script "bin/otrs.UnlockTickets.pl" can be used.'} = '';
    $Self->{Translation}->{'Defines the viewable locks of a ticket. Default: unlock, tmp_lock.'} = '';
    $Self->{Translation}->{'Defines the width for the rich text editor component. Enter number (pixels) or percent value (relative).'} = '';
    $Self->{Translation}->{'Defines the width of the legend.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 1.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 2.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 3.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 4.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 5.'} = '';
    $Self->{Translation}->{'Defines the years (in future and in past) which can get selected in free time field number 6.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 1 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 2 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 3 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 4 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 5 is optional or not.'} = '';
    $Self->{Translation}->{'Defines whether the free time field number 6 is optional or not.'} = '';
    $Self->{Translation}->{'Defines which states should be set automatically (Content), after the pending time of state (Key) has been reached.'} = '';
    $Self->{Translation}->{'Delay time between autocomplete queries.'} = '';
    $Self->{Translation}->{'Delete this ticket!'} = '';
    $Self->{Translation}->{'Deletes a session if the session id is used with an invalid remote IP address.'} = '';
    $Self->{Translation}->{'Deletes requested sessions if they have timed out.'} = '';
    $Self->{Translation}->{'Determines if the list of possible queues to move to ticket into should be displayed in a dropdown list or in a new window in the agent interface. If "New Window" is set you can add a move note to the ticket.'} = '';
    $Self->{Translation}->{'Determines if the search results container for the autocomplete feature should adjust its width dynamically.'} = '';
    $Self->{Translation}->{'Determines if the statatistics module may generate ticket lists.'} = '';
    $Self->{Translation}->{'Determines the next possible ticket states, after the creation of a new email ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Determines the next possible ticket states, after the creation of a new phone ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Determines the next screen after new customer ticket in the customer interface.'} = '';
    $Self->{Translation}->{'Determines the next screen after the follow up screen of a zoomed ticket in the customer interface.'} = '';
    $Self->{Translation}->{'Determines the possible states for pending tickets that changed state after reaching time limit.'} = '';
    $Self->{Translation}->{'Determines the strings that will be shown as receipent (To:) of the phone ticket and as sender (From:) of the email ticket in the agent interface. For Queue as NewQueueSelectionType "<Queue>" shows the names of the queues and for SystemAddress "<Realname> <<Email>>" shows the name and email of the receipent.'} = '';
    $Self->{Translation}->{'Determines the strings that will be shown as receipent (To:) of the ticket in the customer interface. For Queue as CustomerPanelSelectionType, "<Queue>" shows the names of the queues, and for SystemAddress, "<Realname> <<Email>>" shows the name and email of the receipent.'} = '';
    $Self->{Translation}->{'Determines the way the linked objects are displayed in each zoom mask.'} = '';
    $Self->{Translation}->{'Determines which options will be valid of the recepient (phone ticket) and the sender (email ticket) in the agent interface.'} = '';
    $Self->{Translation}->{'Determines which queues will be valid for ticket\'s recepients in the customer interface.'} = '';
    $Self->{Translation}->{'Disables sending reminder notifications to the responsible agent of a ticket (Ticket::Responsible needs to be activated).'} = '';
    $Self->{Translation}->{'Disables the web installer (http://yourhost.example.com/otrs/installer.pl), to prevent the system from being hijacked. If set to "No", the system can be reinstalled and the current basic configuration will be used to pre-populate the questions within the installer script. If not active, it also disables the GenericAgent, PackageManager and SQL Box (to avoid the use of destructive queries, such as DROP DATABASE, and also to steal user passwords).'} = '';
    $Self->{Translation}->{'Displays the accounted time for an article in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Email Addresses'} = '';
    $Self->{Translation}->{'Enables PDF output. The CPAN module PDF::API2 is required, if not installed, PDF output will be disabled.'} = '';
    $Self->{Translation}->{'Enables PGP support. When PGP support is enabled for signing and securing mail, it is HIGHLY recommended that the web server be run as the OTRS user. Otherwise, there will be problems with the privileges when accessing .gnupg folder.'} = '';
    $Self->{Translation}->{'Enables S/MIME support.'} = '';
    $Self->{Translation}->{'Enables customers to create their own accounts.'} = '';
    $Self->{Translation}->{'Enables file upload in the package manager frontend.'} = '';
    $Self->{Translation}->{'Enables or disable the debug mode over frontend interface.'} = '';
    $Self->{Translation}->{'Enables or disables the autocomplete feature for the customer search in the agent interface.'} = '';
    $Self->{Translation}->{'Enables or disables the ticket watcher feature, to keep track of tickets without being the owner nor the responsible.'} = '';
    $Self->{Translation}->{'Enables performance log (to log the page response time). It will affect the system performance. Frontend::Module###AdminPerformanceLog must be enabled.'} = '';
    $Self->{Translation}->{'Enables spell checker support.'} = '';
    $Self->{Translation}->{'Enables ticket bulk action feature for the agent frontend to work on more than one ticket at a time.'} = '';
    $Self->{Translation}->{'Enables ticket bulk action feature only for the listed groups.'} = '';
    $Self->{Translation}->{'Enables ticket responsible feature, to keep track of a specific ticket.'} = '';
    $Self->{Translation}->{'Enables ticket watcher feature only for the listed groups.'} = '';
    $Self->{Translation}->{'Escalation view'} = '';
    $Self->{Translation}->{'Event module registration. For more performance you can define a trigger event (e. g. Event => TicketCreate). This is only possible if all TicketFreeField elements need the same event.'} = '';
    $Self->{Translation}->{'Example for free text'} = '';
    $Self->{Translation}->{'Execute SQL statements.'} = '';
    $Self->{Translation}->{'Executes follow up checks on In-Reply-To or References headers for mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up mail attachments checks in  mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up mail body checks in mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Executes follow up plain/raw mail checks in mails that don\'t have a ticket number in the subject.'} = '';
    $Self->{Translation}->{'Experimental "Slim" skin which tries to save screen space for power users.'} = '';
    $Self->{Translation}->{'Exports the whole article tree in search result (it can affect the system performance).'} = '';
    $Self->{Translation}->{'Fetches packages via proxy. Overwrites "WebUserAgent::Proxy".'} = '';
    $Self->{Translation}->{'File that is displayed in the Kernel::Modules::AgentInfo module, if located under Kernel/Output/HTML/Standard/AgentInfo.dtl.'} = '';
    $Self->{Translation}->{'Filter incoming emails.'} = '';
    $Self->{Translation}->{'Forces encoding of outgoing emails (7bit|8bit|quoted-printable|base64).'} = '';
    $Self->{Translation}->{'Forces to choose a different ticket state (from current) after lock action. Define the current state as key, and the next state after lock action as content.'} = '';
    $Self->{Translation}->{'Forces to unlock tickets after being moved to another queue.'} = '';
    $Self->{Translation}->{'Frontend language'} = '';
    $Self->{Translation}->{'Frontend module registration (disable company link if no company feature is used).'} = '';
    $Self->{Translation}->{'Frontend module registration for the agent interface.'} = '';
    $Self->{Translation}->{'Frontend module registration for the customer interface.'} = '';
    $Self->{Translation}->{'Frontend theme'} = '';
    $Self->{Translation}->{'GenericAgent'} = '';
    $Self->{Translation}->{'Gives end users the possibility to override the separator character for CSV files, defined in the translation files.'} = '';
    $Self->{Translation}->{'Grants access, if the customer ID of the ticket matches the customer user\'s ID and the customer user has group permissions on the queue the ticket is in.'} = '';
    $Self->{Translation}->{'Groups'} = '';
    $Self->{Translation}->{'Helps to extend your articles full-text search (From, To, Cc, Subject and Body search). Runtime will do full-text searches on live data (it works fine for up to 50.000 tickets). StaticDB will strip all articles and will build an index after article creation, increasing fulltext searches about 50%. To create an initial index use "bin/otrs.RebuildFulltextIndex.pl".'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a database driver (normally autodetection is used) can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a password to connect to the customer table can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, a username to connect to the customer table can be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the DSN for the connection to the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the column name for the CustomerPassword in the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the crypt type of passwords must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the name of the column for the CustomerKey in the customer table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for Customer::AuthModule, the name of the table where your customer data should be stored must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a column for the identifiers in session table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a column for the values in session table must be specified.'} = '';
    $Self->{Translation}->{'If "DB" was selected for SessionModule, a table in database where session data will be stored must be specified.'} = '';
    $Self->{Translation}->{'If "FS" was selected for SessionModule, a directory where the session data will be stored must be specified.'} = '';
    $Self->{Translation}->{'If "HTTPBasicAuth" was selected for Customer::AuthModule, you can specify (by using a RegExp) to strip parts of REMOTE_USER (e. g. for to remove trailing domains). RegExp-Note, $1 will be the new Login.'} = '';
    $Self->{Translation}->{'If "HTTPBasicAuth" was selected for Customer::AuthModule, you can specify to strip leading parts of user names (e. g. for domains like example_domain\user to user).'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and if you want to add a suffix to every customer login name, specifiy it here, e. g. you just want to write the username user but in your LDAP directory exists user@domain.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and special paramaters are needed for the Net::LDAP perl module, you can specify them here. See "perldoc Net::LDAP" for more information about the parameters.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and your users have only anonymous access to the LDAP tree, but you want to search through the data, you can do this with a user who has access to the LDAP directory. Specify the password for this special user here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule and your users have only anonymous access to the LDAP tree, but you want to search through the data, you can do this with a user who has access to the LDAP directory. Specify the username for this special user here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the BaseDN must be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the LDAP host can be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, the user identifier must be specified.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, user attributes can be specified. For LDAP posixGroups use UID, for non LDAP posixGroups use full user DN.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, you can specify access attributes here.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::AuthModule, you can specify if the applications will stop if e. g. a connection to a server can\'t be established due to network problems.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected for Customer::Authmodule, you can check if the user is allowed to authenticate because he is in a posixGroup, e.g. user needs to be in a group xyz to use OTRS. Specify the group, who may access the system.'} = '';
    $Self->{Translation}->{'If "LDAP" was selected, you can add a filter to each LDAP query, e.g. (mail=*), (objectclass=user) or (!objectclass=computer).'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, the password to authenticate to the radius host must be specified.'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, the radius host must be specified.'} = '';
    $Self->{Translation}->{'If "Radius" was selected for Customer::AuthModule, you can specify if the applications will stop if e. g. a connection to a server can\'t be established due to network problems.'} = '';
    $Self->{Translation}->{'If "Sendmail" was selected as SendmailModule, the location of the sendmail binary and the needed options must be specified.'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, a special log facility can be specified.'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, a special log sock can be specified (on solaris you may need to use \'stream\').'} = '';
    $Self->{Translation}->{'If "SysLog" was selected for LogModule, the charset that should be used for logging can be specified.'} = '';
    $Self->{Translation}->{'If "file" was selected for LogModule, a logfile must be specified. If the file doesn\'t exist, it will be created by the system.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of a ticket in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If a note is added by an agent, sets the state of the ticket in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, and authentication to the mail server is needed, a password must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, and authentication to the mail server is needed, an username must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, the mailhost that sends out the mails must be specified.'} = '';
    $Self->{Translation}->{'If any of the "SMTP" mechanisms was selected as SendmailModule, the port where your mailserver is listening for incoming connections must be specified.'} = '';
    $Self->{Translation}->{'If configured, all emails sent by the application will contain an X-Header with this organization or company name.'} = '';
    $Self->{Translation}->{'If enabled, OTRS will deliver all CSS files in minified form. WARNING: If you turn this off, there will likely be problems in IE 7, because it cannot load more than 32 CSS files.'} = '';
    $Self->{Translation}->{'If enabled, OTRS will deliver all JavaScript files in minified form.'} = '';
    $Self->{Translation}->{'If enabled, TicketPhone and TicketEmail will be open in new windows.'} = '';
    $Self->{Translation}->{'If enabled, the OTRS version tag will be removed from the HTTP headers.'} = '';
    $Self->{Translation}->{'If enabled, the QueueView will automatically refresh after the specified time.'} = '';
    $Self->{Translation}->{'If enabled, the first level of the main menu opens on mouse hover (instead of click only).'} = '';
    $Self->{Translation}->{'If set, this address is used as envelope from header in outgoing notifications. If no address is specified, the envelope from header is empty.'} = '';
    $Self->{Translation}->{'If this regex matches, no message will be send by the autoresponder.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, specify the DSN to this database.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, the password to authenticate to this database can be specified.'} = '';
    $Self->{Translation}->{'If you want to use a mirror database for agent ticket fulltext search or to generate stats, the user to authenticate to this database can be specified.'} = '';
    $Self->{Translation}->{'Ignore article with system sender type for new article feature (e. g. auto responses or email notifications).'} = '';
    $Self->{Translation}->{'Import'} = '';
    $Self->{Translation}->{'Includes article create times in the ticket search of the agent interface.'} = '';
    $Self->{Translation}->{'IndexAccelerator: to choose your backend TicketViewAccelerator module. "RuntimeDB" generates each queue view on the fly from ticket table (no performance problems up to approx. 60.000 tickets in total and 6.000 open tickets in the system). "StaticDB" is the most powerful module, it uses an extra ticket-index table that works like a view (recommended if more than 80.000 and 6.000 open tickets are stored in the system). Use the script "bin/otrs.RebuildTicketIndex.pl" for initial index update.'} = '';
    $Self->{Translation}->{'Install ispell or aspell on the system, if you want to use a spell checker. Please specify the path to the aspell or ispell binary on your operating system.'} = '';
    $Self->{Translation}->{'Interface language'} = '';
    $Self->{Translation}->{'It is possible to configure different skins, for example to distinguish between diferent agents, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid skin on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'It is possible to configure different skins, for example to distinguish between diferent customers, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid skin on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'It is possible to configure different themes, for example to distinguish between agents and customers, to be used on a per-domain basis within the application. Using a regular expression (regex), you can configure a Key/Content pair to match a domain. The value in "Key" should match the domain, and the value in "Content" should be a valid theme on your system. Please see the example entries for the proper form of the regex.'} = '';
    $Self->{Translation}->{'Language'} = '';
    $Self->{Translation}->{'Link agents to groups.'} = '';
    $Self->{Translation}->{'Link agents to roles.'} = '';
    $Self->{Translation}->{'Link attachments to responses templates.'} = '';
    $Self->{Translation}->{'Link customers to groups.'} = '';
    $Self->{Translation}->{'Link customers to services.'} = '';
    $Self->{Translation}->{'Link queues to auto responses.'} = '';
    $Self->{Translation}->{'Link responses to queues.'} = '';
    $Self->{Translation}->{'Link roles to groups.'} = '';
    $Self->{Translation}->{'Link this ticket to other objects!'} = '';
    $Self->{Translation}->{'Links 2 tickets with a "Normal" type link.'} = '';
    $Self->{Translation}->{'Links 2 tickets with a "ParentChild" type link.'} = '';
    $Self->{Translation}->{'List of CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE6-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE7-specific CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of IE7-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of IE8-specific CSS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of IE8-specific CSS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'List of JS files to always be loaded for the agent interface.'} = '';
    $Self->{Translation}->{'List of JS files to always be loaded for the customer interface.'} = '';
    $Self->{Translation}->{'Log file for the ticket counter.'} = '';
    $Self->{Translation}->{'Look into a ticket!'} = '';
    $Self->{Translation}->{'Makes the application check the MX record of email addresses before sending an email or submitting a telephone or email ticket.'} = '';
    $Self->{Translation}->{'Makes the application check the syntax of email addresses.'} = '';
    $Self->{Translation}->{'Makes the picture transparent.'} = '';
    $Self->{Translation}->{'Makes the session management use html cookies. If html cookies are disabled or if the client browser disabled html cookies, then the system will work as usual and append the session id to the links.'} = '';
    $Self->{Translation}->{'Manage PGP keys for email encryption.'} = '';
    $Self->{Translation}->{'Manage POP3 or IMAP accounts to fetch email from.'} = '';
    $Self->{Translation}->{'Manage S/MIME certificates for email encryption.'} = '';
    $Self->{Translation}->{'Manage existing sessions.'} = '';
    $Self->{Translation}->{'Manage periodic tasks.'} = '';
    $Self->{Translation}->{'Mark as Spam!'} = '';
    $Self->{Translation}->{'Max size (in characters) of the customer information table (phone and email) in the compose screen.'} = '';
    $Self->{Translation}->{'Max size of the subjects in an email reply.'} = '';
    $Self->{Translation}->{'Max. displayed tickets'} = '';
    $Self->{Translation}->{'Maximal auto email responses to own email-address a day (Loop-Protection).'} = '';
    $Self->{Translation}->{'Maximal size in KBytes for mails that can be fetched via POP3/POP3S/IMAP/IMAPS (KBytes).'} = '';
    $Self->{Translation}->{'Maximum number of tickets to be displayed in the result of a search in the agent interface.'} = '';
    $Self->{Translation}->{'Maximum number of tickets to be displayed in the result of a search in the customer interface.'} = '';
    $Self->{Translation}->{'Maximum size (in characters) of the customer info table in the queue view.'} = '';
    $Self->{Translation}->{'Maximum size (in characters) of the customer information table in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Merge this ticket!'} = '';
    $Self->{Translation}->{'Module for To-selection in new ticket screen in the customer interface.'} = '';
    $Self->{Translation}->{'Module to check customer permissions.'} = '';
    $Self->{Translation}->{'Module to check if a user is in a special group. Access is granted, if the user is in the specified group and has ro and rw permissions.'} = '';
    $Self->{Translation}->{'Module to check if arrived emails should be marked as email-internal (because of original forwared internal email it college). ArticleType and SenderType define the values for the arrived email/article.'} = '';
    $Self->{Translation}->{'Module to check the agent responsible of a ticket.'} = '';
    $Self->{Translation}->{'Module to check the group permissions for the access to customer tickets.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} = '';
    $Self->{Translation}->{'Module to check the owner of a ticket.'} = '';
    $Self->{Translation}->{'Module to check the watcher agents of a ticket.'} = '';
    $Self->{Translation}->{'Module to compose signed messages (PGP or S/MIME).'} = '';
    $Self->{Translation}->{'Module to crypt composed messages (PGP or S/MIME).'} = '';
    $Self->{Translation}->{'Module to filter and manipulate incoming messages. Block/ignore all spam email with From: noreply@ address.'} = '';
    $Self->{Translation}->{'Module to filter and manipulate incoming messages. Get a 4 digit number to ticket free text, use regex in Match e. g. From => \'(.+?)@.+?\', and use () as [***] in Set =>.'} = '';
    $Self->{Translation}->{'Module to generate accounted time ticket statistics.'} = '';
    $Self->{Translation}->{'Module to generate html OpenSearch profile for short ticket search in the agent interface.'} = '';
    $Self->{Translation}->{'Module to generate html OpenSearch profile for short ticket search in the customer interface.'} = '';
    $Self->{Translation}->{'Module to generate ticket solution and response time statistics.'} = '';
    $Self->{Translation}->{'Module to generate ticket statistics.'} = '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Module to inform agents, via the agent interface, about the used charset. A notification is displayed, if the default charset is not used, e.g. in tickets.'} = '';
    $Self->{Translation}->{'Module to show notifications and escalations (ShownMax: max. shown escalations, EscalationInMinutes: Show ticket which will escalation in, CacheTime: Cache of calculated escalations in seconds).'} = '';
    $Self->{Translation}->{'Module to use database filter storage.'} = '';
    $Self->{Translation}->{'My Queues'} = '';
    $Self->{Translation}->{'My Tickets'} = '';
    $Self->{Translation}->{'Name of custom queue. The custom queue is a queue selection of your preferred queues and can be selected in the preferences settings.'} = '';
    $Self->{Translation}->{'New'} = '';
    $Self->{Translation}->{'New Ticket'} = '';
    $Self->{Translation}->{'New email ticket'} = '';
    $Self->{Translation}->{'New phone ticket'} = '';
    $Self->{Translation}->{'New ticket notification'} = '';
    $Self->{Translation}->{'Next possible ticket states after adding a phone note in the ticket phone outbound screen of the agent interface.'} = '';
    $Self->{Translation}->{'Notifications (Event)'} = '';
    $Self->{Translation}->{'Number of displayed tickets'} = '';
    $Self->{Translation}->{'Number of lines (per ticket) that are shown by the search utility in the agent interface.'} = '';
    $Self->{Translation}->{'Number of tickets to be displayed in each page of a search result in the agent interface.'} = '';
    $Self->{Translation}->{'Number of tickets to be displayed in each page of a search result in the customer interface.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} = '';
    $Self->{Translation}->{'Out Of Office Time'} = '';
    $Self->{Translation}->{'Overloads (redefines) existing functions in Kernel::System::Ticket. Used to easily add customizations.'} = '';
    $Self->{Translation}->{'Overview'} = '';
    $Self->{Translation}->{'Overview Escalated Tickets'} = '';
    $Self->{Translation}->{'Overview of all open Tickets'} = '';
    $Self->{Translation}->{'Overview of all open Tickets.'} = '';
    $Self->{Translation}->{'PGP Key'} = '';
    $Self->{Translation}->{'PGP Key Upload'} = '';
    $Self->{Translation}->{'PGP Keys'} = '';
    $Self->{Translation}->{'Package Manager'} = '';
    $Self->{Translation}->{'Parameters for the CreateNextMask object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the CustomQueue object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the FollowUpNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the LockTimeoutNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the MoveNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the NewTicketNotify object in the preferences view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the RefreshTime object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the WatcherNotify object in the preference view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the new tickets overview of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket calendar of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket escalation overview of the agent interface . "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket pending reminder overview of the agent interface . "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket pending reminder overview of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the dashboard backend of the ticket stats of the agent interface. "Limit" is the number of entries shown by default. "Group" is used to restrict the access to the plugin (e. g. Group: admin;group1;group2;). "Default" determines if the plugin is enabled by default or if the user needs to enable it manually. "CacheTTLLocal" is the cache time in minutes for the plugin.'} = '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} = '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the medium ticket overview.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the small ticket overview.'} = '';
    $Self->{Translation}->{'Parameters for the pages (in which the tickets are shown) of the ticket preview overview.'} = '';
    $Self->{Translation}->{'Parameters of the example SLA attribute Comment2.'} = '';
    $Self->{Translation}->{'Parameters of the example queue attribute Comment2.'} = '';
    $Self->{Translation}->{'Parameters of the example service attribute Comment2.'} = '';
    $Self->{Translation}->{'Path for the log file (it only applies if "FS" was selected for LoopProtectionModule and it is mandatory).'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the QueueObject object for the agent interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the QueueObject object for the customer interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the TicketObject for the agent interface.'} = '';
    $Self->{Translation}->{'Path of the file that stores all the settings for the TicketObject for the customer interface.'} = '';
    $Self->{Translation}->{'Performance Log'} = '';
    $Self->{Translation}->{'Permitted width for compose email windows.'} = '';
    $Self->{Translation}->{'Permitted width for compose note windows.'} = '';
    $Self->{Translation}->{'PostMaster Filters'} = '';
    $Self->{Translation}->{'PostMaster Mail Accounts'} = '';
    $Self->{Translation}->{'Print this ticket!'} = '';
    $Self->{Translation}->{'Priorities'} = '';
    $Self->{Translation}->{'Protection against CSRF (Cross Site Request Forgery) exploits (for more info see http://en.wikipedia.org/wiki/Cross-site_request_forgery).'} = '';
    $Self->{Translation}->{'Queue view'} = '';
    $Self->{Translation}->{'QueueView Refresh Time'} = '';
    $Self->{Translation}->{'Queues'} = '';
    $Self->{Translation}->{'Refresh QueueView after'} = '';
    $Self->{Translation}->{'Refresh interval'} = '';
    $Self->{Translation}->{'Replaces the original sender with current customer\'s email address on compose answer in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to change the customer of a ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the close ticket screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket bounce screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket compose screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket forward screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket free text screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket merge screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket note screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket phone outbound screen in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Required permissions to use the ticket responsible screen in the agent interface.'} = '';
    $Self->{Translation}->{'Resets and unlocks the owner of a ticket if it was moved to another queue.'} = '';
    $Self->{Translation}->{'Responses'} = '';
    $Self->{Translation}->{'Responses <-> Queues'} = '';
    $Self->{Translation}->{'Restores a ticket from the archive (only if the event is a state change, from closed to any open available state).'} = '';
    $Self->{Translation}->{'Roles'} = '';
    $Self->{Translation}->{'Roles <-> Groups'} = '';
    $Self->{Translation}->{'Runs an initial wildcard search of the existing customer users when accessing the AdminCustomerUser module.'} = '';
    $Self->{Translation}->{'Runs the system in "Demo" mode. If set to "Yes", agents can change preferences, such as selection of language and theme via the agent web interface. These changes are only valid for the current session. It will not be possible for agents to change their passwords.'} = '';
    $Self->{Translation}->{'S/MIME Certificate'} = '';
    $Self->{Translation}->{'S/MIME Certificate Upload'} = '';
    $Self->{Translation}->{'S/MIME Certificates'} = '';
    $Self->{Translation}->{'SQL Box'} = '';
    $Self->{Translation}->{'Salutations'} = '';
    $Self->{Translation}->{'Saves the attachments of articles. "DB" stores all data in the database (not recommended for storing big attachments). "FS" stores the data on the filesystem; this is faster but the webserver should run under the OTRS user. You can switch between the modules even on a system that is already in production without any loss of data.'} = '';
    $Self->{Translation}->{'Saves the login and password on the session table in the database, if "DB" was selected for SessionModule.'} = '';
    $Self->{Translation}->{'Screen after new ticket'} = '';
    $Self->{Translation}->{'Search Tickets'} = '';
    $Self->{Translation}->{'Search backend default router.'} = '';
    $Self->{Translation}->{'Search backend router.'} = '';
    $Self->{Translation}->{'Select the separator character used in CSV files (stats and searches). If you don\'t select a separator here, the default separator for your language will be used.'} = '';
    $Self->{Translation}->{'Select your frontend Theme.'} = '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} = '';
    $Self->{Translation}->{'Selects the module to handle uploads via the web interface. "DB" stores all uploads in the database, "FS" uses the file system.'} = '';
    $Self->{Translation}->{'Selects the ticket number generator module. "AutoIncrement" increments the ticket number, the SystemID and the counter are used with SystemID.counter format (e.g. 1010138, 1010139). With "Date" the ticket numbers will be generated by the current date, the SystemID and the counter. The format looks like Year.Month.Day.SystemID.counter (e.g. 200206231010138, 200206231010139). With "DateChecksum"  the counter will be appended as checksum to the string of date and SystemID. The checksum will be rotated on a daily basis. The format looks like Year.Month.Day.SystemID.Counter.CheckSum (e.g. 2002070110101520, 2002070110101535). "Random" generates randomized ticket numbers in the format "SystemID.Random" (e.g. 100057866352, 103745394596).'} = '';
    $Self->{Translation}->{'Send me a notification if a customer sends a follow up and I\'m the owner of the ticket or the ticket is unlocked and is in one of my subscribed queues.'} = '';
    $Self->{Translation}->{'Send me a notification if a ticket is moved into one of "My Queues".'} = '';
    $Self->{Translation}->{'Send me a notification if a ticket is unlocked by the system.'} = '';
    $Self->{Translation}->{'Send me a notification if there is a new ticket in "My Queues".'} = '';
    $Self->{Translation}->{'Send me the same notifications for my watched tickets that the ticket owners will get.'} = '';
    $Self->{Translation}->{'Send new ticket notifications'} = '';
    $Self->{Translation}->{'Send notifications to users.'} = '';
    $Self->{Translation}->{'Send ticket follow up notifications'} = '';
    $Self->{Translation}->{'Send ticket lock timeout notifications'} = '';
    $Self->{Translation}->{'Send ticket move notifications'} = '';
    $Self->{Translation}->{'Send ticket watch notifications'} = '';
    $Self->{Translation}->{'Sender type for new tickets from the customer inteface.'} = '';
    $Self->{Translation}->{'Sends agent follow-up notification only to the owner, if a ticket is unlocked (the default is to send the notification to all agents).'} = '';
    $Self->{Translation}->{'Sends all outgoing email via bcc to the specified address. Please use this only for backup reasons.'} = '';
    $Self->{Translation}->{'Sends customer notifications just to the mapped customer. Normally, if no customer is mapped, the latest customer sender gets the notification.'} = '';
    $Self->{Translation}->{'Sends reminder notifications of unlocked ticket after reaching the reminder date (only sent to ticket owner).'} = '';
    $Self->{Translation}->{'Sends the notifications which are configured in the admin interface under "Notfication (Event)".'} = '';
    $Self->{Translation}->{'Service Level Agreements'} = '';
    $Self->{Translation}->{'Services'} = '';
    $Self->{Translation}->{'Session Management'} = '';
    $Self->{Translation}->{'Set sender email addresses for this system.'} = '';
    $Self->{Translation}->{'Set the default height (in pixels) of inline HTML articles in AgentTicketZoom.'} = '';
    $Self->{Translation}->{'Set the maximum height (in pixels) of inline HTML articles in AgentTicketZoom.'} = '';
    $Self->{Translation}->{'Set this ticket to pending!'} = '';
    $Self->{Translation}->{'Set this to yes if you trust in all your public and private pgp keys, even if they are not certified with a trusted signature.'} = '';
    $Self->{Translation}->{'Sets if ticket owner must be selected by the agent.'} = '';
    $Self->{Translation}->{'Sets the PendingTime of a ticket to 0 if the state is changed to a non-pending state.'} = '';
    $Self->{Translation}->{'Sets the age in minutes (first level) for highlighting queues that contain untouched tickets.'} = '';
    $Self->{Translation}->{'Sets the age in minutes (second level) for highlighting queues that contain untouched tickets.'} = '';
    $Self->{Translation}->{'Sets the configuration level of the administrator. Depending on the config level, some sysconfig options will be not shown. The config levels are in in ascending order: Expert, Advanced, Beginner. The higher the config level is (e.g. Beginner is the highest), the less likely is it that the user can accidentally configure the system in a way that it is not usable any more.'} = '';
    $Self->{Translation}->{'Sets the default article type for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default article type for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket move screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default body text for notes added in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default charset for the web interface to use (should represent the charset used to create the database or, in some cases, the database management system being used). "utf-8" is a good choice for environments expecting many charsets. You can specify another charset here (i.e. "iso-8859-1"). Please be sure that you will not be receiving foreign emails, or text, otherwise this could lead to problems.'} = '';
    $Self->{Translation}->{'Sets the default link type of splitted tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default next state for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default next ticket state, after the creation of an email ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default note text for new telephone tickets. E.g \'New ticket via call\' in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default priority for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default priority for new phone tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default sender type for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default sender type for new phone ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for new email tickets (e.g. \'email Outbound\') in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for new phone tickets (e.g. \'Phone call\') in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket move screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default subject for notes added in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the default text for new email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the display order of the different items in the preferences view.'} = '';
    $Self->{Translation}->{'Sets the inactivity time (in seconds) to pass before a session is killed and a user is loged out.'} = '';
    $Self->{Translation}->{'Sets the minimal ticket counter size (if "AutoIncrement" was selected as TicketNumberGenerator). Default is 5, this means the counter starts from 10000.'} = '';
    $Self->{Translation}->{'Sets the minimum number of characters before autocomplete query is sent.'} = '';
    $Self->{Translation}->{'Sets the number of lines that are displayed in text messages (e.g. ticket lines in the QueueZoom).'} = '';
    $Self->{Translation}->{'Sets the number of lines that are displayed in the preview of messages (e.g. for tickets in the QueueView).'} = '';
    $Self->{Translation}->{'Sets the number of search results to be displayed for the autocomplete feature.'} = '';
    $Self->{Translation}->{'Sets the options for PGP binary.'} = '';
    $Self->{Translation}->{'Sets the order of the different items in the customer preferences view.'} = '';
    $Self->{Translation}->{'Sets the password for private PGP key.'} = '';
    $Self->{Translation}->{'Sets the prefered time units (e.g. work units, hours, minutes).'} = '';
    $Self->{Translation}->{'Sets the prefix to the scripts folder on the server, as configured on the web server. This setting is used as a variable, OTRS_CONFIG_ScriptAlias which is found in all forms of messaging used by the application, to build links to the tickets within the system.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the responsible agent of the ticket in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the service in the close ticket screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket free text screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket note screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket owner screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket pending screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket priority screen of a zoomed ticket in the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the service in the ticket responsible screen of the agent interface (Ticket::Service needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the size of the statistic graph.'} = '';
    $Self->{Translation}->{'Sets the stats hook.'} = '';
    $Self->{Translation}->{'Sets the system time zone (required a system with UTC as system time). Otherwise this is a diff time to the local time.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket owner in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Sets the ticket type in the close ticket screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket free text screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket note screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket owner screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket pending screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket priority screen of a zoomed ticket in the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the ticket type in the ticket responsible screen of the agent interface (Ticket::Type needs to be activated).'} = '';
    $Self->{Translation}->{'Sets the time type which should be shown.'} = '';
    $Self->{Translation}->{'Sets the timeout (in seconds) for http/ftp downloads.'} = '';
    $Self->{Translation}->{'Sets the timeout (in seconds) for package downloads. Overwrites "WebUserAgent::Timeout".'} = '';
    $Self->{Translation}->{'Sets the user time zone per user (required a system with UTC as system time and UTC under TimeZone). Otherwise this is a diff time to the local time.'} = '';
    $Self->{Translation}->{'Sets the user time zone per user based on java script / browser time zone offset feature at login time.'} = '';
    $Self->{Translation}->{'Show a responsible selection in phone and email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Show article as rich text even if rich text writing is disabled.'} = '';
    $Self->{Translation}->{'Show this screen after I created a new ticket'} = '';
    $Self->{Translation}->{'Shows a count of icons in the ticket zoom, if the article has attachments.'} = '';
    $Self->{Translation}->{'Shows a link in the menu for subscribing / unsubscribing from a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a ticket with another object in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu that allows merging tickets in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a free text field in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a note in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to add a note to a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to close a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to close a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to delete a ticket in every ticket overview of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to delete a ticket in the ticket zoom view of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to lock / unlock a ticket in the ticket overviews of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to lock/unlock tickets in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to move a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to print a ticket or an article in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the customer who requested the ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the history of a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the owner of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the priority of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to see the responsible agent of a ticket in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set a ticket as pending in the ticket zoom view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set a ticket as spam in every ticket overview of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a link in the menu to set the priority of a ticket in every ticket overview of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link in the menu to zoom a ticket in the ticket overviews of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to access article attachments via a html online viewer in the zoom view of the article in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to download article attachments in the zoom view of the article in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a link to see a zoomed email ticket in plain text.'} = '';
    $Self->{Translation}->{'Shows a link to set a ticket as spam in the ticket zoom view of the agent interface. Additional access control to show or not show this link can be done by using Key "Group" and Content like "rw:group1;move_into:group2".'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the involved agents on this ticket, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows a list of all the possible agents (all agents with note permissions on the queue/ticket) to determine who should be informed about this note, in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows a preview of the ticket overview (CustomerInfo => 1 - shows also Customer-Info, CustomerInfoMaxSize max. size in characters of Customer-Info).'} = '';
    $Self->{Translation}->{'Shows all both ro and rw queues in the queue view.'} = '';
    $Self->{Translation}->{'Shows all open tickets (even if they are locked) in the escalation view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows all open tickets (even if they are locked) in the status view of the agent interface.'} = '';
    $Self->{Translation}->{'Shows all the articles of the ticket (expanded) in the zoom view.'} = '';
    $Self->{Translation}->{'Shows all the customer identifiers in a multi-select field (not useful if you have a lot of customer identifiers).'} = '';
    $Self->{Translation}->{'Shows an owner selection in phone and email tickets in the agent interface.'} = '';
    $Self->{Translation}->{'Shows customer history tickets in AgentTicketPhone, AgentTicketEmail and AgentTicketCustomer.'} = '';
    $Self->{Translation}->{'Shows either the last customer article\'s subject or the ticket title in the small format overview.'} = '';
    $Self->{Translation}->{'Shows existing parent/child queue lists in the system in the form of a tree or a list.'} = '';
    $Self->{Translation}->{'Shows the activated ticket attributes in the customer interface (0 = Disabled and 1 = Enabled).'} = '';
    $Self->{Translation}->{'Shows the articles sorted normally or in reverse, under ticket zoom in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the customer user information (phone and email) in the compose screen.'} = '';
    $Self->{Translation}->{'Shows the customer user\'s info in the ticket zoom view.'} = '';
    $Self->{Translation}->{'Shows the message of the day (MOTD) in the agent dashboard. "Group" is used to restrict access to the plugin (e. g. Group: admin;group1;group2;). "Default" indicates if the plugin is enabled by default or if the user needs to enable it manually.'} = '';
    $Self->{Translation}->{'Shows the message of the day on login screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket history (reverse ordered) in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket history!'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the move ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket bulk screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the ticket priority options in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the close ticket screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket free text screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket note screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket owner screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket pending screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket priority screen of a zoomed ticket in the agent interface.'} = '';
    $Self->{Translation}->{'Shows the title fields in the ticket responsible screen of the agent interface.'} = '';
    $Self->{Translation}->{'Shows time in long format (days, hours, minutes), if set to "Yes"; or in short format (days, hours), if set to "No".'} = '';
    $Self->{Translation}->{'Shows time use complete description (days, hours, minutes), if set to "Yes"; or just first letter (d, h, m), if set to "No".'} = '';
    $Self->{Translation}->{'Signatures'} = '';
    $Self->{Translation}->{'Skin'} = '';
    $Self->{Translation}->{'Sorts the tickets (ascendingly or descendingly) when a single queue is selected in the queue view and after the tickets are sorted by priority. Values: 0 = ascending (oldest on top, default), 1 = descending (youngest on top). Use the QueueID for the key and 0 or 1 for value.'} = '';
    $Self->{Translation}->{'Spam Assassin example setup. Ignores emails that are marked with SpamAssassin.'} = '';
    $Self->{Translation}->{'Spam Assassin example setup. Moves marked mails to spam queue.'} = '';
    $Self->{Translation}->{'Specifies if an agent should receive email notification of his own actions.'} = '';
    $Self->{Translation}->{'Specifies the background color of the chart.'} = '';
    $Self->{Translation}->{'Specifies the background color of the picture.'} = '';
    $Self->{Translation}->{'Specifies the border color of the chart.'} = '';
    $Self->{Translation}->{'Specifies the border color of the legend.'} = '';
    $Self->{Translation}->{'Specifies the bottom margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the different article types that will be used in the system.'} = '';
    $Self->{Translation}->{'Specifies the different note types that will be used in the system.'} = '';
    $Self->{Translation}->{'Specifies the directory to store the data in, if "FS" was selected for TicketStorageModule.'} = '';
    $Self->{Translation}->{'Specifies the directory where SSL certificates are stored.'} = '';
    $Self->{Translation}->{'Specifies the directory where private SSL certificates are stored.'} = '';
    $Self->{Translation}->{'Specifies the email address that should be used by the application when sending notifications. The email address is used to build the complete display name for the notification master (i.e. "OTRS Notification Master" otrs@your.example.com). You can use the OTRS_CONFIG_FQDN variable as set in your configuation, or choose another email address. Notifications are messages such as en::Customer::QueueUpdate or en::Agent::Move.'} = '';
    $Self->{Translation}->{'Specifies the left margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the name that should be used by the application when sending notifications. The sender name is used to build the complete display name for the notification master (i.e. "OTRS Notification Master" otrs@your.example.com). Notifications are messages such as en::Customer::QueueUpdate or en::Agent::Move.'} = '';
    $Self->{Translation}->{'Specifies the path of the file for the logo in the page header (gif|jpg|png, 700 x 100 pixel).'} = '';
    $Self->{Translation}->{'Specifies the path of the file for the performance log.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of Microsoft Excel files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of Microsoft Word files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of PDF documents, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the path to the converter that allows the view of XML files, in the web interface.'} = '';
    $Self->{Translation}->{'Specifies the right margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies the text color of the chart (e. g. caption).'} = '';
    $Self->{Translation}->{'Specifies the text color of the legend.'} = '';
    $Self->{Translation}->{'Specifies the text that should appear in the log file to denote a CGI script entry.'} = '';
    $Self->{Translation}->{'Specifies the top margin of the chart.'} = '';
    $Self->{Translation}->{'Specifies user id of the postmaster data base.'} = '';
    $Self->{Translation}->{'Spelling Dictionary'} = '';
    $Self->{Translation}->{'Standard available permissions for agents within the application. If more permissions are needed, they can be entered here. Permissions must be defined to be effective. Some other good permissions have also been provided built-in: note, close, pending, customer, freetext, move, compose, responsible, forward, and bounce. Make sure that "rw" is always the last registered permission.'} = '';
    $Self->{Translation}->{'Start number for statistics counting. Every new stat increments this number.'} = '';
    $Self->{Translation}->{'States'} = '';
    $Self->{Translation}->{'Statistics'} = '';
    $Self->{Translation}->{'Status view'} = '';
    $Self->{Translation}->{'Stores cookies after the browser has been closed.'} = '';
    $Self->{Translation}->{'Strips empty lines on the ticket preview in the queue view.'} = '';
    $Self->{Translation}->{'System Log'} = '';
    $Self->{Translation}->{'The "bin/PostMasterMailAccount.pl" will reconnect to POP3/POP3S/IMAP/IMAPS host after the specified count of messages.'} = '';
    $Self->{Translation}->{'The agent skin\'s InternalName which should be used in the agent interface. Please check the available skins in Frontend::Agent::Skins.'} = '';
    $Self->{Translation}->{'The customer skin\'s InternalName which should be used in the customer interface. Please check the available skins in Frontend::Customer::Skins.'} = '';
    $Self->{Translation}->{'The divider between TicketHook and ticket number. E.g \': \'.'} = '';
    $Self->{Translation}->{'The format of the subject. \'Left\' means \'[TicketHook#:12345] Some Subject\', \'Right\' means \'Some Subject [TicketHook#:12345]\', \'None\' means \'Some Subject\' and no ticket number. In the last case you should enable PostmasterFollowupSearchInRaw or PostmasterFollowUpSearchInReferences to recognize followups based on email headers and/or body.'} = '';
    $Self->{Translation}->{'The headline shown in the customer interface.'} = '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} = '';
    $Self->{Translation}->{'The identifier for a ticket, e.g. Ticket#, Call#, MyTicket#. The default is Ticket#.'} = '';
    $Self->{Translation}->{'The logo shown in the header of the agent interface. The URL to the image must be a relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The logo shown in the header of the customer interface. The URL to the image must be a relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The logo shown on top of the login box of the agent interface. The URL to the image must be relative URL to the skin image directory.'} = '';
    $Self->{Translation}->{'The text at the beginning of the subject in an email reply, e.g. RE, AW, or AS.'} = '';
    $Self->{Translation}->{'The text at the beginning of the subject when an email is forwarded, e.g. FW, Fwd, or WG.'} = '';
    $Self->{Translation}->{'Theme'} = '';
    $Self->{Translation}->{'This module and its PreRun() function will be executed, if defined, for every request. This module is useful to check some user options or to display news about new applications.'} = '';
    $Self->{Translation}->{'Ticket Overview "Medium" Limit'} = '';
    $Self->{Translation}->{'Ticket Overview "Preview" Limit'} = '';
    $Self->{Translation}->{'Ticket Overview "Small" Limit'} = '';
    $Self->{Translation}->{'Ticket follow up notification'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the move ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket forward screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket search of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free text options shown in the ticket search screen in the customer interface. Possible settings: 0 = Disabled and 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the close ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the email ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the move ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the phone ticket screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket compose screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket forward screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket free text screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket message screen of the customer interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required. NOTE. If you want to display these fields also in the ticket zoom of the customer interface, you have to enable them in CustomerTicketZoom###AttributesView.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket note screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket owner screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket pending screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket phone outbound screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket priority screen of a zoomed ticket in the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket responsible screen of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled, 2 = Enabled and required.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket search of the agent interface. Possible settings: 0 = Disabled, 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket free time options shown in the ticket search screen in the customer interface. Possible settings: 0 = Disabled and 1 = Enabled.'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Medium"'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Preview"'} = '';
    $Self->{Translation}->{'Ticket limit per page for Ticket Overview "Small"'} = '';
    $Self->{Translation}->{'Ticket lock timeout notification'} = '';
    $Self->{Translation}->{'Ticket move notification'} = '';
    $Self->{Translation}->{'Ticket overview'} = '';
    $Self->{Translation}->{'Ticket watch notification'} = '';
    $Self->{Translation}->{'Tickets'} = '';
    $Self->{Translation}->{'Time Zone'} = '';
    $Self->{Translation}->{'Time in seconds that gets added to the actual time if setting a pending-state (default: 86400 = 1 day).'} = '';
    $Self->{Translation}->{'Toolbar Item for a shortcut.'} = '';
    $Self->{Translation}->{'Turns on the animations used in the GUI. If you have problems with these animations (e.g. performance issues), you can turn them off here.'} = '';
    $Self->{Translation}->{'Turns on the remote ip address check. It should be set to "No" if the application is used, for example, via a proxy farm or a dialup connection, because the remote ip address is mostly different for the requests.'} = '';
    $Self->{Translation}->{'Types'} = '';
    $Self->{Translation}->{'Update Ticket "Seen" flag if every article got seen or a new Article got created.'} = '';
    $Self->{Translation}->{'Update and extend your system with software packages.'} = '';
    $Self->{Translation}->{'Updates the ticket escalation index after a ticket attribute got updated.'} = '';
    $Self->{Translation}->{'Updates the ticket index accelerator.'} = '';
    $Self->{Translation}->{'Uses Cc recipients in reply Cc list on compose an email answer in the ticket compose screen of the agent interface.'} = '';
    $Self->{Translation}->{'Uses richtext for viewing and editing: articles, salutations, signatures, standard responses, auto responses and notifications.'} = '';
    $Self->{Translation}->{'View performance benchmark results.'} = '';
    $Self->{Translation}->{'View system log messages.'} = '';
    $Self->{Translation}->{'Wear this frontend skin'} = '';
    $Self->{Translation}->{'When tickets are merged, a note will be added automatically to the ticket which is no longer active. In this text area you can define this text (This text cannot be changed by the agent).'} = '';
    $Self->{Translation}->{'When tickets are merged, the customer can be informed per email by setting the check box "Inform Sender". In this text area, you can define a pre-formatted text which can later be modified by the agents.'} = '';
    $Self->{Translation}->{'Your language'} = '';
    $Self->{Translation}->{'Your queue selection of your favourite queues. You also get notified about those queues via email if enabled.'} = '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/es_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::es_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Dirección';
    $Self->{Translation}->{'Admin Tool'} = 'Herramienta de Administración';
    $Self->{Translation}->{'Backup Device'} = 'Dispositivo de Respaldo';
    $Self->{Translation}->{'Beamer'} = 'Proyector';
    $Self->{Translation}->{'Building'} = 'Edificio';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'ConfigItem nuevo (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'ConfigItem eliminado (ID=%s)';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Definición del ConfigItem modificado (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Implementación del estado modificado (nuevo=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Modificación del estado del incidente (nuevo=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Vínculo con %s nuevo (Tipo=%s)';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Vínculo con %s eliminado (Tipo=%s)';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Nombre actualizado (nuevo=%s; alt=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Atributo %s actualizado desde "%s" hasta "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Versión nueva (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versión %s eliminada';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Cámara';
    $Self->{Translation}->{'Capacity'} = 'Capacidad';
    $Self->{Translation}->{'Change Definition'} = 'Modificar Definición';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Actualización de definiciones fallida! Revisar el Log del Sistema para consultar los detalles';
    $Self->{Translation}->{'Client Application'} = 'Aplicación Cliente';
    $Self->{Translation}->{'Client OS'} = 'SO Cliente';
    $Self->{Translation}->{'Concurrent Users'} = 'Usuarios Concurrentes';
    $Self->{Translation}->{'Config Item-Area'} = 'Área de Elementos de Configuración';
    $Self->{Translation}->{'Config Items available'} = 'Elementos de Configuración disponibles';
    $Self->{Translation}->{'Config Items shown'} = 'Elementos de Configuración mostrados';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demostración';
    $Self->{Translation}->{'Desktop'} = 'Escritorio';
    $Self->{Translation}->{'Developer Licence'} = 'Licencia de Desarrollador';
    $Self->{Translation}->{'Docking Station'} = 'Docking Station';
    $Self->{Translation}->{'Duplicate'} = 'Duplicado';
    $Self->{Translation}->{'Embedded'} = 'Embebido';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Licencia Corporativa';
    $Self->{Translation}->{'Expiration Date'} = 'Fecha de Expiración';
    $Self->{Translation}->{'Expired'} = 'Expirado';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Piso';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Puerta de enlace';
    $Self->{Translation}->{'Graphic Adapter'} = 'Tarjeta Gráfica';
    $Self->{Translation}->{'Hard Disk'} = 'Disco Duro';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disco Duro::Capacidad';
    $Self->{Translation}->{'Hide Versions'} = 'Ocultar Versiones';
    $Self->{Translation}->{'IP Address'} = 'Dirección IP';
    $Self->{Translation}->{'IP over DHCP'} = 'IP sobre DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Instalaciones de TI';
    $Self->{Translation}->{'Inactive'} = 'Inactivo';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = 'Fecha de Instalación';
    $Self->{Translation}->{'Keybord'} = 'Teclado';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Computadora portátil';
    $Self->{Translation}->{'Last Change'} = 'Ultima modificación';
    $Self->{Translation}->{'Licence Key'} = 'Clave de Licencia';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Clave de Licencia::Fecha de Expiración';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Clave de Licencia::Cantidad';
    $Self->{Translation}->{'Licence Type'} = 'Tipo de Licencia';
    $Self->{Translation}->{'Maintenance'} = 'Mantenimiento';
    $Self->{Translation}->{'Maximum number of one element'} = 'Número máximo de un elemento ';
    $Self->{Translation}->{'Media'} = 'Medio';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Modelo';
    $Self->{Translation}->{'Modem'} = 'Módem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Mouse';
    $Self->{Translation}->{'Network Adapter'} = 'Adaptador de Red';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adaptador de Red::Dirección IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adaptador de Red::IP Sobre DHCP';
    $Self->{Translation}->{'Network Address'} = 'Dirección de Red';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Dirección de Red::Puerta de enlace';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Dirección de Red::Máscara de Subred';
    $Self->{Translation}->{'Open Source'} = 'Código Abierto';
    $Self->{Translation}->{'Operating System'} = 'Sistema Operativo';
    $Self->{Translation}->{'Operational'} = 'Operacional';
    $Self->{Translation}->{'Other'} = 'Otro';
    $Self->{Translation}->{'Other Equipment'} = 'Otro Equipo';
    $Self->{Translation}->{'Outlet'} = 'Outlet';
    $Self->{Translation}->{'PCMCIA Card'} = 'Tarjeta PCMCIA';
    $Self->{Translation}->{'PDA'} = 'Agenda Personal';
    $Self->{Translation}->{'Per Node'} = 'Por Nodo';
    $Self->{Translation}->{'Per Processor'} = 'Por Procesador';
    $Self->{Translation}->{'Per Server'} = 'Por Servidor';
    $Self->{Translation}->{'Per User'} = 'Por Usuario';
    $Self->{Translation}->{'Phone 1'} = 'Teléfono 1';
    $Self->{Translation}->{'Phone 2'} = 'Teléfono 2';
    $Self->{Translation}->{'Pilot'} = 'Piloto';
    $Self->{Translation}->{'Planned'} = 'Planificado';
    $Self->{Translation}->{'Printer'} = 'Impresora';
    $Self->{Translation}->{'Production'} = 'Producción';
    $Self->{Translation}->{'Quantity'} = 'Cantidad';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'Reparación';
    $Self->{Translation}->{'Retired'} = 'Retirado';
    $Self->{Translation}->{'Review'} = 'Revisado';
    $Self->{Translation}->{'Room'} = 'Cuarto';
    $Self->{Translation}->{'Router'} = 'Enrutador';
    $Self->{Translation}->{'Scanner'} = 'Escáner';
    $Self->{Translation}->{'Search Config Items'} = 'Buscar Elementos de Configuración';
    $Self->{Translation}->{'Security Device'} = 'Dispositivo de Seguridad';
    $Self->{Translation}->{'Serial Number'} = 'Número Serial';
    $Self->{Translation}->{'Server'} = 'Servidor';
    $Self->{Translation}->{'Server Application'} = 'Aplicación Servidor';
    $Self->{Translation}->{'Server OS'} = 'SO Servidor';
    $Self->{Translation}->{'Show Versions'} = 'Mostrar Versiones';
    $Self->{Translation}->{'Single Licence'} = 'Licencia Única';
    $Self->{Translation}->{'Subnet Mask'} = 'Máscara de Subred';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Conferencia telefónica';
    $Self->{Translation}->{'Test/QA'} = 'Pruebas';
    $Self->{Translation}->{'The deployment state of this config item'} = 'El estado de implementación de este elemento de configuración';
    $Self->{Translation}->{'The incident state of this config item'} = 'El estado de este elemento de configuración';
    $Self->{Translation}->{'Time Restricted'} = 'Tiempo Restringido';
    $Self->{Translation}->{'USB Device'} = 'Dispositivo USB';
    $Self->{Translation}->{'Unlimited'} = 'Ilimitada';
    $Self->{Translation}->{'User Tool'} = 'Herramienta de Usuario';
    $Self->{Translation}->{'Volume Licence'} = 'Licencia por Volumen';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'Punto de Acceso WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Fecha de Expiración de la Garantía';
    $Self->{Translation}->{'Workplace'} = 'Lugar de trabajo';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gestión de Elementos de Configuración';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Elemento de Configuración';
    $Self->{Translation}->{'Class'} = 'Clase';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'El nombre de este elemento de configuración';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Estado de la Implementación';
    $Self->{Translation}->{'Incident State'} = 'Estado del Incidente';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Estado Actual del Incidente';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Última modificación';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Estado Actual de la Implementación';
    $Self->{Translation}->{'Last changed by'} = 'Última modificación por';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = '¿Desea buscar en versiones anteriores?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        'Módulo de evento de elementos de configuración que habilita el acceso a la historia en la interfaz del agente.';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Límite de Elementos de Configuración';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Límite por página de Elementos de Configuración';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        'Router backend de búsqueda de elementos de configuración de la interfaz del agente.';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        'Define el subobjeto por default de la clase \'ITSMConfigItem\'.';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = 'Módulo para verificar el grupo responsable de una clase.';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        'Módulo para verificar el grupo responsable de un elemento de configuración.';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = 'Módulo para generar estadísticas de los elementos de configuración ITSM.';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        'Registro del módulo de objeto backend para el módulo de importación/exportación.';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        'Parámetros para los estados de implementación en la vista de preferencias de la interfaz del agente.';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        'Parámetros para las páginas (donde se muestran los elementos de configuración)';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de los elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de búsqueda de elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de detalle de los elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana para agregar elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de edición de los elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de historial de los elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        'Permisos necesarios para usar la ventana de impresión de elementos de configuración en la interfaz del agente.';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        'Selecciona el módulo generador de números de los elementos de configuración. "AutoIncrementar" incrementa el número del elemento de configuración; el SystemID, el ConfigItemClassID y el contador son usados. El formato es "SystemID.ConfigItemClassID.Counter", por ejemplo: 1205000004, 1205000005.';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        'Muestra un link en el menú para vincular un elemento de configuración con otro objeto, en la vista detallada de dicho elemento de configuración de la interfaz del agente.';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        'Muestra un link en el menú para acceder a la historia de un elemento de configuracion en su vista detallada, en la interfaz del agente.';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        'Muestra un link en el menú para duplicar un elemento de configuracion en su vista detallada, en la interfaz del agente.';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        'Muestra un link en el menú para editar un elemento de configuracion en su vista detallada, en la interfaz del agente.';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        'Muestra un link en el menú para regresar en la vista detallada de un elemento de configuración de la interfaz del agente.';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        'Muestra un link en el menú para imprimir un elemento de configuracion en su vista detallada, en la interfaz del agente.';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        'Muestra la historia de los elementos de configuración (ordenados inversamente) en la interfaz del agente.';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/fa_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::fa_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'نشانی';
    $Self->{Translation}->{'Admin Tool'} = 'ابزار مدیریتی';
    $Self->{Translation}->{'Backup Device'} = 'وسایل پشتیبان‌گیری';
    $Self->{Translation}->{'Beamer'} = 'پرتو افکن';
    $Self->{Translation}->{'Building'} = 'ساختمان';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'سی‌پی‌یو';
    $Self->{Translation}->{'Camera'} = 'دوربین';
    $Self->{Translation}->{'Capacity'} = 'ظرفیت';
    $Self->{Translation}->{'Change Definition'} = 'تغییر تعریف';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'عملیات تغییر تعریف ناموفق بود. برای کسب اطلاع بیشتر log سیستم را ببینید.';
    $Self->{Translation}->{'Client Application'} = 'برنامه‌های کلاینت';
    $Self->{Translation}->{'Client OS'} = 'سیستم عامل کلاینت';
    $Self->{Translation}->{'Concurrent Users'} = 'کاربران موازی';
    $Self->{Translation}->{'Config Item-Area'} = 'محدوده CI';
    $Self->{Translation}->{'Config Items available'} = 'CIهای در دسترس';
    $Self->{Translation}->{'Config Items shown'} = 'CIهای نمایش داده شده';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'نسخه نمایشی';
    $Self->{Translation}->{'Desktop'} = 'رومیزی';
    $Self->{Translation}->{'Developer Licence'} = 'اجازه‌نامه توسعه دهنده';
    $Self->{Translation}->{'Docking Station'} = 'ایستگاه اتصال';
    $Self->{Translation}->{'Duplicate'} = 'تکثیر';
    $Self->{Translation}->{'Embedded'} = 'داخلی';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'فیلدهای خالی مشخص می‌کند که مقادیر کنونی باقی خواهند ماند';
    $Self->{Translation}->{'Enterprise Licence'} = 'اجازه‌نامه سازمانی';
    $Self->{Translation}->{'Expiration Date'} = 'تاریخ انقضا';
    $Self->{Translation}->{'Expired'} = 'منقضی شده';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'طبقه';
    $Self->{Translation}->{'Freeware'} = 'نرم افزار مجانی';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'کارت گرافیک';
    $Self->{Translation}->{'Hard Disk'} = 'هارد دیسک';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'هارد دیسک::ظرفیت';
    $Self->{Translation}->{'Hide Versions'} = 'ویرایش‌ها را مخفی کن';
    $Self->{Translation}->{'IP Address'} = 'آدرس IP';
    $Self->{Translation}->{'IP over DHCP'} = 'IP از طریق DHCP';
    $Self->{Translation}->{'IT Facility'} = 'تسهیلات IT';
    $Self->{Translation}->{'Inactive'} = 'غیر فعال';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = 'تاریخ نصب';
    $Self->{Translation}->{'Keybord'} = 'صفحه کلید';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'کیفی';
    $Self->{Translation}->{'Last Change'} = 'آخرین تغییر';
    $Self->{Translation}->{'Licence Key'} = 'کلید اجازه‌نامه';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'کلید اجازه‌نامه::تاریخ انقضا';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'کلید اجازه‌نامه::تعداد';
    $Self->{Translation}->{'Licence Type'} = 'نوع اجازه‌نامه';
    $Self->{Translation}->{'Maintenance'} = 'پشتیبانی و نگهداری';
    $Self->{Translation}->{'Maximum number of one element'} = 'حداکثر شماره یک عنصر';
    $Self->{Translation}->{'Media'} = 'رسانه';
    $Self->{Translation}->{'Middleware'} = 'میان افزار';
    $Self->{Translation}->{'Model'} = 'مدل';
    $Self->{Translation}->{'Modem'} = 'مودم';
    $Self->{Translation}->{'Monitor'} = 'صفحه نمایش';
    $Self->{Translation}->{'Mouse'} = 'ماوس';
    $Self->{Translation}->{'Network Adapter'} = 'کارت شبکه';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'کارت شبکه::آدرس IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'کارت شبکه::IP از طریق DHCP';
    $Self->{Translation}->{'Network Address'} = 'آدرس شبکه';
    $Self->{Translation}->{'Network Address::Gateway'} = 'آدرس شبکه::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'آدرس شبکه::Subnet Mask';
    $Self->{Translation}->{'Open Source'} = 'کد باز';
    $Self->{Translation}->{'Operating System'} = 'سیستم عامل';
    $Self->{Translation}->{'Operational'} = 'عملیاتی';
    $Self->{Translation}->{'Other'} = 'غیره';
    $Self->{Translation}->{'Other Equipment'} = 'تجهیزات متفرقه';
    $Self->{Translation}->{'Outlet'} = 'پریز';
    $Self->{Translation}->{'PCMCIA Card'} = 'کارت PCMCIA';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'به ازای کامپیوتر';
    $Self->{Translation}->{'Per Processor'} = 'به ازای پردازشگر';
    $Self->{Translation}->{'Per Server'} = 'به ازای سرور';
    $Self->{Translation}->{'Per User'} = 'به ازای کاربر';
    $Self->{Translation}->{'Phone 1'} = 'تلفن ۱';
    $Self->{Translation}->{'Phone 2'} = 'تلفن ۲';
    $Self->{Translation}->{'Pilot'} = 'نمونه آزمایشی';
    $Self->{Translation}->{'Planned'} = 'برنامه ریزی شده';
    $Self->{Translation}->{'Printer'} = 'چاپگر';
    $Self->{Translation}->{'Production'} = 'در حال تولید';
    $Self->{Translation}->{'Quantity'} = 'تعداد';
    $Self->{Translation}->{'Rack'} = 'قفسه';
    $Self->{Translation}->{'Ram'} = 'رم';
    $Self->{Translation}->{'Repair'} = 'تعمیر';
    $Self->{Translation}->{'Retired'} = 'بازنشسته شده';
    $Self->{Translation}->{'Review'} = 'بازبینی';
    $Self->{Translation}->{'Room'} = 'اتاق';
    $Self->{Translation}->{'Router'} = 'مسیریاب';
    $Self->{Translation}->{'Scanner'} = 'اسکنر';
    $Self->{Translation}->{'Search Config Items'} = 'جستجوی آیتم‌های پیکربندی';
    $Self->{Translation}->{'Security Device'} = 'وسایل امنیتی';
    $Self->{Translation}->{'Serial Number'} = 'شماره سریال';
    $Self->{Translation}->{'Server'} = 'سرور';
    $Self->{Translation}->{'Server Application'} = 'نرم افزار سرور';
    $Self->{Translation}->{'Server OS'} = 'سیستم عامل سرور';
    $Self->{Translation}->{'Show Versions'} = 'ویرایش‌ها را نمایش بده';
    $Self->{Translation}->{'Single Licence'} = 'اجازه‌نامه تکی';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnet Mask';
    $Self->{Translation}->{'Switch'} = 'سویچ';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'تست/تضمین کیفیت';
    $Self->{Translation}->{'The deployment state of this config item'} = 'وضعیت نصب این CI';
    $Self->{Translation}->{'The incident state of this config item'} = 'وضعیت رخداد این CI';
    $Self->{Translation}->{'Time Restricted'} = 'دارای محدوده زمانی';
    $Self->{Translation}->{'USB Device'} = 'تجهیزات USB';
    $Self->{Translation}->{'Unlimited'} = 'نامحدود';
    $Self->{Translation}->{'User Tool'} = 'ابزار کاربر';
    $Self->{Translation}->{'Volume Licence'} = 'اجازه‌نامه حجمی';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'نقاط دسترسی WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'تاریخ انقضای ضمانت‌نامه';
    $Self->{Translation}->{'Workplace'} = 'محل کار';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'مدیریت CI';
    $Self->{Translation}->{'Change class definition'} = 'تغییر تعریف کلاس';
    $Self->{Translation}->{'Config Item'} = 'آیتم پیکربندی';
    $Self->{Translation}->{'Class'} = 'کلاس';
    $Self->{Translation}->{'Definition'} = 'تعریف';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'فیلتر برای کلاس‌ها';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'کلاسی را برای ساخت یک آیتم پبکربندی جدید انتخا کنید.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'نام این آیتم‌های پیکربندی';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'وضعیت نصب';
    $Self->{Translation}->{'Incident State'} = 'وضعیت رخداد';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'تنظیمات مفاد';
    $Self->{Translation}->{'Config Items per page'} = 'تعداد آیتم‌های پیکربندی در هر صفحه';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'نوع وضعیت نصب';
    $Self->{Translation}->{'Current Incident State'} = 'وضعیت جاری رخداد';
    $Self->{Translation}->{'Current Incident State Type'} = 'نوع وضعیت جاری رخداد';
    $Self->{Translation}->{'Last changed'} = 'آخرین تغییر';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'آیتم پیکربندی';
    $Self->{Translation}->{'ConfigItem-Info'} = 'اطلاعات آیتم پیکربندی';
    $Self->{Translation}->{'Current Deployment State'} = 'وضعیت فعلی نصب';
    $Self->{Translation}->{'Last changed by'} = 'آخرین تغییر به وسیله';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = 'ساختن قالب جدید';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'در ویرایش‌های قبلی هم جستجو انجام شود؟';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'زمان ساختن';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'آیتم پیکربندی';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = 'نمایش یک نسخه';
    $Self->{Translation}->{'Show all versions'} = 'نمایش تمام نسخه‌ها';
    $Self->{Translation}->{'Version Incident State'} = 'وضعیت رخداد نسخه';
    $Self->{Translation}->{'Version Number'} = 'شماره نسخه';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'جزئیات نسخه آیتم پیکربندی';
    $Self->{Translation}->{'Property'} = 'ویژگی';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        'ماژول رویداد آیتم پیکربندی که ثبت وقایع در تاریخچه را در واسط کاربری کارشناس فعال می‌سازد.';
    $Self->{Translation}->{'Configuration Item Limit'} = 'محدودیت آیتم پیکربندی';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'محدودیت آیتم پیکربندی در هر صفحه';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'ساخت و مدیریت تعاریف آیتم‌های پیکربندی';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/fr_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::fr_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adresse';
    $Self->{Translation}->{'Admin Tool'} = 'Outil d\'Administration';
    $Self->{Translation}->{'Backup Device'} = 'Element de sauvegarde';
    $Self->{Translation}->{'Beamer'} = 'Rétroprojecteur';
    $Self->{Translation}->{'Building'} = 'Batiment';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Caméra';
    $Self->{Translation}->{'Capacity'} = 'Capacité';
    $Self->{Translation}->{'Change Definition'} = 'Définition du Changement';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Modification de la définition échouée! Regardez les Log Systèmes pour plus de détails.';
    $Self->{Translation}->{'Client Application'} = 'Application Cliente';
    $Self->{Translation}->{'Client OS'} = 'OS Client';
    $Self->{Translation}->{'Concurrent Users'} = 'Utilisateurs concurrents';
    $Self->{Translation}->{'Config Item-Area'} = 'Zone des Eléments de Configuration';
    $Self->{Translation}->{'Config Items available'} = 'Eléments de configuration disponibles';
    $Self->{Translation}->{'Config Items shown'} = 'Eléments de configuration montrés';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Ordinateur';
    $Self->{Translation}->{'Developer Licence'} = 'License Développeur';
    $Self->{Translation}->{'Docking Station'} = 'Base pour Portable';
    $Self->{Translation}->{'Duplicate'} = 'Dupliquer';
    $Self->{Translation}->{'Embedded'} = 'Embarqué';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'License Entreprise';
    $Self->{Translation}->{'Expiration Date'} = 'Date d\'expiration';
    $Self->{Translation}->{'Expired'} = 'Expiré';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Etage';
    $Self->{Translation}->{'Freeware'} = 'Freeware/Graticiel';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Passerelle';
    $Self->{Translation}->{'Graphic Adapter'} = 'Adaptateur graphique';
    $Self->{Translation}->{'Hard Disk'} = 'Disque dur';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disque dur::Capacité';
    $Self->{Translation}->{'Hide Versions'} = 'Cacher les Versions';
    $Self->{Translation}->{'IP Address'} = 'Adresse IP';
    $Self->{Translation}->{'IP over DHCP'} = 'IP sur DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Département IT';
    $Self->{Translation}->{'Inactive'} = 'Inactif';
    $Self->{Translation}->{'Incident'} = 'Incident';
    $Self->{Translation}->{'Install Date'} = 'Date d\'installation';
    $Self->{Translation}->{'Keybord'} = 'Clavier';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Portable';
    $Self->{Translation}->{'Last Change'} = 'Dernière modification';
    $Self->{Translation}->{'Licence Key'} = 'Clé de la license';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Clé de la license::Date d\'expiration';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Clé de la license::Quantité';
    $Self->{Translation}->{'Licence Type'} = 'Type de license';
    $Self->{Translation}->{'Maintenance'} = 'Maintenance';
    $Self->{Translation}->{'Maximum number of one element'} = 'Quantité maximale pour un élément';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Modèle';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Moniteur';
    $Self->{Translation}->{'Mouse'} = 'Souris';
    $Self->{Translation}->{'Network Adapter'} = 'Adaptateur réseau';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adaptateur réseau:: Adresse IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adaptateur réseau::IP sur DHCP';
    $Self->{Translation}->{'Network Address'} = 'Adresse réseau';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Adresse réseau::Passerelle';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Adresse réseau::Masque du sous réseau';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'Système d\'exploitation';
    $Self->{Translation}->{'Operational'} = 'Opérationnel';
    $Self->{Translation}->{'Other'} = 'Autre';
    $Self->{Translation}->{'Other Equipment'} = 'Autre équipement';
    $Self->{Translation}->{'Outlet'} = 'Prise';
    $Self->{Translation}->{'PCMCIA Card'} = 'Carte PCMCIA';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Par noeud';
    $Self->{Translation}->{'Per Processor'} = 'Par processeur';
    $Self->{Translation}->{'Per Server'} = 'Par Serveur';
    $Self->{Translation}->{'Per User'} = 'Par Utilisateur';
    $Self->{Translation}->{'Phone 1'} = 'Téléphone 1';
    $Self->{Translation}->{'Phone 2'} = 'Téléphone 2';
    $Self->{Translation}->{'Pilot'} = 'Pilote';
    $Self->{Translation}->{'Planned'} = 'Planifié';
    $Self->{Translation}->{'Printer'} = 'Imprimante';
    $Self->{Translation}->{'Production'} = 'Production';
    $Self->{Translation}->{'Quantity'} = 'Quantité';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'En réparation';
    $Self->{Translation}->{'Retired'} = 'Retiré';
    $Self->{Translation}->{'Review'} = 'Revue';
    $Self->{Translation}->{'Room'} = 'Pièce';
    $Self->{Translation}->{'Router'} = 'Routeur';
    $Self->{Translation}->{'Scanner'} = 'Scanner';
    $Self->{Translation}->{'Search Config Items'} = 'Chercher dans les éléments de configuration';
    $Self->{Translation}->{'Security Device'} = 'Périphérique de sécurité';
    $Self->{Translation}->{'Serial Number'} = 'Numéro de série';
    $Self->{Translation}->{'Server'} = 'Serveur';
    $Self->{Translation}->{'Server Application'} = 'Application Serveur';
    $Self->{Translation}->{'Server OS'} = 'OS Server';
    $Self->{Translation}->{'Show Versions'} = 'Montrer les Versions';
    $Self->{Translation}->{'Single Licence'} = 'License unique';
    $Self->{Translation}->{'Subnet Mask'} = 'Masque du sous réseau';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'L\'état de déploiement de cet élément de configuration';
    $Self->{Translation}->{'The incident state of this config item'} = 'L\'état d\'incident de cet élément de configuration';
    $Self->{Translation}->{'Time Restricted'} = 'Limitée dans le temps';
    $Self->{Translation}->{'USB Device'} = 'Périphérique USB';
    $Self->{Translation}->{'Unlimited'} = 'Illimité';
    $Self->{Translation}->{'User Tool'} = 'Outil Utilisateur';
    $Self->{Translation}->{'Volume Licence'} = 'License par volume';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'Point d\'access WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Date d\'expiration de la garantie';
    $Self->{Translation}->{'Workplace'} = 'Emplacement';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gestion des Eléments de Configuration';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Elément de configuration';
    $Self->{Translation}->{'Class'} = 'Classe';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Le nom de cet élément de configuration';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Etat de déploiement';
    $Self->{Translation}->{'Incident State'} = 'Etat de l\'incident';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Etat actuel de l\'incident';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Dernière modification';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Etat actuel de déploiement';
    $Self->{Translation}->{'Last changed by'} = 'Dernière modification effectuée par';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Chercher également dans les versions précédentes??';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/it_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::it_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = 'Strumenti di Amministrazione';
    $Self->{Translation}->{'Backup Device'} = 'Dispositivo di Copia';
    $Self->{Translation}->{'Beamer'} = 'Video Beam';
    $Self->{Translation}->{'Building'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Videocamera';
    $Self->{Translation}->{'Capacity'} = 'Capacità';
    $Self->{Translation}->{'Change Definition'} = 'Modifica Definizione';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Aggiornamento delle definizioni fallita! Guarda nel Log del Sistema per dettagli';
    $Self->{Translation}->{'Client Application'} = 'Applicazione Cliente';
    $Self->{Translation}->{'Client OS'} = 'SO Cliente';
    $Self->{Translation}->{'Concurrent Users'} = 'Utenti concorrenti';
    $Self->{Translation}->{'Config Item-Area'} = 'Area di Configurazione degli Elementi';
    $Self->{Translation}->{'Config Items available'} = 'Elementi di configurazione disponibili';
    $Self->{Translation}->{'Config Items shown'} = 'Elementi di configurazione mostrati';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Dimostrativo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Licenza di Sviluppo';
    $Self->{Translation}->{'Docking Station'} = 'Docking Station';
    $Self->{Translation}->{'Duplicate'} = 'Duplicato';
    $Self->{Translation}->{'Embedded'} = 'Embedded';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Licenza Aziendale';
    $Self->{Translation}->{'Expiration Date'} = 'Data di scadenza';
    $Self->{Translation}->{'Expired'} = 'Scaduto';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Scheda Grafica';
    $Self->{Translation}->{'Hard Disk'} = 'Disco Rigido';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disco Rigido::Capacità';
    $Self->{Translation}->{'Hide Versions'} = 'Nascondi Versioni';
    $Self->{Translation}->{'IP Address'} = 'Indirizzo IP';
    $Self->{Translation}->{'IP over DHCP'} = 'IP su DHCP';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = 'Inattivo';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = 'Data di installazione';
    $Self->{Translation}->{'Keybord'} = 'Tastiera';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Portatile';
    $Self->{Translation}->{'Last Change'} = 'Ultima modifica';
    $Self->{Translation}->{'Licence Key'} = 'Chiave della Licenza';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Chiave della Licenza::Data di scadenza';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Chiave della Licenza::Quantità';
    $Self->{Translation}->{'Licence Type'} = 'Tipo di Licenza';
    $Self->{Translation}->{'Maintenance'} = 'Manutenzione';
    $Self->{Translation}->{'Maximum number of one element'} = 'Numero massimo di un elemento';
    $Self->{Translation}->{'Media'} = 'Supporto';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Modello';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Mouse';
    $Self->{Translation}->{'Network Adapter'} = 'Adattatore di Rete';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adattatore di Rete::Indirizzo IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adattatore di Rete::IP su DHCP';
    $Self->{Translation}->{'Network Address'} = 'Indirizzo di Rete';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Indirizzo di Rete::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Indirizzo di Rete::Subnet Mask';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'Sistema Operativo';
    $Self->{Translation}->{'Operational'} = 'Operativo';
    $Self->{Translation}->{'Other'} = 'Altro';
    $Self->{Translation}->{'Other Equipment'} = 'Altre Apparecchiature';
    $Self->{Translation}->{'Outlet'} = '';
    $Self->{Translation}->{'PCMCIA Card'} = 'Scheda PCMCIA';
    $Self->{Translation}->{'PDA'} = 'Palmare';
    $Self->{Translation}->{'Per Node'} = 'Per Nodo';
    $Self->{Translation}->{'Per Processor'} = 'Per Processore';
    $Self->{Translation}->{'Per Server'} = 'Per Server';
    $Self->{Translation}->{'Per User'} = 'Per Utente';
    $Self->{Translation}->{'Phone 1'} = '';
    $Self->{Translation}->{'Phone 2'} = '';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Pianificato';
    $Self->{Translation}->{'Printer'} = 'Stampante';
    $Self->{Translation}->{'Production'} = 'Produzione';
    $Self->{Translation}->{'Quantity'} = 'Quantità';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = 'Ram';
    $Self->{Translation}->{'Repair'} = 'Riparazione';
    $Self->{Translation}->{'Retired'} = 'Ritirato';
    $Self->{Translation}->{'Review'} = 'Revisionato';
    $Self->{Translation}->{'Room'} = '';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Scanner';
    $Self->{Translation}->{'Search Config Items'} = 'Ricerca elementi di configurazione';
    $Self->{Translation}->{'Security Device'} = 'Dispositivo di sicurezza';
    $Self->{Translation}->{'Serial Number'} = 'Numero Seriale';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Aplicazione Server';
    $Self->{Translation}->{'Server OS'} = 'SO Server';
    $Self->{Translation}->{'Show Versions'} = 'Mostra Versioni';
    $Self->{Translation}->{'Single Licence'} = 'Single Licence';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnet Mask';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Lo stato di implementazione di questo elemento di configurazione';
    $Self->{Translation}->{'The incident state of this config item'} = 'Lo stato di incidente di questo elemento di configurazione';
    $Self->{Translation}->{'Time Restricted'} = 'Limitata nel tempo';
    $Self->{Translation}->{'USB Device'} = 'Dispositivo USB';
    $Self->{Translation}->{'Unlimited'} = 'Illimitata';
    $Self->{Translation}->{'User Tool'} = 'Strumenti Utente';
    $Self->{Translation}->{'Volume Licence'} = 'Licenza per Volume';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN Access Point';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Data di scadenza della garanzia';
    $Self->{Translation}->{'Workplace'} = '';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gestione degli Elementi di Configurazione';
    $Self->{Translation}->{'Change class definition'} = '';
    $Self->{Translation}->{'Config Item'} = 'Elemento di Configurazione';
    $Self->{Translation}->{'Class'} = 'Classe';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Il nome di questo elemento di configurazione';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Stato di implementazione';
    $Self->{Translation}->{'Incident State'} = 'Stato dell\'Incidente';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = '';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Stato attuale dell\'Incidente';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Ultima modifica';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Stato attuale di implementazione';
    $Self->{Translation}->{'Last changed by'} = 'Ultima modifica di';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Cercare anche in versioni precedenti?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '';
    $Self->{Translation}->{'Show all versions'} = '';
    $Self->{Translation}->{'Version Incident State'} = '';
    $Self->{Translation}->{'Version Number'} = '';
    $Self->{Translation}->{'Configuration Item Version Details'} = '';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/ja_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ja_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = '管理ツール';
    $Self->{Translation}->{'Backup Device'} = 'バックアップ・デバイス';
    $Self->{Translation}->{'Beamer'} = 'プロジェクター';
    $Self->{Translation}->{'Building'} = '構築';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = '';
    $Self->{Translation}->{'Camera'} = 'カメラ';
    $Self->{Translation}->{'Capacity'} = '';
    $Self->{Translation}->{'Change Definition'} = '定義の変更';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = '定義の変更に失敗しました。詳細はシステムログを参照してください。';
    $Self->{Translation}->{'Client Application'} = 'クライアントソフト';
    $Self->{Translation}->{'Client OS'} = 'クライアントOS';
    $Self->{Translation}->{'Concurrent Users'} = '同時実行ユーザ';
    $Self->{Translation}->{'Config Item-Area'} = 'アイテムエリアの設定';
    $Self->{Translation}->{'Config Items available'} = '設定項目の利用可 / 不可';
    $Self->{Translation}->{'Config Items shown'} = '設定項目表示';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'デモ';
    $Self->{Translation}->{'Desktop'} = 'デスクトップ';
    $Self->{Translation}->{'Developer Licence'} = '開発者ライセンス';
    $Self->{Translation}->{'Docking Station'} = 'ドッキングステーション';
    $Self->{Translation}->{'Duplicate'} = 'コピー';
    $Self->{Translation}->{'Embedded'} = '埋め込みオブジェクト';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'エンタープライズ・ライセンス';
    $Self->{Translation}->{'Expiration Date'} = '有効期限';
    $Self->{Translation}->{'Expired'} = '期限切れ';
    $Self->{Translation}->{'FQDN'} = '';
    $Self->{Translation}->{'Floor'} = '切捨て';
    $Self->{Translation}->{'Freeware'} = 'フリーウェア';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '';
    $Self->{Translation}->{'Graphic Adapter'} = 'グラフィックアダプタ';
    $Self->{Translation}->{'Hard Disk'} = '';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'ハードディスク容量';
    $Self->{Translation}->{'Hide Versions'} = 'バージョンを非表示';
    $Self->{Translation}->{'IP Address'} = '';
    $Self->{Translation}->{'IP over DHCP'} = 'DHCP有効';
    $Self->{Translation}->{'IT Facility'} = 'ITファシリティ';
    $Self->{Translation}->{'Inactive'} = '無効の';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = '';
    $Self->{Translation}->{'Keybord'} = 'キーボード';
    $Self->{Translation}->{'LAN'} = '';
    $Self->{Translation}->{'Laptop'} = 'ノートPC';
    $Self->{Translation}->{'Last Change'} = '最新の変更';
    $Self->{Translation}->{'Licence Key'} = '';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'ライセンスキーの有効期限';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'ライセンスキーの数';
    $Self->{Translation}->{'Licence Type'} = '';
    $Self->{Translation}->{'Maintenance'} = 'メンテナンス';
    $Self->{Translation}->{'Maximum number of one element'} = '';
    $Self->{Translation}->{'Media'} = '';
    $Self->{Translation}->{'Middleware'} = 'ミドルウェア';
    $Self->{Translation}->{'Model'} = '';
    $Self->{Translation}->{'Modem'} = 'モデム';
    $Self->{Translation}->{'Monitor'} = 'モニタ';
    $Self->{Translation}->{'Mouse'} = 'マウス';
    $Self->{Translation}->{'Network Adapter'} = '';
    $Self->{Translation}->{'Network Adapter::IP Address'} = '';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'ネットワーク・DHCP有効';
    $Self->{Translation}->{'Network Address'} = '';
    $Self->{Translation}->{'Network Address::Gateway'} = 'デフォルトゲートウェイ';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'サブネットマスク';
    $Self->{Translation}->{'Open Source'} = 'オープンソース';
    $Self->{Translation}->{'Operating System'} = '';
    $Self->{Translation}->{'Operational'} = '運用';
    $Self->{Translation}->{'Other'} = '他';
    $Self->{Translation}->{'Other Equipment'} = 'その他の機器';
    $Self->{Translation}->{'Outlet'} = 'アウトレット';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA カード';
    $Self->{Translation}->{'PDA'} = '';
    $Self->{Translation}->{'Per Node'} = 'ノード毎';
    $Self->{Translation}->{'Per Processor'} = 'プロセッサ毎';
    $Self->{Translation}->{'Per Server'} = 'サーバ毎';
    $Self->{Translation}->{'Per User'} = 'ユーザ毎';
    $Self->{Translation}->{'Phone 1'} = '電話 1';
    $Self->{Translation}->{'Phone 2'} = '電話 2';
    $Self->{Translation}->{'Pilot'} = 'パイロット';
    $Self->{Translation}->{'Planned'} = '計画';
    $Self->{Translation}->{'Printer'} = 'プリンタ';
    $Self->{Translation}->{'Production'} = '生産';
    $Self->{Translation}->{'Quantity'} = '数量';
    $Self->{Translation}->{'Rack'} = 'ラック';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = '修理';
    $Self->{Translation}->{'Retired'} = '引退';
    $Self->{Translation}->{'Review'} = 'レビュー';
    $Self->{Translation}->{'Room'} = '室内';
    $Self->{Translation}->{'Router'} = 'ルータ';
    $Self->{Translation}->{'Scanner'} = 'スキャナ';
    $Self->{Translation}->{'Search Config Items'} = '設定項目の検索';
    $Self->{Translation}->{'Security Device'} = 'セキュリティデバイス';
    $Self->{Translation}->{'Serial Number'} = '';
    $Self->{Translation}->{'Server'} = 'サーバ';
    $Self->{Translation}->{'Server Application'} = 'サーバソフト';
    $Self->{Translation}->{'Server OS'} = 'サーバOS';
    $Self->{Translation}->{'Show Versions'} = 'バージョンの表示';
    $Self->{Translation}->{'Single Licence'} = 'シングルライセンス';
    $Self->{Translation}->{'Subnet Mask'} = '';
    $Self->{Translation}->{'Switch'} = 'スイッチ';
    $Self->{Translation}->{'Telco'} = '電話会社';
    $Self->{Translation}->{'Test/QA'} = 'テスト / QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'この設定項目の展開状態';
    $Self->{Translation}->{'The incident state of this config item'} = 'この設定項目のインシデント状態';
    $Self->{Translation}->{'Time Restricted'} = '時間制限';
    $Self->{Translation}->{'USB Device'} = 'USBデバイス';
    $Self->{Translation}->{'Unlimited'} = '無制限';
    $Self->{Translation}->{'User Tool'} = 'ユーザ・ツール';
    $Self->{Translation}->{'Volume Licence'} = 'ボリュームライセンス';
    $Self->{Translation}->{'WLAN'} = '';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN アクセスポイント';
    $Self->{Translation}->{'Warranty Expiration Date'} = '';
    $Self->{Translation}->{'Workplace'} = '職場';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = '構成アイテム管理';
    $Self->{Translation}->{'Change class definition'} = 'クラス定義を変更';
    $Self->{Translation}->{'Config Item'} = '';
    $Self->{Translation}->{'Class'} = '';
    $Self->{Translation}->{'Definition'} = '記述';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = '';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = '';
    $Self->{Translation}->{'Incident State'} = '';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'コンテキストの設定';
    $Self->{Translation}->{'Config Items per page'} = '1ページ毎の設定項目';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '展開の状態';
    $Self->{Translation}->{'Current Incident State'} = '現在のインシデント状態';
    $Self->{Translation}->{'Current Incident State Type'} = '現在のインシデント状態のタイプ';
    $Self->{Translation}->{'Last changed'} = '最終変更日時';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '設定項目';
    $Self->{Translation}->{'ConfigItem-Info'} = '設定項目情報';
    $Self->{Translation}->{'Current Deployment State'} = '現在の展開状態';
    $Self->{Translation}->{'Last changed by'} = '最終変更者';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'プレビュー時、以前のバージョンも検索対象としますか？';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '作成日時';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '詳細設定';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = '説明を表示';
    $Self->{Translation}->{'Show all versions'} = 'すべての説明を表示';
    $Self->{Translation}->{'Version Incident State'} = 'インシデント状態';
    $Self->{Translation}->{'Version Number'} = 'バージョンナンバー';
    $Self->{Translation}->{'Configuration Item Version Details'} = '構成の詳細';
    $Self->{Translation}->{'Property'} = '項目';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/ms_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ms_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Alamat';
    $Self->{Translation}->{'Admin Tool'} = 'Admin Tool';
    $Self->{Translation}->{'Backup Device'} = 'Peralatan Backup';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Bangunan';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'ConfigItem Baru (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'ConfigItem (ID=%s) dipadam';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Definisi ConfigItems dikemaskini (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Gunakan status berubah (baru=%s; lama=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Status Insiden berubah (baru=%s; lama=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Pautan ditambah pada %s (jenis=%s)';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Pautan dipadam pada %s (jenis=%s)';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'nama ditukar (baru=%s; lama=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Atribut% s "%s" kepada "%s" berubah';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Versi baru menjana (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versi %s dipadam';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Muatan';
    $Self->{Translation}->{'Change Definition'} = 'Ubah definisi';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Perubahan definisi gagal! Lihat Log Sistem untuk maklumat lanjut.';
    $Self->{Translation}->{'Client Application'} = 'Aplikasi pelanggan';
    $Self->{Translation}->{'Client OS'} = 'OS Pelanggan';
    $Self->{Translation}->{'Concurrent Users'} = 'Pengguna Sedia ada';
    $Self->{Translation}->{'Config Item-Area'} = 'Config Perkara-Kawasan';
    $Self->{Translation}->{'Config Items available'} = 'Item config disediakan';
    $Self->{Translation}->{'Config Items shown'} = 'Item config ditunjukkan';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Lesen Pemaju';
    $Self->{Translation}->{'Docking Station'} = 'Dok Stesen';
    $Self->{Translation}->{'Duplicate'} = 'Gandakan';
    $Self->{Translation}->{'Embedded'} = 'terbenam';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Medan kosong menunjukkan bahawa nilai semasa disimpan';
    $Self->{Translation}->{'Enterprise Licence'} = 'Lesen Enterprise';
    $Self->{Translation}->{'Expiration Date'} = 'Tarikh Tamat Tempoh';
    $Self->{Translation}->{'Expired'} = 'Tamat Tempoh';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'tingkat';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gerbang';
    $Self->{Translation}->{'Graphic Adapter'} = 'Penyesuai grafik';
    $Self->{Translation}->{'Hard Disk'} = 'Cakera Keras';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Cakera Keras :: Kapasiti';
    $Self->{Translation}->{'Hide Versions'} = 'Sembunyi Versi';
    $Self->{Translation}->{'IP Address'} = 'IP Addresse';
    $Self->{Translation}->{'IP over DHCP'} = 'IP lebih DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT Kemudahan';
    $Self->{Translation}->{'Inactive'} = 'Tidak Aktif';
    $Self->{Translation}->{'Incident'} = 'insiden';
    $Self->{Translation}->{'Install Date'} = 'Pasang Tarikh';
    $Self->{Translation}->{'Keybord'} = 'Juruteknik';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Perubahan akhir';
    $Self->{Translation}->{'Licence Key'} = 'Kunci Lesen';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Kunci Lesen :: Tarikh Tamat Tempoh';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Kunci Lesen:: Kuantiti';
    $Self->{Translation}->{'Licence Type'} = 'Jenis Lesen';
    $Self->{Translation}->{'Maintenance'} = 'penyelenggaraan';
    $Self->{Translation}->{'Maximum number of one element'} = 'Bilangan maksimum satu elemen';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'tetikus';
    $Self->{Translation}->{'Network Adapter'} = 'Network Adapter';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Network Adapter :: IP Address';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Network Adapter :: IP lebih DHCP';
    $Self->{Translation}->{'Network Address'} = 'Alamat Rangkaian';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Rangkaian Alamat :: Gerbang';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Rangkaian Alamat :: Subnet Mask';
    $Self->{Translation}->{'Open Source'} = 'Sumber Terbuka';
    $Self->{Translation}->{'Operating System'} = 'Sistem Operasi';
    $Self->{Translation}->{'Operational'} = 'operasi';
    $Self->{Translation}->{'Other'} = 'lain-lain';
    $Self->{Translation}->{'Other Equipment'} = 'Peralatan lain-lain';
    $Self->{Translation}->{'Outlet'} = 'Outlet';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA Kad';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'per Nod';
    $Self->{Translation}->{'Per Processor'} = 'untuk Pemproses';
    $Self->{Translation}->{'Per Server'} = 'Setiap pelayan';
    $Self->{Translation}->{'Per User'} = 'setiap Pengguna';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Dirancang';
    $Self->{Translation}->{'Printer'} = 'pencetak';
    $Self->{Translation}->{'Production'} = 'pengeluaran';
    $Self->{Translation}->{'Quantity'} = 'Kuantiti';
    $Self->{Translation}->{'Rack'} = 'Rak';
    $Self->{Translation}->{'Ram'} = 'memori utama';
    $Self->{Translation}->{'Repair'} = 'Membaiki';
    $Self->{Translation}->{'Retired'} = 'bersara';
    $Self->{Translation}->{'Review'} = 'mengkaji';
    $Self->{Translation}->{'Room'} = 'Bilik';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Pengimbas';
    $Self->{Translation}->{'Search Config Items'} = 'Carian Config Item';
    $Self->{Translation}->{'Security Device'} = 'Peranti Keselamatan';
    $Self->{Translation}->{'Serial Number'} = 'Nombor Series';
    $Self->{Translation}->{'Server'} = 'Pelayan';
    $Self->{Translation}->{'Server Application'} = 'Permohonan Pelayan';
    $Self->{Translation}->{'Server OS'} = 'Server OS';
    $Self->{Translation}->{'Show Versions'} = 'Papar versi';
    $Self->{Translation}->{'Single Licence'} = 'Lesen Sahaja';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnet Mask';
    $Self->{Translation}->{'Switch'} = 'Tukar';
    $Self->{Translation}->{'Telco'} = 'Telko';
    $Self->{Translation}->{'Test/QA'} = 'Ujian/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Keadaan penempatan item ini config';
    $Self->{Translation}->{'The incident state of this config item'} = 'Keadaan insiden bagi config item ini';
    $Self->{Translation}->{'Time Restricted'} = 'masa Terhad';
    $Self->{Translation}->{'USB Device'} = 'Peranti USB';
    $Self->{Translation}->{'Unlimited'} = 'Tiada batasan';
    $Self->{Translation}->{'User Tool'} = 'Alat pengguna';
    $Self->{Translation}->{'Volume Licence'} = 'Lesen Jilid';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'pusat akses WLAN';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Tarikh Waranti Peluputan';
    $Self->{Translation}->{'Workplace'} = 'Tempat kerja';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Pengurusan Config Item';
    $Self->{Translation}->{'Change class definition'} = 'Ubah definisi kelas';
    $Self->{Translation}->{'Config Item'} = 'Config Item';
    $Self->{Translation}->{'Class'} = 'Kelas';
    $Self->{Translation}->{'Definition'} = 'Definisi';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Menapis Kelas';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Pilih Kelas dari senarai untuk mewujudkan Perkara Config baru.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Nama config item ini';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Keadaan Pertukaran';
    $Self->{Translation}->{'Incident State'} = 'insiden keadaan';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'konteks Tetapan';
    $Self->{Translation}->{'Config Items per page'} = 'Item config per halaman';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Jenis Pertukaran Keadaan';
    $Self->{Translation}->{'Current Incident State'} = 'Insiden keadaan semasa';
    $Self->{Translation}->{'Current Incident State Type'} = 'Nyatakan Jenis Insiden Semasa';
    $Self->{Translation}->{'Last changed'} = 'Terkini berubah';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'ConfigItem';
    $Self->{Translation}->{'ConfigItem-Info'} = 'ConfigItem-Info';
    $Self->{Translation}->{'Current Deployment State'} = 'Pertukaran keadaan semasa';
    $Self->{Translation}->{'Last changed by'} = 'Terakhir diubah oleh';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Juga mencari dalam versi sebelumnya?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Cipta Masa';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Perkara konfigurasi';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = 'Tunjukkan satu versi';
    $Self->{Translation}->{'Show all versions'} = 'Tunjukkan semua versi';
    $Self->{Translation}->{'Version Incident State'} = 'Versi Insiden Negeri';
    $Self->{Translation}->{'Version Number'} = 'Bilangan versi';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Konfigurasi Versi Item Keperinchian';
    $Self->{Translation}->{'Property'} = 'harta';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        'Definiert das Standard-Subobject der Klasse';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        'Objekt-Backend Modul Registration des Import/Export Moduls.';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #
    $Self->{Translation}->{'Changed On'} = 'berubah Pada';
    $Self->{Translation}->{'Created By'} = 'Dibuat Oleh';
    $Self->{Translation}->{'Last Changed'} = 'Terkini berubah';

}

1;

# --
# Kernel/Language/nb_NO_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::nb_NO_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '';
    $Self->{Translation}->{'Admin Tool'} = '';
    $Self->{Translation}->{'Backup Device'} = 'Backup-enhet';
    $Self->{Translation}->{'Beamer'} = '';
    $Self->{Translation}->{'Building'} = 'Bygning';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Ny Konfigurasjonsenhet (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'Konfigurasjonsenhet (ID=%s) slettet';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Konfigurasjonsenhetens definisjon ble oppdatert (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Produksjonssettingstilstand endret (ny=%s; gml=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Hendelsestilstand oppdatert (ny=%s; gml=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Kobling til %s (type=%s) lagt til';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Kobling til %s (type=%s) lagt til';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Navn oppdatert (nytt=%s; gml=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Attributt %s oppdatert fra "%s" til "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Ny versjon (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versjon %s slettet';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'Prosessor';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Kapasitet';
    $Self->{Translation}->{'Change Definition'} = 'Endre definisjon';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Endring feilet! Se systemloggen for detaljer.';
    $Self->{Translation}->{'Client Application'} = 'Klient-applikasjon';
    $Self->{Translation}->{'Client OS'} = 'Klient-OS';
    $Self->{Translation}->{'Concurrent Users'} = 'Samtidige brukere';
    $Self->{Translation}->{'Config Item-Area'} = 'Konfigurasjonsenhet-område';
    $Self->{Translation}->{'Config Items available'} = 'Tilgjengelige konfigurasjonsenheter';
    $Self->{Translation}->{'Config Items shown'} = 'Viste konfigurasjonsenheter';
    $Self->{Translation}->{'CMDB'} = 'CMDB';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Stasjonær';
    $Self->{Translation}->{'Developer Licence'} = 'Utviklerlisens';
    $Self->{Translation}->{'Docking Station'} = 'Dokkingstasjon';
    $Self->{Translation}->{'Duplicate'} = 'Duplisér';
    $Self->{Translation}->{'Embedded'} = 'Innebygd';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Tomme felter indikerer at de nåværende verdiene beholdes';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterprise-lisens';
    $Self->{Translation}->{'Expiration Date'} = 'Utgår dato';
    $Self->{Translation}->{'Expired'} = 'Utgått';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Etasje';
    $Self->{Translation}->{'Freeware'} = 'Gratis programvare';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Ruter';
    $Self->{Translation}->{'Graphic Adapter'} = 'Grafikkort';
    $Self->{Translation}->{'Hard Disk'} = 'Harddisk';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Harddisk::Kapasitet';
    $Self->{Translation}->{'Hide Versions'} = 'Skjul versjoner';
    $Self->{Translation}->{'IP Address'} = 'IP-adresse';
    $Self->{Translation}->{'IP over DHCP'} = 'IP fra DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT-fasilitet';
    $Self->{Translation}->{'Inactive'} = 'Inaktiv';
    $Self->{Translation}->{'Incident'} = '';
    $Self->{Translation}->{'Install Date'} = 'Installasjonsdato';
    $Self->{Translation}->{'Keybord'} = 'Tastatur';
    $Self->{Translation}->{'LAN'} = 'Lokalnett';
    $Self->{Translation}->{'Laptop'} = 'Bærbar';
    $Self->{Translation}->{'Last Change'} = 'Sist endret';
    $Self->{Translation}->{'Licence Key'} = 'Lisensnøkkel';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Lisensnøkkel::Utgår dato';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Lisensnøkkel::Antall';
    $Self->{Translation}->{'Licence Type'} = 'Lisenstype';
    $Self->{Translation}->{'Maintenance'} = 'Vedlikehold';
    $Self->{Translation}->{'Maximum number of one element'} = 'Maks. antall av ett element';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = 'Mellomvare';
    $Self->{Translation}->{'Model'} = 'Modell';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Skjerm';
    $Self->{Translation}->{'Mouse'} = 'Mus';
    $Self->{Translation}->{'Network Adapter'} = 'Nettverkskort';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Nettverkskort::IP-adresse';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Nettverkskort::IP fra DHCP';
    $Self->{Translation}->{'Network Address'} = 'Nettverksadresse';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Nettverksadresse::Ruter';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Nettverksadresse::Subnettmaske';
    $Self->{Translation}->{'Open Source'} = 'Åpen kildekode';
    $Self->{Translation}->{'Operating System'} = 'Operativsystem';
    $Self->{Translation}->{'Operational'} = 'Operativ';
    $Self->{Translation}->{'Other'} = 'Annet';
    $Self->{Translation}->{'Other Equipment'} = 'Annet utstyr';
    $Self->{Translation}->{'Outlet'} = 'Kontakt';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA-kort';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Per Node';
    $Self->{Translation}->{'Per Processor'} = 'Per Prosessor';
    $Self->{Translation}->{'Per Server'} = 'Per Tjener';
    $Self->{Translation}->{'Per User'} = 'Per Bruker';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Planlagt';
    $Self->{Translation}->{'Printer'} = 'Skriver';
    $Self->{Translation}->{'Production'} = 'Produksjon';
    $Self->{Translation}->{'Quantity'} = 'Antall';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'Internminne';
    $Self->{Translation}->{'Repair'} = 'Reparasjon';
    $Self->{Translation}->{'Retired'} = 'Pensjonert';
    $Self->{Translation}->{'Review'} = 'Evaluering';
    $Self->{Translation}->{'Room'} = 'Rom';
    $Self->{Translation}->{'Router'} = 'Ruter';
    $Self->{Translation}->{'Scanner'} = 'Skanner';
    $Self->{Translation}->{'Search Config Items'} = 'Søk konfigurasjonsenheter';
    $Self->{Translation}->{'Security Device'} = 'Sikkerhetsenhet';
    $Self->{Translation}->{'Serial Number'} = 'Serienummer';
    $Self->{Translation}->{'Server'} = 'Tjener';
    $Self->{Translation}->{'Server Application'} = 'Tjener-applikasjon';
    $Self->{Translation}->{'Server OS'} = 'Tjener-OS';
    $Self->{Translation}->{'Show Versions'} = 'Vis versjoner';
    $Self->{Translation}->{'Single Licence'} = 'Enkeltlisens';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnettmaske';
    $Self->{Translation}->{'Switch'} = 'Svitsj';
    $Self->{Translation}->{'Telco'} = 'Teleutstyr';
    $Self->{Translation}->{'Test/QA'} = 'Test/Kvalitetskontroll';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Produksjonssettingstilstand for denne konfigurasjonsenheten';
    $Self->{Translation}->{'The incident state of this config item'} = 'Hendelsestilstanden for denne konfigurasjonsenheten';
    $Self->{Translation}->{'Time Restricted'} = 'Tidsbegrenset';
    $Self->{Translation}->{'USB Device'} = 'USB-enhet';
    $Self->{Translation}->{'Unlimited'} = 'Ubegrenset';
    $Self->{Translation}->{'User Tool'} = 'Brukerverktøy';
    $Self->{Translation}->{'Volume Licence'} = 'Volumlisens';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN-basestasjon';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Utløpsdato for garanti';
    $Self->{Translation}->{'Workplace'} = 'Arbeidssted';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Administrasjon av konfigurasjonsenheter';
    $Self->{Translation}->{'Change class definition'} = 'Endre klassedefinisjon';
    $Self->{Translation}->{'Config Item'} = 'Konfigurasjonsenhet';
    $Self->{Translation}->{'Class'} = 'Klasse';
    $Self->{Translation}->{'Definition'} = 'Definisjon';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filter for klasser';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Velg en klasse fra listen for å opprette en ny konfigurasjonsenhet';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Navnet til denne konfigurasjonsenheten';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Produksjonssettingstilstand';
    $Self->{Translation}->{'Incident State'} = 'Hendelsestilstand';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Kontekstvalg';
    $Self->{Translation}->{'Config Items per page'} = 'Konfigurasjonsenheter per side';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Type Produksjonssettingstilstand';
    $Self->{Translation}->{'Current Incident State'} = 'Nåværende Hendelsestilstand';
    $Self->{Translation}->{'Current Incident State Type'} = 'Nåværende type Hendelsestilstand';
    $Self->{Translation}->{'Last changed'} = 'Sist endret';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'Konfigurasjonsenhet';
    $Self->{Translation}->{'ConfigItem-Info'} = 'Konfigurasjonsenhet-info';
    $Self->{Translation}->{'Current Deployment State'} = 'Nåværende Produksjonssettingstilstand';
    $Self->{Translation}->{'Last changed by'} = 'Sist endret av';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Også søke i tidligere versjoner?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Opprettelsestidspunkt';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Konfigurasjonsenhet';
    $Self->{Translation}->{'Configuration Item Information'} = '';
    $Self->{Translation}->{'Show one version'} = 'Vis én versjon';
    $Self->{Translation}->{'Show all versions'} = 'Vis alle versjoner';
    $Self->{Translation}->{'Version Incident State'} = 'Hendelsestilstand for versjonen';
    $Self->{Translation}->{'Version Number'} = 'Versjon';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Versjonsdetaljer for enheten';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/nl_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::nl_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adres';
    $Self->{Translation}->{'Admin Tool'} = 'Admin Tool';
    $Self->{Translation}->{'Backup Device'} = 'Backupapparaat';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Gebouw';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Nieuw configuratie-item (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'Configuratie-item (ID=%s) verwijderd';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'ConfigItems\' definitie bijgewerkt (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Status bijgewerkt (nieuw=%s; oud=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Incident-status bijgewerkt (nieuw=%s; oud=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Koppeling naar %s (type=%s) toegevoegd';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Koppeling naar %s (type=%s) verwijderd';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Naam bijgewerkt (nieuw=%s; oud=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Attribuut %s bijgewerkt van "%s" naar "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Nieuwe versie (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versie %s verwijderd';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Camera';
    $Self->{Translation}->{'Capacity'} = 'Capaciteit';
    $Self->{Translation}->{'Change Definition'} = 'Definitie veranderen';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Definitiewijziging mislukt! Zie de System Log voor details.';
    $Self->{Translation}->{'Client Application'} = 'Clienttoepassing';
    $Self->{Translation}->{'Client OS'} = 'Client besturingssysteem';
    $Self->{Translation}->{'Concurrent Users'} = 'Gelijktijdige gebruikers';
    $Self->{Translation}->{'Config Item-Area'} = 'Configuratie-item-gebied';
    $Self->{Translation}->{'Config Items available'} = 'Beschikbare configuratie-items';
    $Self->{Translation}->{'Config Items shown'} = 'Getoonde configuratie-items';
    $Self->{Translation}->{'CMDB'} = 'CMDB';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Ontwikkelaarslicentie';
    $Self->{Translation}->{'Docking Station'} = 'Docking station';
    $Self->{Translation}->{'Duplicate'} = 'Dupliceren';
    $Self->{Translation}->{'Embedded'} = 'Embedded';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterpriselicentie';
    $Self->{Translation}->{'Expiration Date'} = 'Expiratiedatum';
    $Self->{Translation}->{'Expired'} = 'Verlopen';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Etage';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Videokaart';
    $Self->{Translation}->{'Hard Disk'} = 'Harde schijf';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Harde schijf::Capaciteit';
    $Self->{Translation}->{'Hide Versions'} = 'Verberg versies';
    $Self->{Translation}->{'IP Address'} = 'IP adres';
    $Self->{Translation}->{'IP over DHCP'} = 'IP via DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Serverruimte';
    $Self->{Translation}->{'Inactive'} = 'Inactief';
    $Self->{Translation}->{'Incident'} = 'Incident';
    $Self->{Translation}->{'Install Date'} = 'Installatiedatum';
    $Self->{Translation}->{'Keybord'} = 'Toetsenbord';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Laatste wijziging';
    $Self->{Translation}->{'Licence Key'} = 'Licentiesleutel';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Licentiesleutel::Expiratiedatum';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Licentiesleutel::Hoeveelheid';
    $Self->{Translation}->{'Licence Type'} = 'Licentietype';
    $Self->{Translation}->{'Maintenance'} = 'In onderhoud';
    $Self->{Translation}->{'Maximum number of one element'} = 'Maximale hoeveelheid';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Muis';
    $Self->{Translation}->{'Network Adapter'} = 'Netwerk adapter';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Netwerk adapter::IP adres';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Netwerk adapter::IP via DHCP';
    $Self->{Translation}->{'Network Address'} = 'Netwerkadres';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Netwerkadres::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Netwerkadres::Subnet Mask';
    $Self->{Translation}->{'Open Source'} = 'Open Source';
    $Self->{Translation}->{'Operating System'} = 'Besturingssysteem';
    $Self->{Translation}->{'Operational'} = 'Operationeel';
    $Self->{Translation}->{'Other'} = 'Overige';
    $Self->{Translation}->{'Other Equipment'} = 'Overige uitrusting';
    $Self->{Translation}->{'Outlet'} = 'Aansluiting';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA kaart';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Per node';
    $Self->{Translation}->{'Per Processor'} = 'Per CPU';
    $Self->{Translation}->{'Per Server'} = 'Per server';
    $Self->{Translation}->{'Per User'} = 'Per gebruiker';
    $Self->{Translation}->{'Phone 1'} = 'Telefoon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefoon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Geplanned';
    $Self->{Translation}->{'Printer'} = 'Printer';
    $Self->{Translation}->{'Production'} = 'Produktie';
    $Self->{Translation}->{'Quantity'} = 'Hoeveelheid';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'In reparatie';
    $Self->{Translation}->{'Retired'} = 'Uitgefaseerd';
    $Self->{Translation}->{'Review'} = 'Review';
    $Self->{Translation}->{'Room'} = 'Kamer';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Scanner';
    $Self->{Translation}->{'Search Config Items'} = 'Zoek Configuratie-items';
    $Self->{Translation}->{'Security Device'} = 'Security device';
    $Self->{Translation}->{'Serial Number'} = 'Serienummer';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Servertoepassing';
    $Self->{Translation}->{'Server OS'} = 'Server besturingssysteem';
    $Self->{Translation}->{'Show Versions'} = 'Toon versies';
    $Self->{Translation}->{'Single Licence'} = 'Single Licence';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnet Mask';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'De status van dit configuratie-item';
    $Self->{Translation}->{'The incident state of this config item'} = 'De incidentstatus van dit configuratie-item';
    $Self->{Translation}->{'Time Restricted'} = 'Time restricted';
    $Self->{Translation}->{'USB Device'} = 'USB apparaat';
    $Self->{Translation}->{'Unlimited'} = 'Ongelimiteerd';
    $Self->{Translation}->{'User Tool'} = 'User Tool';
    $Self->{Translation}->{'Volume Licence'} = 'Volume Licentie';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN Access Point';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Einddatum garantie';
    $Self->{Translation}->{'Workplace'} = 'Werkplek';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Configuratie-item beheer';
    $Self->{Translation}->{'Change class definition'} = 'Wijzig definitie';
    $Self->{Translation}->{'Config Item'} = 'Configuratie-item';
    $Self->{Translation}->{'Class'} = 'Klasse';
    $Self->{Translation}->{'Definition'} = 'Definitie';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filter op klassen';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Selecteer een klasse uit de lijst om een nieuw configuratie-item aan te maken.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'De naam van dit configuratie-item';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Status';
    $Self->{Translation}->{'Incident State'} = 'Incidentstatus';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '';
    $Self->{Translation}->{'Config Items per page'} = 'Aantal configuratie-items per pagina';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '';
    $Self->{Translation}->{'Current Incident State'} = 'Actuele incidentstatus';
    $Self->{Translation}->{'Current Incident State Type'} = '';
    $Self->{Translation}->{'Last changed'} = 'Laaste wijziging';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = 'Actuele status';
    $Self->{Translation}->{'Last changed by'} = 'Laaste wijziging door';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Ook in eerdere versies zoeken?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Configuratie-item';
    $Self->{Translation}->{'Configuration Item Information'} = 'Configuratie-item informatie';
    $Self->{Translation}->{'Show one version'} = 'Toon één versie';
    $Self->{Translation}->{'Show all versions'} = 'Toon alle versies';
    $Self->{Translation}->{'Version Incident State'} = 'Versie Incident-status';
    $Self->{Translation}->{'Version Number'} = 'Versienummer';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Configuratie-item versie details';
    $Self->{Translation}->{'Property'} = 'Attribuut';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = 'Configuratie-items';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Aanmaken en beheren van definities voor configuratie-items.';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/pl_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::pl_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adres';
    $Self->{Translation}->{'Admin Tool'} = 'Narzędzie administratorskie';
    $Self->{Translation}->{'Backup Device'} = 'Urządzenie do backupu';
    $Self->{Translation}->{'Beamer'} = '';
    $Self->{Translation}->{'Building'} = 'Budynek';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Nowy CI (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'Usunięcie CI (ID=%s)';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Aktualizacja definicji CI (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Aktualizacja stanu wdrożenia CI (nowy=%s; stary=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Aktualizacja stanu zdarzenia (nowy=%s; stary=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'Dodany link do %s (Typ=%s)';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'Usunięty link do %s (Typ=%s)';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Aktualizacja nazwy (nowa=%s; stara=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'Aktualizacja wartości atrybutu %s z "%s" na "%s"';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Utworzenie nowej wersji (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Usunięcie wersji %s';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = 'Utworzenie załącznika (%s)';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = 'Usunięcie załącznika (%s)';
    $Self->{Translation}->{'CPU'} = 'Procesor';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Pojemność';
    $Self->{Translation}->{'Change Definition'} = 'Definicja zmiany';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Zmiana definicji nie powiodła się! Szczegóły znajdują się w logu systemu.';
    $Self->{Translation}->{'Client Application'} = 'Aplikacja kliencka';
    $Self->{Translation}->{'Client OS'} = 'System kliencki';
    $Self->{Translation}->{'Concurrent Users'} = 'Jednocześni użytkownicy';
    $Self->{Translation}->{'Config Item-Area'} = 'CI-Obszar';
    $Self->{Translation}->{'Config Items available'} = 'Dostępne CI';
    $Self->{Translation}->{'Config Items shown'} = 'Wyświetlone CI';
    $Self->{Translation}->{'CMDB'} = 'CMDB';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Licencja developerska';
    $Self->{Translation}->{'Docking Station'} = 'Stacja dokująca';
    $Self->{Translation}->{'Duplicate'} = 'Duplikat';
    $Self->{Translation}->{'Embedded'} = 'Osadzony';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Puste pola znaczają, że zatrzymane będą bieżące wartości';
    $Self->{Translation}->{'Enterprise Licence'} = 'Licencja Enterprise';
    $Self->{Translation}->{'Expiration Date'} = 'Data wygaśnięcia';
    $Self->{Translation}->{'Expired'} = 'Wygasło';
    $Self->{Translation}->{'FQDN'} = 'Nazwa FQDN';
    $Self->{Translation}->{'Floor'} = 'Piętro';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Brama';
    $Self->{Translation}->{'Graphic Adapter'} = 'Karta graficzna';
    $Self->{Translation}->{'Hard Disk'} = 'Dysk twardy';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Pojemność dysku twardego';
    $Self->{Translation}->{'Hide Versions'} = 'Ukryj wersje';
    $Self->{Translation}->{'IP Address'} = 'Adres IP';
    $Self->{Translation}->{'IP over DHCP'} = 'Adres IP z DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Dział IT';
    $Self->{Translation}->{'Incident'} = 'Zdarzenie';
    $Self->{Translation}->{'Install Date'} = 'Data instalacji';
    $Self->{Translation}->{'Keybord'} = 'Klawiatura';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Ostatnia zmiana';
    $Self->{Translation}->{'Licence Key'} = 'Klucz licencyjny';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Klucz licencyjny::Data wygaśnięcia';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Klucz licencyjny::Ilość';
    $Self->{Translation}->{'Licence Type'} = 'Typ licencji';
    $Self->{Translation}->{'Maintenance'} = 'Utrzymanie';
    $Self->{Translation}->{'Maximum number of one element'} = 'Maksymalna liczba wystąpień pojednyczego elemetntu';
    $Self->{Translation}->{'Media'} = 'Nośnik';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Model';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Myszka';
    $Self->{Translation}->{'Network Adapter'} = 'Karta sieciowa';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Karta sieciowa::Adres IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Karta sieciowa::Adres IP z DHCP';
    $Self->{Translation}->{'Network Address'} = 'Adres sieciowy';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Adres sieciowy::Brama';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Adres sieciowy::Maska sieci';
    $Self->{Translation}->{'Open Source'} = 'Open source';
    $Self->{Translation}->{'Operating System'} = 'System operacyjny';
    $Self->{Translation}->{'Operational'} = 'Operacyjny';
    $Self->{Translation}->{'Other'} = 'Inne';
    $Self->{Translation}->{'Other Equipment'} = 'Pozostałe wyposażenie';
    $Self->{Translation}->{'Outlet'} = 'Punkt sprzedaży';
    $Self->{Translation}->{'PCMCIA Card'} = 'Karta PCMCIA';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Na urządzenie';
    $Self->{Translation}->{'Per Processor'} = 'Na procesor';
    $Self->{Translation}->{'Per Server'} = 'Na serwer';
    $Self->{Translation}->{'Per User'} = 'Na użytkownika';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilotaż';
    $Self->{Translation}->{'Planned'} = 'Planowany';
    $Self->{Translation}->{'Printer'} = 'Drukarka';
    $Self->{Translation}->{'Production'} = 'Produkcja';
    $Self->{Translation}->{'Quantity'} = 'Ilość';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'Naprawa';
    $Self->{Translation}->{'Retired'} = 'Wycofany';
    $Self->{Translation}->{'Review'} = 'Przegląd';
    $Self->{Translation}->{'Room'} = 'Pokój';
    $Self->{Translation}->{'Router'} = 'Ruter';
    $Self->{Translation}->{'Scanner'} = 'Skaner';
    $Self->{Translation}->{'Search Config Items'} = 'Szukaj CI';
    $Self->{Translation}->{'Security Device'} = 'Urządzenie zabezpieczające';
    $Self->{Translation}->{'Serial Number'} = 'Numer seryjny';
    $Self->{Translation}->{'Server'} = 'Serwer';
    $Self->{Translation}->{'Server Application'} = 'Aplikacja serwerowa';
    $Self->{Translation}->{'Server OS'} = 'System serwerowy';
    $Self->{Translation}->{'Show Versions'} = 'Pokaż wersje';
    $Self->{Translation}->{'Single Licence'} = 'Pojedyńcza licencja';
    $Self->{Translation}->{'Subnet Mask'} = 'Maska sieci';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Stan wdrożenia tego CI';
    $Self->{Translation}->{'The incident state of this config item'} = 'Stan zdarzenia tego CI';
    $Self->{Translation}->{'Time Restricted'} = 'Czasowo ograniczona';
    $Self->{Translation}->{'USB Device'} = 'Urządzenie USB';
    $Self->{Translation}->{'Unlimited'} = 'Bez limitu';
    $Self->{Translation}->{'User Tool'} = 'Narzędzie użytkownika';
    $Self->{Translation}->{'Volume Licence'} = 'Zbiorcza licencja';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'Access Point';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Data wygaśnięcia gwarancji';
    $Self->{Translation}->{'Workplace'} = 'Miejsce pracy';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Zarządzanie CI';
    $Self->{Translation}->{'Change class definition'} = 'Zmień definicję klasy';
    $Self->{Translation}->{'Config Item'} = 'CI';
    $Self->{Translation}->{'Class'} = 'Klasa';
    $Self->{Translation}->{'Definition'} = 'Definicja';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filtr dla klas';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Zaznacz klasę na liście aby utworzyć nowe CI.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Nazwa tego CI';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        'Nazwa jest już używana przez CI o następujących numerach: %s';
    $Self->{Translation}->{'Deployment State'} = 'Stan wdrożenia';
    $Self->{Translation}->{'Incident State'} = 'Stan zdarzenia';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Ustawienia kontekstu';
    $Self->{Translation}->{'Config Items per page'} = 'Liczba CI na stronie';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Typ stanu wdrożenia';
    $Self->{Translation}->{'Current Incident State'} = 'Aktualny stan';
    $Self->{Translation}->{'Current Incident State Type'} = 'Aktualny typ stanu';
    $Self->{Translation}->{'Last changed'} = 'Ostatnio zmienione';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'CI';
    $Self->{Translation}->{'ConfigItem-Info'} = 'CI-Info';
    $Self->{Translation}->{'Current Deployment State'} = 'Aktualny stan wdrożenia';
    $Self->{Translation}->{'Last changed by'} = 'Ostatnio zmienione przez';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '';
    $Self->{Translation}->{'Run Search'} = '';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Uwzględnić poprzednie wersje?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Czas utworzenia';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'CI';
    $Self->{Translation}->{'Configuration Item Information'} = 'Informacje o CI';
    $Self->{Translation}->{'Show one version'} = 'Pokaż jedną wersję!';
    $Self->{Translation}->{'Show all versions'} = 'Pokaż wszystkie wersje';
    $Self->{Translation}->{'Version Incident State'} = 'Stan';
    $Self->{Translation}->{'Version Number'} = 'Wersja';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Szczegóły wersji CI';
    $Self->{Translation}->{'Property'} = 'Właściwość';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Limit liczby CI';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Limit liczby CI na stronę';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Tworzenie i zarządzanie definicjami elementów konfiguracji.';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #
    $Self->{Translation}->{'Changed On'} = 'Zmienione';
    $Self->{Translation}->{'Computer'} = 'Komputer';
    $Self->{Translation}->{'Config Item Search Result: Class'} = 'Wynik wyszukiwania CI: klasa';
    $Self->{Translation}->{'Created By'} = 'Utworzone przez';
    $Self->{Translation}->{'Hardware'} = 'Sprzęt';
    $Self->{Translation}->{'ITSM ConfigItem'} = 'CI';
    $Self->{Translation}->{'Network'} = 'Sieć';
    $Self->{Translation}->{'Search-Template'} = 'Szukaj-szablon';
    $Self->{Translation}->{'Software'} = 'Oprogramowanie';

}

1;

# --
# Kernel/Language/pt_BR_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::pt_BR_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Endereço';
    $Self->{Translation}->{'Admin Tool'} = 'Ferramenta de Administração';
    $Self->{Translation}->{'Backup Device'} = 'Dispositivo de Backup';
    $Self->{Translation}->{'Beamer'} = 'Projetor';
    $Self->{Translation}->{'Building'} = 'Prédio';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Novo item de configuração (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'Item de configuração (ID=%s) excluído';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Definição do IC atualizada (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Estado de implantação alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Estado de incidente alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'O link para %s (Typ=%s) foi adicionado';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'O link para %s (Typ=%s) excluído';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Nome alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'O atributo %s de "%s" para "%s" mudou';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Nova versão criada (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versão %s excluída';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = 'Anexo (%s) adicionado';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = 'Anexo (%s) excluído';
    $Self->{Translation}->{'CPU'} = 'Processador';
    $Self->{Translation}->{'Camera'} = 'Câmera';
    $Self->{Translation}->{'Capacity'} = 'Capacidade';
    $Self->{Translation}->{'Change Definition'} = 'Alterar Definição';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Mudança de definição falhou! Veja o registro do sistema para mais detalhes.';
    $Self->{Translation}->{'Client Application'} = 'Aplicação Cliente';
    $Self->{Translation}->{'Client OS'} = 'SO Cliente';
    $Self->{Translation}->{'Concurrent Users'} = 'Usuários Concorrentes';
    $Self->{Translation}->{'Config Item-Area'} = 'Área Item de Configuração';
    $Self->{Translation}->{'Config Items available'} = 'Itens de Configuração disponíveis';
    $Self->{Translation}->{'Config Items shown'} = 'Itens de Configuração visualizados';
    $Self->{Translation}->{'CMDB'} = 'BDGC';
    $Self->{Translation}->{'Demo'} = 'Demonstração';
    $Self->{Translation}->{'Desktop'} = 'Área ';
    $Self->{Translation}->{'Developer Licence'} = 'Licença de Desenvolvedor';
    $Self->{Translation}->{'Docking Station'} = '';
    $Self->{Translation}->{'Duplicate'} = 'Duplicar';
    $Self->{Translation}->{'Embedded'} = 'Integrado';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Os campos vazios indicam que os valores atuais são mantidos';
    $Self->{Translation}->{'Enterprise Licence'} = 'Licença Corporativa';
    $Self->{Translation}->{'Expiration Date'} = 'Data de Expiração';
    $Self->{Translation}->{'Expired'} = 'Expirado';
    $Self->{Translation}->{'FQDN'} = '';
    $Self->{Translation}->{'Floor'} = 'Andar';
    $Self->{Translation}->{'Freeware'} = 'Livre';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = 'Roteador Padrão';
    $Self->{Translation}->{'Graphic Adapter'} = 'Adaptador Gráfico';
    $Self->{Translation}->{'Hard Disk'} = 'Disco Rígido';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disco Rígido::Capacidade';
    $Self->{Translation}->{'Hide Versions'} = 'Ocultar Versões';
    $Self->{Translation}->{'IP Address'} = 'Endereço IP';
    $Self->{Translation}->{'IP over DHCP'} = 'DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Departamento de TI';
    $Self->{Translation}->{'Inactive'} = 'Inativo';
    $Self->{Translation}->{'Incident'} = 'Incidente';
    $Self->{Translation}->{'Install Date'} = 'Data Instalação';
    $Self->{Translation}->{'Keybord'} = 'Teclado';
    $Self->{Translation}->{'LAN'} = 'REDE';
    $Self->{Translation}->{'Laptop'} = 'Notebook';
    $Self->{Translation}->{'Last Change'} = 'Última Alteração';
    $Self->{Translation}->{'Licence Key'} = 'Chave de Licença';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Chave de Licença::Data de Expiração';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Chave de Licença::Quantidade';
    $Self->{Translation}->{'Licence Type'} = 'Tipo de Licença';
    $Self->{Translation}->{'Maintenance'} = 'Manutenção';
    $Self->{Translation}->{'Maximum number of one element'} = 'Número máximo de um elemento';
    $Self->{Translation}->{'Media'} = 'Mídia';
    $Self->{Translation}->{'Middleware'} = '';
    $Self->{Translation}->{'Model'} = 'Modelo';
    $Self->{Translation}->{'Modem'} = '';
    $Self->{Translation}->{'Monitor'} = '';
    $Self->{Translation}->{'Mouse'} = '';
    $Self->{Translation}->{'Network Adapter'} = 'Adaptador de Rede';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adaptador de Rede::Endereço IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adaptador de Rede::DHCP';
    $Self->{Translation}->{'Network Address'} = 'Endereço de Rede';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Endereço de Rede::Roteador Padrão';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Endereço de Rede::Máscara de Subrede';
    $Self->{Translation}->{'Open Source'} = 'Código aberto';
    $Self->{Translation}->{'Operating System'} = 'Sistema Operacional';
    $Self->{Translation}->{'Operational'} = 'Operacional';
    $Self->{Translation}->{'Other'} = 'Outro';
    $Self->{Translation}->{'Other Equipment'} = 'Outro Equipamento';
    $Self->{Translation}->{'Outlet'} = 'Tomada';
    $Self->{Translation}->{'PCMCIA Card'} = 'Cartão PCMCIA';
    $Self->{Translation}->{'PDA'} = '';
    $Self->{Translation}->{'Per Node'} = 'Por Nó';
    $Self->{Translation}->{'Per Processor'} = 'Por Processador';
    $Self->{Translation}->{'Per Server'} = 'Por Servidor';
    $Self->{Translation}->{'Per User'} = 'Por Usuário';
    $Self->{Translation}->{'Phone 1'} = 'Telefone 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefone 2';
    $Self->{Translation}->{'Pilot'} = 'Piloto';
    $Self->{Translation}->{'Planned'} = 'Planejado';
    $Self->{Translation}->{'Printer'} = 'Impressora';
    $Self->{Translation}->{'Production'} = 'Produção';
    $Self->{Translation}->{'Quantity'} = 'Quantidade';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = 'Memória RAM';
    $Self->{Translation}->{'Repair'} = 'Reparo';
    $Self->{Translation}->{'Retired'} = 'Retirado';
    $Self->{Translation}->{'Review'} = 'Revisão';
    $Self->{Translation}->{'Room'} = 'Sala';
    $Self->{Translation}->{'Router'} = 'Roteador';
    $Self->{Translation}->{'Scanner'} = '';
    $Self->{Translation}->{'Search Config Items'} = 'Pesquisar Itens de Configuração';
    $Self->{Translation}->{'Security Device'} = 'Dispositivo de Segurança';
    $Self->{Translation}->{'Serial Number'} = 'Número de Série';
    $Self->{Translation}->{'Server'} = 'Servidor';
    $Self->{Translation}->{'Server Application'} = 'Aplicação Servidor';
    $Self->{Translation}->{'Server OS'} = 'SO Servidor';
    $Self->{Translation}->{'Show Versions'} = 'Visualizar Versões';
    $Self->{Translation}->{'Single Licence'} = 'Licença Única';
    $Self->{Translation}->{'Subnet Mask'} = 'Máscara de Subrede';
    $Self->{Translation}->{'Switch'} = '';
    $Self->{Translation}->{'Telco'} = 'Telecomunicação';
    $Self->{Translation}->{'Test/QA'} = 'Teste de Qualidade';
    $Self->{Translation}->{'The deployment state of this config item'} = 'O estado de implantação deste item de configuração';
    $Self->{Translation}->{'The incident state of this config item'} = 'O estado de incidente deste item de configuração';
    $Self->{Translation}->{'Time Restricted'} = 'Tempo Restrito';
    $Self->{Translation}->{'USB Device'} = 'Dispositivo USB';
    $Self->{Translation}->{'Unlimited'} = 'Ilimitada';
    $Self->{Translation}->{'User Tool'} = 'Ferramenta do Usuário';
    $Self->{Translation}->{'Volume Licence'} = 'Licença por Volume';
    $Self->{Translation}->{'WLAN'} = '';
    $Self->{Translation}->{'WLAN Access Point'} = '';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Data de Expiração da Garantia';
    $Self->{Translation}->{'Workplace'} = 'Local de Trabalho';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gerenciamento de Itens de Configuração';
    $Self->{Translation}->{'Change class definition'} = 'Mudar definição de classe';
    $Self->{Translation}->{'Config Item'} = 'Item de Configuração';
    $Self->{Translation}->{'Class'} = 'Classe';
    $Self->{Translation}->{'Definition'} = 'Definição';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filtro para Classes';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Selecione uma classe a partir da lista para criar um novo item de configuração.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'O nome deste item de configuração';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = 'Estado de Implantação';
    $Self->{Translation}->{'Incident State'} = 'Estado de Incidente';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Configurações de Contexto';
    $Self->{Translation}->{'Config Items per page'} = 'Itens de configuração por página';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Tipo de Estado de Implantação';
    $Self->{Translation}->{'Current Incident State'} = 'Estado do Incidente Atual';
    $Self->{Translation}->{'Current Incident State Type'} = 'Estado Atual de Incidente por tipo';
    $Self->{Translation}->{'Last changed'} = 'Última modificação';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'Item de configuração';
    $Self->{Translation}->{'ConfigItem-Info'} = ' Informação do Item de configuração';
    $Self->{Translation}->{'Current Deployment State'} = 'Estado de Implantação Atual';
    $Self->{Translation}->{'Last changed by'} = 'Última modificação por';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = 'Criar novo Modelo';
    $Self->{Translation}->{'Run Search'} = 'Executar Pesquisa';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Procurar nas verões anteriores também?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Tempo de criação';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Item de configuração';
    $Self->{Translation}->{'Configuration Item Information'} = 'Informação do Item de Configuração';
    $Self->{Translation}->{'Show one version'} = 'Visualizar uma versão';
    $Self->{Translation}->{'Show all versions'} = 'Visualizar todas as versões';
    $Self->{Translation}->{'Version Incident State'} = 'Estado da Versão de Incidentes';
    $Self->{Translation}->{'Version Number'} = 'Número da versão';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Detalhes da Versão do Item de Configuração';
    $Self->{Translation}->{'Linked as'} = 'Associado como';
    $Self->{Translation}->{'Property'} = 'Propriedade';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = 'Itens de Configuração';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        'Módulo de evento de item de configuração que permite registrar o histórico da interface do atendente.';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Limite de Item de Configuração';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Limite de Item de Configuração por página';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        'Roteador de pesquisa de item de configuração da interface do atendente.';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Criar e gerenciar as definições de Itens de Configuração.';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        'Define um módulo de visão geral para mostrar a visão pequena da lista de itens de configuração.';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        'Define o subobjeto padrão da classe \'ITSMConfigItem\'.';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        'Define as colunas mostradas na visão geral de item de configuração. Esta opção não tem efeito sobre a posição da coluna. Nota: A coluna de classe está sempre disponível, se o filtro \'All\' é selecionado.';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        'Define as colunas mostradas na busca de item de configuração. Esta opção não tem efeito sobre a posição da coluna.';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = 'Módulo para verificar o grupo responsável por uma classe.';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        'Módulo para verificar o grupo responsável por um item de configuração.';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = 'Módulo para gerar estatísticas do item de configuração ITSM.';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        'Modulo de registro de objeto para o módulo de importação/exportação.';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        'Parâmetros de estado de implantação nas preferências de exibição da interface de atendente.';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        'Parâmetros do grupos de permissão de exemplo dos atributos do catálogo geral.';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        'Parâmetros das páginas (nas quais os itens de configuração são mostrados).';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de pesquisa de item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de detalhes do item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de adição de item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de edição de item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de histórico de item de configuração ITSM na interface de atendente.';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        'Permissões necessárias para usar a tela de impressão de item de configuração ITSM na interface do atendente.';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        'Seleciona o módulo de geração de número de item de configuração. "Autoincremento" incrementa o número do item de configuração, o SystemID, o ConfigItemClassID e o Counter são usados. O formato é "SystemID.ConfigItemClassID.Counter", por exemplo, 1205000004, 1205000005.';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        'Mostra um link no menu que permite associar um item de configuração com um outro objeto na visão de detalhes do item de configuração da interface de atendente.';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        'Mostra um link no menu para acessar o histórico de item de configuração na visão de detalhes do mesmo na interface de atendente.';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        'Mostra um link no menu para duplicar um item de configuração na visão de detalhes do mesmo na interface de atendente.';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        'Mostra um link no menu para editar um item de configuração na visão de detalhes do mesmo na interface de atendente.';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        'Mostra um link no menu para retornar à tela de visão de detalhes de item de configuração da interface de atendente.';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        'Mostra um link no menu para imprimir um item de configuração na visão de detalhes do mesmo na interface de atendente.';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        'Mostra o histórico do item configuração (ordem reversa) na interface de atendente.';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/pt_PT_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# Copyright (C) 2012 FCCN - Rui Francisco <rui.francisco@fccn.pt>
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::pt_PT_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Endereço';
    $Self->{Translation}->{'Admin Tool'} = 'Ferramenta de Administração';
    $Self->{Translation}->{'Backup Device'} = 'Dispositivo de Backup';
    $Self->{Translation}->{'Beamer'} = 'Projetor';
    $Self->{Translation}->{'Building'} = 'Prédio';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = 'Novo item de configuração (ID=%s)';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = 'Item de configuração (ID=%s) excluído';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = 'Definição do CI atualizada (ID=%s)';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = 'Estado de implementação alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = 'Estado de incidente alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = 'O link para %s (Typ=%s) foi adicionado';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = 'O link %s (Typ=%s) foi apagado';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = 'Nome alterado (novo=%s; antigo=%s)';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = 'O atributo %s foi alterado de "%s" para "%s" ';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = 'Nova versão criada (ID=%s)';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = 'Versão %s foi apagada';
    $Self->{Translation}->{'CPU'} = 'Processador';
    $Self->{Translation}->{'Camera'} = 'Camera';
    $Self->{Translation}->{'Capacity'} = 'CapacAntiguidade';
    $Self->{Translation}->{'Change Definition'} = 'Alterar Definição';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Alteração da definição falhou! Veja o log para mais informação.';
    $Self->{Translation}->{'Client Application'} = 'Aplicação Cliente';
    $Self->{Translation}->{'Client OS'} = 'SO Cliente';
    $Self->{Translation}->{'Concurrent Users'} = 'Utilizadores Concorrentes';
    $Self->{Translation}->{'Config Item-Area'} = 'Área Item de Configuração';
    $Self->{Translation}->{'Config Items available'} = 'Itens de Configuração disponíveis';
    $Self->{Translation}->{'Config Items shown'} = 'Itens de Configuração visíveis';
    $Self->{Translation}->{'CMDB'} = 'CMDB';
    $Self->{Translation}->{'Demo'} = 'Demonstração';
    $Self->{Translation}->{'Desktop'} = 'Área ';
    $Self->{Translation}->{'Developer Licence'} = 'Licença de desenvolvimento';
    $Self->{Translation}->{'Docking Station'} = '';
    $Self->{Translation}->{'Duplicate'} = 'Duplicar';
    $Self->{Translation}->{'Embedded'} = 'Integrado';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Os campos vazios indicam que os valores atuais são mantidos';
    $Self->{Translation}->{'Enterprise Licence'} = 'Licença Corporativa';
    $Self->{Translation}->{'Expiration Date'} = 'Data de Expiração';
    $Self->{Translation}->{'Expired'} = 'Expirado';
    $Self->{Translation}->{'FQDN'} = '';
    $Self->{Translation}->{'Floor'} = 'Piso';
    $Self->{Translation}->{'Freeware'} = 'Livre';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '';
    $Self->{Translation}->{'Graphic Adapter'} = 'Adaptador Gráfico';
    $Self->{Translation}->{'Hard Disk'} = 'Disco Rígido';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Disco Rígido::CapacAntiguidade';
    $Self->{Translation}->{'Hide Versions'} = 'Ocultar Versões';
    $Self->{Translation}->{'IP Address'} = 'Endereço IP';
    $Self->{Translation}->{'IP over DHCP'} = 'DHCP';
    $Self->{Translation}->{'IT Facility'} = 'Departamento de TI';
    $Self->{Translation}->{'Inactive'} = 'Inativo';
    $Self->{Translation}->{'Incident'} = 'Incidente';
    $Self->{Translation}->{'Install Date'} = 'Data Instalação';
    $Self->{Translation}->{'Keybord'} = 'Teclado';
    $Self->{Translation}->{'LAN'} = 'REDE';
    $Self->{Translation}->{'Laptop'} = 'portátil';
    $Self->{Translation}->{'Last Change'} = 'Última Alteração';
    $Self->{Translation}->{'Licence Key'} = 'Chave de Licença';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Chave de Licença::Data de Expiração';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Chave de Licença::QuantAntiguidade';
    $Self->{Translation}->{'Licence Type'} = 'Tipo de Licença';
    $Self->{Translation}->{'Maintenance'} = 'Manutenção';
    $Self->{Translation}->{'Maximum number of one element'} = 'Número máximo de um elemento';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = '';
    $Self->{Translation}->{'Model'} = 'Modelo';
    $Self->{Translation}->{'Modem'} = '';
    $Self->{Translation}->{'Monitor'} = '';
    $Self->{Translation}->{'Mouse'} = 'rato';
    $Self->{Translation}->{'Network Adapter'} = 'Adaptador de Rede';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Adaptador de Rede::Endereço IP';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Adaptador de Rede::DHCP';
    $Self->{Translation}->{'Network Address'} = 'Endereço de Rede';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Endereço de Rede::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Endereço de Rede::Máscara de Subrede';
    $Self->{Translation}->{'Open Source'} = 'Código aberto';
    $Self->{Translation}->{'Operating System'} = 'Sistema Operativo';
    $Self->{Translation}->{'Operational'} = 'Operativo';
    $Self->{Translation}->{'Other'} = 'Outro';
    $Self->{Translation}->{'Other Equipment'} = 'Outro Equipamento';
    $Self->{Translation}->{'Outlet'} = 'Tomada';
    $Self->{Translation}->{'PCMCIA Card'} = 'Placa PCMCIA';
    $Self->{Translation}->{'PDA'} = '';
    $Self->{Translation}->{'Per Node'} = 'Por Posto';
    $Self->{Translation}->{'Per Processor'} = 'Por Processador';
    $Self->{Translation}->{'Per Server'} = 'Por Servidor';
    $Self->{Translation}->{'Per User'} = 'Por Utilizador';
    $Self->{Translation}->{'Phone 1'} = 'Telefone 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefone 2';
    $Self->{Translation}->{'Pilot'} = 'Piloto';
    $Self->{Translation}->{'Planned'} = 'Planeado';
    $Self->{Translation}->{'Printer'} = 'Impressora';
    $Self->{Translation}->{'Production'} = 'Produção';
    $Self->{Translation}->{'Quantity'} = 'QuantAntiguidade';
    $Self->{Translation}->{'Rack'} = '';
    $Self->{Translation}->{'Ram'} = 'Memória RAM';
    $Self->{Translation}->{'Repair'} = 'Reparação';
    $Self->{Translation}->{'Retired'} = 'Retirado';
    $Self->{Translation}->{'Review'} = 'Revisão';
    $Self->{Translation}->{'Room'} = 'Sala';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = '';
    $Self->{Translation}->{'Search Config Items'} = 'Pesquisar Itens de Configuração';
    $Self->{Translation}->{'Security Device'} = 'Dispositivo de Segurança';
    $Self->{Translation}->{'Serial Number'} = 'Número de Série';
    $Self->{Translation}->{'Server'} = 'Servidor';
    $Self->{Translation}->{'Server Application'} = 'Servidor Aplicacional ';
    $Self->{Translation}->{'Server OS'} = 'SO Servidor';
    $Self->{Translation}->{'Show Versions'} = 'Visualizar Versões';
    $Self->{Translation}->{'Single Licence'} = 'Licença Única';
    $Self->{Translation}->{'Subnet Mask'} = 'Máscara de rede';
    $Self->{Translation}->{'Switch'} = '';
    $Self->{Translation}->{'Telco'} = 'Telecomunicações';
    $Self->{Translation}->{'Test/QA'} = 'Teste de QualAntiguidade';
    $Self->{Translation}->{'The deployment state of this config item'} = 'O estado de implementação do item de configuração';
    $Self->{Translation}->{'The incident state of this config item'} = 'O estado de incidente deste item de configuração';
    $Self->{Translation}->{'Time Restricted'} = 'Tempo Restrito';
    $Self->{Translation}->{'USB Device'} = 'Dispositivo USB';
    $Self->{Translation}->{'Unlimited'} = 'Ilimitada';
    $Self->{Translation}->{'User Tool'} = 'Ferramenta de Utilizador';
    $Self->{Translation}->{'Volume Licence'} = 'Licença por Volume';
    $Self->{Translation}->{'WLAN'} = '';
    $Self->{Translation}->{'WLAN Access Point'} = '';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Data de Expiração da Garantia';
    $Self->{Translation}->{'Workplace'} = 'Local de Trabalho';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Gestão de Itens de Configuração';
    $Self->{Translation}->{'Change class definition'} = 'Mudar definição de classe';
    $Self->{Translation}->{'Config Item'} = 'Item de Configuração';
    $Self->{Translation}->{'Class'} = 'Classe';
    $Self->{Translation}->{'Definition'} = 'Definição';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filtro para Classes';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Selecione uma classe a partir da lista para criar um novo item de configuração.';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'O nome deste item de configuração';
    $Self->{Translation}->{'Deployment State'} = 'Estado de Implementação';
    $Self->{Translation}->{'Incident State'} = 'Estado de Incidente';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Configurações de Contexto';
    $Self->{Translation}->{'Config Items per page'} = 'Itens de configuração por página';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Tipo de Estado de Implementação';
    $Self->{Translation}->{'Current Incident State'} = 'Estado do Incidente Atual';
    $Self->{Translation}->{'Current Incident State Type'} = 'Estado Atual de Incidente por tipo';
    $Self->{Translation}->{'Last Changed'} = 'Última Modificação';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'Item de configuração';
    $Self->{Translation}->{'ConfigItem-Info'} = ' Informação do Item de configuração';
    $Self->{Translation}->{'Current Deployment State'} = 'Estado de Implementação Atual';
    $Self->{Translation}->{'Last changed'} = 'Última modificação';
    $Self->{Translation}->{'Last changed by'} = 'Última modificação por';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Also search in previous versions?'} = 'Procurar nas versões anteriores também?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Hora de criação';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Item de configuração';
    $Self->{Translation}->{'Show one version'} = 'Visualizar uma versão';
    $Self->{Translation}->{'Show all versions'} = 'Visualizar todas as versões';
    $Self->{Translation}->{'Version Incident State'} = 'Estado da Versão de Incidentes';
    $Self->{Translation}->{'Version Number'} = 'Número da versão';
    $Self->{Translation}->{'Created By'} = 'Criado por';
    $Self->{Translation}->{'Changed On'} = 'Modificado por';
    $Self->{Translation}->{'Show or hide the content.'} = 'Mostrar ou ocultar o conteúdo.';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Detalhes da Versão do Item de Configuração';
    $Self->{Translation}->{'Property'} = 'Propriedade';

    # SysConfig
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} = 'Módulo de evento de item de configuração que permite registar o histórico da interface do agente.';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Limite de Items de Configuração';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Limite de Items de Configuração por página';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} = 'Router de pesquisa de item de configuração da interface do agente.';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Criar e gerir as definições de Itens de Configuração.';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} = 'Define um módulo de vista geral para mostrar a vista pequena da lista de itens de configuração.';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} = 'Define o subobjeto por omissão da classe \'ITSMConfigItem\'.';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} = 'Define as colunas da vista geral de item de configuração. Esta opção não tem efeito sobre a posição da coluna. Nota: A coluna de classe está sempre disponível, se o filtro \'All\' for selecionado.';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} = 'Define as colunas mostradas na busca de item de configuração. Esta opção não tem efeito sobre a posição da coluna.';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = 'Módulo para verificar o grupo responsável por uma classe.';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} = 'Módulo para verificar o grupo responsável por um item de configuração.';
    $Self->{Translation}->{'Module to genetare ITSM config item statistics.'} = 'Módulo para gerar estatísticas do item de configuração ITSM.';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} = 'Modulo de registo de objeto para o módulo de importação/exportação.';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} = 'Parâmetros de estado de implementação nas preferências de visualização da interface de agente.';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} = 'Parâmetros do grupos de permissão de exemplo dos atributos do catálogo geral.';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} = 'Parâmetros das páginas (nas quais os itens de configuração são visualizados).';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de pesquisa de item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de detalhes do item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de adição de item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de edição de item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de histórico de item de configuração ITSM de agente.';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} = 'Permissões necessárias para usar o formulário de impressão de item de configuração ITSM na interface do agente.';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} = 'Seleciona o módulo de geração de número de item de configuração. "Autoincremento" incrementa o número do item de configuração, o SystemID, o ConfigItemClassID e o Counter são utilizados. O formato é "SystemID.ConfigItemClassID.Counter", por exemplo, 1205000004, 1205000005.';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} = 'Mostra um link no menu que permite associar um item de configuração a outro objeto na vista de detalhes do item de configuração de agente.';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} = 'Mostra um link no menu para aceder o histórico de item de configuração na vista de agente.';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} = 'Mostra um link no menu para duplicar um item de configuração na vista de agente.';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} = 'Mostra um link no menu para editar um item de configuração na vista de agente.';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} = 'Mostra um link no menu para retornar à vista de detalhes do item de configuração de agente.';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} = 'Mostra um link no menu para imprimir um item de configuração na vista de detalhes de agente.';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} = 'Mostra o histórico do item configuração (ordem inversa) no interface de agente.';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem, MyConfigItem. The default is ConfigItem.'} = 'O identificador de um item de configuração, por exemplo, ConfigItem, ItemConfig, MeuItemConfig. O valor por omissão é ConfigItem.';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/ru_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# Copyright (C) 2013 Yuriy Kolesnikov <ynkolesnikov at gmail.com>
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::ru_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Адрес';
    $Self->{Translation}->{'Admin Tool'} = 'Системные утилиты';
    $Self->{Translation}->{'Backup Device'} = 'Устройство бэкапа';
    $Self->{Translation}->{'Beamer'} = 'Проектор';
    $Self->{Translation}->{'Building'} = 'Здание';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'ЦПУ';
    $Self->{Translation}->{'Camera'} = 'Камера';
    $Self->{Translation}->{'Capacity'} = 'Объем';
    $Self->{Translation}->{'Change Definition'} = 'Изменить описание';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Невозможно изменить описание! Для подробной информации смотри System Log.';
    $Self->{Translation}->{'Client Application'} = 'Клиентское приложение';
    $Self->{Translation}->{'Client OS'} = 'Клиентская ОС';
    $Self->{Translation}->{'Concurrent Users'} = 'Конкурентая лицензия';
    $Self->{Translation}->{'Config Item-Area'} = 'Обзор основных средств';
    $Self->{Translation}->{'Config Items available'} = 'Доступно основных средств';
    $Self->{Translation}->{'Config Items shown'} = 'Показано основных средств';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = 'Демо-версия';
    $Self->{Translation}->{'Desktop'} = 'Настольный ПК';
    $Self->{Translation}->{'Developer Licence'} = 'Лицензия для разработчика';
    $Self->{Translation}->{'Docking Station'} = 'Док-станция';
    $Self->{Translation}->{'Duplicate'} = 'Резерв';
    $Self->{Translation}->{'Embedded'} = 'Встроенный';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Пустые поля показывают, что текущие значения сохранятся';
    $Self->{Translation}->{'Enterprise Licence'} = 'Корпоративная лицензия';
    $Self->{Translation}->{'Expiration Date'} = 'Срок лицензии';
    $Self->{Translation}->{'Expired'} = 'Устарело';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '';
    $Self->{Translation}->{'Freeware'} = 'Бесплатное ПО';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Шлюз';
    $Self->{Translation}->{'Graphic Adapter'} = 'Видео адаптер';
    $Self->{Translation}->{'Hard Disk'} = 'Жесткий диск';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Жесткий диск::Объем';
    $Self->{Translation}->{'Hide Versions'} = 'Скрыть версии';
    $Self->{Translation}->{'IP Address'} = 'IP адрес';
    $Self->{Translation}->{'IP over DHCP'} = 'IP по DHCP';
    $Self->{Translation}->{'IT Facility'} = '';
    $Self->{Translation}->{'Inactive'} = 'Неактивно';
    $Self->{Translation}->{'Incident'} = 'Инцидент';
    $Self->{Translation}->{'Install Date'} = 'Дата установки';
    $Self->{Translation}->{'Keybord'} = 'Клавиатура';
    $Self->{Translation}->{'LAN'} = 'Сетевая карта';
    $Self->{Translation}->{'Laptop'} = 'Ноутбук';
    $Self->{Translation}->{'Last Change'} = 'Время последнего изменения';
    $Self->{Translation}->{'Licence Key'} = 'Лицензионный ключ';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Лицензионный ключ::Срок лицензии';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Лицензионный ключ::Количество';
    $Self->{Translation}->{'Licence Type'} = 'Тип лицензии';
    $Self->{Translation}->{'Maintenance'} = 'Техническое обслуживание';
    $Self->{Translation}->{'Maximum number of one element'} = 'Максимальное количество одного элемента';
    $Self->{Translation}->{'Media'} = 'Мультимедийные средства';
    $Self->{Translation}->{'Middleware'} = 'Промежуточное ПО';
    $Self->{Translation}->{'Model'} = 'Модель';
    $Self->{Translation}->{'Modem'} = 'Модем';
    $Self->{Translation}->{'Monitor'} = 'Монитор';
    $Self->{Translation}->{'Mouse'} = 'Мышка';
    $Self->{Translation}->{'Network Adapter'} = 'Сетевой адаптер';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Сетевой адаптер::IP адрес';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Сетевой адаптер::IP по DHCP';
    $Self->{Translation}->{'Network Address'} = 'Сетевой адрес';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Сетевой адрес::Шлюз';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Сетевой адрес::Маска подсети';
    $Self->{Translation}->{'Open Source'} = 'ПО с открытым кодом';
    $Self->{Translation}->{'Operating System'} = 'Операционная система';
    $Self->{Translation}->{'Operational'} = 'В эксплуатации';
    $Self->{Translation}->{'Other'} = 'Другое';
    $Self->{Translation}->{'Other Equipment'} = 'Другое оборудование';
    $Self->{Translation}->{'Outlet'} = 'Розетка';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA карта';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'На ноду(узел)';
    $Self->{Translation}->{'Per Processor'} = 'На ЦПУ';
    $Self->{Translation}->{'Per Server'} = 'На сервер';
    $Self->{Translation}->{'Per User'} = 'На пользователя';
    $Self->{Translation}->{'Phone 1'} = 'Телефон 1';
    $Self->{Translation}->{'Phone 2'} = 'Телефон 2';
    $Self->{Translation}->{'Pilot'} = 'Эксперимент';
    $Self->{Translation}->{'Planned'} = 'Запланированно';
    $Self->{Translation}->{'Printer'} = 'Принтер';
    $Self->{Translation}->{'Production'} = 'Производство';
    $Self->{Translation}->{'Quantity'} = 'Количество';
    $Self->{Translation}->{'Rack'} = 'Стойка';
    $Self->{Translation}->{'Ram'} = 'ОЗУ';
    $Self->{Translation}->{'Repair'} = 'Ремонт';
    $Self->{Translation}->{'Retired'} = 'Списано';
    $Self->{Translation}->{'Review'} = 'Экспертиза';
    $Self->{Translation}->{'Room'} = 'Кабинет';
    $Self->{Translation}->{'Router'} = 'Маршрутизатор';
    $Self->{Translation}->{'Scanner'} = 'Сканер';
    $Self->{Translation}->{'Search Config Items'} = 'Поиск конфигурационных единиц';
    $Self->{Translation}->{'Security Device'} = 'Смарт-карта';
    $Self->{Translation}->{'Serial Number'} = 'Серийный номер';
    $Self->{Translation}->{'Server'} = 'Сервер';
    $Self->{Translation}->{'Server Application'} = 'Серверное приложение';
    $Self->{Translation}->{'Server OS'} = 'Серверная ОС';
    $Self->{Translation}->{'Show Versions'} = 'Показать версии';
    $Self->{Translation}->{'Single Licence'} = 'Однократная лицензия';
    $Self->{Translation}->{'Subnet Mask'} = 'Маска подсети';
    $Self->{Translation}->{'Switch'} = 'Коммутатор';
    $Self->{Translation}->{'Telco'} = '';
    $Self->{Translation}->{'Test/QA'} = 'Тестирование';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Состояние использования этой КЕ';
    $Self->{Translation}->{'The incident state of this config item'} = 'Состояние инцидента для этой КЕ';
    $Self->{Translation}->{'Time Restricted'} = 'Ограниченная по времени';
    $Self->{Translation}->{'USB Device'} = 'USB устройство';
    $Self->{Translation}->{'Unlimited'} = 'Без ограничений';
    $Self->{Translation}->{'User Tool'} = 'Пользовательские утилиты';
    $Self->{Translation}->{'Volume Licence'} = 'Корпоративная лицензия';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN точка доступа';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Срок истечения гарантии';
    $Self->{Translation}->{'Workplace'} = 'Рабочее место';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Управление Конфигурационными единицами';
    $Self->{Translation}->{'Change class definition'} = 'Изменить описание класса';
    $Self->{Translation}->{'Config Item'} = 'Основные средства';
    $Self->{Translation}->{'Class'} = 'Класс';
    $Self->{Translation}->{'Definition'} = 'Описание';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Фильтр для классов';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Выберите класс из списка для создания новой КЕ';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Имя этого учетного элемента';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        'Имя уже используется другой КЕ со следующим номером (ами): %s';
    $Self->{Translation}->{'Deployment State'} = 'Состояние использования';
    $Self->{Translation}->{'Incident State'} = 'Состояние инцидента';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Config Items per page'} = 'Конфигурационных единиц на страницу';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Тип Состояния использования';
    $Self->{Translation}->{'Current Incident State'} = 'Текущее состояние инцидента';
    $Self->{Translation}->{'Current Incident State Type'} = 'Тип Текущего состояния инцидента';
    $Self->{Translation}->{'Last changed'} = 'Время последнего изменения';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'Конфигурационная единица';
    $Self->{Translation}->{'ConfigItem-Info'} = 'Информация о КЕ';
    $Self->{Translation}->{'Current Deployment State'} = 'Текущее состояние использования';
    $Self->{Translation}->{'Last changed by'} = 'Автор последнего изменения';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Also search in previous versions?'} = 'Искать и в предыдущих версиях?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = 'Дата создания';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Конфигурационная единица';
    $Self->{Translation}->{'Configuration Item Information'} = ' Информация о Конф. ед.';
    $Self->{Translation}->{'Show one version'} = 'Показать одну версию';
    $Self->{Translation}->{'Show all versions'} = 'Показать все версии';
    $Self->{Translation}->{'Version Incident State'} = 'Состояние инцидента версии';
    $Self->{Translation}->{'Version Number'} = 'Номер версии';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Полная информация о КЕ выбранной версии';
    $Self->{Translation}->{'Property'} = '';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        'Проверка уникальности Имени внутри текущего класса КЕ(\'class\') или глобально (\'global\'),что означает, что любая существующая КЕ учитывается при поиске дубликатов ';
    $Self->{Translation}->{'Config Items'} = 'Конфигурационные единицы';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        'Config item (КЕ) event module ведущий запись в историю в агентском интерфейсе.';
    $Self->{Translation}->{'Configuration Item Limit'} = ' Лимит КЕ';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Количество КЕ на страницу';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        'Модуль поиска КЕ в агентском интерфейсе';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Создание и управление описаниями конфигурационных единиц.';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        'Задает модуль просмотра КЕ в кратком виде.';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        'Задает регулярные выражения для каждого отдельного класса для проверки имен КЕ и выдачи сообщений об ошибках.';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        'Задает умалчивамый подобъект для класса \'ITSMConfigItem\'.';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        'Задает количество строк для редактора описаний КЕ (CI) в интерфейсе админа.';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        'Задает лимит поиска объектов для экрана AgentITSMConfigItem';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        'Задает лимит поиска объектов для экрана AgentITSMConfigItemSearch';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected.'} =
        'Задает список показываемых столбцов в обзоре КЕ. Этот параметр не влияет на их порядок. Помните: Столбец Класс доступен только при условии выбора в фильтре "Все"(All)';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        'Задает список показываемых столбцов в результатах поиска КЕ. Этот параметр не влияет на порядок их отображения.';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        'Задает список отображаемых столбцов при просмотре списков КЕ в зависимости от класса. Каждое имя атрибута должно иметь в качестве префикса - имя класса и два двоеточия (i.e. Computer::). Есть ряд атрибутов, общих для всех классов (например, для класса Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). Для отображения индивидуальных атрибутов, специфичных для конкретного класса из описания КЕ (CI-Definition), используется следующий синтаксис (например, для класса Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. Если нет атрибутов для конкретного класса, отображаются столбцы заданные параметром ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        'Задает список отображаемых столбцов в результатах поиска КЕ в зависимости от выбранного класса. Каждое имя атрибута должно иметь в качестве префикса - имя класса и два двоеточия (i.e. Computer::). Есть ряд атрибутов, общих для всех классов (например, для класса Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). Для отображения индивидуальных атрибутов, специфичных для конкретного класса из описания КЕ (CI-Definition), используется следующий синтаксис (например, для класса Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. Если нет атрибутов для конкретного класса, отображаются столбцы заданные параметром ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        'Задает перечень отображаемых столбцов отображаемых КЕ в таблице при создании связи, в зависимости от класса. Каждое имя атрибута должно иметь в качестве префикса - имя класса и два двоеточия (i.e. Computer::). Есть ряд атрибутов, общих для всех классов (например, для класса Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). Для отображения индивидуальных атрибутов, специфичных для конкретного класса из описания КЕ (CI-Definition), используется следующий синтаксис (например, для класса Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. Если нет атрибутов для конкретного класса, отображаются столбцы заданные параметром ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        'Включает/выключает проверку уникальности имен КЕ. До включения этого параметра, проверьте вашу БД на наличие дубликатов имен КЕ. Вы можете сделать это с помощью скрипта bin/otrs.ITSMConfigItemListDuplicates.pl.';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = 'Модуль для проверки группы ответственной за класс';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        'Модуль для проверки группы ответственной за КЕ';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = 'Модуль формирования статистики по КЕ.';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        'Параметры страниц (на которых отображаются КЕ)';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        'Требуемые права для использования обзора КЕ в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        'Требуемые права для использования поиска в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        'Требуемые права для использования полного просмотра КЕ (zoom view) в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        'Требуемые права для добавления КЕ в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        'Требуемые права для редактирования содержимого КЕ в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        'Требуемые права для просмотра истории содержимого КЕ в CMDB агентом';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        'Требуемые права для печати характеристик КЕ в CMDB агентом';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        'Выбор модуля генерации номера КЕ. "AutoIncrement" последовательно увеличивает номер на 1.Для формирования номера используются SystemID, ConfigItemClassID и счетчик. Формат - "SystemID.ConfigItemClassID.Counter", т.е. 1205000004, 1205000005.';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        'Показывает пункт меню Связать (Link) для организации связи КЕ с другим объектом на экране полного (zoom view) просмотра';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        'Показывает пункт меню История для просмотра истории КЕ';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        'Показывает пункт меню Дублировать для создания новой КЕ путем копирования характеристик текущей КЕ';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        'Показывает пункт меню Редактировать для изменения характеристик КЕ';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        'Показывает пункт меню Назад';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        'Показывает пункт меню Печать для печати характеристик КЕ';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        'Показ истории содержимого КЕ (порядок показа)';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        'Идентификатор (префикс) к номеру КЕ, т.е КЕ_№, КЕ#, Учетный_элемент_№. По умолчанию - ConfigItem# (или его перевод).';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/sv_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::sv_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = 'Adress';
    $Self->{Translation}->{'Admin Tool'} = 'Administrationsverktyg';
    $Self->{Translation}->{'Backup Device'} = 'Backupenhet';
    $Self->{Translation}->{'Beamer'} = 'Beamer';
    $Self->{Translation}->{'Building'} = 'Byggnad';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = 'Kamera';
    $Self->{Translation}->{'Capacity'} = 'Kapacitet';
    $Self->{Translation}->{'Change Definition'} = 'Ändra definition';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = 'Ändring av definition misslyckades! Se systemloggen för detaljer.';
    $Self->{Translation}->{'Client Application'} = 'Klientapplikation';
    $Self->{Translation}->{'Client OS'} = 'Klient-OS';
    $Self->{Translation}->{'Concurrent Users'} = 'Samtidiga användare';
    $Self->{Translation}->{'Config Item-Area'} = 'Konfigurationsenhet-område';
    $Self->{Translation}->{'Config Items available'} = 'Tillgängliga konfigurationsenheter';
    $Self->{Translation}->{'Config Items shown'} = 'Visa konfigurationsenheter';
    $Self->{Translation}->{'CMDB'} = 'Konfigurationsdatabas';
    $Self->{Translation}->{'Demo'} = 'Demo';
    $Self->{Translation}->{'Desktop'} = 'Desktop';
    $Self->{Translation}->{'Developer Licence'} = 'Utvecklarlicens';
    $Self->{Translation}->{'Docking Station'} = 'Dockningsstation';
    $Self->{Translation}->{'Duplicate'} = 'Duplicera';
    $Self->{Translation}->{'Embedded'} = 'Embedded';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = 'Tomma fält anger att tidigare värden ska användas.';
    $Self->{Translation}->{'Enterprise Licence'} = 'Enterpriselicens';
    $Self->{Translation}->{'Expiration Date'} = 'Löper ut datum';
    $Self->{Translation}->{'Expired'} = 'Löpt ut';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = 'Våning';
    $Self->{Translation}->{'Freeware'} = 'Freeware';
    $Self->{Translation}->{'GSM'} = 'GSM';
    $Self->{Translation}->{'Gateway'} = 'Gateway';
    $Self->{Translation}->{'Graphic Adapter'} = 'Grafikkort';
    $Self->{Translation}->{'Hard Disk'} = 'Hårddisk';
    $Self->{Translation}->{'Hard Disk::Capacity'} = 'Hårddisk::Kapacitet';
    $Self->{Translation}->{'Hide Versions'} = 'Dölj versioner';
    $Self->{Translation}->{'IP Address'} = 'IP-adress';
    $Self->{Translation}->{'IP over DHCP'} = 'IP över DHCP';
    $Self->{Translation}->{'IT Facility'} = 'IT-byggnad';
    $Self->{Translation}->{'Inactive'} = 'Inaktiv';
    $Self->{Translation}->{'Incident'} = 'Incident';
    $Self->{Translation}->{'Install Date'} = 'Installationsdatum';
    $Self->{Translation}->{'Keybord'} = 'Tangentbord';
    $Self->{Translation}->{'LAN'} = 'LAN';
    $Self->{Translation}->{'Laptop'} = 'Laptop';
    $Self->{Translation}->{'Last Change'} = 'Sist ändrat';
    $Self->{Translation}->{'Licence Key'} = 'Licensnyckel';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = 'Licensnyckel::Löper ut';
    $Self->{Translation}->{'Licence Key::Quantity'} = 'Licensnyckel::Antal';
    $Self->{Translation}->{'Licence Type'} = 'Licenstyper';
    $Self->{Translation}->{'Maintenance'} = 'Underhåll';
    $Self->{Translation}->{'Maximum number of one element'} = 'Max antal av ett element';
    $Self->{Translation}->{'Media'} = 'Media';
    $Self->{Translation}->{'Middleware'} = 'Middleware';
    $Self->{Translation}->{'Model'} = 'Modell';
    $Self->{Translation}->{'Modem'} = 'Modem';
    $Self->{Translation}->{'Monitor'} = 'Monitor';
    $Self->{Translation}->{'Mouse'} = 'Mus';
    $Self->{Translation}->{'Network Adapter'} = 'Nätverkskort';
    $Self->{Translation}->{'Network Adapter::IP Address'} = 'Nätverkskort::IP-adress';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = 'Nätverksadapter::IP över DHCP';
    $Self->{Translation}->{'Network Address'} = 'Nätverksadress';
    $Self->{Translation}->{'Network Address::Gateway'} = 'Nätverksadress::Gateway';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = 'Nätverksadress::Subnätmask';
    $Self->{Translation}->{'Open Source'} = 'Öppen källkod';
    $Self->{Translation}->{'Operating System'} = 'Operativsystem';
    $Self->{Translation}->{'Operational'} = 'Operationell';
    $Self->{Translation}->{'Other'} = 'Annan';
    $Self->{Translation}->{'Other Equipment'} = 'Annan utrustning';
    $Self->{Translation}->{'Outlet'} = 'Väggkontakt';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA-kort';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = 'Per nod';
    $Self->{Translation}->{'Per Processor'} = 'Per processor';
    $Self->{Translation}->{'Per Server'} = 'Per server';
    $Self->{Translation}->{'Per User'} = 'Per användare';
    $Self->{Translation}->{'Phone 1'} = 'Telefon 1';
    $Self->{Translation}->{'Phone 2'} = 'Telefon 2';
    $Self->{Translation}->{'Pilot'} = 'Pilot';
    $Self->{Translation}->{'Planned'} = 'Planlagd';
    $Self->{Translation}->{'Printer'} = 'Skrivare';
    $Self->{Translation}->{'Production'} = 'Produktion';
    $Self->{Translation}->{'Quantity'} = 'Mängd';
    $Self->{Translation}->{'Rack'} = 'Rack';
    $Self->{Translation}->{'Ram'} = 'RAM';
    $Self->{Translation}->{'Repair'} = 'Reperation';
    $Self->{Translation}->{'Retired'} = 'Pensionerad';
    $Self->{Translation}->{'Review'} = 'Översyn';
    $Self->{Translation}->{'Router'} = 'Router';
    $Self->{Translation}->{'Scanner'} = 'Scanner';
    $Self->{Translation}->{'Search Config Items'} = 'Sök konfigurationsenheter';
    $Self->{Translation}->{'Security Device'} = 'Säkerhetsutrustning';
    $Self->{Translation}->{'Serial Number'} = 'Serienummer';
    $Self->{Translation}->{'Server'} = 'Server';
    $Self->{Translation}->{'Server Application'} = 'Serverapplikation';
    $Self->{Translation}->{'Server OS'} = 'Server-OS';
    $Self->{Translation}->{'Show Versions'} = 'Visa versioner';
    $Self->{Translation}->{'Single Licence'} = 'Enstaka licens';
    $Self->{Translation}->{'Subnet Mask'} = 'Subnätmask';
    $Self->{Translation}->{'Switch'} = 'Switch';
    $Self->{Translation}->{'Telco'} = 'Telco';
    $Self->{Translation}->{'Test/QA'} = 'Test/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = 'Driftläge för konfigurationsenhet';
    $Self->{Translation}->{'The incident state of this config item'} = 'Incidentläge för konfigurationsenhet';
    $Self->{Translation}->{'Time Restricted'} = 'Tidsbegränsad';
    $Self->{Translation}->{'USB Device'} = 'USB-enhet';
    $Self->{Translation}->{'Unlimited'} = 'Obegränsad';
    $Self->{Translation}->{'User Tool'} = 'Användarverktyg';
    $Self->{Translation}->{'Volume Licence'} = 'Volymlicens';
    $Self->{Translation}->{'WLAN'} = 'WLAN';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN Accesspunkt';
    $Self->{Translation}->{'Warranty Expiration Date'} = 'Sista dag för garanti';
    $Self->{Translation}->{'Workplace'} = 'Arbetsplats';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = 'Hantering av konfigurationsenheter';
    $Self->{Translation}->{'Change class definition'} = 'Ändra klassdefinition';
    $Self->{Translation}->{'Config Item'} = 'Konfigurationsenhet';
    $Self->{Translation}->{'Class'} = 'Klass';
    $Self->{Translation}->{'Definition'} = 'Definition';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = 'Filtrera klasser';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = 'Välj en klass från listan för att skapa en ny konfigurationsenhet';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = 'Namnet på denna konfigurationsenhet';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        'Namnet används redan i konfigurationsenheter med förljande nummer: %s';
    $Self->{Translation}->{'Deployment State'} = 'Driftläge';
    $Self->{Translation}->{'Incident State'} = 'Incidentläge';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = 'Anpassa vy';
    $Self->{Translation}->{'Config Items per page'} = 'Konfigurationsenheter per sida';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = 'Driftlägestyper';
    $Self->{Translation}->{'Current Incident State'} = 'Nuvarande incidentläge';
    $Self->{Translation}->{'Current Incident State Type'} = 'Nuvarande typ av incidentläge';
    $Self->{Translation}->{'Last changed'} = 'Senast ändrad';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = 'Konfigurationsenhet';
    $Self->{Translation}->{'ConfigItem-Info'} = 'KE-information';
    $Self->{Translation}->{'Current Deployment State'} = 'Nuvarande driftläge';
    $Self->{Translation}->{'Last changed by'} = 'Senast ändrad av';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = 'Skapa ny mall';
    $Self->{Translation}->{'Run Search'} = 'Utför sökning';
    $Self->{Translation}->{'Also search in previous versions?'} = 'Sök även i tidigare versioner?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = 'Konfigurationsenhet';
    $Self->{Translation}->{'Configuration Item Information'} = 'Information om konfigurationsenhet';
    $Self->{Translation}->{'Show one version'} = 'Visa en version';
    $Self->{Translation}->{'Show all versions'} = 'Visa alla versioner';
    $Self->{Translation}->{'Version Incident State'} = 'Incidentläge för version';
    $Self->{Translation}->{'Version Number'} = 'Versionsnummer';
    $Self->{Translation}->{'Configuration Item Version Details'} = 'Versionsinformation för konfigurationsenhet';
    $Self->{Translation}->{'Property'} = 'Egenskap';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = 'Konfigurationsenheter';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = 'Begränsning konfigurationsenheter';
    $Self->{Translation}->{'Configuration Item limit per page'} = 'Max antal konfigurationsenheter per sida';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = 'Skapa och hantera definitioner för konfigurationsenheter';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        'Anger antal rader för KE-editorn i admingränssnittet.';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/zh_CN_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# Copyright (C) 2013 Michael Shi <micshi at 163.com>
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::zh_CN_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '地址';
    $Self->{Translation}->{'Admin Tool'} = '管理工具';
    $Self->{Translation}->{'Backup Device'} = '备份设备';
    $Self->{Translation}->{'Beamer'} = '投影仪';
    $Self->{Translation}->{'Building'} = '大厦';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = '照相机';
    $Self->{Translation}->{'Capacity'} = '容量';
    $Self->{Translation}->{'Change Definition'} = '修改定义';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = '修改定义失败!详细信息请参考系统日志.';
    $Self->{Translation}->{'Client Application'} = '客户端应用程序';
    $Self->{Translation}->{'Client OS'} = '客户操作系统';
    $Self->{Translation}->{'Concurrent Users'} = '并发用户数';
    $Self->{Translation}->{'Config Item-Area'} = '配置项区域';
    $Self->{Translation}->{'Config Items available'} = '有效的配置项';
    $Self->{Translation}->{'Config Items shown'} = '显示配置项';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = '演示';
    $Self->{Translation}->{'Desktop'} = '台式电脑';
    $Self->{Translation}->{'Developer Licence'} = '开发许可';
    $Self->{Translation}->{'Docking Station'} = '坞站';
    $Self->{Translation}->{'Duplicate'} = '复制';
    $Self->{Translation}->{'Embedded'} = '嵌入式';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '空字段表示当前值被保存';
    $Self->{Translation}->{'Enterprise Licence'} = '企业执照';
    $Self->{Translation}->{'Expiration Date'} = '过期日期';
    $Self->{Translation}->{'Expired'} = '到期';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '楼层';
    $Self->{Translation}->{'Freeware'} = '免费软件';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '网关';
    $Self->{Translation}->{'Graphic Adapter'} = '图形处理器';
    $Self->{Translation}->{'Hard Disk'} = '硬盘';
    $Self->{Translation}->{'Hard Disk::Capacity'} = '硬盘::容量';
    $Self->{Translation}->{'Hide Versions'} = '隐藏版本';
    $Self->{Translation}->{'IP Address'} = 'IP地址';
    $Self->{Translation}->{'IP over DHCP'} = '从DHCP获取IP';
    $Self->{Translation}->{'IT Facility'} = 'IT设施';
    $Self->{Translation}->{'Inactive'} = '非活动的';
    $Self->{Translation}->{'Incident'} = '故障';
    $Self->{Translation}->{'Install Date'} = '安装日期';
    $Self->{Translation}->{'Keybord'} = '键盘';
    $Self->{Translation}->{'LAN'} = '';
    $Self->{Translation}->{'Laptop'} = '笔记本';
    $Self->{Translation}->{'Last Change'} = '最后修改于';
    $Self->{Translation}->{'Licence Key'} = '许可密钥';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = '许可密钥::到期日期';
    $Self->{Translation}->{'Licence Key::Quantity'} = '许可密钥::数量';
    $Self->{Translation}->{'Licence Type'} = '许可类别';
    $Self->{Translation}->{'Maintenance'} = '维护';
    $Self->{Translation}->{'Maximum number of one element'} = '此元素的最大数量';
    $Self->{Translation}->{'Media'} = '介质';
    $Self->{Translation}->{'Middleware'} = '中间件';
    $Self->{Translation}->{'Model'} = '型号';
    $Self->{Translation}->{'Modem'} = '调解调器';
    $Self->{Translation}->{'Monitor'} = '显示器';
    $Self->{Translation}->{'Mouse'} = '鼠标';
    $Self->{Translation}->{'Network Adapter'} = '网卡';
    $Self->{Translation}->{'Network Adapter::IP Address'} = '网卡::IP地址';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = '网卡::从DHCP获取IP';
    $Self->{Translation}->{'Network Address'} = '网络地址';
    $Self->{Translation}->{'Network Address::Gateway'} = '网络地址::网关';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = '网络地址::子网掩码';
    $Self->{Translation}->{'Open Source'} = '开源';
    $Self->{Translation}->{'Operating System'} = '操作系统';
    $Self->{Translation}->{'Operational'} = '正常';
    $Self->{Translation}->{'Other'} = '其它';
    $Self->{Translation}->{'Other Equipment'} = '其它设备';
    $Self->{Translation}->{'Outlet'} = '插座';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA卡';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = '每个节点';
    $Self->{Translation}->{'Per Processor'} = '每个处理器';
    $Self->{Translation}->{'Per Server'} = '每个服务器';
    $Self->{Translation}->{'Per User'} = '每个用户';
    $Self->{Translation}->{'Phone 1'} = '电话1';
    $Self->{Translation}->{'Phone 2'} = '电话2';
    $Self->{Translation}->{'Pilot'} = '试验';
    $Self->{Translation}->{'Planned'} = '已计划';
    $Self->{Translation}->{'Printer'} = '打印机';
    $Self->{Translation}->{'Production'} = '生产';
    $Self->{Translation}->{'Quantity'} = '数量';
    $Self->{Translation}->{'Rack'} = '机架';
    $Self->{Translation}->{'Ram'} = '内存';
    $Self->{Translation}->{'Repair'} = '修复';
    $Self->{Translation}->{'Retired'} = '报废';
    $Self->{Translation}->{'Review'} = '复审';
    $Self->{Translation}->{'Room'} = '房间';
    $Self->{Translation}->{'Router'} = '路由器';
    $Self->{Translation}->{'Scanner'} = '扫描仪';
    $Self->{Translation}->{'Search Config Items'} = '搜索配置项';
    $Self->{Translation}->{'Security Device'} = '安全设备';
    $Self->{Translation}->{'Serial Number'} = '序列号';
    $Self->{Translation}->{'Server'} = '服务器';
    $Self->{Translation}->{'Server Application'} = '服务器应用程序';
    $Self->{Translation}->{'Server OS'} = '服务器操作系统';
    $Self->{Translation}->{'Show Versions'} = '显示版本';
    $Self->{Translation}->{'Single Licence'} = '单一许可';
    $Self->{Translation}->{'Subnet Mask'} = '子网掩码';
    $Self->{Translation}->{'Switch'} = '交换机';
    $Self->{Translation}->{'Telco'} = '电话公司';
    $Self->{Translation}->{'Test/QA'} = '测试/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = '配置项部署状态';
    $Self->{Translation}->{'The incident state of this config item'} = '配置项故障状态';
    $Self->{Translation}->{'Time Restricted'} = '时间限制';
    $Self->{Translation}->{'USB Device'} = 'USB 设备';
    $Self->{Translation}->{'Unlimited'} = '无限制的';
    $Self->{Translation}->{'User Tool'} = '用户工具';
    $Self->{Translation}->{'Volume Licence'} = '批量授权';
    $Self->{Translation}->{'WLAN'} = '无线网络';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN 无线访问点';
    $Self->{Translation}->{'Warranty Expiration Date'} = '保修过期日期';
    $Self->{Translation}->{'Workplace'} = '车间';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = '管理配置项';
    $Self->{Translation}->{'Change class definition'} = '修改类定义';
    $Self->{Translation}->{'Config Item'} = '配置项';
    $Self->{Translation}->{'Class'} = '类';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '过滤类';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '先从列表中选择类，然后创建新的配置项。';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = '为这个配置项命名';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = '部署状态';
    $Self->{Translation}->{'Incident State'} = '故障状态';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '上下文设置';
    $Self->{Translation}->{'Config Items per page'} = '每页配置项个数';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '部署状态类型';
    $Self->{Translation}->{'Current Incident State'} = '当前的故障状态';
    $Self->{Translation}->{'Current Incident State Type'} = '当前的故障状态类型';
    $Self->{Translation}->{'Last changed'} = '最后修改';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '配置项';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = '当前的部署状态';
    $Self->{Translation}->{'Last changed by'} = '最后修改于';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '创建模板';
    $Self->{Translation}->{'Run Search'} = '搜索';
    $Self->{Translation}->{'Also search in previous versions?'} = '同时搜索以前的版本?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '创建时间';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '配置项';
    $Self->{Translation}->{'Configuration Item Information'} = '配置项信息';
    $Self->{Translation}->{'Show one version'} = '显示一个版本';
    $Self->{Translation}->{'Show all versions'} = '显示所有版本';
    $Self->{Translation}->{'Version Incident State'} = '版本故障状态';
    $Self->{Translation}->{'Version Number'} = '版本号';
    $Self->{Translation}->{'Configuration Item Version Details'} = '配置项版本详情';
    $Self->{Translation}->{'Property'} = '属性';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '配置项';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '创建和管理配置项定义';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    # Missed Translation Items
    $Self->{Translation}->{'ITSM ConfigItem'} ='ITSM配置项',
    $Self->{Translation}->{'Computer'} ='计算机',
    $Self->{Translation}->{'Hardware'} ='硬件',
    $Self->{Translation}->{'Network'} ='网络',
    $Self->{Translation}->{'Software'} ='软件',
    $Self->{Translation}->{'ConfigItem#'} = '配置项#',
    $Self->{Translation}->{'Config Items'} = '配置项',
    $Self->{Translation}->{'ConfigItem Type'} = '配置项类型',
    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Language/zh_TW_ITSMConfigItem.pm - translation file
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# Copyright (C) 2013 Michael Shi <micshi at 163.com>
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Language::zh_TW_ITSMConfigItem;

use strict;
use warnings;

sub Data {
    my $Self = shift;

    # Template: AAAITSMConfigItem
    $Self->{Translation}->{'Address'} = '地址';
    $Self->{Translation}->{'Admin Tool'} = '管理工具';
    $Self->{Translation}->{'Backup Device'} = '備份設備';
    $Self->{Translation}->{'Beamer'} = '投影儀';
    $Self->{Translation}->{'Building'} = '大廈';
    $Self->{Translation}->{'CIHistory::ConfigItemCreate'} = '';
    $Self->{Translation}->{'CIHistory::ConfigItemDelete'} = '';
    $Self->{Translation}->{'CIHistory::DefinitionUpdate'} = '';
    $Self->{Translation}->{'CIHistory::DeploymentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::IncidentStateUpdate'} = '';
    $Self->{Translation}->{'CIHistory::LinkAdd'} = '';
    $Self->{Translation}->{'CIHistory::LinkDelete'} = '';
    $Self->{Translation}->{'CIHistory::NameUpdate'} = '';
    $Self->{Translation}->{'CIHistory::ValueUpdate'} = '';
    $Self->{Translation}->{'CIHistory::VersionCreate'} = '';
    $Self->{Translation}->{'CIHistory::VersionDelete'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentAdd'} = '';
    $Self->{Translation}->{'CIHistory::AttachmentDelete'} = '';
    $Self->{Translation}->{'CPU'} = 'CPU';
    $Self->{Translation}->{'Camera'} = '照相機';
    $Self->{Translation}->{'Capacity'} = '容量';
    $Self->{Translation}->{'Change Definition'} = '修改定義';
    $Self->{Translation}->{'Change of definition failed! See System Log for details.'} = '修改定義失敗!詳細信息請参考系统日誌.';
    $Self->{Translation}->{'Client Application'} = '客户端應用程序';
    $Self->{Translation}->{'Client OS'} = '客户操作系統';
    $Self->{Translation}->{'Concurrent Users'} = '並發用戶數';
    $Self->{Translation}->{'Config Item-Area'} = '配置項區域';
    $Self->{Translation}->{'Config Items available'} = '有效的配置項';
    $Self->{Translation}->{'Config Items shown'} = '顯示配置項';
    $Self->{Translation}->{'CMDB'} = '';
    $Self->{Translation}->{'Demo'} = '演示';
    $Self->{Translation}->{'Desktop'} = '桌上型電腦';
    $Self->{Translation}->{'Developer Licence'} = '開發許可';
    $Self->{Translation}->{'Docking Station'} = '塢站';
    $Self->{Translation}->{'Duplicate'} = '複製';
    $Self->{Translation}->{'Embedded'} = '嵌入式';
    $Self->{Translation}->{'Empty fields indicate that the current values are kept'} = '空字段表示當前值被保存';
    $Self->{Translation}->{'Enterprise Licence'} = '企業執照';
    $Self->{Translation}->{'Expiration Date'} = '失效日期';
    $Self->{Translation}->{'Expired'} = '到期';
    $Self->{Translation}->{'FQDN'} = 'FQDN';
    $Self->{Translation}->{'Floor'} = '樓層';
    $Self->{Translation}->{'Freeware'} = '免費軟件';
    $Self->{Translation}->{'GSM'} = '';
    $Self->{Translation}->{'Gateway'} = '網關';
    $Self->{Translation}->{'Graphic Adapter'} = '圖形處理器';
    $Self->{Translation}->{'Hard Disk'} = '硬盤';
    $Self->{Translation}->{'Hard Disk::Capacity'} = '硬盤::容量';
    $Self->{Translation}->{'Hide Versions'} = '隱藏版本';
    $Self->{Translation}->{'IP Address'} = 'IP地址';
    $Self->{Translation}->{'IP over DHCP'} = '從DHCP獲取IP';
    $Self->{Translation}->{'IT Facility'} = 'IT設施';
    $Self->{Translation}->{'Inactive'} = '非活動的';
    $Self->{Translation}->{'Incident'} = '故障';
    $Self->{Translation}->{'Install Date'} = '安装日期';
    $Self->{Translation}->{'Keybord'} = '鍵盤';
    $Self->{Translation}->{'LAN'} = '';
    $Self->{Translation}->{'Laptop'} = '筆記本';
    $Self->{Translation}->{'Last Change'} = '最後修改於';
    $Self->{Translation}->{'Licence Key'} = '許可密鑰';
    $Self->{Translation}->{'Licence Key::Expiration Date'} = '許可密鑰::失效日期';
    $Self->{Translation}->{'Licence Key::Quantity'} = '許可密鑰::數量';
    $Self->{Translation}->{'Licence Type'} = '許可類别';
    $Self->{Translation}->{'Maintenance'} = '維護';
    $Self->{Translation}->{'Maximum number of one element'} = '此元素的最大數量';
    $Self->{Translation}->{'Media'} = '介質';
    $Self->{Translation}->{'Middleware'} = '中間件';
    $Self->{Translation}->{'Model'} = '型號';
    $Self->{Translation}->{'Modem'} = '調解調器';
    $Self->{Translation}->{'Monitor'} = '顯示器';
    $Self->{Translation}->{'Mouse'} = '滑鼠';
    $Self->{Translation}->{'Network Adapter'} = '網絡卡';
    $Self->{Translation}->{'Network Adapter::IP Address'} = '網絡卡::IP地址';
    $Self->{Translation}->{'Network Adapter::IP over DHCP'} = '網絡卡::從DHCP獲取IP';
    $Self->{Translation}->{'Network Address'} = '網絡地址';
    $Self->{Translation}->{'Network Address::Gateway'} = '網絡地址::網關';
    $Self->{Translation}->{'Network Address::Subnet Mask'} = '網絡地址::子網掩碼';
    $Self->{Translation}->{'Open Source'} = '開源';
    $Self->{Translation}->{'Operating System'} = '操作系統';
    $Self->{Translation}->{'Operational'} = '正常';
    $Self->{Translation}->{'Other'} = '其它';
    $Self->{Translation}->{'Other Equipment'} = '其它設備';
    $Self->{Translation}->{'Outlet'} = '插座';
    $Self->{Translation}->{'PCMCIA Card'} = 'PCMCIA卡';
    $Self->{Translation}->{'PDA'} = 'PDA';
    $Self->{Translation}->{'Per Node'} = '每個節點';
    $Self->{Translation}->{'Per Processor'} = '每個處理器';
    $Self->{Translation}->{'Per Server'} = '每個服務器';
    $Self->{Translation}->{'Per User'} = '每個用戶';
    $Self->{Translation}->{'Phone 1'} = '電話1';
    $Self->{Translation}->{'Phone 2'} = '電話2';
    $Self->{Translation}->{'Pilot'} = '試驗';
    $Self->{Translation}->{'Planned'} = '已計劃';
    $Self->{Translation}->{'Printer'} = '打印機';
    $Self->{Translation}->{'Production'} = '生產';
    $Self->{Translation}->{'Quantity'} = '數量';
    $Self->{Translation}->{'Rack'} = '機架';
    $Self->{Translation}->{'Ram'} = '内存';
    $Self->{Translation}->{'Repair'} = '修復';
    $Self->{Translation}->{'Retired'} = '報廢';
    $Self->{Translation}->{'Review'} = '複審';
    $Self->{Translation}->{'Room'} = '房間';
    $Self->{Translation}->{'Router'} = '路由器';
    $Self->{Translation}->{'Scanner'} = '掃描儀';
    $Self->{Translation}->{'Search Config Items'} = '搜索配置項';
    $Self->{Translation}->{'Security Device'} = '安全設備';
    $Self->{Translation}->{'Serial Number'} = '序列號';
    $Self->{Translation}->{'Server'} = '服務器';
    $Self->{Translation}->{'Server Application'} = '服務器應用程序';
    $Self->{Translation}->{'Server OS'} = '服務器操作系統';
    $Self->{Translation}->{'Show Versions'} = '顯示版本';
    $Self->{Translation}->{'Single Licence'} = '單一許可';
    $Self->{Translation}->{'Subnet Mask'} = '子網掩碼';
    $Self->{Translation}->{'Switch'} = '交換機';
    $Self->{Translation}->{'Telco'} = '電話公司';
    $Self->{Translation}->{'Test/QA'} = '测試/QA';
    $Self->{Translation}->{'The deployment state of this config item'} = '配置項部署狀態';
    $Self->{Translation}->{'The incident state of this config item'} = '配置項故障狀態';
    $Self->{Translation}->{'Time Restricted'} = '時間限制';
    $Self->{Translation}->{'USB Device'} = 'USB 設備';
    $Self->{Translation}->{'Unlimited'} = '無限制的';
    $Self->{Translation}->{'User Tool'} = '用戶工具';
    $Self->{Translation}->{'Volume Licence'} = '批量授權';
    $Self->{Translation}->{'WLAN'} = '無綫網絡';
    $Self->{Translation}->{'WLAN Access Point'} = 'WLAN 無綫訪問點';
    $Self->{Translation}->{'Warranty Expiration Date'} = '保養失效日期';
    $Self->{Translation}->{'Workplace'} = '工作間';

    # Template: AdminITSMConfigItem
    $Self->{Translation}->{'Config Item Management'} = '管理配置項';
    $Self->{Translation}->{'Change class definition'} = '修改類定義';
    $Self->{Translation}->{'Config Item'} = '配置項';
    $Self->{Translation}->{'Class'} = '類';
    $Self->{Translation}->{'Definition'} = '';

    # Template: AgentITSMConfigItemAdd
    $Self->{Translation}->{'Filter for Classes'} = '過濾類';
    $Self->{Translation}->{'Select a Class from the list to create a new Config Item.'} = '先從列表中選擇類，然後創建新的配置項。';

    # Template: AgentITSMConfigItemEdit
    $Self->{Translation}->{'The name of this config item'} = '為這個配置項命名';
    $Self->{Translation}->{'Name is already in use by the ConfigItems with the following Number(s): %s'} =
        '';
    $Self->{Translation}->{'Deployment State'} = '部署狀態';
    $Self->{Translation}->{'Incident State'} = '故障狀態';

    # Template: AgentITSMConfigItemHistory

    # Template: AgentITSMConfigItemOverviewNavBar
    $Self->{Translation}->{'Context Settings'} = '上下文設置';
    $Self->{Translation}->{'Config Items per page'} = '每頁配置項個數';

    # Template: AgentITSMConfigItemOverviewSmall
    $Self->{Translation}->{'Deployment State Type'} = '部署狀態類型';
    $Self->{Translation}->{'Current Incident State'} = '當前的故障狀態';
    $Self->{Translation}->{'Current Incident State Type'} = '當前的故障狀態類型';
    $Self->{Translation}->{'Last changed'} = '最後修改';

    # Template: AgentITSMConfigItemPrint
    $Self->{Translation}->{'ConfigItem'} = '配置項';
    $Self->{Translation}->{'ConfigItem-Info'} = '';
    $Self->{Translation}->{'Current Deployment State'} = '當前的部署狀態';
    $Self->{Translation}->{'Last changed by'} = '最後修改於';

    # Template: AgentITSMConfigItemSearch
    $Self->{Translation}->{'Create New Template'} = '創建模板';
    $Self->{Translation}->{'Run Search'} = '搜索';
    $Self->{Translation}->{'Also search in previous versions?'} = '同時搜索以前的版本?';

    # Template: AgentITSMConfigItemSearchResultPrint
    $Self->{Translation}->{'CreateTime'} = '創建時間';

    # Template: AgentITSMConfigItemZoom
    $Self->{Translation}->{'Configuration Item'} = '配置項';
    $Self->{Translation}->{'Configuration Item Information'} = '配置項信息';
    $Self->{Translation}->{'Show one version'} = '顯示一個版本';
    $Self->{Translation}->{'Show all versions'} = '顯示所有版本';
    $Self->{Translation}->{'Version Incident State'} = '版本故障狀態';
    $Self->{Translation}->{'Version Number'} = '版本號碼';
    $Self->{Translation}->{'Configuration Item Version Details'} = '配置項版本詳情';
    $Self->{Translation}->{'Property'} = '屬性';

    # SysConfig
    $Self->{Translation}->{'Check for a unique name only within the same ConfigItem class (\'class\') or globally (\'global\'), which means every existing ConfigItem is taken into account when looking for duplicates.'} =
        '';
    $Self->{Translation}->{'Config Items'} = '配置項';
    $Self->{Translation}->{'Config item event module that enables logging to history in the agent interface.'} =
        '';
    $Self->{Translation}->{'Configuration Item Limit'} = '';
    $Self->{Translation}->{'Configuration Item limit per page'} = '';
    $Self->{Translation}->{'Configuration item search backend router of the agent interface.'} =
        '';
    $Self->{Translation}->{'Create and manage the definitions for Configuration Items.'} = '創建和管理配置項定義';
    $Self->{Translation}->{'Defines an overview module to show the small view of a configuration item list.'} =
        '';
    $Self->{Translation}->{'Defines regular expressions individually for each ConfigItem class to check the ConfigItem name and to show corresponding error messages.'} =
        '';
    $Self->{Translation}->{'Defines the default subobject of the class \'ITSMConfigItem\'.'} =
        '';
    $Self->{Translation}->{'Defines the number of rows for the CI definition editor in the admin interface.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItem screen.'} =
        '';
    $Self->{Translation}->{'Defines the search limit for the AgentITSMConfigItemSearch screen.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item overview. This option has no effect on the position of the column. Note: Class column is always available if filter \'All\' is selected'} =
        '';
    $Self->{Translation}->{'Defines the shown columns in the config item search. This option has no effect on the position of the column.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item overview depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the config item search depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that are common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown as defined in the setting ITSMConfigItem::Frontend::AgentITSMConfigItem###ShowColumns.'} =
        '';
    $Self->{Translation}->{'Defines the shown columns of CIs in the link table complex view, depending on the CI class. Each entry must be prefixed with the class name and double colons (i.e. Computer::). There are a few CI-Attributes that common to all CIs (example for the class Computer: Computer::Name, Computer::CurDeplState, Computer::CreateTime). To show individual CI-Attributes as defined in the CI-Definition, the following scheme must be used (example for the class Computer): Computer::HardDisk::1, Computer::HardDisk::1::Capacity::1, Computer::HardDisk::2, Computer::HardDisk::2::Capacity::1. If there is no entry for a CI class, then the default columns are shown.'} =
        '';
    $Self->{Translation}->{'Enables/disables the functionality to check ConfigItems for unique names. Before enabling this option you should check your system for already existing config items with duplicate names. You can do this with the script bin/otrs.ITSMConfigItemListDuplicates.pl.'} =
        '';
    $Self->{Translation}->{'Module to check the group responsible for a class.'} = '';
    $Self->{Translation}->{'Module to check the group responsible for a configuration item.'} =
        '';
    $Self->{Translation}->{'Module to generate ITSM config item statistics.'} = '';
    $Self->{Translation}->{'Object backend module registration for the import/export module.'} =
        '';
    $Self->{Translation}->{'Parameters for the deployment states in the preferences view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Parameters for the example permission groups of the general catalog attributes.'} =
        '';
    $Self->{Translation}->{'Parameters for the pages (in which the configuration items are shown).'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item search screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the ITSM configuration item zoom screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the add ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the edit ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the history ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Required permissions to use the print ITSM configuration item screen in the agent interface.'} =
        '';
    $Self->{Translation}->{'Selects the configuration item number generator module. "AutoIncrement" increments the configuration item number, the SystemID, the ConfigItemClassID and the counter are used. The format is "SystemID.ConfigItemClassID.Counter", e.g. 1205000004, 1205000005.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu that allows linking a configuration item with another object in the config item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to access the history of a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to duplicate a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to edit a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to go back in the configuraton item zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows a link in the menu to print a configuration item in the its zoom view of the agent interface.'} =
        '';
    $Self->{Translation}->{'Shows the config item history (reverse ordered) in the agent interface.'} =
        '';
    $Self->{Translation}->{'The identifier for a configuration item, e.g. ConfigItem#, MyConfigItem#. The default is ConfigItem#.'} =
        '';

    # Missed Translation Items
    $Self->{Translation}->{'ITSM ConfigItem'} ='ITSM配置項',
    $Self->{Translation}->{'Computer'} ='計算機',
    $Self->{Translation}->{'Hardware'} ='硬件',
    $Self->{Translation}->{'Network'} ='網絡',
    $Self->{Translation}->{'Software'} ='軟件',
    $Self->{Translation}->{'ConfigItem#'} = '配置項#',
    $Self->{Translation}->{'Config Items'} = '配置項',
    $Self->{Translation}->{'ConfigItem Type'} = '配置項類型',
    #
    # OBSOLETE ENTRIES FOR REFERENCE, DO NOT TRANSLATE!
    #

}

1;

# --
# Kernel/Modules/AdminITSMConfigItem.pm - admin frontend to manage config items
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AdminITSMConfigItem;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject ConfigObject LogObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );
    return $Self->{LayoutObject}->ErrorScreen() if !$ClassList;
    return $Self->{LayoutObject}->ErrorScreen() if ref $ClassList ne 'HASH';
    return $Self->{LayoutObject}->ErrorScreen() if !%{$ClassList};

    # ------------------------------------------------------------ #
    # definition list
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'DefinitionList' ) {

        # get class id
        my $ClassID = $Self->{ParamObject}->GetParam( Param => 'ClassID' );

        return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" ) if !$ClassID;

        # generate ClassOptionStrg
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'ClassID',
            PossibleNone => 1,
            Translation  => 0,
            SelectedID   => $ClassID,
        );

        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
            },
        );

        # output overview result
        $Self->{LayoutObject}->Block(
            Name => 'DefinitionList',
            Data => {
                Name => $ClassList->{$ClassID},
            },
        );

        # get definition list
        my $DefinitionList = $Self->{ConfigItemObject}->DefinitionList(
            ClassID => $ClassID,
        );

        for my $Definition ( reverse @{$DefinitionList} ) {

            # get user data
            my $FullName = $Self->{UserObject}->UserName(
                UserID => $Definition->{CreateBy},
            );

            # output definition
            $Self->{LayoutObject}->Block(
                Name => 'DefinitionListRow',
                Data => {
                    %{$Definition},
                    Class        => $ClassList->{$ClassID},
                    CreateByUser => $FullName,
                },
            );
        }

        # ActionOverview
        $Self->{LayoutObject}->Block(
            Name => 'ActionOverview',
        );

        # output header
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # generate output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminITSMConfigItem',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # definition view
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'DefinitionView' ) {

        # get definition id
        my $DefinitionID = $Self->{ParamObject}->GetParam( Param => 'DefinitionID' );

        return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" ) if !$DefinitionID;

        # get definition
        my $Definition = $Self->{ConfigItemObject}->DefinitionGet(
            DefinitionID => $DefinitionID,
        );
        $Definition->{DefinitionString} = $Self->{LayoutObject}->Ascii2Html(
            Text           => $Definition->{Definition},
            HTMLResultMode => 1,
        );

        # generate ClassOptionStrg
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'ClassID',
            PossibleNone => 1,
            Translation  => 0,
            SelectedID   => $Definition->{ClassID},
        );

        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
            },
        );

        # get user data
        my $UserName = $Self->{UserObject}->UserName(
            UserID => $Definition->{CreateBy},
        );

        # output overview result
        $Self->{LayoutObject}->Block(
            Name => 'DefinitionView',
            Data => {
                %{$Definition},
                CreateByUser => $UserName,
            },
        );

        # ActionOverview
        $Self->{LayoutObject}->Block(
            Name => 'ActionOverview',
        );

        # output header
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # generate output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminITSMConfigItem',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # definition change
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'DefinitionChange' ) {

        # get class id
        my $ClassID = $Self->{ParamObject}->GetParam( Param => 'ClassID' );

        return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" ) if !$ClassID;

        # get class list
        my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::Class',
        );

        # get definition
        my $Definition = $Self->{ConfigItemObject}->DefinitionGet(
            ClassID => $ClassID,
        );

        # generate ClassOptionStrg
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'ClassID',
            PossibleNone => 1,
            Translation  => 0,
            SelectedID   => $ClassID,
        );

        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
            },
        );

        # output overview result
        $Self->{LayoutObject}->Block(
            Name => 'DefinitionChange',
            Data => {
                %{$Definition},
                ClassID => $ClassID,
                Class   => $ClassList->{$ClassID},
                Rows    => $Self->{Config}->{EditorRows} || 30,
            },
        );

        # ActionOverview
        $Self->{LayoutObject}->Block(
            Name => 'ActionOverview',
        );

        # output header
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # generate output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminITSMConfigItem',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # definition save
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'DefinitionSave' ) {
        my %Definition;

        # get params
        for my $FormParam (qw(ClassID Definition)) {
            $Definition{$FormParam} = $Self->{ParamObject}->GetParam( Param => $FormParam ) || '';
        }
        for my $FormParam (qw(ClassID Definition)) {
            if ( !$Definition{$FormParam} ) {
                $Self->{LogObject}->Log( Priority => 'error', Message => "Need $FormParam!" );
                return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
            }
        }

        # add to database
        my $DefinitionID = $Self->{ConfigItemObject}->DefinitionAdd(
            %Definition,
            UserID => $Self->{UserID},
        );

        return $Self->{LayoutObject}->ErrorScreen() if !$DefinitionID;
        return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
    }

    # ------------------------------------------------------------ #
    # config item class overview
    # ------------------------------------------------------------ #
    else {

        # generate ClassOptionStrg
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'ClassID',
            PossibleNone => 1,
            Translation  => 0,
        );

        # output overview
        $Self->{LayoutObject}->Block(
            Name => 'Overview',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
            },
        );

        # output overview result
        $Self->{LayoutObject}->Block(
            Name => 'OverviewList',
        );

        for my $ClassID ( sort { $ClassList->{$a} cmp $ClassList->{$b} } keys %{$ClassList} ) {

            $Self->{LayoutObject}->Block(
                Name => 'OverviewListRow',
                Data => {
                    ClassID => $ClassID,
                    Name    => $ClassList->{$ClassID},
                },
            );
        }

        # output header
        my $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # generate output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AdminITSMConfigItem',
            Data         => \%Param,
        );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }
}

1;

# --
# Kernel/Modules/AgentITSMConfigItem.pm - the OTRS ITSM config item module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItem;

use strict;
use warnings;

use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;
use Kernel::System::VariableCheck qw(:all);

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    # get default parameters, try to get filter (ClassID) from session if not given as parameter
    $Self->{Filter}
        = $Self->{ParamObject}->GetParam( Param => 'Filter' )
        || $Self->{AgentITSMConfigItemClassFilter}
        || '';
    $Self->{View} = $Self->{ParamObject}->GetParam( Param => 'View' ) || '';

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get config data
    $Self->{SearchLimit} = $Self->{Config}->{SearchLimit} || 10000;

    # store last screen, used for backlinks
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreenView',
        Value     => $Self->{RequestedURL},
    );

    # store last screen overview
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreenOverview',
        Value     => $Self->{RequestedURL},
    );

    # store filter (ClassID) in session
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'AgentITSMConfigItemClassFilter',
        Value     => $Self->{Filter},
    );

    # get sorting parameters
    my $SortBy = $Self->{ParamObject}->GetParam( Param => 'SortBy' )
        || $Self->{Config}->{'SortBy::Default'}
        || 'Number';

    # get ordering parameters
    my $OrderBy = $Self->{ParamObject}->GetParam( Param => 'OrderBy' )
        || $Self->{Config}->{'Order::Default'}
        || 'Down';

    # set Sort and Order by as Arrays
    my @SortByArray  = ($SortBy);
    my @OrderByArray = ($OrderBy);

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # get possible deployment state list for config items to be shown
    my $StateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::ConfigItem::DeploymentState',
        Preferences => {
            Functionality => [ 'preproductive', 'productive' ],
        },
    );

    # set the deployment state IDs parameter for the search
    my $DeplStateIDs;
    for my $DeplStateKey ( sort keys %{$StateList} ) {
        push @{$DeplStateIDs}, $DeplStateKey;
    }

    # to store the default class
    my $ClassIDAuto = '';

    # to store the NavBar filters
    my %Filters;

    # define position of the filter in the frontend
    my $PrioCounter = 1000;

    # to store the total number of config items in all classes that the user has access
    my $TotalCount;

    # to store all the clases that the user has access, used in search for filter 'All'
    my $AccessClassList;

    CLASSID:
    for my $ClassID ( sort { ${$ClassList}{$a} cmp ${$ClassList}{$b} } keys %{$ClassList} ) {

        # show menu link only if user has access rights
        my $HasAccess = $Self->{ConfigItemObject}->Permission(
            Scope   => 'Class',
            ClassID => $ClassID,
            UserID  => $Self->{UserID},
            Type    => $Self->{Config}->{Permission},
        );

        next CLASSID if !$HasAccess;

        # insert this class to be passed as search parameter for filter 'All'
        push @{$AccessClassList}, $ClassID;

        # count all records of this class
        my $ClassCount = $Self->{ConfigItemObject}->ConfigItemCount(
            ClassID => $ClassID,
        );

        # add the config items number in this class to the total
        $TotalCount += $ClassCount;

        # increase the PrioCounter
        $PrioCounter++;

        # add filter with params for the search method
        $Filters{$ClassID} = {
            Name   => $ClassList->{$ClassID},
            Prio   => $PrioCounter,
            Count  => $ClassCount,
            Search => {
                ClassIDs         => [$ClassID],
                DeplStateIDs     => $DeplStateIDs,
                OrderBy          => \@SortByArray,
                OrderByDirection => \@OrderByArray,
                Limit            => $Self->{SearchLimit},
            },
        };

        # remember the first class id to show this in the overview
        # if no class id was given
        if ( !$ClassIDAuto ) {
            $ClassIDAuto = $ClassID;
        }
    }

    # if only one filter exists
    if ( scalar keys %Filters == 1 ) {

        # get the name of the only filter
        my ($FilterName) = keys %Filters;

        # activate this filter
        $Self->{Filter} = $FilterName;
    }
    else {

        # add default filter, which shows all items
        $Filters{All} = {
            Name   => 'All',
            Prio   => 1000,
            Count  => $TotalCount,
            Search => {
                ClassIDs         => $AccessClassList,
                DeplStateIDs     => $DeplStateIDs,
                OrderBy          => \@SortByArray,
                OrderByDirection => \@OrderByArray,
                Limit            => $Self->{SearchLimit},
            },
        };

        # if no filter was selected activate the filter for the default class
        if ( !$Self->{Filter} ) {
            $Self->{Filter} = $ClassIDAuto;
        }
    }

    # check if filter is valid
    if ( !$Filters{ $Self->{Filter} } ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'No access to Class is given!',
            Comment => 'Please contact the admin.',
        );
    }

    # investigate refresh
    my $Refresh = $Self->{UserRefreshTime} ? 60 * $Self->{UserRefreshTime} : undef;

    # output header
    my $Output = $Self->{LayoutObject}->Header(
        Title   => 'Overview',
        Refresh => $Refresh,
    );
    $Output .= $Self->{LayoutObject}->NavigationBar();
    $Self->{LayoutObject}->Print( Output => \$Output );
    $Output = '';

    # display all navbar filters
    my %NavBarFilter;
    for my $Filter ( sort keys %Filters ) {

        # display the navbar filter
        $NavBarFilter{ $Filters{$Filter}->{Prio} } = {
            Filter => $Filter,
            %{ $Filters{$Filter} },
        };
    }

    # search config items which match the selected filter
    my $ConfigItemIDs = $Self->{ConfigItemObject}->ConfigItemSearchExtended(
        %{ $Filters{ $Self->{Filter} }->{Search} },
    );

    # find out which columns should be shown
    my @ShowColumns;
    if ( $Self->{Config}->{ShowColumns} ) {

        # get all possible columns from config
        my %PossibleColumn = %{ $Self->{Config}->{ShowColumns} };

        # show column "Class" if filter 'All' is selected
        if ( $Self->{Filter} eq 'All' ) {
            $PossibleColumn{Class} = '1';
        }

        # get the column names that should be shown
        COLUMNNAME:
        for my $Name ( sort keys %PossibleColumn ) {
            next COLUMNNAME if !$PossibleColumn{$Name};
            push @ShowColumns, $Name;
        }
    }

    # get the configured columns and reorganize them by class name
    if (
        IsArrayRefWithData( $Self->{Config}->{ShowColumnsByClass} )
        && $Self->{Filter}
        && $Self->{Filter} ne 'All'
        )
    {

        my %ColumnByClass;
        NAME:
        for my $Name ( @{ $Self->{Config}->{ShowColumnsByClass} } ) {
            my ( $Class, $Column ) = split /::/, $Name, 2;

            next NAME if !$Column;

            push @{ $ColumnByClass{$Class} }, $Column;
        }

        # check if there is a specific column config for the selected class
        my $SelectedClass = $ClassList->{ $Self->{Filter} };
        if ( $ColumnByClass{$SelectedClass} ) {
            @ShowColumns = @{ $ColumnByClass{$SelectedClass} };
        }
    }

    # show the list
    my $LinkPage =
        'Filter=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Filter} )
        . ';View=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{View} )
        . ';SortBy=' . $Self->{LayoutObject}->Ascii2Html( Text => $SortBy )
        . ';OrderBy=' . $Self->{LayoutObject}->Ascii2Html( Text => $OrderBy )
        . ';';
    my $LinkSort =
        'Filter=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Filter} )
        . ';View=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{View} )
        . ';';
    my $LinkFilter =
        'SortBy=' . $Self->{LayoutObject}->Ascii2Html( Text => $SortBy )
        . ';OrderBy=' . $Self->{LayoutObject}->Ascii2Html( Text => $OrderBy )
        . ';View=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{View} )
        . ';';

    # show config item list
    $Output .= $Self->{LayoutObject}->ITSMConfigItemListShow(
        ConfigItemIDs => $ConfigItemIDs,
        Total         => scalar @{$ConfigItemIDs},

        View => $Self->{View},

        Filter     => $Self->{Filter},
        Filters    => \%NavBarFilter,
        FilterLink => $LinkFilter,

        TitleName => $Self->{LayoutObject}->{LanguageObject}->Get('Overview')
            . ': ' . $Self->{LayoutObject}->{LanguageObject}->Get('ITSM ConfigItem'),

        TitleValue => $Filters{ $Self->{Filter} }->{Name},

        Env      => $Self,
        LinkPage => $LinkPage,
        LinkSort => $LinkSort,

        ShowColumns => \@ShowColumns,
        SortBy      => $Self->{LayoutObject}->Ascii2Html( Text => $SortBy ),
        OrderBy     => $Self->{LayoutObject}->Ascii2Html( Text => $OrderBy ),
    );

    # add footer
    $Output .= $Self->{LayoutObject}->Footer();

    return $Output;
}

1;

IyAtLQojIEtlcm5lbC9Nb2R1bGVzL0FnZW50SVRTTUNvbmZpZ0l0ZW1BZGQucG0gLSB0aGUgT1RSUyBJVFNNIGNvbmZpZyBpdGVtIGFkZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TW9kdWxlczo6QWdlbnRJVFNNQ29uZmlnSXRlbUFkZDsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW07CnVzZSBLZXJuZWw6OlN5c3RlbTo6R2VuZXJhbENhdGFsb2c7CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHslUGFyYW19OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0IChxdyhQYXJhbU9iamVjdCBEQk9iamVjdCBMYXlvdXRPYmplY3QgTG9nT2JqZWN0IENvbmZpZ09iamVjdCkpIHsKICAgICAgICBpZiAoICEkU2VsZi0+eyRPYmplY3R9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xheW91dE9iamVjdH0tPkZhdGFsRXJyb3IoIE1lc3NhZ2UgPT4gIkdvdCBubyAkT2JqZWN0ISIgKTsKICAgICAgICB9CiAgICB9CiAgICAkU2VsZi0+e0dlbmVyYWxDYXRhbG9nT2JqZWN0fSA9IEtlcm5lbDo6U3lzdGVtOjpHZW5lcmFsQ2F0YWxvZy0+bmV3KCVQYXJhbSk7CiAgICAkU2VsZi0+e0NvbmZpZ0l0ZW1PYmplY3R9ICAgICA9IEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbS0+bmV3KCVQYXJhbSk7CgogICAgIyBnZXQgY29uZmlnIG9mIGZyb250ZW5kIG1vZHVsZQogICAgJFNlbGYtPntDb25maWd9ID0gJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoIklUU01Db25maWdJdGVtOjpGcm9udGVuZDo6JFNlbGYtPntBY3Rpb259Iik7CgogICAgcmV0dXJuICRTZWxmOwp9CgpzdWIgUnVuIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBnZXQgY2xhc3MgbGlzdAogICAgbXkgJENsYXNzTGlzdCA9ICRTZWxmLT57R2VuZXJhbENhdGFsb2dPYmplY3R9LT5JdGVtTGlzdCgKICAgICAgICBDbGFzcyA9PiAnSVRTTTo6Q29uZmlnSXRlbTo6Q2xhc3MnLAogICAgKTsKCiAgICAjIGNoZWNrIGZvciBhY2Nlc3MgcmlnaHRzCiAgICBmb3IgbXkgJENsYXNzSUQgKCBzb3J0IGtleXMgJXskQ2xhc3NMaXN0fSApIHsKICAgICAgICBteSAkSGFzQWNjZXNzID0gJFNlbGYtPntDb25maWdJdGVtT2JqZWN0fS0+UGVybWlzc2lvbigKICAgICAgICAgICAgVHlwZSAgICA9PiAkU2VsZi0+e0NvbmZpZ30tPntQZXJtaXNzaW9ufSwKICAgICAgICAgICAgU2NvcGUgICA9PiAnQ2xhc3MnLAogICAgICAgICAgICBDbGFzc0lEID0+ICRDbGFzc0lELAogICAgICAgICAgICBVc2VySUQgID0+ICRTZWxmLT57VXNlcklEfSwKICAgICAgICApOwoKICAgICAgICBkZWxldGUgJENsYXNzTGlzdC0+eyRDbGFzc0lEfSBpZiAhJEhhc0FjY2VzczsKICAgIH0KCiAgICAjIHNob3cgdGhlIGxpc3Qgb2YgQ0kgY2xhc3NlcyBzb3J0ZWQgYnkgbmFtZQogICAgZm9yIG15ICRJdGVtSUQgKCBzb3J0IHsgJHskQ2xhc3NMaXN0fXskYX0gY21wICR7JENsYXNzTGlzdH17JGJ9IH0ga2V5cyAleyRDbGFzc0xpc3R9ICkgewoKICAgICAgICAjIGdldCBpdGVtIGRhdGEKICAgICAgICBteSAkSXRlbURhdGEgPSAkU2VsZi0+e0dlbmVyYWxDYXRhbG9nT2JqZWN0fS0+SXRlbUdldCgKICAgICAgICAgICAgSXRlbUlEID0+ICRJdGVtSUQsCiAgICAgICAgKTsKCiAgICAgICAgIyBvdXRwdXQgb3ZlcnZpZXcgaXRlbSBsaXN0CiAgICAgICAgJFNlbGYtPntMYXlvdXRPYmplY3R9LT5CbG9jaygKICAgICAgICAgICAgTmFtZSA9PiAnT3ZlcnZpZXdJdGVtTGlzdCcsCiAgICAgICAgICAgIERhdGEgPT4gewogICAgICAgICAgICAgICAgQ2xhc3NJRCA9PiAkSXRlbUlELAogICAgICAgICAgICAgICAgTmFtZSAgICA9PiAkQ2xhc3NMaXN0LT57JEl0ZW1JRH0sCiAgICAgICAgICAgIH0sCiAgICAgICAgKTsKICAgIH0KCiAgICAjIG91dHB1dCBoZWFkZXIKICAgIG15ICRPdXRwdXQgPSAkU2VsZi0+e0xheW91dE9iamVjdH0tPkhlYWRlciggVGl0bGUgPT4gJ0FkZCcgKTsKICAgICRPdXRwdXQgLj0gJFNlbGYtPntMYXlvdXRPYmplY3R9LT5OYXZpZ2F0aW9uQmFyKCk7CgogICAgIyBvdXRwdXQgb3ZlcnZpZXcKICAgICRPdXRwdXQgLj0gJFNlbGYtPntMYXlvdXRPYmplY3R9LT5PdXRwdXQoCiAgICAgICAgVGVtcGxhdGVGaWxlID0+ICdBZ2VudElUU01Db25maWdJdGVtQWRkJywKICAgICAgICBEYXRhICAgICAgICAgPT4gewogICAgICAgICAgICAlUGFyYW0sCiAgICAgICAgfSwKICAgICk7CgogICAgIyBvdXRwdXQgZm9vdGVyCiAgICAkT3V0cHV0IC49ICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+Rm9vdGVyKCk7CgogICAgcmV0dXJuICRPdXRwdXQ7Cn0KCjE7Cg==
# --
# Kernel/Modules/AgentITSMConfigItemEdit.pm - the OTRS ITSM config item edit module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItemEdit;

use strict;
use warnings;

use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;
use Kernel::System::Web::UploadCache;
use Kernel::System::VariableCheck qw(:all);

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }

    # create additional objects
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%Param);
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);
    $Self->{UploadCacheObject}    = Kernel::System::Web::UploadCache->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    # get form id
    $Self->{FormID} = $Self->{ParamObject}->GetParam( Param => 'FormID' );

    # create form id
    if ( !$Self->{FormID} ) {
        $Self->{FormID} = $Self->{UploadCacheObject}->FormIDCreate();
    }

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get configitem id and class id
    my $ConfigItem = {};
    $ConfigItem->{ConfigItemID} = $Self->{ParamObject}->GetParam( Param => 'ConfigItemID' ) || 0;
    $ConfigItem->{ClassID}      = $Self->{ParamObject}->GetParam( Param => 'ClassID' )      || 0;
    my $DuplicateID = $Self->{ParamObject}->GetParam( Param => 'DuplicateID' ) || 0;

    my $HasAccess;

    # get needed data
    if ( $ConfigItem->{ConfigItemID} && $ConfigItem->{ConfigItemID} ne 'NEW' ) {

        # check access for config item
        $HasAccess = $Self->{ConfigItemObject}->Permission(
            Scope  => 'Item',
            ItemID => $ConfigItem->{ConfigItemID},
            UserID => $Self->{UserID},
            Type   => $Self->{Config}->{Permission},
        );

        # get config item
        $ConfigItem = $Self->{ConfigItemObject}->ConfigItemGet(
            ConfigItemID => $ConfigItem->{ConfigItemID},
        );
    }
    elsif ($DuplicateID) {

        # get config item to duplicate
        $ConfigItem = $Self->{ConfigItemObject}->ConfigItemGet(
            ConfigItemID => $DuplicateID,
        );

        # check access for config item
        $HasAccess = $Self->{ConfigItemObject}->Permission(
            Scope  => 'Item',
            ItemID => $ConfigItem->{ConfigItemID},
            UserID => $Self->{UserID},
            Type   => $Self->{Config}->{Permission},
        );

        # set config item id and number
        $ConfigItem->{ConfigItemID} = 'NEW';
        $ConfigItem->{Number}       = 'NEW';
    }
    elsif ( $ConfigItem->{ClassID} ) {

        # set config item id and number
        $ConfigItem->{ConfigItemID} = 'NEW';
        $ConfigItem->{Number}       = 'NEW';

        # check access for config item
        $HasAccess = $Self->{ConfigItemObject}->Permission(
            Scope   => 'Class',
            ClassID => $ConfigItem->{ClassID},
            UserID  => $Self->{UserID},
            Type    => $Self->{Config}->{Permission},
        );

        # get class list
        my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::Class',
        );
        $ConfigItem->{Class} = $ClassList->{ $ConfigItem->{ClassID} };
    }
    else {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'No ConfigItemID, DuplicateID or ClassID is given!',
            Comment => 'Please contact the admin.',
        );
    }

    # if user has no access rights show error page
    if ( !$HasAccess ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'No access is given!',
            Comment => 'Please contact the admin.',
        );
    }

    # get definition
    my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ConfigItem->{ClassID},
    );

    # abort, if no definition is defined
    if ( !$XMLDefinition->{DefinitionID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "No Definition was defined for class $ConfigItem->{Class}!",
            Comment => 'Please contact the admin.',
        );
    }

    # when there's no ClassID it means, an existing config item is edited as the ClassID is only
    # provided as GET param when creating a new config item
    if ( !$Self->{ParamObject}->GetParam( Param => 'ClassID' ) ) {

        # get all attachments meta data
        my @ExistingAttachments = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
            ConfigItemID => $ConfigItem->{ConfigItemID},
        );

        # copy all existing attachments to upload cache
        FILENAME:
        for my $Filename (@ExistingAttachments) {

            # get the existing attachment data
            my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
                ConfigItemID => $ConfigItem->{ConfigItemID},
                Filename     => $Filename,
                UserID       => $Self->{UserID},
            );

            # add attachment to the upload cache
            $Self->{UploadCacheObject}->FormIDAddFile(
                FormID      => $Self->{FormID},
                Filename    => $AttachmentData->{Filename},
                Content     => $AttachmentData->{Content},
                ContentType => $AttachmentData->{ContentType},
            );
        }
    }

    # get submit save
    my $SubmitSave = $Self->{ParamObject}->GetParam( Param => 'SubmitSave' );

    # get xml data
    my $Version = {};
    my $NameDuplicates;
    my $CINameRegexErrorMessage;
    if ( $Self->{Subaction} eq 'VersionSave' ) {

        # check if an attachment must be deleted
        ATTACHMENT:
        for my $Number ( 1 .. 32 ) {

            # check if the delete button was pressed for this attachment
            my $Delete = $Self->{ParamObject}->GetParam( Param => "AttachmentDelete$Number" );

            # check next attachment if it was not pressed
            next ATTACHMENT if !$Delete;

            # remove the attachment from the upload cache
            $Self->{UploadCacheObject}->FormIDRemoveFile(
                FormID => $Self->{FormID},
                FileID => $Number,
            );
        }

        # check if there was an attachment upload
        if ( $Self->{ParamObject}->GetParam( Param => 'AttachmentUpload' ) ) {

            # get the uploaded attachment
            my %UploadStuff = $Self->{ParamObject}->GetUploadAll(
                Param  => 'FileUpload',
                Source => 'string',
            );

            # add attachment to the upload cache
            $Self->{UploadCacheObject}->FormIDAddFile(
                FormID => $Self->{FormID},
                %UploadStuff,
            );
        }

        my $AllRequired = 1;

        # get general form data
        for my $FormParam (qw(Name DeplStateID InciStateID)) {
            $Version->{$FormParam} = $Self->{ParamObject}->GetParam( Param => $FormParam );
            if ( !$Version->{$FormParam} ) {
                $AllRequired = 0;
            }
        }

        # get xml form data
        $Version->{XMLData}->[1]->{Version}->[1] = $Self->_XMLFormGet(
            XMLDefinition => $XMLDefinition->{DefinitionRef},
            AllRequired   => \$AllRequired,
            ConfigItemID  => $ConfigItem->{ConfigItemID},
        );

        # check, whether the feature to check for a unique name is enabled
        if (
            IsStringWithData( $Version->{Name} )
            && $Self->{ConfigObject}->Get('UniqueCIName::EnableUniquenessCheck')
            )
        {

            if ( $Self->{ConfigObject}->{Debug} > 0 ) {
                $Self->{LogObject}->Log(
                    Priority => 'debug',
                    Message  => "Checking for duplicate names (ClassID: $ConfigItem->{ClassID}, "
                        . "Name: $Version->{Name}, ConfigItemID: $ConfigItem->{ConfigItemID})",
                );
            }

            $NameDuplicates = $Self->{ConfigItemObject}->UniqueNameCheck(
                ConfigItemID => $ConfigItem->{ConfigItemID},
                ClassID      => $ConfigItem->{ClassID},
                Name         => $Version->{Name},
            );

            # stop processing if the name is not unique
            if ( IsArrayRefWithData($NameDuplicates) ) {

                $AllRequired = 0;

                # build a string of all duplicate IDs
                my $NameDuplicatesString = join ', ', @{$NameDuplicates};

                $Self->{LogObject}->Log(
                    Priority => 'error',
                    Message =>
                        "The name $Version->{Name} is already in use by the ConfigItemID(s): "
                        . $NameDuplicatesString,
                );
            }
        }

        # get the config option for the name regex checks
        my $CINameRegexConfig = $Self->{ConfigObject}->Get("ITSMConfigItem::CINameRegex");

        # check if the CI name is given and should be checked with a regular expression
        if ( IsStringWithData( $Version->{Name} ) && $CINameRegexConfig ) {

            # get class list
            my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
                Class => 'ITSM::ConfigItem::Class',
            );

            # get the class name
            my $ClassName = $ClassList->{ $ConfigItem->{ClassID} } || '';

            # get the regex for this class
            my $CINameRegex = $CINameRegexConfig->{ $ClassName . '::' . 'CINameRegex' } || '';

            # if a regex is defined and the CI name does not match the regular expression
            if ( $CINameRegex && $Version->{Name} !~ m{ $CINameRegex }xms ) {

                $AllRequired = 0;

                # get the error message for this class
                $CINameRegexErrorMessage
                    = $CINameRegexConfig->{ $ClassName . '::' . 'CINameRegexErrorMessage' } || '';
            }
        }

        # save version to database
        if ( $SubmitSave && $AllRequired ) {

            if ( $ConfigItem->{ConfigItemID} eq 'NEW' ) {
                $ConfigItem->{ConfigItemID} = $Self->{ConfigItemObject}->ConfigItemAdd(
                    ClassID => $ConfigItem->{ClassID},
                    UserID  => $Self->{UserID},
                );
            }

            # get all attachments from upload cache
            my @Attachments = $Self->{UploadCacheObject}->FormIDGetAllFilesData(
                FormID => $Self->{FormID},
            );

            # build a lookup lookup hash of the new attachments
            my %NewAttachment;
            for my $Attachment (@Attachments) {

                # the key is the filename + filesize + content type
                my $Key = $Attachment->{Filename}
                    . $Attachment->{Filesize}
                    . $Attachment->{ContentType};

                # store all of the new attachment data
                $NewAttachment{$Key} = $Attachment;
            }

            # get all attachments meta data
            my @ExistingAttachments = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
                ConfigItemID => $ConfigItem->{ConfigItemID},
            );

            # check the existing attachments
            FILENAME:
            for my $Filename (@ExistingAttachments) {

                # get the existing attachment data
                my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
                    ConfigItemID => $ConfigItem->{ConfigItemID},
                    Filename     => $Filename,
                    UserID       => $Self->{UserID},
                );

                # the key is the filename + filesize + content type
                # (no content id, as existing attachments don't have it)
                my $Key = $AttachmentData->{Filename}
                    . $AttachmentData->{Filesize}
                    . $AttachmentData->{ContentType};

                # attachment is already existing, we can delete it from the new attachment hash
                if ( $NewAttachment{$Key} ) {
                    delete $NewAttachment{$Key};
                }

                # existing attachment is no longer in new attachments hash
                else {

                    # delete the existing attachment
                    my $DeleteSuccessful = $Self->{ConfigItemObject}->ConfigItemAttachmentDelete(
                        ConfigItemID => $ConfigItem->{ConfigItemID},
                        Filename     => $Filename,
                        UserID       => $Self->{UserID},
                    );

                    # check error
                    if ( !$DeleteSuccessful ) {
                        return $Self->{LayoutObject}->FatalError();
                    }
                }
            }

            # write the new attachments
            ATTACHMENT:
            for my $Attachment ( values %NewAttachment ) {

                # add attachment
                my $Success = $Self->{ConfigItemObject}->ConfigItemAttachmentAdd(
                    %{$Attachment},
                    ConfigItemID => $ConfigItem->{ConfigItemID},
                    UserID       => $Self->{UserID},
                );

                # check error
                if ( !$Success ) {
                    return $Self->{LayoutObject}->FatalError();
                }
            }

            # add version
            $Self->{ConfigItemObject}->VersionAdd(
                %{$Version},
                ConfigItemID => $ConfigItem->{ConfigItemID},
                DefinitionID => $XMLDefinition->{DefinitionID},
                UserID       => $Self->{UserID},
            );

            # redirect to zoom mask
            my $ScreenType = $Self->{ParamObject}->GetParam( Param => 'ScreenType' ) || 0;
            if ($ScreenType) {
                return $Self->{LayoutObject}->PopupClose(
                    URL =>
                        "Action=AgentITSMConfigItemZoom;ConfigItemID=$ConfigItem->{ConfigItemID}",
                );
            }
            else {
                return $Self->{LayoutObject}->Redirect(
                    OP => "Action=AgentITSMConfigItemZoom;ConfigItemID=$ConfigItem->{ConfigItemID}",
                );
            }
        }
    }
    elsif ($DuplicateID) {
        my $VersionID = $Self->{ParamObject}->GetParam( Param => 'VersionID' );
        if ($VersionID) {

            # get version data to duplicate config item
            $Version = $Self->{ConfigItemObject}->VersionGet(
                VersionID => $VersionID,
            );
        }
        else {

            # get last version data to duplicate config item
            $Version = $Self->{ConfigItemObject}->VersionGet(
                ConfigItemID => $DuplicateID,
            );
        }
    }
    elsif ( $ConfigItem->{ConfigItemID} ne 'NEW' ) {

        # get last version data
        $Version = $Self->{ConfigItemObject}->VersionGet(
            ConfigItemID => $ConfigItem->{ConfigItemID},
        );
    }

    my %XMLFormOutputParam;
    if ( $Version->{XMLData}->[1]->{Version}->[1] ) {
        $XMLFormOutputParam{XMLData} = $Version->{XMLData}->[1]->{Version}->[1];
    }

    # output deployment state invalid block
    my $RowNameInvalid = '';
    if ( !$Version->{Name} && $Self->{Subaction} eq 'VersionSave' && $SubmitSave ) {
        $RowNameInvalid = 'ServerError';
    }

    # check for name duplicates
    if ( IsArrayRefWithData($NameDuplicates) ) {
        $RowNameInvalid = 'ServerError';
    }

    # check for not matched name regex
    if ($CINameRegexErrorMessage) {
        $RowNameInvalid = 'ServerError';
    }

    # output name block
    $Self->{LayoutObject}->Block(
        Name => 'RowName',
        Data => {
            %{$Version},
            RowNameInvalid => $RowNameInvalid,
        },
    );

    if (
        IsStringWithData($RowNameInvalid)
        && !IsArrayRefWithData($NameDuplicates)
        && !$CINameRegexErrorMessage
        )
    {

        if ( $Self->{ConfigObject}->{Debug} > 0 ) {
            $Self->{LogObject}->Log(
                Priority => 'debug',
                Message  => "Rendering default error block",
            );
        }

        $Self->{LayoutObject}->Block(
            Name => 'RowNameErrorDefault',
        );
    }
    elsif ( IsArrayRefWithData($NameDuplicates) ) {

        # build array with CI-Numbers
        my @NameDuplicatesByCINumber;
        for my $ConfigItemID ( @{$NameDuplicates} ) {

            # lookup the CI number
            my $CINumber = $Self->{ConfigItemObject}->ConfigItemLookup(
                ConfigItemID => $ConfigItemID,
            );

            push @NameDuplicatesByCINumber, $CINumber;
        }

        my $DuplicateString = join ', ', @NameDuplicatesByCINumber;

        if ( $Self->{ConfigObject}->{Debug} > 0 ) {
            $Self->{LogObject}->Log(
                Priority => 'debug',
                Message =>
                    "Rendering block for duplicates (CI-Numbers: $DuplicateString) error message",
            );
        }

        $Self->{LayoutObject}->Block(
            Name => 'RowNameErrorDuplicates',
            Data => {
                Duplicates => $DuplicateString,
            },
        );
    }

    elsif ($CINameRegexErrorMessage) {

        $Self->{LayoutObject}->Block(
            Name => 'RowNameErrorRegEx',
            Data => {
                RegExErrorMessage => $CINameRegexErrorMessage,
            },
        );
    }

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    );

    # output deployment state invalid block
    my $RowDeplStateInvalid = '';
    if ( !$Version->{DeplStateID} && $Self->{Subaction} eq 'VersionSave' && $SubmitSave ) {
        $RowDeplStateInvalid = ' ServerError';
    }

    # generate DeplStateOptionStrg
    my $DeplStateOptionStrg = $Self->{LayoutObject}->BuildSelection(
        Data         => $DeplStateList,
        Name         => 'DeplStateID',
        PossibleNone => 1,
        Class        => 'Validate_Required' . $RowDeplStateInvalid,
        SelectedID   => $Version->{DeplStateID},
    );

    # output deployment state block
    $Self->{LayoutObject}->Block(
        Name => 'RowDeplState',
        Data => {
            DeplStateOptionStrg => $DeplStateOptionStrg,
        },
    );

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::Core::IncidentState',
        Preferences => {
            Functionality => [ 'operational', 'incident' ],
        },
    );

    # output deployment state invalid block
    my $RowInciStateInvalid = '';
    if ( !$Version->{InciStateID} && $Self->{Subaction} eq 'VersionSave' && $SubmitSave ) {
        $RowInciStateInvalid = ' ServerError';
    }

    # generate InciStateOptionStrg
    my $InciStateOptionStrg = $Self->{LayoutObject}->BuildSelection(
        Data         => $InciStateList,
        Name         => 'InciStateID',
        PossibleNone => 1,
        Class        => 'Validate_Required' . $RowInciStateInvalid,
        SelectedID   => $Version->{InciStateID},
    );

    # output incident state block
    $Self->{LayoutObject}->Block(
        Name => 'RowInciState',
        Data => {
            InciStateOptionStrg => $InciStateOptionStrg,
        },
    );

    # output xml form
    if ( $XMLDefinition->{Definition} ) {
        $Self->_XMLFormOutput(
            XMLDefinition => $XMLDefinition->{DefinitionRef},
            %XMLFormOutputParam,
        );
    }

    # show the attachment upload button
    $Self->{LayoutObject}->Block(
        Name => 'AttachmentUpload',
        Data => {%Param},
    );

    # get all attachments meta data
    my @Attachments = $Self->{UploadCacheObject}->FormIDGetAllFilesMeta(
        FormID => $Self->{FormID},
    );

    # show attachments
    ATTACHMENT:
    for my $Attachment (@Attachments) {
        $Self->{LayoutObject}->Block(
            Name => 'Attachment',
            Data => $Attachment,
        );
    }

    my $Output = '';
    if ( ( $ConfigItem->{ConfigItemID} && $ConfigItem->{ConfigItemID} ne 'NEW' ) || $DuplicateID ) {

        # output block
        $Self->{LayoutObject}->Block(
            Name => 'StartSmall',
            Data => {
                %Param,
                %{$ConfigItem},
            },
        );
        $Self->{LayoutObject}->Block( Name => 'EndSmall' );

        # output header
        $Output .= $Self->{LayoutObject}->Header(
            Title => 'Edit',
            Type  => 'Small',
        );

        # start template output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemEdit',
            Data         => {
                %Param,
                %{$ConfigItem},
                DuplicateID => $DuplicateID,
                FormID      => $Self->{FormID},
            },
        );
        $Output .= $Self->{LayoutObject}->Footer( Type => 'Small' );
    }
    else {

        # Necessary stuff for Add New
        # get class list
        my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::Class',
        );

        # check for access rights
        for my $ClassID ( sort keys %{$ClassList} ) {
            my $HasAccess = $Self->{ConfigItemObject}->Permission(
                Type    => $Self->{Config}->{Permission},
                Scope   => 'Class',
                ClassID => $ClassID,
                UserID  => $Self->{UserID},
            );

            delete $ClassList->{$ClassID} if !$HasAccess;
        }

        # generate ClassOptionStrg
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'ClassID',
            PossibleNone => 1,
            Translation  => 0,
            Class        => 'W100pc',
            SelectedID   => $ConfigItem->{ClassID},
        );

        # End Necessary stuff for Add New

        # output block
        $Self->{LayoutObject}->Block(
            Name => 'StartNormal',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
                %Param,
                %{$ConfigItem},
            },
        );

        $Self->{LayoutObject}->Block( Name => 'EndNormal' );

        # output header
        $Output .= $Self->{LayoutObject}->Header( Title => 'Edit' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # start template output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemEdit',
            Data         => {
                %Param,
                %{$ConfigItem},
                DuplicateID => $DuplicateID,
                FormID      => $Self->{FormID},
            },
        );
        $Output .= $Self->{LayoutObject}->Footer();
    }

    return $Output;
}

sub _XMLFormGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{AllRequired};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{AllRequired} ne 'SCALAR';
    return if !$Param{ConfigItemID};

    my $FormData = {};

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        my $CounterInsert = 1;

        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # create inputkey and addkey
            my $InputKey = $Item->{Key} . '::' . $Counter;
            my $AddKey   = $Item->{Key} . '::Add';
            if ( $Param{Prefix} ) {
                $InputKey = $Param{Prefix} . '::' . $InputKey;
                $AddKey   = $Param{Prefix} . '::' . $AddKey;
            }

            # get param
            my $FormValues = $Self->{LayoutObject}->ITSMConfigItemFormDataGet(
                Key          => $InputKey,
                Item         => $Item,
                ConfigItemID => $Param{ConfigItemID},
            );

            if ( defined $FormValues->{Value} ) {

                # check required value
                if ( $FormValues->{Invalid} ) {
                    ${ $Param{AllRequired} } = 0;
                }

                # check delete button
                next COUNTER if $Self->{ParamObject}->GetParam( Param => $InputKey . '::Delete' );

                # start recursion, if "Sub" was found
                if ( $Item->{Sub} ) {
                    my $SubFormData = $Self->_XMLFormGet(
                        XMLDefinition => $Item->{Sub},
                        Prefix        => $InputKey,
                        AllRequired   => $Param{AllRequired},
                        ConfigItemID  => $Param{ConfigItemID},
                    );
                    $FormData->{ $Item->{Key} }->[$CounterInsert] = $SubFormData;
                }
                $FormData->{ $Item->{Key} }->[$CounterInsert]->{Content} = $FormValues->{Value};
                $CounterInsert++;
            }
            else {

                # check add button
                if ( $Self->{ParamObject}->GetParam( Param => $AddKey ) ) {
                    if ( $Item->{Sub} ) {
                        $FormData->{ $Item->{Key} }->[$CounterInsert] = $Self->_XMLDefaultSet(
                            XMLDefinition => $Item->{Sub},
                        );
                    }
                    $FormData->{ $Item->{Key} }->[$CounterInsert]->{Content} = '';
                }
                last COUNTER;
            }
        }
    }

    return $FormData;
}

sub _XMLDefaultSet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    my $DefaultData = {};

    for my $Item ( @{ $Param{XMLDefinition} } ) {
        for my $Counter ( 1 .. $Item->{CountDefault} ) {

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                $DefaultData->{ $Item->{Key} }->[$Counter] = $Self->_XMLDefaultSet(
                    XMLDefinition => $Item->{Sub},
                );
            }

            $DefaultData->{ $Item->{Key} }->[$Counter]->{Content} = '';
        }
    }

    return $DefaultData;
}

sub _XMLFormOutput {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    $Param{Level}  ||= 0;
    $Param{Prefix} ||= '';

    # get submit save
    my $SubmitSave = $Self->{ParamObject}->GetParam( Param => 'SubmitSave' );

    # set data present mode
    my $DataPresentMode = 0;
    if ( $Param{XMLData} && ref $Param{XMLData} eq 'HASH' ) {
        $DataPresentMode = 1;
    }

    my $ItemCounter = 1;
    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # set loop
        my $Loop = $Item->{CountDefault};
        if ($DataPresentMode) {
            $Loop = 0;

            # search the last content
            COUNTER:
            for my $Counter ( 1 .. $Item->{CountMax} ) {
                last COUNTER if !defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content};
                $Loop = $Counter;
            }

            # set absolut minimum
            if ( $Loop < $Item->{CountMin} ) {
                $Loop = $Item->{CountMin};
            }
        }

        # set delete
        my $Delete = 0;
        if ( $Loop > $Item->{CountMin} ) {
            $Delete = 1;
        }

        # output content rows
        for my $Counter ( 1 .. $Loop ) {

            # output row block
            $Self->{LayoutObject}->Block( Name => 'XMLRow' );

            if ( !$Param{Level} ) {
                $Self->{LayoutObject}->Block( Name => 'XMLRowFieldsetStart' );
            }

            # create inputkey and addkey
            my $InputKey = $Item->{Key} . '::' . $Counter;
            if ( $Param{Prefix} ) {
                $InputKey = $Param{Prefix} . '::' . $InputKey;
            }

            # output blue required star
            my $XMLRowValueContentRequired = 0;
            my $LabelClass                 = '';
            if ( $Item->{Input}->{Required} ) {
                $XMLRowValueContentRequired = 1;
                $LabelClass                 = 'Mandatory';
            }

            # output red invalid star
            my $XMLRowValueContentInvalid = 0;
            if ( $Item->{Form}->{$InputKey}->{Invalid} && $SubmitSave ) {
                $XMLRowValueContentInvalid = 1;
            }

            my $ItemID = 'Item' . $ItemCounter++ . $Param{Prefix} . $Param{Level};

            if ( $Item->{Input}->{Type} eq 'Customer' ) {

                $Self->{LayoutObject}->Block(
                    Name => 'CustomerSearchInit',
                    Data => {
                        ItemID => $ItemID,
                    },
                );
            }

            # create input element
            my $InputString = $Self->{LayoutObject}->ITSMConfigItemInputCreate(
                Key      => $InputKey,
                Item     => $Item,
                Value    => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content},
                ItemId   => $ItemID,
                Required => $XMLRowValueContentRequired,
                Invalid  => $XMLRowValueContentInvalid,
            );

            # ID?
            my $LabelFor = $ItemID;
            if ( $Item->{Input}->{Type} eq 'Date' || $Item->{Input}->{Type} eq 'DateTime' ) {
                $LabelFor = '';
            }

            # id needed?
            if ($LabelFor) {
                $LabelFor = 'for="' . $LabelFor . '"';
            }

            # is this a sub field?
            my $Class = '';
            if ( $Param{Level} ) {
                $Class = 'SubElement';
            }

            # class needed?
            if ($LabelClass) {
                $LabelClass = 'class="' . "$Class  $LabelClass" . '"';
            }
            else {
                $LabelClass = 'class="' . $Class . '"';
            }

            # output row value content block
            $Self->{LayoutObject}->Block(
                Name => 'XMLRowValue',
                Data => {
                    Name        => $Item->{Name},
                    ItemID      => $ItemID,
                    LabelFor    => $LabelFor || '',
                    Description => $Item->{Description} || $Item->{Name},
                    InputString => $InputString,
                    LabelClass  => $LabelClass || '',
                    Class       => $Class || '',
                },
            );

            if ( $Item->{Input}->{Required} ) {
                $Self->{LayoutObject}->Block( Name => 'XMLRowValueContentRequired' );
            }

            # output delete button
            if ($Delete) {
                $Self->{LayoutObject}->Block(
                    Name => 'XMLRowValueContentDelete',
                    Data => {
                        InputKey => $InputKey,
                    },
                );
            }

            # the content is invalid
            if ($XMLRowValueContentInvalid) {

                # show regex error message block
                if ( $Item->{Form}->{$InputKey}->{RegExErrorMessage} ) {

                    $Self->{LayoutObject}->Block(
                        Name => 'XMLRowValueRegExError',
                        Data => {
                            ItemID            => $ItemID,
                            RegExErrorMessage => $Item->{Form}->{$InputKey}->{RegExErrorMessage},
                        },
                    );
                }

                # otherwise show normal server error block
                else {
                    $Self->{LayoutObject}->Block(
                        Name => 'XMLRowValueServerError',
                        Data => {
                            ItemID => $ItemID,
                        },
                    );
                }
            }

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                my %XMLFormOutputParam;
                if (
                    $DataPresentMode
                    && defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content}
                    )
                {
                    $XMLFormOutputParam{XMLData} = $Param{XMLData}->{ $Item->{Key} }->[$Counter];
                }

                $Self->_XMLFormOutput(
                    XMLDefinition => $Item->{Sub},
                    %XMLFormOutputParam,
                    Level  => $Param{Level} + 1,
                    Prefix => $InputKey,
                );
            }

            if ( !$Param{Level} ) {
                $Self->{LayoutObject}->Block( Name => 'XMLRowFieldsetEnd' );
            }

            # output row to sort rows correctly
            $Self->{LayoutObject}->Block( Name => 'XMLRow' );
        }

        # output add button
        if ( $Loop < $Item->{CountMax} ) {

            # if no item should be shown we need to show the add button
            # and therefore we need to show the XMLRow block
            if ( !$Loop ) {
                $Self->{LayoutObject}->Block( Name => 'XMLRow' );
            }

            my $Class = '';
            if ( $Param{Level} ) {
                $Class = 'class="SubElement"';
            }
            else {
                $Self->{LayoutObject}->Block( Name => 'XMLRowFieldsetEnd' );
                $Self->{LayoutObject}->Block( Name => 'XMLRowFieldsetStart' );
            }

            # set prefix
            my $InputKey = $Item->{Key};
            if ( $Param{Prefix} ) {
                $InputKey = $Param{Prefix} . '::' . $InputKey;
            }

            # output row add content block
            $Self->{LayoutObject}->Block(
                Name => 'XMLRowAddContent',
                Data => {
                    ItemID      => $InputKey . 'Add',
                    Name        => $Item->{Name},
                    Description => $Item->{Description} || $Item->{Name},
                    InputKey    => $InputKey,
                    Class       => $Class,
                },
            );
        }
    }

    return 1;
}

1;

# --
# Kernel/Modules/AgentITSMConfigItemHistory.pm - ticket history
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItemHistory;

use strict;
use warnings;

use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for (
        qw( DBObject LayoutObject LogObject UserObject ConfigObject
        ParamObject EncodeObject MainObject )
        )
    {
        if ( !$Self->{$_} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $_!" );
        }
    }

    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    $Self->{ConfigItemID} = $Self->{ParamObject}->GetParam( Param => 'ConfigItemID' );

    # check needed stuff
    if ( !$Self->{ConfigItemID} ) {

        # error page
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'Can\'t show history, no ConfigItemID is given!',
            Comment => 'Please contact the admin.',
        );
    }

    # check for access rights
    my $HasAccess = $Self->{ConfigItemObject}->Permission(
        Scope  => 'Item',
        ItemID => $Self->{ConfigItemID},
        UserID => $Self->{UserID},
        Type   => $Self->{Config}->{Permission},
    );

    if ( !$HasAccess ) {

        # error page
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'Can\'t show history, no access rights given!',
            Comment => 'Please contact the admin.',
        );
    }

    # get all information about the config item
    my $ConfigItem = $Self->{ConfigItemObject}->ConfigItemGet(
        ConfigItemID => $Self->{ConfigItemID},
    );
    my $ConfigItemName = $ConfigItem->{Number};

    # get all entries in the history for this config item
    my $Lines = $Self->{ConfigItemObject}->HistoryGet(
        ConfigItemID => $Self->{ConfigItemID},
    );

    # get shown user info
    my @NewLines = @{$Lines};
    if ( $Self->{ConfigObject}->Get('ITSMConfigItem::Frontend::HistoryOrder') eq 'reverse' ) {
        @NewLines = reverse @{$Lines};
    }

    # get definition for CI's class
    my $Definition = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ConfigItem->{ClassID},
    );

    my $Table   = '';
    my $Counter = 1;
    my $Version = 0;
    for my $DataTmp (@NewLines) {
        $Counter++;
        my %Data = (
            %{$DataTmp},
            VersionID => $Version,
        );

        # trim the comment to only show version number
        if ( $Data{HistoryType} eq 'VersionCreate' ) {
            $Data{Comment} =~ s/\D//g;
            $Data{VersionID} = $Data{Comment};
            $Version = $Data{Comment};
        }
        elsif ( $Data{HistoryType} eq 'ValueUpdate' ) {

            # beautify comment
            my @Parts = split /%%/, $Data{Comment};
            $Parts[0] =~ s{ \A \[.*?\] \{'Version'\} \[.*?\] \{' }{}xms;
            $Parts[0] =~ s{ '\} \[.*?\] \{' }{::}xmsg;
            $Parts[0] =~ s{ '\} \[.*?\] \z }{}xms;

            # get info about attribute
            my $AttributeInfo = $Self->_GetAttributeInfo(
                Definition => $Definition->{DefinitionRef},
                Path       => $Parts[0],
            );

            if ( $AttributeInfo && $AttributeInfo->{Input}->{Type} eq 'GeneralCatalog' ) {
                my $ItemList = $Self->{GeneralCatalogObject}->ItemList(
                    Class => $AttributeInfo->{Input}->{Class},
                );

                $Parts[1] = $ItemList->{ $Parts[1] } || '';
                $Parts[2] = $ItemList->{ $Parts[2] } || '';
            }

            # assemble parts
            $Data{Comment} = join '%%', @Parts;
        }
        elsif ( $Data{HistoryType} eq 'DeploymentStateUpdate' ) {

            # get deployment state list
            my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
                Class => 'ITSM::ConfigItem::DeploymentState',
            );

            # show names
            my @Parts = split /%%/, $Data{Comment};
            for my $Part (@Parts) {
                $Part = $DeplStateList->{$Part} || '';
            }

            # assemble parts
            $Data{Comment} = join '%%', @Parts;
        }
        elsif ( $Data{HistoryType} eq 'IncidentStateUpdate' ) {

            # get deployment state list
            my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
                Class => 'ITSM::Core::IncidentState',
            );

            # show names
            my @Parts = split /%%/, $Data{Comment};
            for my $Part (@Parts) {
                $Part = $DeplStateList->{$Part} || '';
            }

            # assemble parts
            $Data{Comment} = join '%%', @Parts;
        }

        # replace text
        if ( $Data{Comment} ) {
            my %Info = ();
            $Data{Comment} =~ s/^%%//g;
            my @Values = split( /%%/, $Data{Comment} );
            $Data{Comment} = '';
            for (@Values) {
                if ( $Data{Comment} ) {
                    $Data{Comment} .= "\", ";
                }
                $Data{Comment} .= "\"$_";
            }
            if ( !$Data{Comment} ) {
                $Data{Comment} = '" ';
            }
            $Data{Comment} = $Self->{LayoutObject}->{LanguageObject}->Get(
                'CIHistory::' . $Data{HistoryType} . '", ' . $Data{Comment}
            );

            # remove not needed place holder
            $Data{Comment} =~ s/\%s//g;
        }

        $Self->{LayoutObject}->Block(
            Name => 'Row',
            Data => {%Data},
        );
    }

    # build page
    my $Output = $Self->{LayoutObject}->Header( Value => $ConfigItemName, Type => 'Small' );
    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'AgentITSMConfigItemHistory',
        Data         => {
            Name         => $ConfigItemName,
            ConfigItemID => $Self->{ConfigItemID},
            VersionID    => $Self->{ParamObject}->GetParam( Param => 'VersionID' ),
        },
    );
    $Output .= $Self->{LayoutObject}->Footer( Type => 'Small' );

    return $Output;
}

sub _GetAttributeInfo {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Definition Path)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Subtree = $Param{Definition};
    my $Info;

    PART:
    for my $Part ( split /::/, $Param{Path} ) {
        my ($Found) = grep { $_->{Key} eq $Part } @{$Subtree};

        last PART if !$Found;

        $Subtree = $Found->{Sub};
        $Info    = $Found;
    }

    return $Info;
}

1;

# --
# Kernel/Modules/AgentITSMConfigItemPrint.pm - print layout for itsm config item agent interface
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItemPrint;

use strict;
use warnings;

use Kernel::System::ITSMConfigItem;
use Kernel::System::LinkObject;
use Kernel::System::PDF;
use Kernel::System::HTMLUtils;

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{ConfigItemObject} = Kernel::System::ITSMConfigItem->new(%Param);
    $Self->{LinkObject}       = Kernel::System::LinkObject->new(%Param);
    $Self->{PDFObject}        = Kernel::System::PDF->new(%Param);
    $Self->{HTMLUtilsObject}  = Kernel::System::HTMLUtils->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get params
    my $ConfigItemID = $Self->{ParamObject}->GetParam( Param => 'ConfigItemID' );
    my $VersionID    = $Self->{ParamObject}->GetParam( Param => 'VersionID' );

    # check needed stuff
    if ( !$ConfigItemID || !$VersionID ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'No ConfigItemID or VersionID is given!',
            Comment => 'Please contact the admin.',
        );
    }

    # check for access rights
    my $HasAccess = $Self->{ConfigItemObject}->Permission(
        Scope  => 'Item',
        ItemID => $ConfigItemID,
        UserID => $Self->{UserID},
        Type   => $Self->{Config}->{Permission},
    );

    if ( !$HasAccess ) {

        # error page
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'Can\'t show config item, no access rights given!',
            Comment => 'Please contact the admin.',
        );
    }

    # get config item
    my $ConfigItem = $Self->{ConfigItemObject}->ConfigItemGet(
        ConfigItemID => $ConfigItemID,
    );
    if ( !$ConfigItem->{ConfigItemID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "ConfigItemID $ConfigItemID not found in database!",
            Comment => 'Please contact the admin.',
        );
    }

    # get version
    my $Version = $Self->{ConfigItemObject}->VersionGet(
        VersionID => $VersionID,
    );
    if ( !$Version->{VersionID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "VersionID $VersionID not found in database!",
            Comment => 'Please contact the admin.',
        );
    }

    # get last version
    my $LastVersion = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $ConfigItemID,
    );
    $ConfigItem->{CurrentName} = $LastVersion->{Name};

    # get version list
    my $VersionList = $Self->{ConfigItemObject}->VersionList(
        ConfigItemID => $ConfigItemID,
    );

    my $VersionNumber = 1;
    LISTVERSIONID:
    for my $ListVersionID ( @{$VersionList} ) {

        last LISTVERSIONID if $VersionID eq $ListVersionID;
        $VersionNumber++;
    }

    # get create & change user data
    for my $Key (qw(Create Change)) {
        $ConfigItem->{ $Key . 'ByName' } = $Self->{UserObject}->UserName(
            UserID => $ConfigItem->{ $Key . 'By' },
        );
    }

    # get user data of version (create by)
    $Version->{CreateByName} = $Self->{UserObject}->UserName(
        UserID => $Version->{CreateBy},
    );

    # get linked objects
    my $LinkListWithData = $Self->{LinkObject}->LinkListWithData(
        Object => 'ITSMConfigItem',
        Key    => $ConfigItemID,
        State  => 'Valid',
        UserID => $Self->{UserID},
    );

    # get link type list
    my %LinkTypeList = $Self->{LinkObject}->TypeList(
        UserID => $Self->{UserID},
    );

    # get the link data
    my %LinkData;
    if ( $LinkListWithData && ref $LinkListWithData eq 'HASH' && %{$LinkListWithData} ) {
        %LinkData = $Self->{LayoutObject}->LinkObjectTableCreate(
            LinkListWithData => $LinkListWithData,
            ViewMode         => 'SimpleRaw',
        );
    }

    # get attachments
    my @Attachments = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
        ConfigItemID => $ConfigItemID,
    );

    # generate pdf output
    if ( $Self->{PDFObject} ) {

        my %Page;

        # get maximum number of pages
        $Page{MaxPages} = $Self->{ConfigObject}->Get('PDF::MaxPages');
        if ( !$Page{MaxPages} || $Page{MaxPages} < 1 || $Page{MaxPages} > 1000 ) {
            $Page{MaxPages} = 100;
        }

        $Page{MarginTop}    = 30;
        $Page{MarginRight}  = 40;
        $Page{MarginBottom} = 40;
        $Page{MarginLeft}   = 40;
        $Page{HeaderRight}  = $Self->{LayoutObject}->{LanguageObject}->Get('ConfigItem') . '#'
            . $ConfigItem->{Number};
        $Page{HeadlineLeft}  = $Version->{Name};
        $Page{HeadlineRight} = $Self->{LayoutObject}->{LanguageObject}->Get('printed by') . ' '
            . $Self->{UserFullname} . ' '
            . $Self->{LayoutObject}->Output( Template => '$Env{"Time"}' );
        $Page{FooterLeft} = '';
        $Page{PageText}   = $Self->{LayoutObject}->{LanguageObject}->Get('Page');
        $Page{PageCount}  = 1;

        # create new pdf document
        $Self->{PDFObject}->DocumentNew(
            Title  => $Self->{ConfigObject}->Get('Product') . ':' . $Version->{Name},
            Encode => $Self->{LayoutObject}->{UserCharset},
        );

        # create first pdf page
        $Self->{PDFObject}->PageNew(
            %Page,
            FooterRight => $Page{PageText} . ' ' . $Page{PageCount},
        );
        $Page{PageCount}++;

        # output general information
        $Self->_PDFOutputGeneralInfos(
            Page       => \%Page,
            ConfigItem => $ConfigItem,
        );

        # output linked objects
        if (%LinkData) {
            $Self->_PDFOutputLinkedObjects(
                PageData     => \%Page,
                LinkData     => \%LinkData,
                LinkTypeList => \%LinkTypeList,
            );
        }

        # output attachments
        if (@Attachments) {
            $Self->_PDFOutputAttachments(
                PageData       => \%Page,
                ConfigItemID   => $ConfigItemID,
                AttachmentData => \@Attachments,
            );
        }

        # output version infos
        $Self->_PDFOutputVersionInfos(
            Page          => \%Page,
            Version       => $Version,
            VersionNumber => $VersionNumber,
        );

        # create file name
        my $Filename = $Self->{MainObject}->FilenameCleanUp(
            Filename => $ConfigItem->{Number},
            Type     => 'Attachment',
        );
        my ( $s, $m, $h, $D, $M, $Y ) = $Self->{TimeObject}->SystemTime2Date(
            SystemTime => $Self->{TimeObject}->SystemTime(),
        );
        $M = sprintf( "%02d", $M );
        $D = sprintf( "%02d", $D );
        $h = sprintf( "%02d", $h );
        $m = sprintf( "%02d", $m );

        return $Self->{LayoutObject}->Attachment(
            Filename    => 'configitem_' . $Filename . "_$Y-$M-$D\_$h-$m.pdf",
            ContentType => 'application/pdf',
            Content     => $Self->{PDFObject}->DocumentOutput(),
            Type        => 'attachment',
        );
    }

    # generate html output
    else {

        # output header
        my $Output = $Self->{LayoutObject}->PrintHeader( Value => $Version->{Name} );

        if (%LinkData) {

            # output link data
            $Self->{LayoutObject}->Block(
                Name => 'Link',
            );

            for my $LinkTypeLinkDirection ( sort { lc $a cmp lc $b } keys %LinkData ) {

                # investigate link type name
                my @LinkData = split q{::}, $LinkTypeLinkDirection;

                # output link type data
                $Self->{LayoutObject}->Block(
                    Name => 'LinkType',
                    Data => {
                        LinkTypeName => $LinkTypeList{ $LinkData[0] }->{ $LinkData[1] . 'Name' },
                    },
                );

                # extract object list
                my $ObjectList = $LinkData{$LinkTypeLinkDirection};

                for my $Object ( sort { lc $a cmp lc $b } keys %{$ObjectList} ) {

                    for my $Item ( @{ $ObjectList->{$Object} } ) {

                        # output link type data
                        $Self->{LayoutObject}->Block(
                            Name => 'LinkTypeRow',
                            Data => {
                                LinkStrg => $Item->{Title},
                            },
                        );
                    }
                }
            }
        }

        # output version block
        $Self->{LayoutObject}->Block(
            Name => "Version",
            Data => {
                %{$Version},
                VersionNumber => $VersionNumber,
            },
        );

        # output xml structure
        if (
            $Version
            && ref $Version eq 'HASH'
            && $Version->{XMLDefinition}
            && $Version->{XMLData}
            && ref $Version->{XMLDefinition} eq 'ARRAY'
            && ref $Version->{XMLData}       eq 'ARRAY'
            && $Version->{XMLData}->[1]
            && ref $Version->{XMLData}->[1] eq 'HASH'
            && $Version->{XMLData}->[1]->{Version}
            && ref $Version->{XMLData}->[1]->{Version} eq 'ARRAY'
            )
        {
            $Self->_HTMLOutputXMLStructure(
                XMLDefinition => $Version->{XMLDefinition},
                XMLData       => $Version->{XMLData}->[1]->{Version}->[1],
            );
        }

        if (@Attachments) {

            # get the metadata of the 1st attachment
            my $FirstAttachment = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
                ConfigItemID => $ConfigItemID,
                Filename     => $Attachments[0],
            );

            $Self->{LayoutObject}->Block(
                Name => 'Attachments',
                Data => {
                    ConfigItemID => $ConfigItemID,
                    Filename     => $FirstAttachment->{Filename},
                    Filesize     => $FirstAttachment->{Filesize},
                },
            );

            # the 1st attachment was directly rendered into the 1st row's right cell, all further
            # attachments are rendered into a separate row
            ATTACHMENT:
            for my $Attachment (@Attachments) {

                # skip the 1st attachment
                next ATTACHMENT if $Attachment eq $Attachments[0];

                # get the metadata of the current attachment
                my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
                    ConfigItemID => $ConfigItemID,
                    Filename     => $Attachment,
                );

                $Self->{LayoutObject}->Block(
                    Name => 'AttachmentRow',
                    Data => {
                        ConfigItemID => $ConfigItemID,
                        Filename     => $AttachmentData->{Filename},
                        Filesize     => $AttachmentData->{Filesize},
                    },
                );
            }
        }

        # generate output
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemPrint',
            Data         => {
                %{$ConfigItem},
            },
        );

        # add footer
        $Output .= $Self->{LayoutObject}->PrintFooter();

        # return output
        return $Output;
    }
}

sub _PDFOutputGeneralInfos {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Page ConfigItem)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # create left table
    my $TableLeft = [
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Class') . ':',
            Value => $Param{ConfigItem}->{Class},
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('ConfigItem') . ':',
            Value => $Param{ConfigItem}->{CurrentName},
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Current Deployment State') . ':',
            Value => $Self->{LayoutObject}->{LanguageObject}->Get(
                $Param{ConfigItem}->{CurDeplState},
            ),
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Current Incident State') . ':',
            Value => $Self->{LayoutObject}->{LanguageObject}->Get(
                $Param{ConfigItem}->{CurInciState},
            ),
        },
    ];

    # create right table
    my $TableRight = [
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Created') . ':',
            Value => $Self->{LayoutObject}->Output(
                Template => '$TimeLong{"$Data{"CreateTime"}"}',
                Data     => \%{ $Param{ConfigItem} },
            ),
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Created by') . ':',
            Value => $Param{ConfigItem}->{CreateByName},
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Last changed') . ':',
            Value => $Self->{LayoutObject}->Output(
                Template => '$TimeLong{"$Data{"ChangeTime"}"}',
                Data     => \%{ $Param{ConfigItem} },
            ),
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Last changed by') . ':',
            Value => $Param{ConfigItem}->{ChangeByName},
        },
    ];

    my $Rows = @{$TableLeft};
    if ( @{$TableRight} > $Rows ) {
        $Rows = @{$TableRight};
    }

    my %TableParam;
    for my $Row ( 1 .. $Rows ) {
        $Row--;
        $TableParam{CellData}[$Row][0]{Content}         = $TableLeft->[$Row]->{Key};
        $TableParam{CellData}[$Row][0]{Font}            = 'ProportionalBold';
        $TableParam{CellData}[$Row][1]{Content}         = $TableLeft->[$Row]->{Value};
        $TableParam{CellData}[$Row][2]{Content}         = ' ';
        $TableParam{CellData}[$Row][2]{BackgroundColor} = '#FFFFFF';
        $TableParam{CellData}[$Row][3]{Content}         = $TableRight->[$Row]->{Key};
        $TableParam{CellData}[$Row][3]{Font}            = 'ProportionalBold';
        $TableParam{CellData}[$Row][4]{Content}         = $TableRight->[$Row]->{Value};
    }

    $TableParam{ColumnData}[0]{Width} = 80;
    $TableParam{ColumnData}[1]{Width} = 170.5;
    $TableParam{ColumnData}[2]{Width} = 4;
    $TableParam{ColumnData}[3]{Width} = 80;
    $TableParam{ColumnData}[4]{Width} = 170.5;
    $TableParam{Type}                 = 'Cut';
    $TableParam{Border}               = 0;
    $TableParam{FontSize}             = 6;
    $TableParam{BackgroundColorEven}  = '#AAAAAA';
    $TableParam{BackgroundColorOdd}   = '#DDDDDD';
    $TableParam{Padding}              = 1;
    $TableParam{PaddingTop}           = 3;
    $TableParam{PaddingBottom}        = 3;

    # output table
    PAGE:
    for ( $Param{Page}->{PageCount} .. $Param{Page}->{MaxPages} ) {

        # output table (or a fragment of it)
        %TableParam = $Self->{PDFObject}->Table(%TableParam);

        # stop output or output next page
        last PAGE if $TableParam{State};

        $Self->{PDFObject}->PageNew(
            %{ $Param{Page} },
            FooterRight => $Param{Page}->{PageText} . ' ' . $Param{Page}->{PageCount},
        );
        $Param{Page}->{PageCount}++;
    }

    return 1;
}

sub _PDFOutputLinkedObjects {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for (qw(PageData LinkData LinkTypeList)) {
        if ( !defined( $Param{$_} ) ) {
            $Self->{LogObject}->Log( Priority => 'error', Message => "Need $_!" );
            return;
        }
    }

    my %Page     = %{ $Param{PageData} };
    my %TypeList = %{ $Param{LinkTypeList} };
    my %TableParam;
    my $Row = 0;

    for my $LinkTypeLinkDirection ( sort { lc $a cmp lc $b } keys %{ $Param{LinkData} } ) {

        # investigate link type name
        my @LinkData = split q{::}, $LinkTypeLinkDirection;
        my $LinkTypeName = $TypeList{ $LinkData[0] }->{ $LinkData[1] . 'Name' };
        $LinkTypeName = $Self->{LayoutObject}->{LanguageObject}->Get($LinkTypeName);

        # define headline
        $TableParam{CellData}[$Row][0]{Content} = $LinkTypeName . ':';
        $TableParam{CellData}[$Row][0]{Font}    = 'ProportionalBold';
        $TableParam{CellData}[$Row][1]{Content} = '';

        # extract object list
        my $ObjectList = $Param{LinkData}->{$LinkTypeLinkDirection};

        for my $Object ( sort { lc $a cmp lc $b } keys %{$ObjectList} ) {

            for my $Item ( @{ $ObjectList->{$Object} } ) {

                $TableParam{CellData}[$Row][0]{Content} ||= '';
                $TableParam{CellData}[$Row][1]{Content} = $Item->{Title} || '';
            }
            continue {
                $Row++;
            }
        }
    }

    $TableParam{ColumnData}[0]{Width} = 80;
    $TableParam{ColumnData}[1]{Width} = 431;

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -15,
    );

    # output headline
    $Self->{PDFObject}->Text(
        Text     => $Self->{LayoutObject}->{LanguageObject}->Get('Linked Objects'),
        Height   => 7,
        Type     => 'Cut',
        Font     => 'ProportionalBoldItalic',
        FontSize => 7,
        Color    => '#666666',
    );

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -4,
    );

    # table params
    $TableParam{Type}            = 'Cut';
    $TableParam{Border}          = 0;
    $TableParam{FontSize}        = 6;
    $TableParam{BackgroundColor} = '#DDDDDD';
    $TableParam{Padding}         = 1;
    $TableParam{PaddingTop}      = 3;
    $TableParam{PaddingBottom}   = 3;

    # output table
    for ( $Page{PageCount} .. $Page{MaxPages} ) {

        # output table (or a fragment of it)
        %TableParam = $Self->{PDFObject}->Table( %TableParam, );

        # stop output or output next page
        if ( $TableParam{State} ) {
            last;
        }
        else {
            $Self->{PDFObject}->PageNew(
                %Page, FooterRight => $Page{PageText} . ' ' . $Page{PageCount},
            );
            $Page{PageCount}++;
        }
    }

    return 1;
}

sub _PDFOutputAttachments {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for (qw(PageData ConfigItemID AttachmentData)) {
        if ( !defined( $Param{$_} ) ) {
            $Self->{LogObject}->Log( Priority => 'error', Message => "Need $_!" );
            return;
        }
    }

    my %Page = %{ $Param{PageData} };
    my %TableParam;
    my $Row = 0;

    # attachments are rendered into a separate row
    ATTACHMENT:
    for my $Attachment ( @{ $Param{AttachmentData} } ) {

        # get the metadata of the current attachment
        my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
            ConfigItemID => $Param{ConfigItemID},
            Filename     => $Attachment,
        );

        # define attachment line
        $TableParam{CellData}[$Row][0]{Content}
            = $AttachmentData->{Filename} . '  (' . $AttachmentData->{Filesize} . ')';

        $Row++;
    }

    $TableParam{ColumnData}[0]{Width} = 80;
    $TableParam{ColumnData}[1]{Width} = 431;

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -15,
    );

    # output headline
    $Self->{PDFObject}->Text(
        Text     => $Self->{LayoutObject}->{LanguageObject}->Get('Attachments'),
        Height   => 7,
        Type     => 'Cut',
        Font     => 'ProportionalBoldItalic',
        FontSize => 7,
        Color    => '#666666',
    );

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -4,
    );

    # table params
    $TableParam{Type}            = 'Cut';
    $TableParam{Border}          = 0;
    $TableParam{FontSize}        = 6;
    $TableParam{BackgroundColor} = '#DDDDDD';
    $TableParam{Padding}         = 1;
    $TableParam{PaddingTop}      = 3;
    $TableParam{PaddingBottom}   = 3;

    # output table
    for ( $Page{PageCount} .. $Page{MaxPages} ) {

        # output table (or a fragment of it)
        %TableParam = $Self->{PDFObject}->Table( %TableParam, );

        # stop output or output next page
        if ( $TableParam{State} ) {
            last;
        }
        else {
            $Self->{PDFObject}->PageNew(
                %Page, FooterRight => $Page{PageText} . ' ' . $Page{PageCount},
            );
            $Page{PageCount}++;
        }
    }

    return 1;
}

sub _PDFOutputVersionInfos {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Page Version VersionNumber)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -15,
    );

    # output headline
    $Self->{PDFObject}->Text(
        Text => $Self->{LayoutObject}->{LanguageObject}->Get('Version') . ' '
            . $Param{VersionNumber},
        Height   => 7,
        Type     => 'Cut',
        Font     => 'ProportionalBoldItalic',
        FontSize => 7,
        Color    => '#666666',
    );

    # set new position
    $Self->{PDFObject}->PositionSet(
        Move => 'relativ',
        Y    => -4,
    );

    # create table
    my $Table = [
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Created') . ':',
            Value => $Self->{LayoutObject}->Output(
                Template => '$TimeLong{"$Data{"CreateTime"}"}',
                Data     => \%{ $Param{Version} },
            ),
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Created by') . ':',
            Value => $Param{Version}->{CreateByName},
        },
        {
            Key   => ' ',
            Value => ' ',
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Name') . ':',
            Value => $Param{Version}->{Name},
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Deployment State') . ':',
            Value => $Self->{LayoutObject}->{LanguageObject}->Get( $Param{Version}->{DeplState} ),
        },
        {
            Key   => $Self->{LayoutObject}->{LanguageObject}->Get('Incident State') . ':',
            Value => $Self->{LayoutObject}->{LanguageObject}->Get( $Param{Version}->{InciState} ),
        },
    ];

    # add xml data to table
    if (
        ref $Param{Version} eq 'HASH'
        && $Param{Version}->{XMLDefinition}
        && $Param{Version}->{XMLData}
        && ref $Param{Version}->{XMLDefinition} eq 'ARRAY'
        && ref $Param{Version}->{XMLData}       eq 'ARRAY'
        && $Param{Version}->{XMLData}->[1]
        && ref $Param{Version}->{XMLData}->[1] eq 'HASH'
        && $Param{Version}->{XMLData}->[1]->{Version}
        && ref $Param{Version}->{XMLData}->[1]->{Version} eq 'ARRAY'
        )
    {
        $Self->_PDFOutputXMLOutput(
            XMLDefinition => $Param{Version}->{XMLDefinition},
            XMLData       => $Param{Version}->{XMLData}->[1]->{Version}->[1],
            TableData     => $Table,
        );
    }

    my %TableParam;
    my $Rows = @{$Table};

    for my $Row ( 1 .. $Rows ) {
        $Row--;
        $TableParam{CellData}[$Row][0]{Content} = $Table->[$Row]->{Key};
        $TableParam{CellData}[$Row][0]{Font}    = 'ProportionalBold';
        $TableParam{CellData}[$Row][1]{Content} = $Table->[$Row]->{Value};
    }

    $TableParam{ColumnData}[0]{Width} = 100;
    $TableParam{ColumnData}[1]{Width} = 411;
    $TableParam{Type}                 = 'Cut';
    $TableParam{Border}               = 0;
    $TableParam{FontSize}             = 6;
    $TableParam{BackgroundColor}      = '#DDDDDD';
    $TableParam{Padding}              = 1;
    $TableParam{PaddingTop}           = 3;
    $TableParam{PaddingBottom}        = 3;

    # output table
    PAGE:
    for ( $Param{Page}->{PageCount} .. $Param{Page}->{MaxPages} ) {

        # output table (or a fragment of it)
        %TableParam = $Self->{PDFObject}->Table(%TableParam);

        # stop output or output next page
        last PAGE if $TableParam{State};

        $Self->{PDFObject}->PageNew(
            %{ $Param{Page} },
            FooterRight => $Param{Page}->{PageText} . ' ' . $Param{Page}->{PageCount},
        );
        $Param{Page}->{PageCount}++;
    }

    return 1;
}

sub _PDFOutputXMLOutput {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{TableData};
    return if !$Param{XMLData};
    return if !$Param{XMLDefinition};
    return if ref $Param{TableData} ne 'ARRAY';
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    $Param{Level} ||= 0;

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # stop loop, if no content was given
            last COUNTER if !defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content};

            # lookup value
            my $Value = $Self->{ConfigItemObject}->XMLValueLookup(
                Item  => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content},
            );

            # create output string
            $Value = $Self->{LayoutObject}->ITSMConfigItemOutputStringCreate(
                Value => $Value,
                Item  => $Item,
                Print => 1,
            );

            # replace newlines with <br/> (fix for bug# 5928)
            $Value =~ s{ \n }{<br/>}gxms;

            # convert value to ascii
            $Value = $Self->{HTMLUtilsObject}->ToAscii( String => $Value );

            # new row
            my $NewRow = {
                Key   => $Self->{LayoutObject}->{LanguageObject}->Get( $Item->{Name} ) . ':',
                Value => $Value,
            };

            # output space, if level was given
            if ( $Param{Level} ) {
                for ( 1 .. $Param{Level} ) {
                    $NewRow->{Key}   = '    ' . $NewRow->{Key};
                    $NewRow->{Value} = '    ' . $NewRow->{Value};
                }
            }

            # add row data
            push @{ $Param{TableData} }, $NewRow;

            next COUNTER if !$Item->{Sub};

            # start recursion, if "Sub" was found
            $Self->_PDFOutputXMLOutput(
                XMLDefinition => $Item->{Sub},
                XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                TableData     => $Param{TableData},
                Level         => $Param{Level} + 1,
            );
        }
    }

    return 1;
}

sub _HTMLOutputXMLStructure {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLData};
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    $Param{Level} ||= 0;

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # stop loop, if no content was given
            last COUNTER if !defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content};

            # lookup value
            my $Value = $Self->{ConfigItemObject}->XMLValueLookup(
                Item  => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content},
            );

            # create output string
            $Value = $Self->{LayoutObject}->ITSMConfigItemOutputStringCreate(
                Value => $Value,
                Item  => $Item,
            );

            # output data block
            $Self->{LayoutObject}->Block(
                Name => 'VersionRow',
                Data => {
                    Name        => $Item->{Name},
                    Description => $Item->{Description} || $Item->{Name},
                    Value       => $Value,
                },
            );

            # output space, if level was given
            if ( $Param{Level} ) {
                for ( 1 .. $Param{Level} ) {
                    $Self->{LayoutObject}->Block( Name => 'VersionRowNamePre' );
                    $Self->{LayoutObject}->Block( Name => 'VersionRowValuePre' );
                }
            }

            next COUNTER if !$Item->{Sub};

            # start recursion, if "Sub" was found
            $Self->_HTMLOutputXMLStructure(
                XMLDefinition => $Item->{Sub},
                XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                Level         => $Param{Level} + 1,
            );
        }
    }

    return 1;
}

1;

# --
# Kernel/Modules/AgentITSMConfigItemSearch.pm - the OTRS ITSM config item search module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItemSearch;

use strict;
use warnings;

use Kernel::System::ITSMConfigItem;
use Kernel::System::GeneralCatalog;
use Kernel::System::SearchProfile;
use Kernel::System::CSV;
use Kernel::System::VariableCheck qw(:all);

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }

    # create additional objects
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%Param);
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);
    $Self->{SearchProfileObject}  = Kernel::System::SearchProfile->new(%Param);
    $Self->{CSVObject}            = Kernel::System::CSV->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;
    my $Output;

    # get config data
    $Self->{StartHit} = int( $Self->{ParamObject}->GetParam( Param => 'StartHit' ) || 1 );
    $Self->{SearchLimit} = $Self->{Config}->{SearchLimit} || 10000;
    $Self->{SortBy} = $Self->{ParamObject}->GetParam( Param => 'SortBy' )
        || $Self->{Config}->{'SortBy::Default'}
        || 'Number';
    $Self->{OrderBy} = $Self->{ParamObject}->GetParam( Param => 'OrderBy' )
        || $Self->{Config}->{'Order::Default'}
        || 'Down';
    $Self->{Profile}     = $Self->{ParamObject}->GetParam( Param => 'Profile' )     || '';
    $Self->{SaveProfile} = $Self->{ParamObject}->GetParam( Param => 'SaveProfile' ) || '';
    $Self->{TakeLastSearch} = $Self->{ParamObject}->GetParam( Param => 'TakeLastSearch' );

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # check for access rights on the classes
    for my $ClassID ( sort keys %{$ClassList} ) {
        my $HasAccess = $Self->{ConfigItemObject}->Permission(
            Type    => $Self->{Config}->{Permission},
            Scope   => 'Class',
            ClassID => $ClassID,
            UserID  => $Self->{UserID},
        );

        delete $ClassList->{$ClassID} if !$HasAccess;
    }

    # get class id
    my $ClassID = $Self->{ParamObject}->GetParam( Param => 'ClassID' );

    # check if class id is valid
    if ( $ClassID && !$ClassList->{$ClassID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'Invalid ClassID!',
            Comment => 'Please contact the admin.',
        );
    }

    # get single params
    my %GetParam;

    # load profiles string params
    if ( ( $ClassID && $Self->{Profile} ) && $Self->{TakeLastSearch} ) {
        %GetParam = $Self->{SearchProfileObject}->SearchProfileGet(
            Base      => 'ConfigItemSearch' . $ClassID,
            Name      => $Self->{Profile},
            UserLogin => $Self->{UserLogin},
        );
    }

    # ------------------------------------------------------------ #
    # delete search profiles
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'AJAXProfileDelete' ) {

        # remove old profile stuff
        $Self->{SearchProfileObject}->SearchProfileDelete(
            Base      => 'ConfigItemSearch' . $ClassID,
            Name      => $Self->{Profile},
            UserLogin => $Self->{UserLogin},
        );
        my $Output = $Self->{LayoutObject}->JSONEncode(
            Data => 1,
        );
        return $Self->{LayoutObject}->Attachment(
            NoCache     => 1,
            ContentType => 'text/html',
            Content     => $Output,
            Type        => 'inline'
        );
    }

    # ------------------------------------------------------------ #
    # init search dialog (select class)
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AJAX' ) {

        # generate dropdown for selecting the class
        # automatically show search mask after selecting a class via AJAX
        my $ClassOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data         => $ClassList,
            Name         => 'SearchClassID',
            PossibleNone => 1,
            SelectedID   => $ClassID || '',
            Translation  => 0,
        );

        # html search mask output
        $Self->{LayoutObject}->Block(
            Name => 'SearchAJAX',
            Data => {
                ClassOptionStrg => $ClassOptionStrg,
                Profile         => $Self->{Profile},
            },
        );

        # set class fields if class specified
        if ($ClassID) {
            $Self->{LayoutObject}->Block(
                Name => 'SearchAJAXSetClass',
                Data => {
                    Profile => $Self->{Profile},
                },
            );
        }

        # output template
        $Output = $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemSearch',
        );

        return $Output;
    }

    # ------------------------------------------------------------ #
    # set search fields for selected class
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AJAXUpdate' ) {

        # ClassID is required for the search mask and for actual searching
        if ( !$ClassID ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'No ClassID is given!',
                Comment => 'Please contact the admin.',
            );
        }

        # check if user is allowed to search class
        my $HasAccess = $Self->{ConfigItemObject}->Permission(
            Type    => $Self->{Config}->{Permission},
            Scope   => 'Class',
            ClassID => $ClassID,
            UserID  => $Self->{UserID},
        );

        # show error screen
        if ( !$HasAccess ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'No access rights for this class given!',
                Comment => 'Please contact the admin.',
            );
        }

        # get current definition
        my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
            ClassID => $ClassID,
        );

        # abort, if no definition is defined
        if ( !$XMLDefinition->{DefinitionID} ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => "No Definition was defined for class $ClassID!",
                Comment => 'Please contact the admin.',
            );
        }

        my @XMLAttributes = (
            {
                Key   => 'Number',
                Value => 'Number',
            },
            {
                Key   => 'Name',
                Value => 'Name',
            },
            {
                Key   => 'DeplStateIDs',
                Value => 'Deployment State',
            },
            {
                Key   => 'InciStateIDs',
                Value => 'Incident State',
            },
        );

        my %GetParam = $Self->{SearchProfileObject}->SearchProfileGet(
            Base      => 'ConfigItemSearch' . $ClassID,
            Name      => $Self->{Profile},
            UserLogin => $Self->{UserLogin},
        );

        # get attributes to include in attributes string
        if ( $XMLDefinition->{Definition} ) {
            $Self->_XMLSearchAttributesGet(
                XMLDefinition => $XMLDefinition->{DefinitionRef},
                XMLAttributes => \@XMLAttributes,
            );
        }

        # build attributes string for attributes list
        $Param{AttributesStrg} = $Self->{LayoutObject}->BuildSelection(
            Data     => \@XMLAttributes,
            Name     => 'Attribute',
            Multiple => 0,
        );

        # build attributes string for recovery on add or subtract search fields
        $Param{AttributesOrigStrg} = $Self->{LayoutObject}->BuildSelection(
            Data     => \@XMLAttributes,
            Name     => 'AttributeOrig',
            Multiple => 0,
        );

        my %Profiles = $Self->{SearchProfileObject}->SearchProfileList(
            Base      => 'ConfigItemSearch' . $ClassID,
            UserLogin => $Self->{UserLogin},
        );

        delete $Profiles{''};
        $Profiles{'last-search'} = '-';
        $Param{ProfilesStrg} = $Self->{LayoutObject}->BuildSelection(
            Data       => \%Profiles,
            Name       => 'Profile',
            ID         => 'SearchProfile',
            SelectedID => $Self->{Profile},
        );

        # get deployment state list
        my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::DeploymentState',
        );

        # generate dropdown for selecting the wanted deployment states
        my $CurDeplStateOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data       => $DeplStateList,
            Name       => 'DeplStateIDs',
            SelectedID => $GetParam{DeplStateIDs} || [],
            Size       => 5,
            Multiple   => 1,
        );

        # get incident state list
        my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::Core::IncidentState',
        );

        # generate dropdown for selecting the wanted incident states
        my $CurInciStateOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Data       => $InciStateList,
            Name       => 'InciStateIDs',
            SelectedID => $GetParam{InciStateIDs} || [],
            Size       => 5,
            Multiple   => 1,
        );

        # generate PreviousVersionOptionStrg
        my $PreviousVersionOptionStrg = $Self->{LayoutObject}->BuildSelection(
            Name => 'PreviousVersionSearch',
            Data => {
                0 => 'No',
                1 => 'Yes',
            },
            SelectedID => $GetParam{PreviousVersionSearch} || '0',
        );

        # build output format string
        $Param{ResultFormStrg} = $Self->{LayoutObject}->BuildSelection(
            Data => {
                Normal => 'Normal',
                Print  => 'Print',
                CSV    => 'CSV',
            },
            Name => 'ResultForm',
            SelectedID => $GetParam{ResultForm} || 'Normal',
        );

        $Self->{LayoutObject}->Block(
            Name => 'AJAXContent',
            Data => {
                ClassID                   => $ClassID,
                AttributesStrg            => $Param{AttributesStrg},
                CurDeplStateOptionStrg    => $CurDeplStateOptionStrg,
                CurInciStateOptionStrg    => $CurInciStateOptionStrg,
                PreviousVersionOptionStrg => $PreviousVersionOptionStrg,
                AttributesStrg            => $Param{AttributesStrg},
                AttributesOrigStrg        => $Param{AttributesOrigStrg},
                ResultFormStrg            => $Param{ResultFormStrg},
                ProfilesStrg              => $Param{ProfilesStrg},
                Number                    => $GetParam{Number} || '',
                Name                      => $GetParam{Name} || '',
            },
        );

        # output xml search form
        if ( $XMLDefinition->{Definition} ) {
            $Self->_XMLSearchFormOutput(
                XMLDefinition => $XMLDefinition->{DefinitionRef},
                XMLAttributes => \@XMLAttributes,
                GetParam      => \%GetParam,
            );
        }

        # show attributes
        my $AttributeIsUsed = 0;
        KEY:
        for my $Key ( sort keys %GetParam ) {
            next KEY if !$Key;
            next KEY if !defined $GetParam{$Key};
            next KEY if $GetParam{$Key} eq '';

            $AttributeIsUsed = 1;

            $Self->{LayoutObject}->Block(
                Name => 'SearchAJAXShow',
                Data => {
                    Attribute => $Key,
                },
            );
        }

        # output template
        $Output = $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemSearch',
        );

        return $Output;
    }

    # ------------------------------------------------------------ #
    # perform search
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'Search' ) {

        my $SearchDialog = $Self->{ParamObject}->GetParam( Param => 'SearchDialog' );

        # fill up profile name (e.g. with last-search)
        if ( !$Self->{Profile} || !$Self->{SaveProfile} ) {
            $Self->{Profile} = 'last-search';
        }

        # store last overview screen
        my $URL
            = "Action=AgentITSMConfigItemSearch;Profile=$Self->{Profile};"
            . "TakeLastSearch=1;StartHit=$Self->{StartHit};Subaction=Search;"
            . "OrderBy=$Self->{OrderBy};SortBy=$Self->{SortBy}";

        if ($ClassID) {
            $URL .= ";ClassID=$ClassID";
        }

        $Self->{SessionObject}->UpdateSessionID(
            SessionID => $Self->{SessionID},
            Key       => 'LastScreenOverview',
            Value     => $URL,
        );
        $Self->{SessionObject}->UpdateSessionID(
            SessionID => $Self->{SessionID},
            Key       => 'LastScreenView',
            Value     => $URL,
        );

        # ClassID is required for the search mask and for actual searching
        if ( !$ClassID ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'No ClassID is given!',
                Comment => 'Please contact the admin.',
            );
        }

        # check if user is allowed to search class
        my $HasAccess = $Self->{ConfigItemObject}->Permission(
            Type    => $Self->{Config}->{Permission},
            Scope   => 'Class',
            ClassID => $ClassID,
            UserID  => $Self->{UserID},
        );

        # show error screen
        if ( !$HasAccess ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => 'No access rights for this class given!',
                Comment => 'Please contact the admin.',
            );
        }

        # get current definition
        my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
            ClassID => $ClassID,
        );

        # abort, if no definition is defined
        if ( !$XMLDefinition->{DefinitionID} ) {
            return $Self->{LayoutObject}->ErrorScreen(
                Message => "No Definition was defined for class $ClassID!",
                Comment => 'Please contact the admin.',
            );
        }

        # get scalar search attributes (special handling for Number and Name)
        FORMVALUE:
        for my $FormValue (qw(Number Name)) {

            my $Value = $Self->{ParamObject}->GetParam( Param => $FormValue );

            # must be defined and not be an empty string
            # BUT the number 0 is an allowed value
            next FORMVALUE if !defined $Value;
            next FORMVALUE if $Value eq '';

            $GetParam{$FormValue} = $Value;
        }

        # get ther scalar search attributes
        FORMVALUE:
        for my $FormValue (qw(PreviousVersionSearch ResultForm)) {

            my $Value = $Self->{ParamObject}->GetParam( Param => $FormValue );

            next FORMVALUE if !$Value;

            $GetParam{$FormValue} = $Value;
        }

        # get array search attributes
        FORMARRAY:
        for my $FormArray (qw(DeplStateIDs InciStateIDs)) {

            my @Array = $Self->{ParamObject}->GetArray( Param => $FormArray );

            next FORMARRAY if !@Array;

            $GetParam{$FormArray} = \@Array;
        }

        # get xml search form
        my $XMLFormData = [];
        my $XMLGetParam = [];
        $Self->_XMLSearchFormGet(
            XMLDefinition => $XMLDefinition->{DefinitionRef},
            XMLFormData   => $XMLFormData,
            XMLGetParam   => $XMLGetParam,
            %GetParam,
        );

        if ( @{$XMLFormData} ) {
            $GetParam{What} = $XMLFormData;
        }

        # save search profile (under last-search or real profile name)
        $Self->{SaveProfile} = 1;

        # remember last search values only if search is called from a search dialog
        # not from results page
        if ( $Self->{SaveProfile} && $Self->{Profile} && $SearchDialog ) {

            # remove old profile stuff
            $Self->{SearchProfileObject}->SearchProfileDelete(
                Base      => 'ConfigItemSearch' . $ClassID,
                Name      => $Self->{Profile},
                UserLogin => $Self->{UserLogin},
            );

            # insert new profile params
            for my $Key ( sort keys %GetParam ) {
                if ( $GetParam{$Key} && $Key ne 'What' ) {
                    $Self->{SearchProfileObject}->SearchProfileAdd(
                        Base      => 'ConfigItemSearch' . $ClassID,
                        Name      => $Self->{Profile},
                        Key       => $Key,
                        Value     => $GetParam{$Key},
                        UserLogin => $Self->{UserLogin},
                    );
                }
            }

            # insert new profile params also from XMLform
            if ( @{$XMLGetParam} ) {
                for my $Parameter ( @{$XMLGetParam} ) {
                    for my $Key ( sort keys %{$Parameter} ) {
                        if ( $Parameter->{$Key} ) {
                            $Self->{SearchProfileObject}->SearchProfileAdd(
                                Base      => 'ConfigItemSearch' . $ClassID,
                                Name      => $Self->{Profile},
                                Key       => $Key,
                                Value     => $Parameter->{$Key},
                                UserLogin => $Self->{UserLogin},
                            );

                        }
                    }
                }
            }
        }

        my $SearchResultList = [];

        # start search if called from a search dialog or from a resutls page
        if ( $SearchDialog || $Self->{TakeLastSearch} ) {

            # start search
            $SearchResultList = $Self->{ConfigItemObject}->ConfigItemSearchExtended(
                %GetParam,
                OrderBy          => [ $Self->{SortBy} ],
                OrderByDirection => [ $Self->{OrderBy} ],
                Limit            => $Self->{SearchLimit},
                ClassIDs         => [$ClassID],
            );
        }

        # get param only if called from a search dialog, otherwise it must be already in %GetParam
        # from a loaded profile
        if ($SearchDialog) {
            $GetParam{ResultForm} = $Self->{ParamObject}->GetParam( Param => 'ResultForm' );
        }

        # CSV output
        if ( $GetParam{ResultForm} eq 'CSV' ) {
            my @CSVData;
            my @CSVHead;

            CONFIGITEMID:
            for my $ConfigItemID ( @{$SearchResultList} ) {

                # check for access rights
                my $HasAccess = $Self->{ConfigItemObject}->Permission(
                    Scope  => 'Item',
                    ItemID => $ConfigItemID,
                    UserID => $Self->{UserID},
                    Type   => $Self->{Config}->{Permission},
                );

                next CONFIGITEMID if !$HasAccess;

                # get version
                my $LastVersion = $Self->{ConfigItemObject}->VersionGet(
                    ConfigItemID => $ConfigItemID,
                    XMLDataGet   => 0,
                );

                # csv quote
                if ( !@CSVHead ) {
                    @CSVHead = @{ $Self->{Config}->{SearchCSVData} };
                }

                # store data
                my @Data;
                for (qw(Class InciState Name Number DeplState VersionID CreateTime)) {
                    push @Data, $LastVersion->{$_};
                }
                push @CSVData, \@Data;
            }

            # csv quote
            # translate non existing header may result in a garbage file
            if ( !@CSVHead ) {
                @CSVHead = @{ $Self->{Config}->{SearchCSVData} };
            }

            # translate headers
            for my $Header (@CSVHead) {

                # replace FAQNumber header with the current FAQHook from config
                if ( $Header eq 'ConfigItemNumber' ) {
                    $Header = $Self->{ConfigObject}->Get('ITSMConfigItem::Hook');
                }
                else {
                    $Header = $Self->{LayoutObject}->{LanguageObject}->Get($Header);
                }
            }

            # assable CSV data
            my $CSV = $Self->{CSVObject}->Array2CSV(
                Head      => \@CSVHead,
                Data      => \@CSVData,
                Separator => $Self->{UserCSVSeparator},
            );

            # return csv to download
            my $CSVFile = 'configitem_search';
            my ( $s, $m, $h, $D, $M, $Y ) = $Self->{TimeObject}->SystemTime2Date(
                SystemTime => $Self->{TimeObject}->SystemTime(),
            );
            $M = sprintf( "%02d", $M );
            $D = sprintf( "%02d", $D );
            $h = sprintf( "%02d", $h );
            $m = sprintf( "%02d", $m );
            return $Self->{LayoutObject}->Attachment(
                Filename    => $CSVFile . "_" . "$Y-$M-$D" . "_" . "$h-$m.csv",
                ContentType => "text/csv; charset=" . $Self->{LayoutObject}->{UserCharset},
                Content     => $CSV,
            );
        }

        # print output ( PDF or HTML (print only) )
        elsif ( $GetParam{ResultForm} eq 'Print' ) {

            my @PDFData;
            use Kernel::System::PDF;
            $Self->{PDFObject} = Kernel::System::PDF->new( %{$Self} );

            CONFIGITEMID:
            for my $ConfigItemID ( @{$SearchResultList} ) {

                # check for access rights
                my $HasAccess = $Self->{ConfigItemObject}->Permission(
                    Scope  => 'Item',
                    ItemID => $ConfigItemID,
                    UserID => $Self->{UserID},
                    Type   => $Self->{Config}->{Permission},
                );

                next CONFIGITEMID if !$HasAccess;

                # get version
                my $LastVersion = $Self->{ConfigItemObject}->VersionGet(
                    ConfigItemID => $ConfigItemID,
                    XMLDataGet   => 0,
                );

                # set pdf rows
                if ( $Self->{PDFObject} ) {
                    my @PDFRow;
                    for (qw(Class InciState Name Number DeplState VersionID CreateTime)) {
                        push @PDFRow, $LastVersion->{$_};
                    }
                    push @PDFData, \@PDFRow;
                }
                else {

                    # add table block
                    $Self->{LayoutObject}->Block(
                        Name => 'Record',
                        Data => { %{$LastVersion} },
                    );
                }
            }

            # PDF Output
            if ( $Self->{PDFObject} ) {
                my $Title = $Self->{LayoutObject}->{LanguageObject}->Get('Configuration Item') . ' '
                    . $Self->{LayoutObject}->{LanguageObject}->Get('Search');
                my $PrintedBy = $Self->{LayoutObject}->{LanguageObject}->Get('printed by');
                my $Page      = $Self->{LayoutObject}->{LanguageObject}->Get('Page');
                my $Time      = $Self->{LayoutObject}->Output( Template => '$Env{"Time"}' );

                # get maximum number of pages
                my $MaxPages = $Self->{ConfigObject}->Get('PDF::MaxPages');
                if ( !$MaxPages || $MaxPages < 1 || $MaxPages > 1000 ) {
                    $MaxPages = 100;
                }

                # create the header
                my $CellData;
                $CellData->[0]->[0]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Class');
                $CellData->[0]->[0]->{Font} = 'ProportionalBold';
                $CellData->[0]->[1]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Incident State');
                $CellData->[0]->[1]->{Font} = 'ProportionalBold';
                $CellData->[0]->[2]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Name');
                $CellData->[0]->[2]->{Font} = 'ProportionalBold';
                $CellData->[0]->[3]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Number');
                $CellData->[0]->[3]->{Font} = 'ProportionalBold';
                $CellData->[0]->[4]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Deployment State');
                $CellData->[0]->[4]->{Font} = 'ProportionalBold';
                $CellData->[0]->[5]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Version');
                $CellData->[0]->[5]->{Font} = 'ProportionalBold';
                $CellData->[0]->[6]->{Content}
                    = $Self->{LayoutObject}->{LanguageObject}->Get('Create Time');
                $CellData->[0]->[6]->{Font} = 'ProportionalBold';

                # create the content array
                my $CounterRow = 1;
                for my $Row (@PDFData) {
                    my $CounterColumn = 0;
                    for my $Content ( @{$Row} ) {
                        $CellData->[$CounterRow]->[$CounterColumn]->{Content} = $Content;
                        $CounterColumn++;
                    }
                    $CounterRow++;
                }

                # output 'No Result', if no content was given
                if ( !$CellData->[0]->[0] ) {
                    $CellData->[0]->[0]->{Content}
                        = $Self->{LayoutObject}->{LanguageObject}->Get('No Result!');
                }

                # page params
                my %PageParam;
                $PageParam{PageOrientation} = 'landscape';
                $PageParam{MarginTop}       = 30;
                $PageParam{MarginRight}     = 40;
                $PageParam{MarginBottom}    = 40;
                $PageParam{MarginLeft}      = 40;
                $PageParam{HeaderRight}     = $Title;
                $PageParam{FooterLeft}      = '';
                $PageParam{HeadlineLeft}    = $Title;
                $PageParam{HeadlineRight}   = $PrintedBy . ' '
                    . $Self->{UserFullname} . ' '
                    . $Time;

                # table params
                my %TableParam;
                $TableParam{CellData}            = $CellData;
                $TableParam{Type}                = 'Cut';
                $TableParam{FontSize}            = 6;
                $TableParam{Border}              = 0;
                $TableParam{BackgroundColorEven} = '#AAAAAA';
                $TableParam{BackgroundColorOdd}  = '#DDDDDD';
                $TableParam{Padding}             = 1;
                $TableParam{PaddingTop}          = 3;
                $TableParam{PaddingBottom}       = 3;

                # create new pdf document
                $Self->{PDFObject}->DocumentNew(
                    Title  => $Self->{ConfigObject}->Get('Product') . ': ' . $Title,
                    Encode => $Self->{LayoutObject}->{UserCharset},
                );

                # start table output
                $Self->{PDFObject}->PageNew( %PageParam, FooterRight => $Page . ' 1', );
                for ( 2 .. $MaxPages ) {

                    # output table (or a fragment of it)
                    %TableParam = $Self->{PDFObject}->Table( %TableParam, );

                    # stop output or another page
                    if ( $TableParam{State} ) {
                        last;
                    }
                    else {
                        $Self->{PDFObject}->PageNew( %PageParam, FooterRight => $Page . ' ' . $_, );
                    }
                }

                # return the pdf document
                my $Filename = 'configitem_search';
                my ( $s, $m, $h, $D, $M, $Y )
                    = $Self->{TimeObject}->SystemTime2Date(
                    SystemTime => $Self->{TimeObject}->SystemTime(),
                    );
                $M = sprintf( "%02d", $M );
                $D = sprintf( "%02d", $D );
                $h = sprintf( "%02d", $h );
                $m = sprintf( "%02d", $m );
                my $PDFString = $Self->{PDFObject}->DocumentOutput();
                return $Self->{LayoutObject}->Attachment(
                    Filename    => $Filename . "_" . "$Y-$M-$D" . "_" . "$h-$m.pdf",
                    ContentType => "application/pdf",
                    Content     => $PDFString,
                    Type        => 'attachment',
                );
            }

            # output printable html result page
            else {
                $Output = $Self->{LayoutObject}->PrintHeader( Width => 800 );
                if ( @{$SearchResultList} == $Self->{SearchLimit} ) {
                    $Param{Warning} = '$Text{"Reached max. count of %s search hits!", "'
                        . $Self->{SearchLimit} . '"}';
                }
                $Output .= $Self->{LayoutObject}->Output(
                    TemplateFile => 'AgentITSMConfigItemSearchResultPrint',
                    Data         => \%Param,
                );

                # add footer
                $Output .= $Self->{LayoutObject}->PrintFooter();

                # return output
                return $Output;
            }
        }

        # normal HTML output
        else {

            # start html page
            my $Output = $Self->{LayoutObject}->Header();
            $Output .= $Self->{LayoutObject}->NavigationBar();
            $Self->{LayoutObject}->Print( Output => \$Output );
            $Output = '';

            $Self->{Filter} = $Self->{ParamObject}->GetParam( Param => 'Filter' ) || '';
            $Self->{View}   = $Self->{ParamObject}->GetParam( Param => 'View' )   || '';

            # show config items
            my $LinkPage = 'Filter='
                . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Filter} )
                . ';View=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{View} )
                . ';SortBy=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{SortBy} )
                . ';OrderBy='
                . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{OrderBy} )
                . ';Profile=' . $Self->{Profile} . ';TakeLastSearch=1;Subaction=Search'
                . ';ClassID=' . $ClassID
                . ';';
            my $LinkSort = 'Filter='
                . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Filter} )
                . ';View=' . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{View} )
                . ';Profile=' . $Self->{Profile} . ';TakeLastSearch=1;Subaction=Search'
                . ';ClassID=' . $ClassID
                . ';';
            my $LinkFilter = 'TakeLastSearch=1;Subaction=Search;Profile='
                . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Profile} )
                . ';ClassID='
                . $Self->{LayoutObject}->Ascii2Html( Text => $ClassID )
                . ';';
            my $LinkBack = 'Subaction=LoadProfile;Profile='
                . $Self->{LayoutObject}->Ascii2Html( Text => $Self->{Profile} )
                . ';ClassID='
                . $Self->{LayoutObject}->Ascii2Html( Text => $ClassID )
                . ';TakeLastSearch=1;';

            # find out which columns should be shown
            my @ShowColumns;
            if ( $Self->{Config}->{ShowColumns} ) {

                # get all possible columns from config
                my %PossibleColumn = %{ $Self->{Config}->{ShowColumns} };

                # get the column names that should be shown
                COLUMNNAME:
                for my $Name ( sort keys %PossibleColumn ) {
                    next COLUMNNAME if !$PossibleColumn{$Name};
                    push @ShowColumns, $Name;
                }
            }

            # get the configured columns and reorganize them by class name
            if (
                IsArrayRefWithData( $Self->{Config}->{ShowColumnsByClass} )
                && $ClassID
                )
            {

                my %ColumnByClass;

                NAME:
                for my $Name ( @{ $Self->{Config}->{ShowColumnsByClass} } ) {
                    my ( $Class, $Column ) = split /::/, $Name, 2;

                    next NAME if !$Column;

                    push @{ $ColumnByClass{$Class} }, $Column;
                }

                # check if there is a specific column config for the selected class
                my $SelectedClass = $ClassList->{$ClassID};
                if ( $ColumnByClass{$SelectedClass} ) {
                    @ShowColumns = @{ $ColumnByClass{$SelectedClass} };
                }
            }

            my $ClassName = $ClassList->{$ClassID};
            my $Title
                = $Self->{LayoutObject}->{LanguageObject}->Get('Config Item Search Results')
                . ' '
                . $Self->{LayoutObject}->{LanguageObject}->Get('Class')
                . ' '
                . $Self->{LayoutObject}->{LanguageObject}->Get($ClassName);

            $Output .= $Self->{LayoutObject}->ITSMConfigItemListShow(
                ConfigItemIDs => $SearchResultList,
                Total         => scalar @{$SearchResultList},
                View          => $Self->{View},
                Filter        => $ClassID,
                Env           => $Self,
                LinkPage      => $LinkPage,
                LinkSort      => $LinkSort,
                LinkFilter    => $LinkFilter,
                LinkBack      => $LinkBack,
                Profile       => $Self->{Profile},
                TitleName     => $Title,
                ShowColumns   => \@ShowColumns,
                SortBy        => $Self->{LayoutObject}->Ascii2Html( Text => $Self->{SortBy} ),
                OrderBy       => $Self->{LayoutObject}->Ascii2Html( Text => $Self->{OrderBy} ),
                ClassID       => $ClassID,
            );

            # build footer
            $Output .= $Self->{LayoutObject}->Footer();

            return $Output;
        }
    }

    # ------------------------------------------------------------ #
    # call search dialog from search empty screen
    # ------------------------------------------------------------ #
    else {

        # show default search screen
        $Output = $Self->{LayoutObject}->Header();
        $Output .= $Self->{LayoutObject}->NavigationBar();

        $Self->{LayoutObject}->Block(
            Name => 'Search',
            Data => {
                Profile => $Self->{Profile},
                ClassID => $ClassID,
            },
        );

        # output template
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentITSMConfigItemSearch',
        );

        # output footer
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }
}

sub _XMLSearchFormOutput {
    my ( $Self, %Param ) = @_;

    my %GetParam = %{ $Param{GetParam} };

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{XMLAttributes} ne 'ARRAY';

    $Param{Level} ||= 0;
    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # set prefix
        my $InputKey = $Item->{Key};
        my $Name     = $Item->{Name};
        if ( $Param{Prefix} ) {
            $InputKey = $Param{Prefix} . '::' . $InputKey;
            $Name     = $Param{PrefixName} . '::' . $Name;
        }

        # output attribute, if marked as searchable
        if ( $Item->{Searchable} ) {
            my $Value;

            # date type fields must to get all date parameters
            if ( $Item->{Input}->{Type} eq 'Date' ) {
                $Value =
                    {
                    $InputKey                      => $GetParam{$InputKey},
                    $InputKey . '::TimeStart::Day' => $GetParam{ $InputKey . '::TimeStart::Day' },
                    $InputKey
                        . '::TimeStart::Month' => $GetParam{ $InputKey . '::TimeStart::Month' },
                    $InputKey . '::TimeStart::Year' => $GetParam{ $InputKey . '::TimeStart::Year' },
                    $InputKey . '::TimeStop::Day'   => $GetParam{ $InputKey . '::TimeStop::Day' },
                    $InputKey . '::TimeStop::Month' => $GetParam{ $InputKey . '::TimeStop::Month' },
                    $InputKey . '::TimeStop::Year'  => $GetParam{ $InputKey . '::TimeStop::Year' },
                    } || '';
            }

            # date-time type fields must get all date and time parameters
            elsif ( $Item->{Input}->{Type} eq 'DateTime' ) {
                $Value =
                    {
                    $InputKey => $GetParam{$InputKey},
                    $InputKey
                        . '::TimeStart::Minute' => $GetParam{ $InputKey . '::TimeStart::Minute' },
                    $InputKey . '::TimeStart::Hour' => $GetParam{ $InputKey . '::TimeStart::Hour' },
                    $InputKey . '::TimeStart::Day'  => $GetParam{ $InputKey . '::TimeStart::Day' },
                    $InputKey
                        . '::TimeStart::Month' => $GetParam{ $InputKey . '::TimeStart::Month' },
                    $InputKey . '::TimeStart::Year' => $GetParam{ $InputKey . '::TimeStart::Year' },
                    $InputKey
                        . '::TimeStop::Minute' => $GetParam{ $InputKey . '::TimeStop::Minute' },
                    $InputKey . '::TimeStop::Hour'  => $GetParam{ $InputKey . '::TimeStop::Hour' },
                    $InputKey . '::TimeStop::Day'   => $GetParam{ $InputKey . '::TimeStop::Day' },
                    $InputKey . '::TimeStop::Month' => $GetParam{ $InputKey . '::TimeStop::Month' },
                    $InputKey . '::TimeStop::Year'  => $GetParam{ $InputKey . '::TimeStop::Year' },
                    } || '';
            }

            # other kinds of fields can get its value directly
            else {
                $Value = $GetParam{$InputKey} || '';
            }

            # create search input element
            my $InputString = $Self->{LayoutObject}->ITSMConfigItemSearchInputCreate(
                Key   => $InputKey,
                Item  => $Item,
                Value => $Value,
            );

            # output attribute row
            $Self->{LayoutObject}->Block(
                Name => 'AttributeRow',
                Data => {
                    Key         => $InputKey,
                    Name        => $Name,
                    Description => $Item->{Description} || $Item->{Name},
                    InputString => $InputString,
                },
            );

            push @{ $Param{XMLAttributes} }, {
                Key   => $InputKey,
                Value => $Name,
            };
        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_XMLSearchFormOutput(
            XMLDefinition => $Item->{Sub},
            XMLAttributes => $Param{XMLAttributes},
            Level         => $Param{Level} + 1,
            Prefix        => $InputKey,
            PrefixName    => $Name,
            GetParam      => \%GetParam,
        );
    }

    return 1;
}

sub _XMLSearchFormGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{XMLFormData};
    return if !$Param{XMLGetParam};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{XMLFormData} ne 'ARRAY';
    return if ref $Param{XMLGetParam} ne 'ARRAY';

    $Param{Level} ||= 0;

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # create inputkey
        my $InputKey = $Item->{Key};
        if ( $Param{Prefix} ) {
            $InputKey = $Param{Prefix} . '::' . $InputKey;
        }

        # get search form data
        my $Values = $Self->{LayoutObject}->ITSMConfigItemSearchFormDataGet(
            Key   => $InputKey,
            Item  => $Item,
            Value => $Param{$InputKey},
        );

        # create search key
        my $SearchKey = $InputKey;
        $SearchKey =~ s{ :: }{\'\}[%]\{\'}xmsg;
        $SearchKey = "[1]{'Version'}[1]{'$SearchKey'}[%]{'Content'}";

        # ITSMConfigItemSearchFormDataGet() can return string, arrayref or hashref
        if ( ref $Values eq 'ARRAY' ) {

            # filter empty elements
            my @SearchValues = grep {$_} @{$Values};

            if (@SearchValues) {
                push @{ $Param{XMLFormData} }, {
                    $SearchKey => \@SearchValues,
                };

                push @{ $Param{XMLGetParam} }, {
                    $InputKey => \@SearchValues,
                };
            }

        }
        elsif ($Values) {

            # e.g. for Date between searches
            push @{ $Param{XMLFormData} }, {
                $SearchKey => $Values,
            };

            if ( ref $Values eq 'HASH' ) {
                if ( $Item->{Input}->{Type} eq 'Date' ) {
                    if ( $Values->{'-between'} ) {

                        # get time elemet values
                        my ( $StartDate, $StopDate ) = @{ $Values->{'-between'} };
                        my ( $StartYear, $StartMonth, $StartDay ) = split( /-/, $StartDate );
                        my ( $StopYear,  $StopMonth,  $StopDay )  = split( /-/, $StopDate );

                        # store time elment values
                        push @{ $Param{XMLGetParam} }, {
                            $InputKey                        => 1,
                            $InputKey . '::TimeStart::Day'   => $StartDay,
                            $InputKey . '::TimeStart::Month' => $StartMonth,
                            $InputKey . '::TimeStart::Year'  => $StartYear,
                            $InputKey . '::TimeStop::Day'    => $StopDay,
                            $InputKey . '::TimeStop::Month'  => $StopMonth,
                            $InputKey . '::TimeStop::Year'   => $StopYear,
                        };
                    }
                }
                elsif ( $Item->{Input}->{Type} eq 'DateTime' ) {
                    if ( $Values->{'-between'} ) {

                        # get time elemet values
                        my ( $StartDateTime, $StopDateTime ) = @{ $Values->{'-between'} };
                        my ( $StartDate, $StartTime ) = split( /\s/, $StartDateTime );
                        my ( $StartYear, $StartMonth,  $StartDay )    = split( /-/,  $StartDate );
                        my ( $StartHour, $StartMinute, $StartSecond ) = split( /\:/, $StartTime );

                        my ( $StopDate, $StopTime ) = split( /\s/, $StopDateTime );
                        my ( $StopYear, $StopMonth,  $StopDay )    = split( /-/,  $StopDate );
                        my ( $StopHour, $StopMinute, $StopSecond ) = split( /\:/, $StopTime );

                        # store time elment values
                        push @{ $Param{XMLGetParam} }, {
                            $InputKey                         => 1,
                            $InputKey . '::TimeStart::Minute' => $StartMinute,
                            $InputKey . '::TimeStart::Hour'   => $StartHour,
                            $InputKey . '::TimeStart::Day'    => $StartDay,
                            $InputKey . '::TimeStart::Month'  => $StartMonth,
                            $InputKey . '::TimeStart::Year'   => $StartYear,
                            $InputKey . '::TimeStop::Minute'  => $StopMinute,
                            $InputKey . '::TimeStop::Hour'    => $StopHour,
                            $InputKey . '::TimeStop::Day'     => $StopDay,
                            $InputKey . '::TimeStop::Month'   => $StopMonth,
                            $InputKey . '::TimeStop::Year'    => $StopYear,
                        };
                    }
                }
            }
            else {
                push @{ $Param{XMLGetParam} }, {
                    $InputKey => $Values,
                };
            }

        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_XMLSearchFormGet(
            XMLDefinition => $Item->{Sub},
            XMLFormData   => $Param{XMLFormData},
            XMLGetParam   => $Param{XMLGetParam},
            Level         => $Param{Level} + 1,
            Prefix        => $InputKey,
        );
    }

    return 1;
}

sub _XMLSearchAttributesGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{XMLAttributes} ne 'ARRAY';

    $Param{Level} ||= 0;
    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # set prefix
        my $InputKey = $Item->{Key};
        my $Name     = $Item->{Name};
        if ( $Param{Prefix} ) {
            $InputKey = $Param{Prefix} . '::' . $InputKey;
            $Name     = $Param{PrefixName} . '::' . $Name;
        }

        # store attribute, if marked as searchable
        if ( $Item->{Searchable} ) {
            push @{ $Param{XMLAttributes} }, {
                Key   => $InputKey,
                Value => $Name,
            };
        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_XMLSearchAttributesGet(
            XMLDefinition => $Item->{Sub},
            XMLAttributes => $Param{XMLAttributes},
            Level         => $Param{Level} + 1,
            Prefix        => $InputKey,
            PrefixName    => $Name,
        );
    }

    return 1;
}

1;

# --
# Kernel/Modules/AgentITSMConfigItemZoom.pm - the OTRS ITSM config item zoom module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AgentITSMConfigItemZoom;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;
use Kernel::System::LinkObject;

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new(%Param);
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new(%Param);
    $Self->{LinkObject}           = Kernel::System::LinkObject->new(%Param);

    # get config of frontend module
    $Self->{Config} = $Self->{ConfigObject}->Get("ITSMConfigItem::Frontend::$Self->{Action}");

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get params
    my $ConfigItemID = $Self->{ParamObject}->GetParam( Param => 'ConfigItemID' ) || 0;
    my $VersionID    = $Self->{ParamObject}->GetParam( Param => 'VersionID' )    || 0;

    # check needed stuff
    if ( !$ConfigItemID ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "No ConfigItemID is given!",
            Comment => 'Please contact the admin.',
        );
    }

    # check for access rights
    my $HasAccess = $Self->{ConfigItemObject}->Permission(
        Scope  => 'Item',
        ItemID => $ConfigItemID,
        UserID => $Self->{UserID},
        Type   => $Self->{Config}->{Permission},
    );

    if ( !$HasAccess ) {

        # error page
        return $Self->{LayoutObject}->ErrorScreen(
            Message => 'Can\'t show item, no access rights for ConfigItem are given!',
            Comment => 'Please contact the admin.',
        );
    }

    # set show versions
    $Param{ShowVersions} = 0;
    if ( $Self->{ParamObject}->GetParam( Param => 'ShowVersions' ) ) {
        $Param{ShowVersions} = 1;
    }

    # get content
    my $ConfigItem = $Self->{ConfigItemObject}->ConfigItemGet(
        ConfigItemID => $ConfigItemID,
    );
    if ( !$ConfigItem->{ConfigItemID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "ConfigItemID $ConfigItemID not found in database!",
            Comment => 'Please contact the admin.',
        );
    }

    # get version list
    my $VersionList = $Self->{ConfigItemObject}->VersionZoomList(
        ConfigItemID => $ConfigItemID,
    );
    if ( !$VersionList->[0]->{VersionID} ) {
        return $Self->{LayoutObject}->ErrorScreen(
            Message => "No Version found for ConfigItemID $ConfigItemID!",
            Comment => 'Please contact the admin.',
        );
    }

    # set version id
    if ( !$VersionID ) {
        $VersionID = $VersionList->[-1]->{VersionID};
    }
    if ( $VersionID ne $VersionList->[-1]->{VersionID} ) {
        $Param{ShowVersions} = 1;
    }

    # set version id in param hash (only for menu module)
    if ($VersionID) {
        $Param{VersionID} = $VersionID;
    }

    # run config item menu modules
    if ( ref $Self->{ConfigObject}->Get('ITSMConfigItem::Frontend::MenuModule') eq 'HASH' ) {
        my %Menus   = %{ $Self->{ConfigObject}->Get('ITSMConfigItem::Frontend::MenuModule') };
        my $Counter = 0;
        for my $Menu ( sort keys %Menus ) {

            # load module
            if ( $Self->{MainObject}->Require( $Menus{$Menu}->{Module} ) ) {
                my $Object = $Menus{$Menu}->{Module}->new(
                    %{$Self},
                    ConfigItemID => $Self->{ConfigItemID},
                );

                # set classes
                if ( $Menus{$Menu}->{Target} ) {

                    if ( $Menus{$Menu}->{Target} eq 'PopUp' ) {
                        $Menus{$Menu}->{MenuClass} = 'AsPopup';
                    }
                    elsif ( $Menus{$Menu}->{Target} eq 'Back' ) {
                        $Menus{$Menu}->{MenuClass} = 'HistoryBack';
                    }

                }

                # run module
                $Counter = $Object->Run(
                    %Param,
                    ConfigItem => $ConfigItem,
                    Counter    => $Counter,
                    Config     => $Menus{$Menu},
                );
            }
            else {
                return $Self->{LayoutObject}->FatalError();
            }
        }
    }

    # build version tree
    $Self->{LayoutObject}->Block( Name => 'Tree' );
    my $Counter = 1;
    if ( !$Param{ShowVersions} && $VersionID eq $VersionList->[-1]->{VersionID} ) {
        $Counter     = @{$VersionList};
        $VersionList = [ $VersionList->[-1] ];
    }

    # get last version
    my $LastVersion = $VersionList->[-1];

    # set incident signal
    my %InciSignals = (
        operational => 'greenled',
        warning     => 'yellowled',
        incident    => 'redled',
    );

    # output version tree header
    if ( $Param{ShowVersions} ) {
        $Self->{LayoutObject}->Block(
            Name => 'Collapse',
            Data => {
                ConfigItemID => $ConfigItemID,
            },
        );
    }
    else {
        $Self->{LayoutObject}->Block(
            Name => 'Expand',
            Data => {
                ConfigItemID => $ConfigItemID,
            },
        );
    }

    # output version tree
    for my $VersionHash ( @{$VersionList} ) {

        $Param{CreateByUserFullName} = $Self->{UserObject}->UserName(
            UserID => $VersionHash->{CreateBy},
        );

        $Self->{LayoutObject}->Block(
            Name => 'TreeItem',
            Data => {
                %Param,
                %{$ConfigItem},
                %{$VersionHash},
                Count      => $Counter,
                InciSignal => $InciSignals{ $VersionHash->{InciStateType} },
                Active     => $VersionHash->{VersionID} eq $VersionID ? 'Active' : '',
            },
        );

        $Counter++;
    }

    # output header
    my $Output = $Self->{LayoutObject}->Header( Value => $ConfigItem->{Number} );
    $Output .= $Self->{LayoutObject}->NavigationBar();

    # get version
    my $Version = $Self->{ConfigItemObject}->VersionGet(
        VersionID => $VersionID,
    );

    if (
        $Version
        && ref $Version eq 'HASH'
        && $Version->{XMLDefinition}
        && $Version->{XMLData}
        && ref $Version->{XMLDefinition} eq 'ARRAY'
        && ref $Version->{XMLData}       eq 'ARRAY'
        && $Version->{XMLData}->[1]
        && ref $Version->{XMLData}->[1] eq 'HASH'
        && $Version->{XMLData}->[1]->{Version}
        && ref $Version->{XMLData}->[1]->{Version} eq 'ARRAY'
        )
    {

        # transform ascii to html
        $Version->{Name} = $Self->{LayoutObject}->Ascii2Html(
            Text           => $Version->{Name},
            HTMLResultMode => 1,
            LinkFeature    => 1,
        );

        # output name
        $Self->{LayoutObject}->Block(
            Name => 'Data',
            Data => {
                Name        => 'Name',
                Description => 'The name of this config item',
                Value       => $Version->{Name},
                Identation  => 10,
            },
        );

        # output deployment state
        $Self->{LayoutObject}->Block(
            Name => 'Data',
            Data => {
                Name        => 'Deployment State',
                Description => 'The deployment state of this config item',
                Value       => $Self->{LayoutObject}->{LanguageObject}->Get(
                    $Version->{DeplState},
                ),
                Identation => 10,
            },
        );

        # output incident state
        $Self->{LayoutObject}->Block(
            Name => 'Data',
            Data => {
                Name        => 'Incident State',
                Description => 'The incident state of this config item',
                Value       => $Self->{LayoutObject}->{LanguageObject}->Get(
                    $Version->{InciState},
                ),
                Identation => 10,
            },
        );

        # start xml output
        $Self->_XMLOutput(
            XMLDefinition => $Version->{XMLDefinition},
            XMLData       => $Version->{XMLData}->[1]->{Version}->[1],
        );
    }

    # get create & change user data
    for my $Key (qw(Create Change)) {
        $ConfigItem->{ $Key . 'ByUserFullName' } = $Self->{UserObject}->UserName(
            UserID => $ConfigItem->{ $Key . 'By' },
        );
    }

    # output meta block
    $Self->{LayoutObject}->Block(
        Name => 'Meta',
        Data => {
            %{$LastVersion},
            %{$ConfigItem},
            CurInciSignal => $InciSignals{ $LastVersion->{CurInciStateType} },
        },
    );

    # get linked objects
    my $LinkListWithData = $Self->{LinkObject}->LinkListWithData(
        Object => 'ITSMConfigItem',
        Key    => $ConfigItemID,
        State  => 'Valid',
        UserID => $Self->{UserID},
    );

    # get link table view mode
    my $LinkTableViewMode = $Self->{ConfigObject}->Get('LinkObject::ViewMode');

    # create the link table
    my $LinkTableStrg = $Self->{LayoutObject}->LinkObjectTableCreate(
        LinkListWithData => $LinkListWithData,
        ViewMode         => $LinkTableViewMode,
    );

    # output the link table
    if ($LinkTableStrg) {
        $Self->{LayoutObject}->Block(
            Name => 'LinkTable' . $LinkTableViewMode,
            Data => {
                LinkTableStrg => $LinkTableStrg,
            },
        );
    }

    my @Attachments = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
        ConfigItemID => $ConfigItemID,
    );

    if (@Attachments) {

        # get the metadata of the 1st attachment
        my $FirstAttachment = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
            ConfigItemID => $ConfigItemID,
            Filename     => $Attachments[0],
        );

        $Self->{LayoutObject}->Block(
            Name => 'Attachments',
            Data => {
                ConfigItemID => $ConfigItemID,
                Filename     => $FirstAttachment->{Filename},
                Filesize     => $FirstAttachment->{Filesize},
            },
        );

        # the 1st attachment was directly rendered into the 1st row's right cell, all further
        # attachments are rendered into a separate row
        ATTACHMENT:
        for my $Attachment (@Attachments) {

            # skip the 1st attachment
            next ATTACHMENT if $Attachment eq $Attachments[0];

            # get the metadata of the current attachment
            my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
                ConfigItemID => $ConfigItemID,
                Filename     => $Attachment,
            );

            $Self->{LayoutObject}->Block(
                Name => 'AttachmentRow',
                Data => {
                    ConfigItemID => $ConfigItemID,
                    Filename     => $AttachmentData->{Filename},
                    Filesize     => $AttachmentData->{Filesize},
                },
            );
        }
    }

    # handle DownloadAttachment
    if ( $Self->{Subaction} eq 'DownloadAttachment' ) {

        # get data for attachment
        my $Filename = $Self->{ParamObject}->GetParam( Param => 'Filename' );
        my $AttachmentData = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
            ConfigItemID => $ConfigItemID,
            Filename     => $Filename,
        );

        # return error if file does not exist
        if ( !$AttachmentData ) {
            $Self->{LogObject}->Log(
                Message  => "No such attachment ($Filename)!",
                Priority => 'error',
            );
            return $Self->{LayoutObject}->ErrorScreen();
        }

        return $Self->{LayoutObject}->Attachment(
            %{$AttachmentData},
            Type => 'attachment',
        );
    }

    # store last screen
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'LastScreenView',
        Value     => $Self->{RequestedURL},
    );

    # start template output
    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'AgentITSMConfigItemZoom',
        Data         => {
            %{$LastVersion},
            %{$ConfigItem},
            CurInciSignal => $InciSignals{ $LastVersion->{CurInciStateType} },
        },
    );

    # add footer
    $Output .= $Self->{LayoutObject}->Footer();

    return $Output;
}

sub _XMLOutput {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLData};
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    $Param{Level} ||= 0;

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # stop loop, if no content was given
            last COUNTER if !defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content};

            # lookup value
            my $Value = $Self->{ConfigItemObject}->XMLValueLookup(
                Item  => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content},
            );

            # create output string
            $Value = $Self->{LayoutObject}->ITSMConfigItemOutputStringCreate(
                Value => $Value,
                Item  => $Item,
            );

            # calculate indentation for left-padding css based on 15px per level and 10px as default
            my $Indentation = 10;

            if ( $Param{Level} ) {
                $Indentation += 15 * $Param{Level};
            }

            # output data block
            $Self->{LayoutObject}->Block(
                Name => 'Data',
                Data => {
                    Name        => $Item->{Name},
                    Description => $Item->{Description} || $Item->{Name},
                    Value       => $Value,
                    Indentation => $Indentation,
                },
            );

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                $Self->_XMLOutput(
                    XMLDefinition => $Item->{Sub},
                    XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                    Level         => $Param{Level} + 1,
                );
            }
        }
    }

    return 1;
}

1;

# --
# Kernel/Output/HTML/ITSMConfigItemLayoutCustomer.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutCustomer;

use strict;
use warnings;

use Kernel::System::CustomerUser;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutCustomer - layout backend module

=head1 SYNOPSIS

All layout functions of customer objects

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutCustomer->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(ConfigObject EncodeObject LogObject MainObject ParamObject DBObject LayoutObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    # create additional objects
    $Self->{CustomerUserObject} = Kernel::System::CustomerUser->new( %{$Self} );

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => 11,       # (optional)
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    # transform ascii to html
    $Param{Value} = $Self->{LayoutObject}->Ascii2Html(
        Text => $Param{Value} || '',
        HTMLResultMode => 1,
    );

    return $Param{Value};
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get selected customer user
    $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} );

    # check search button
    if ( $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::ButtonSearch' ) ) {
        $Param{Item}->{Form}->{ $Param{Key} }->{Search}
            = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Search' );
    }

    # check select button
    elsif ( $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::ButtonSelect' ) ) {
        $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Select' );
    }

    # check clear button
    elsif ( $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::ButtonClear' ) ) {
        $FormData{Value} = '';
    }
    else {

        # reset value if search field is empty
        if (
            !$Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Search' )
            && defined $FormData{Value}
            )
        {
            $FormData{Value} = '';
        }

        # check required option
        if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
            $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
            $FormData{Invalid} = 1;
        }
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,       # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Value = '';
    if ( defined $Param{Value} ) {
        $Value = $Param{Value};
    }
    elsif ( $Param{Item}->{Input}->{ValueDefault} ) {
        $Value = $Param{Item}->{Input}->{ValueDefault};
    }
    my $Class    = 'W50pc ITSMCustomerSearch';
    my $Search   = '';
    my $Required = $Param{Required} || '';
    my $Invalid  = $Param{Invalid} || '';
    my $ItemId   = $Param{ItemId} || '';

    if ($Required) {
        $Class .= ' Validate_Required';
    }

    if ($Invalid) {
        $Class .= ' ServerError';
    }

    # create customer string
    if ($Value) {

        # get customer data
        my %CustomerSearchList = $Self->{CustomerUserObject}->CustomerSearch(
            Search => $Value,
        );

        # transform ascii to html
        $Search = $Self->{LayoutObject}->Ascii2Html(
            Text => $CustomerSearchList{$Value} || '',
            HTMLResultMode => 1,
        );
    }

    # create string
    my $String
        = '<input type="hidden" name="'
        . $Param{Key}
        . '" value="'
        . $Value
        . '" id="'
        . $ItemId . 'Selected'
        . '"/>'
        . '<input type="text" name="'
        . $Param{Key}
        . '::Search" class="'
        . $Class
        . '" id="'
        . $ItemId
        . '" value="'
        . $Search . '"/>';

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Key} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Key!',
        );
        return;
    }

    # get form data
    my $Value;
    if ( $Param{Value} ) {
        $Value = $Param{Value};
    }
    else {
        $Value = $Self->{ParamObject}->GetParam( Param => $Param{Key} );
    }
    return $Value;
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Key = $Param{Key};

    # hash with values for the input field
    my %FormData;

    if ( $Param{Value} ) {
        $FormData{Value} = $Param{Value};
    }

    # create input field
    my $InputString = $Self->InputCreate(
        %FormData,
        Key    => $Param{Key},
        Item   => $Param{Item},
        ItemId => $Param{Key},
    );

    return $InputString;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9PdXRwdXQvSFRNTC9JVFNNQ29uZmlnSXRlbUxheW91dEN1c3RvbWVyQ29tcGFueS5wbSAtIGxheW91dCBiYWNrZW5kIG1vZHVsZQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpPdXRwdXQ6OkhUTUw6OklUU01Db25maWdJdGVtTGF5b3V0Q3VzdG9tZXJDb21wYW55OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIEtlcm5lbDo6U3lzdGVtOjpDdXN0b21lckNvbXBhbnk7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpPdXRwdXQ6OkhUTUw6OklUU01Db25maWdJdGVtTGF5b3V0Q3VzdG9tZXJDb21wYW55IC0gbGF5b3V0IGJhY2tlbmQgbW9kdWxlCgo9aGVhZDEgU1lOT1BTSVMKCkFsbCBsYXlvdXQgZnVuY3Rpb25zIG9mIGN1c3RvbWVyIGNvbXBhbnkgb2JqZWN0cwoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICAkQmFja2VuZE9iamVjdCA9IEtlcm5lbDo6T3V0cHV0OjpIVE1MOjpJVFNNQ29uZmlnSXRlbUxheW91dEN1c3RvbWVyQ29tcGFueS0+bmV3KAogICAgICAgICVQYXJhbSwKICAgICk7Cgo9Y3V0CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0ICgKICAgICAgICBxdyhDb25maWdPYmplY3QgRW5jb2RlT2JqZWN0IExvZ09iamVjdCBNYWluT2JqZWN0IFBhcmFtT2JqZWN0IERCT2JqZWN0IExheW91dE9iamVjdCkKICAgICAgICApCiAgICB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgIyBjcmVhdGUgYWRkaXRpb25hbCBvYmplY3RzCiAgICAkU2VsZi0+e0N1c3RvbWVyQ29tcGFueU9iamVjdH0gPSBLZXJuZWw6OlN5c3RlbTo6Q3VzdG9tZXJDb21wYW55LT5uZXcoICV7JFNlbGZ9ICk7CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBPdXRwdXRTdHJpbmdDcmVhdGUoKQoKY3JlYXRlIG91dHB1dCBzdHJpbmcKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+T3V0cHV0U3RyaW5nQ3JlYXRlKAogICAgICAgIFZhbHVlID0+IDExLCAgICAgICAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgT3V0cHV0U3RyaW5nQ3JlYXRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyB0cmFuc2Zvcm0gYXNjaWkgdG8gaHRtbAogICAgJFBhcmFte1ZhbHVlfSA9ICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+QXNjaWkySHRtbCgKICAgICAgICBUZXh0ID0+ICRQYXJhbXtWYWx1ZX0gfHwgJycsCiAgICAgICAgSFRNTFJlc3VsdE1vZGUgPT4gMSwKICAgICk7CgogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEZvcm1EYXRhR2V0KCkKCmdldCBmb3JtIGRhdGEgYXMgaGFzaCByZWZlcmVuY2UKCiAgICBteSAkRm9ybURhdGFSZWYgPSAkQmFja2VuZE9iamVjdC0+Rm9ybURhdGFHZXQoCiAgICAgICAgS2V5ID0+ICdJdGVtOjoxOjpOb2RlOjozJywKICAgICAgICBJdGVtID0+ICRJdGVtUmVmLAogICAgKTsKCj1jdXQKCnN1YiBGb3JtRGF0YUdldCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhLZXkgSXRlbSkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JEFyZ3VtZW50fSApIHsKICAgICAgICAgICAgJFNlbGYtPntMb2dPYmplY3R9LT5Mb2coCiAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICAgICAgTWVzc2FnZSAgPT4gIk5lZWQgJEFyZ3VtZW50ISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgbXkgJUZvcm1EYXRhOwoKICAgICMgZ2V0IGZvcm0gZGF0YQogICAgJEZvcm1EYXRhe1ZhbHVlfSA9ICRTZWxmLT57UGFyYW1PYmplY3R9LT5HZXRQYXJhbSggUGFyYW0gPT4gJFBhcmFte0tleX0gKTsKCiAgICAjIHNldCBpbnZhbGlkIHBhcmFtCiAgICBpZiAoICRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e1JlcXVpcmVkfSAmJiAhJEZvcm1EYXRhe1ZhbHVlfSApIHsKICAgICAgICAkRm9ybURhdGF7SW52YWxpZH0gPSAxOwogICAgICAgICRQYXJhbXtJdGVtfS0+e0Zvcm19LT57ICRQYXJhbXtLZXl9IH0tPntJbnZhbGlkfSA9IDE7CiAgICB9CgogICAgcmV0dXJuIFwlRm9ybURhdGE7Cn0KCnN1YiBJbnB1dENyZWF0ZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhLZXkgSXRlbSkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JEFyZ3VtZW50fSApIHsKICAgICAgICAgICAgJFNlbGYtPntMb2dPYmplY3R9LT5Mb2coCiAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICAgICAgTWVzc2FnZSAgPT4gIk5lZWQgJEFyZ3VtZW50ISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgbXkgJFNlbGVjdGVkSUQgPSAkUGFyYW17VmFsdWV9IHx8ICRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e1ZhbHVlRGVmYXVsdH0gfHwgJyc7CgogICAgbXkgJENTU0NsYXNzID0gJyc7CiAgICBteSAkUmVxdWlyZWQgPSAkUGFyYW17UmVxdWlyZWR9OwogICAgbXkgJEludmFsaWQgID0gJFBhcmFte0ludmFsaWR9OwogICAgbXkgJEl0ZW1JZCAgID0gJFBhcmFte0l0ZW1JZH07CgogICAgaWYgKCRSZXF1aXJlZCkgewogICAgICAgICRDU1NDbGFzcyAuPSAnVmFsaWRhdGVfUmVxdWlyZWQnOwogICAgfQoKICAgIGlmICgkSW52YWxpZCkgewogICAgICAgICRDU1NDbGFzcyAuPSAnIFNlcnZlckVycm9yJzsKICAgIH0KCiAgICAjIGdldCBjbGFzcyBsaXN0CiAgICBteSAlQ29tcGFueUxpc3QgPSAkU2VsZi0+e0N1c3RvbWVyQ29tcGFueU9iamVjdH0tPkN1c3RvbWVyQ29tcGFueUxpc3QoKTsKCiAgICAjIGdlbmVyYXRlIHN0cmluZwogICAgbXkgJFN0cmluZyA9ICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+QnVpbGRTZWxlY3Rpb24oCiAgICAgICAgRGF0YSAgICAgICAgID0+IFwlQ29tcGFueUxpc3QsCiAgICAgICAgTmFtZSAgICAgICAgID0+ICRQYXJhbXtLZXl9LAogICAgICAgIElEICAgICAgICAgICA9PiAkSXRlbUlkLAogICAgICAgIFBvc3NpYmxlTm9uZSA9PiAxLAogICAgICAgIFRyYW5zbGF0aW9uICA9PiAwLAogICAgICAgIFNlbGVjdGVkSUQgICA9PiAkU2VsZWN0ZWRJRCwKICAgICAgICBDbGFzcyAgICAgICAgPT4gJENTU0NsYXNzLAogICAgKTsKCiAgICByZXR1cm4gJFN0cmluZzsKfQoKPWl0ZW0gU2VhcmNoRm9ybURhdGFHZXQoKQoKZ2V0IHNlYXJjaCBmb3JtIGRhdGEKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+U2VhcmNoRm9ybURhdGFHZXQoCiAgICAgICAgS2V5ID0+ICdJdGVtOjoxOjpOb2RlOjozJywKICAgICAgICBJdGVtID0+ICRJdGVtUmVmLAogICAgKTsKCj1jdXQKCnN1YiBTZWFyY2hGb3JtRGF0YUdldCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBpZiAoICEkUGFyYW17S2V5fSApIHsKICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgTWVzc2FnZSAgPT4gJ05lZWQgS2V5IScsCiAgICAgICAgKTsKICAgICAgICByZXR1cm47CiAgICB9CgogICAgIyBnZXQgZm9ybSBkYXRhCiAgICBteSAkVmFsdWU7CiAgICBpZiAoICRQYXJhbXtWYWx1ZX0gKSB7CiAgICAgICAgJFZhbHVlID0gJFBhcmFte1ZhbHVlfTsKICAgIH0KICAgIGVsc2UgewogICAgICAgICRWYWx1ZSA9ICRTZWxmLT57UGFyYW1PYmplY3R9LT5HZXRQYXJhbSggUGFyYW0gPT4gJFBhcmFte0tleX0gKTsKICAgIH0KICAgIHJldHVybiAkVmFsdWU7Cn0KCj1pdGVtIFNlYXJjaElucHV0Q3JlYXRlKCkKCmNyZWF0ZSBhIHNlYXJjaCBpbnB1dCBzdHJpbmcKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+U2VhcmNoSW5wdXRDcmVhdGUoCiAgICAgICAgS2V5ID0+ICdJdGVtOjoxOjpOb2RlOjozJywKICAgICk7Cgo9Y3V0CgpzdWIgU2VhcmNoSW5wdXRDcmVhdGUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGNoZWNrIG5lZWRlZCBzdHVmZgogICAgZm9yIG15ICRBcmd1bWVudCAocXcoS2V5IEl0ZW0pKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyRBcmd1bWVudH0gKSB7CiAgICAgICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICRBcmd1bWVudCEiLAogICAgICAgICAgICApOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgfQoKICAgIG15ICRWYWx1ZXMgPSAkU2VsZi0+U2VhcmNoRm9ybURhdGFHZXQoJVBhcmFtKTsKCiAgICAjIGdldCBjb21wYW55IGRhdGEKICAgIG15ICVDb21wYW55TGlzdCA9ICRTZWxmLT57Q3VzdG9tZXJDb21wYW55T2JqZWN0fS0+Q3VzdG9tZXJDb21wYW55TGlzdCgpOwoKICAgICMgZ2VuZXJhdGUgc3RyaW5nCiAgICBteSAkU3RyaW5nID0gJFNlbGYtPntMYXlvdXRPYmplY3R9LT5CdWlsZFNlbGVjdGlvbigKICAgICAgICBEYXRhICAgICAgICA9PiBcJUNvbXBhbnlMaXN0LAogICAgICAgIE5hbWUgICAgICAgID0+ICRQYXJhbXtLZXl9LAogICAgICAgIFNpemUgICAgICAgID0+IDUsCiAgICAgICAgTXVsdGlwbGUgICAgPT4gMSwKICAgICAgICBUcmFuc2xhdGlvbiA9PiAwLAogICAgICAgIFNlbGVjdGVkSUQgID0+ICRWYWx1ZXMsCiAgICApOwoKICAgIHJldHVybiAkU3RyaW5nOwp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKEw8aHR0cDovL290cnMub3JnLz4pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
# --
# Kernel/Output/HTML/ITSMConfigItemLayoutDate.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutDate;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutDate - layout backend module

=head1 SYNOPSIS

All layout functions of date objects.

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutDate->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject MainObject ParamObject LayoutObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => '2007-01-01',  # (optional)
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    return '' if !$Param{Value};

    $Param{Value} = $Self->{LayoutObject}->Output(
        Template => '$Date{"$QData{"Date"}"}',
        Data     => {
            Date => $Param{Value} . ' 00:00:00',
        },
    );
    $Param{Value} =~ s/00:00:00//;

    return $Param{Value} || '';
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    my $Day   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Day' );
    my $Month = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Month' );
    my $Year  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Year' );

    if ( $Day && $Month && $Year ) {
        $FormData{Value} = sprintf '%02d-%02d-%02d', $Year, $Month, $Day;
    }

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => '2007-03-26',      # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %Values;
    if ( $Param{Value} || $Param{Item}->{Input}->{ValueDefault} ) {
        my $Value = $Param{Value} || $Param{Item}->{Input}->{ValueDefault};

        if ( $Value =~ /^(\d\d\d\d)-(\d\d|\d)-(\d\d|\d)$/i ) {
            $Values{ $Param{Key} . '::Year' }  = $1;
            $Values{ $Param{Key} . '::Month' } = $2;
            $Values{ $Param{Key} . '::Day' }   = $3;
        }
    }

    my $String = $Self->{LayoutObject}->BuildDateSelection(
        Prefix           => $Param{Key} . '::',
        Format           => 'DateInputFormat',
        YearPeriodPast   => $Param{Item}->{Input}->{YearPeriodPast} || 10,
        YearPeriodFuture => $Param{Item}->{Input}->{YearPeriodFuture} || 10,
        %Values,
    );

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get form data
    my $Used;
    my $StartDay;
    my $StartMonth;
    my $StartYear;
    my $StopDay;
    my $StopMonth;
    my $StopYear;

    if ( $Param{Value} ) {
        $Used       = $Param{Value}->{ $Param{Key} };
        $StartDay   = $Param{Value}->{ $Param{Key} . '::TimeStart::Day' };
        $StartMonth = $Param{Value}->{ $Param{Key} . '::TimeStart::Month' };
        $StartYear  = $Param{Value}->{ $Param{Key} . '::TimeStart::Year' };
        $StopDay    = $Param{Value}->{ $Param{Key} . '::TimeStop::Day' };
        $StopMonth  = $Param{Value}->{ $Param{Key} . '::TimeStop::Month' };
        $StopYear   = $Param{Value}->{ $Param{Key} . '::TimeStop::Year' };
    }
    else {
        $Used       = $Self->{ParamObject}->GetParam( Param => $Param{Key} );
        $StartDay   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Day' );
        $StartMonth = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Month' );
        $StartYear  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Year' );
        $StopDay    = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Day' );
        $StopMonth  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Month' );
        $StopYear   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Year' );
    }
    if (
        $Used
        && $StartDay && $StartMonth && $StartYear
        && $StopDay  && $StopMonth  && $StopYear
        )
    {
        my $StartDate = sprintf '%02d-%02d-%02d', $StartYear, $StartMonth, $StartDay;
        my $StopDate  = sprintf '%02d-%02d-%02d', $StopYear,  $StopMonth,  $StopDay;

        return { '-between' => [ $StartDate, $StopDate ] };
    }

    return [];    # no conditions by default
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # just for convenience
    my $Key         = $Param{Key};
    my $PrefixStart = $Key . '::TimeStart::';
    my $PrefixStop  = $Key . '::TimeStop::';

    # get time related params
    my %GetParam;

    if ( $Param{Value} ) {
        %GetParam = %{ $Param{Value} }
    }
    else {
        $GetParam{$Key} = $Self->{ParamObject}->GetParam( Param => $Key );
        for my $TimeType ( $PrefixStart, $PrefixStop ) {
            for my $Part (qw( Year Month Day )) {
                my $ParamKey = $TimeType . $Part;
                my $ParamVal = $Self->{ParamObject}->GetParam( Param => $ParamKey );

                # remove white space on the start and end
                if ($ParamVal) {
                    $ParamVal =~ s{ \A \s+ }{}xms;
                    $ParamVal =~ s{ \s+ \z }{}xms;
                }

                # store in %GetParam
                $GetParam{$ParamKey} = $ParamVal;
            }
        }
    }

    # Build selection for the start and stop time.
    # Note that searching is by date, while input is by time as well
    my $TimeStartSelectionString = $Self->{LayoutObject}->BuildDateSelection(
        Prefix           => $PrefixStart,
        Format           => 'DateInputFormat',
        YearPeriodPast   => 10,
        YearPeriodFuture => 10,
        %GetParam,
    );
    my $TimeStopSelectionString = $Self->{LayoutObject}->BuildDateSelection(
        Optional         => 0,
        Prefix           => $PrefixStop,
        Format           => 'DateInputFormat',
        YearPeriodPast   => 10,
        YearPeriodFuture => 10,
        %GetParam,
    );

    my $Checkbox = qq{<input type="hidden" name="$Key" value="1"/>};
    my $Between  = $Self->{LayoutObject}->{LanguageObject}->Get('Between');
    my $And      = $Self->{LayoutObject}->{LanguageObject}->Get('and');

    return "<div> $Checkbox $Between $TimeStartSelectionString </div>"
        . "<span style=\"margin-left: 27px;\">$And</span> $TimeStopSelectionString";
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/Output/HTML/ITSMConfigItemLayoutDateTime.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutDateTime;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutDateTime - layout backend module

=head1 SYNOPSIS

All layout functions of datetime objects.

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutDateTime->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject MainObject ParamObject LayoutObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => '2007-01-01 12:00',  # (optional)
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    return '' if !$Param{Value};

    $Param{Value} = $Self->{LayoutObject}->Output(
        Template => '$TimeLong{"$QData{"Date"}"}',
        Data     => {
            Date => $Param{Value} . ':00',
        },
    );

    return $Param{Value} || '';
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    my $Day    = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Day' );
    my $Month  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Month' );
    my $Year   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Year' );
    my $Hour   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Hour' ) || 0;
    my $Minute = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::Minute' ) || 0;

    if ( $Day && $Month && $Year ) {
        $FormData{Value} = sprintf '%02d-%02d-%02d %02d:%02d', $Year, $Month, $Day, $Hour, $Minute;
    }

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => '2007-03-26 12:00',  # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %Values;
    if ( $Param{Value} || $Param{Item}->{Input}->{ValueDefault} ) {
        my $Value = $Param{Value} || $Param{Item}->{Input}->{ValueDefault};

        if ( $Value =~ /^(\d\d\d\d)-(\d\d|\d)-(\d\d|\d) (\d\d|\d):(\d\d|\d)$/i ) {
            $Values{ $Param{Key} . '::Year' }   = $1;
            $Values{ $Param{Key} . '::Month' }  = $2;
            $Values{ $Param{Key} . '::Day' }    = $3;
            $Values{ $Param{Key} . '::Hour' }   = $4;
            $Values{ $Param{Key} . '::Minute' } = $5;
        }
    }

    my $String = $Self->{LayoutObject}->BuildDateSelection(
        Prefix           => $Param{Key} . '::',
        Format           => 'DateInputFormatLong',
        YearPeriodPast   => $Param{Item}->{Input}->{YearPeriodPast} || 10,
        YearPeriodFuture => $Param{Item}->{Input}->{YearPeriodFuture} || 10,
        %Values,
    );

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Used;
    my $StartMinute;
    my $StartHour;
    my $StartDay;
    my $StartMonth;
    my $StartYear;
    my $StopMinute;
    my $StopHour;
    my $StopDay;
    my $StopMonth;
    my $StopYear;

    # get form data
    if ( $Param{Value} ) {
        $Used        = $Param{Value}->{ $Param{Key} };
        $StartMinute = $Param{Value}->{ $Param{Key} . '::TimeStart::Minute' };
        $StartHour   = $Param{Value}->{ $Param{Key} . '::TimeStart::Hour' };
        $StartDay    = $Param{Value}->{ $Param{Key} . '::TimeStart::Day' };
        $StartMonth  = $Param{Value}->{ $Param{Key} . '::TimeStart::Month' };
        $StartYear   = $Param{Value}->{ $Param{Key} . '::TimeStart::Year' };
        $StopMinute  = $Param{Value}->{ $Param{Key} . '::TimeStop::Minute' };
        $StopHour    = $Param{Value}->{ $Param{Key} . '::TimeStop::Hour' };
        $StopDay     = $Param{Value}->{ $Param{Key} . '::TimeStop::Day' };
        $StopMonth   = $Param{Value}->{ $Param{Key} . '::TimeStop::Month' };
        $StopYear    = $Param{Value}->{ $Param{Key} . '::TimeStop::Year' };
    }
    else {
        $Used = $Self->{ParamObject}->GetParam( Param => $Param{Key} );
        $StartMinute
            = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Minute' ) || 00;
        $StartHour = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Hour' )
            || 00;
        $StartDay   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Day' );
        $StartMonth = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Month' );
        $StartYear  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStart::Year' );
        $StopMinute = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Minute' )
            || 59;
        $StopHour = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Hour' )
            || 23;
        $StopDay   = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Day' );
        $StopMonth = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Month' );
        $StopYear  = $Self->{ParamObject}->GetParam( Param => $Param{Key} . '::TimeStop::Year' );
    }

    if (
        $Used
        && $StartMinute && $StartHour && $StartDay && $StartMonth && $StartYear
        && $StopMinute  && $StopHour  && $StopDay  && $StopMonth  && $StopYear
        )
    {

        # add hour, minutes and seconds,
        # so that that the first and the last day is selected as well
        my $StartDate = sprintf '%02d-%02d-%02d %02d:%02d:00'
            , $StartYear, $StartMonth, $StartDay, $StartHour, $StartMinute;
        my $StopDate = sprintf '%02d-%02d-%02d %02d:%02d:59'
            , $StopYear, $StopMonth, $StopDay, $StopHour, $StopMinute;

        return { '-between' => [ $StartDate, $StopDate ] };
    }

    return [];    # no conditions by default
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # just for convenience
    my $Key         = $Param{Key};
    my $PrefixStart = $Key . '::TimeStart::';
    my $PrefixStop  = $Key . '::TimeStop::';

    # get time related params
    my %GetParam;

    if ( $Param{Value} ) {
        %GetParam = %{ $Param{Value} }
    }
    else {
        $GetParam{$Key} = $Self->{ParamObject}->GetParam( Param => $Key );
        for my $TimeType ( $PrefixStart, $PrefixStop ) {
            for my $Part (qw( Year Month Day )) {
                my $ParamKey = $TimeType . $Part;
                my $ParamVal = $Self->{ParamObject}->GetParam( Param => $ParamKey );

                # remove white space on the start and end
                if ($ParamVal) {
                    $ParamVal =~ s{ \A \s+ }{}xms;
                    $ParamVal =~ s{ \s+ \z }{}xms;
                }

                # store in %GetParam
                $GetParam{$ParamKey} = $ParamVal;
            }
        }
    }

    # Build selection for the start and stop time.
    my $TimeStartSelectionString = $Self->{LayoutObject}->BuildDateSelection(
        Prefix           => $PrefixStart,
        Format           => 'DateInputFormatLong',
        YearPeriodPast   => 10,
        YearPeriodFuture => 10,
        %GetParam,
    );
    my $TimeStopSelectionString = $Self->{LayoutObject}->BuildDateSelection(
        Optional         => 0,
        Prefix           => $PrefixStop,
        Format           => 'DateInputFormatLong',
        YearPeriodPast   => 10,
        YearPeriodFuture => 10,
        %GetParam,
    );

    my $Checkbox = qq{<input type="hidden" name="$Key" value="1"/>};
    my $Between  = $Self->{LayoutObject}->{LanguageObject}->Get('Between');
    my $And      = $Self->{LayoutObject}->{LanguageObject}->Get('and');

    return "<div> $Checkbox $Between $TimeStartSelectionString </div>"
        . "<span style=\"margin-left: 27px;\"> $And </span> $TimeStopSelectionString";
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9PdXRwdXQvSFRNTC9JVFNNQ29uZmlnSXRlbUxheW91dER1bW15LnBtIC0gbGF5b3V0IGJhY2tlbmQgbW9kdWxlCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Ok91dHB1dDo6SFRNTDo6SVRTTUNvbmZpZ0l0ZW1MYXlvdXREdW1teTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6Ok91dHB1dDo6SFRNTDo6SVRTTUNvbmZpZ0l0ZW1MYXlvdXREdW1teSAtIGxheW91dCBiYWNrZW5kIG1vZHVsZQoKPWhlYWQxIFNZTk9QU0lTCgpBbGwgbGF5b3V0IGZ1bmN0aW9ucyBvZiBkdW1teSBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgICRCYWNrZW5kT2JqZWN0ID0gS2VybmVsOjpPdXRwdXQ6OkhUTUw6OklUU01Db25maWdJdGVtTGF5b3V0RHVtbXktPm5ldygKICAgICAgICAlUGFyYW0sCiAgICApOwoKPWN1dAoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGNoZWNrIG5lZWRlZCBvYmplY3RzCiAgICBmb3IgbXkgJE9iamVjdCAocXcoQ29uZmlnT2JqZWN0IEVuY29kZU9iamVjdCBMb2dPYmplY3QgTWFpbk9iamVjdCBQYXJhbU9iamVjdCBMYXlvdXRPYmplY3QpKSB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBPdXRwdXRTdHJpbmdDcmVhdGUoKQoKY3JlYXRlIG91dHB1dCBzdHJpbmcKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+T3V0cHV0U3RyaW5nQ3JlYXRlKCk7Cgo9Y3V0CgpzdWIgT3V0cHV0U3RyaW5nQ3JlYXRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGlmICggISRQYXJhbXtJdGVtfSApIHsKICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgTWVzc2FnZSAgPT4gJ05lZWQgSXRlbSEnLAogICAgICAgICk7CiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgIGlmICggIWRlZmluZWQgJFBhcmFte1ZhbHVlfSApIHsKICAgICAgICAkUGFyYW17VmFsdWV9ID0gJyc7CiAgICB9CgogICAgIyB0cmFuc2xhdGUKICAgIGlmICggJFBhcmFte0l0ZW19LT57SW5wdXR9LT57VHJhbnNsYXRpb259ICkgewogICAgICAgICRQYXJhbXtWYWx1ZX0gPSAkU2VsZi0+e0xheW91dE9iamVjdH0tPntMYW5ndWFnZU9iamVjdH0tPkdldCggJFBhcmFte1ZhbHVlfSApOwogICAgfQoKICAgIG15ICRMaW5rRmVhdHVyZSAgICA9IDE7CiAgICBteSAkSFRNTFJlc3VsdE1vZGUgPSAxOwoKICAgICMgZG8gbm90IHRyYW5zZm9ybSBsaW5rcyBpbiBwcmludCB2aWV3CiAgICBpZiAoICRQYXJhbXtQcmludH0gKSB7CiAgICAgICAgJExpbmtGZWF0dXJlID0gMDsKCiAgICAgICAgIyBkbyBub3QgY29udmVydCB3aGl0ZXNwYWNlIGFuZCBuZXdsaW5lcyBpbiBQREYgbW9kZQogICAgICAgIGlmICggJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoJ1BERicpICkgewogICAgICAgICAgICAkSFRNTFJlc3VsdE1vZGUgPSAwOwogICAgICAgIH0KICAgIH0KCiAgICAjIHRyYW5zZm9ybSBhc2NpaSB0byBodG1sCiAgICAkUGFyYW17VmFsdWV9ID0gJFNlbGYtPntMYXlvdXRPYmplY3R9LT5Bc2NpaTJIdG1sKAogICAgICAgIFRleHQgICAgICAgICAgID0+ICRQYXJhbXtWYWx1ZX0sCiAgICAgICAgSFRNTFJlc3VsdE1vZGUgPT4gJEhUTUxSZXN1bHRNb2RlLAogICAgICAgIExpbmtGZWF0dXJlICAgID0+ICRMaW5rRmVhdHVyZSwKICAgICk7CgogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEZvcm1EYXRhR2V0KCkKCmdldCBmb3JtIGRhdGEgYXMgaGFzaCByZWZlcmVuY2UKCiAgICBteSAkRm9ybURhdGFSZWYgPSAkQmFja2VuZE9iamVjdC0+Rm9ybURhdGFHZXQoKTsKCj1jdXQKCnN1YiBGb3JtRGF0YUdldCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhLZXkgSXRlbSkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JEFyZ3VtZW50fSApIHsKICAgICAgICAgICAgJFNlbGYtPntMb2dPYmplY3R9LT5Mb2coCiAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICAgICAgTWVzc2FnZSAgPT4gIk5lZWQgJEFyZ3VtZW50ISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgbXkgJUZvcm1EYXRhOwoKICAgICMgZ2V0IGZvcm0gZGF0YQogICAgJEZvcm1EYXRhe1ZhbHVlfSA9ICRTZWxmLT57UGFyYW1PYmplY3R9LT5HZXRQYXJhbSggUGFyYW0gPT4gJFBhcmFte0tleX0gKTsKCiAgICAjIHNldCBpbnZhbGlkIHBhcmFtCiAgICBpZiAoICRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e1JlcXVpcmVkfSAmJiAhJEZvcm1EYXRhe1ZhbHVlfSApIHsKICAgICAgICAkRm9ybURhdGF7SW52YWxpZH0gPSAxOwogICAgICAgICRQYXJhbXtJdGVtfS0+e0Zvcm19LT57ICRQYXJhbXtLZXl9IH0tPntJbnZhbGlkfSA9IDE7CiAgICB9CgogICAgcmV0dXJuIFwlRm9ybURhdGE7Cn0KCj1pdGVtIElucHV0Q3JlYXRlKCkKCmNyZWF0ZSBhIGlucHV0IHN0cmluZwoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5JbnB1dENyZWF0ZSgpOwoKPWN1dAoKc3ViIElucHV0Q3JlYXRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGZvciBteSAkQXJndW1lbnQgKHF3KEtleSBJdGVtKSkgewogICAgICAgIGlmICggISRQYXJhbXskQXJndW1lbnR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkQXJndW1lbnQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICBteSAkVmFsdWUgPSAkUGFyYW17VmFsdWV9OwogICAgaWYgKCAhZGVmaW5lZCAkUGFyYW17VmFsdWV9ICkgewogICAgICAgICRWYWx1ZSA9ICRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e1ZhbHVlRGVmYXVsdH0gfHwgJyc7CiAgICB9CgogICAgbXkgJENsYXNzICAgID0gJyc7CiAgICBteSAkU2l6ZSAgICAgPSAnVzUwcGMnOwogICAgbXkgJFJlcXVpcmVkID0gJFBhcmFte1JlcXVpcmVkfTsKICAgIG15ICRJbnZhbGlkICA9ICRQYXJhbXtJbnZhbGlkfTsKICAgIG15ICRJdGVtSWQgICA9ICRQYXJhbXtJdGVtSWR9OwoKICAgIGlmICgkUmVxdWlyZWQpIHsKICAgICAgICAkQ2xhc3MgLj0gJyBWYWxpZGF0ZV9SZXF1aXJlZCc7CiAgICB9CgogICAgaWYgKCRJbnZhbGlkKSB7CiAgICAgICAgJENsYXNzIC49ICcgU2VydmVyRXJyb3InOwogICAgfQogICAgJENsYXNzIC49ICcgJyAuICRTaXplOwogICAgbXkgJFN0cmluZyA9ICI8c3BhbiBzdHlsZT1cImRpc3BsYXk6IGlubGluZS1ibG9jazsgaGVpZ2h0OiAxLjNlbTtcIj4iOwogICAgJFN0cmluZwogICAgICAgIC49ICI8aW5wdXQgc3R5bGU9XCJkaXNwbGF5Om5vbmU7XCIgdHlwZT1cInRleHRcIiBuYW1lPVwiJFBhcmFte0tleX1cIiBjbGFzcz1cIiRDbGFzc1wiICI7CgogICAgaWYgKCRJdGVtSWQpIHsKICAgICAgICAkU3RyaW5nIC49ICJpZD1cIiRJdGVtSWRcIiAiOwogICAgfQoKICAgIGlmICgkVmFsdWUpIHsKCiAgICAgICAgIyB0cmFuc2xhdGUKICAgICAgICBpZiAoICRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e1RyYW5zbGF0aW9ufSApIHsKICAgICAgICAgICAgJFZhbHVlID0gJFNlbGYtPntMYXlvdXRPYmplY3R9LT57TGFuZ3VhZ2VPYmplY3R9LT5HZXQoJFZhbHVlKTsKICAgICAgICB9CgogICAgICAgICMgdHJhbnNmb3JtIGFzY2lpIHRvIGh0bWwKICAgICAgICAkVmFsdWUgPSAkU2VsZi0+e0xheW91dE9iamVjdH0tPkFzY2lpMkh0bWwoCiAgICAgICAgICAgIFRleHQgICAgICAgICAgID0+ICRWYWx1ZSwKICAgICAgICAgICAgSFRNTFJlc3VsdE1vZGUgPT4gMSwKICAgICAgICApOwogICAgfQoKICAgICRTdHJpbmcgLj0gInZhbHVlPVwiJFZhbHVlXCIgIjsKCiAgICAjIGFkZCBtYXhpbXVtIGxlbmd0aAogICAgaWYgKCAkUGFyYW17SXRlbX0tPntJbnB1dH0tPntNYXhMZW5ndGh9ICkgewogICAgICAgICRTdHJpbmcgLj0gIm1heGxlbmd0aD1cIiRQYXJhbXtJdGVtfS0+e0lucHV0fS0+e01heExlbmd0aH1cIiAiOwogICAgfQoKICAgICRTdHJpbmcgLj0gJy8+IDwvc3Bhbj4nOwoKICAgIHJldHVybiAkU3RyaW5nOwp9Cgo9aXRlbSBTZWFyY2hGb3JtRGF0YUdldCgpCgpnZXQgc2VhcmNoIGZvcm0gZGF0YQoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5TZWFyY2hGb3JtRGF0YUdldCgpOwoKPWN1dAoKc3ViIFNlYXJjaEZvcm1EYXRhR2V0IHsKICAgIHJldHVybiBbXTsKfQoKPWl0ZW0gU2VhcmNoSW5wdXRDcmVhdGUoKQoKY3JlYXRlIGEgc2VhcmNoIGlucHV0IHN0cmluZwoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5TZWFyY2hJbnB1dENyZWF0ZSgpOwoKPWN1dAoKc3ViIFNlYXJjaElucHV0Q3JlYXRlIHsKICAgIHJldHVybiAnJm5ic3A7JzsKfQoKMTsKCj1iYWNrCgo9aGVhZDEgVEVSTVMgQU5EIENPTkRJVElPTlMKClRoaXMgc29mdHdhcmUgaXMgcGFydCBvZiB0aGUgT1RSUyBwcm9qZWN0IChodHRwOi8vb3Rycy5vcmcvKS4KClRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCnRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIEw8aHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0Pi4KCj1jdXQK
# --
# Kernel/Output/HTML/ITSMConfigItemLayoutGeneralCatalog.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutGeneralCatalog;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutGeneralCatalog - layout backend module

=head1 SYNOPSIS

All layout functions of general catalog objects

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutGeneralCatalog->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(ConfigObject EncodeObject LogObject MainObject ParamObject DBObject LayoutObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => 11,       # (optional)
        Item => $ItemRef,
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    $Param{Value} //= '';

    # translate
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Param{Value} = $Self->{LayoutObject}->{LanguageObject}->Get( $Param{Value} );
    }

    return $Param{Value};
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} );

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,                # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $CSSClass = '';
    my $Required = $Param{Required};
    my $Invalid  = $Param{Invalid};
    my $ItemId   = $Param{ItemId};

    if ($Required) {
        $CSSClass .= 'Validate_Required';
    }

    if ($Invalid) {
        $CSSClass .= ' ServerError';
    }

    # translation on or off
    my $Translation = 0;
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Translation = 1;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    # reverse the class list
    my %ReverseClassList = reverse %{$ClassList};

    my $SelectedID;

    # get the current value
    if ( defined $Param{Value} ) {
        $SelectedID = $Param{Value};
    }

    # get the default id by default value
    else {
        $SelectedID = $ReverseClassList{ $Param{Item}->{Input}->{ValueDefault} || '' } || '';
    }

    # generate string
    my $String = $Self->{LayoutObject}->BuildSelection(
        Data         => $ClassList,
        Name         => $Param{Key},
        ID           => $ItemId,
        PossibleNone => 1,
        Translation  => $Translation,
        SelectedID   => $SelectedID,
        Class        => $CSSClass,
    );

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Key} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Key!',
        );
        return;
    }

    # get form data
    my @Values;
    if ( $Param{Value} ) {
        @Values = @{ $Param{Value} };
    }
    else {
        @Values = $Self->{ParamObject}->GetArray( Param => $Param{Key} );
    }

    return \@Values;
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Values = $Self->SearchFormDataGet(%Param);

    # translation on or off
    my $Translation = 0;
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Translation = 1;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    # generate string
    my $String = $Self->{LayoutObject}->BuildSelection(
        Data        => $ClassList,
        Name        => $Param{Key},
        Size        => 5,
        Multiple    => 1,
        Translation => $Translation,
        SelectedID  => $Values,
    );

    return $String;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/Output/HTML/ITSMConfigItemLayoutInteger.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutInteger;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutInteger - layout backend module

=head1 SYNOPSIS

All layout functions of integer objects

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutInteger->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject MainObject ParamObject LayoutObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => 11,       # (optional)
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    if ( !defined $Param{Value} ) {
        $Param{Value} = '';
    }

    return $Param{Value};
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} );

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,                # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # set min, max and default
    my $ValueMin = $Param{Item}->{Input}->{ValueMin} || 1;
    my $ValueMax = $Param{Item}->{Input}->{ValueMax} || 1;
    if ( $ValueMin > $ValueMax ) {
        $ValueMin = $ValueMax;
    }
    if (
        $Param{Item}->{Input}->{ValueDefault}
        && (
            $Param{Item}->{Input}->{ValueDefault} < $ValueMin
            || $Param{Item}->{Input}->{ValueDefault} > $ValueMax
        )
        )
    {
        $Param{Item}->{Input}->{ValueDefault} = '';
    }

    # create data array
    my $IntegerList = [];
    for my $Counter ( $ValueMin .. $ValueMax ) {
        push @{$IntegerList}, $Counter;
    }

    # generate string
    my $String = $Self->{LayoutObject}->BuildSelection(
        Data         => $IntegerList,
        Name         => $Param{Key},
        PossibleNone => 1,
        Translation  => 0,
        SelectedID   => $Param{Value} || $Param{Item}->{Input}->{ValueDefault} || '',
    );

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Key} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Key!'
        );
        return;
    }

    # get form data
    my @Values;
    if ( $Param{Value} ) {
        @Values = @{ $Param{Value} };
    }
    else {
        @Values = $Self->{ParamObject}->GetArray( Param => $Param{Key} );
    }

    return \@Values;
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # set min, max
    my $ValueMin = $Param{Item}->{Input}->{ValueMin} || 1;
    my $ValueMax = $Param{Item}->{Input}->{ValueMax} || 1;
    if ( $ValueMin > $ValueMax ) {
        $ValueMin = $ValueMax;
    }

    # set preselected value, either from previous selection or the default
    my $Values = $Self->SearchFormDataGet(%Param);

    # check whether the preselected value is within the valid range
    my @FilteredValues;
    VALUE:
    for my $Value ( @{$Values} ) {
        next VALUE if !defined $Value;
        next VALUE if !$Value;
        next VALUE if $Value < $ValueMin;
        next VALUE if $Value > $ValueMax;

        push @FilteredValues, $Value;
    }

    # create data array
    my @IntegerList = ( $ValueMin .. $ValueMax );

    # generate string
    my $String = $Self->{LayoutObject}->BuildSelection(
        Data        => \@IntegerList,
        Name        => $Param{Key},
        Size        => 5,
        Translation => 0,
        SelectedID  => \@FilteredValues,
        Multiple    => 1,
    );

    return $String;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/Output/HTML/ITSMConfigItemLayoutText.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutText;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutText - layout backend module

=head1 SYNOPSIS

All layout functions of text objects

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutText->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject MainObject ParamObject LayoutObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => 11,       # (optional)
        Item => $ItemRef,
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    if ( !defined $Param{Value} ) {
        $Param{Value} = '';
    }

    # translate
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Param{Value} = $Self->{LayoutObject}->{LanguageObject}->Get( $Param{Value} );
    }

    my $LinkFeature    = 1;
    my $HTMLResultMode = 1;

    # do not transform links in print view
    if ( $Param{Print} ) {
        $LinkFeature = 0;

        # do not convert whitespace and newlines in PDF mode
        if ( $Self->{ConfigObject}->Get('PDF') ) {
            $HTMLResultMode = 0;
        }
    }

    # transform ascii to html
    $Param{Value} = $Self->{LayoutObject}->Ascii2Html(
        Text           => $Param{Value},
        HTMLResultMode => $HTMLResultMode,
        LinkFeature    => $LinkFeature,
    );

    return $Param{Value};
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} );

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    # value was entered in the form, a regex is defined and the value does not match the regex
    if (
        $FormData{Value}
        && $Param{Item}->{Input}->{RegEx}
        && $FormData{Value} !~ m{ $Param{Item}->{Input}->{RegEx} }xms
        )
    {

        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{RegExErrorMessage}
            = $Param{Item}->{Input}->{RegExErrorMessage};
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,                # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Value = $Param{Value};
    if ( !defined $Param{Value} ) {
        $Value = $Param{Item}->{Input}->{ValueDefault} || '';
    }

    my $Class    = '';
    my $Size     = 'W50pc';
    my $Required = $Param{Required};
    my $Invalid  = $Param{Invalid};
    my $ItemId   = $Param{ItemId};

    if ($Required) {
        $Class .= ' Validate_Required';
    }

    if ($Invalid) {
        $Class .= ' ServerError';
    }
    $Class .= ' ' . $Size;
    my $String = "<input type=\"text\" name=\"$Param{Key}\" class=\"$Class\" ";

    if ($ItemId) {
        $String .= "id=\"$ItemId\" ";
    }

    if ($Value) {

        # translate
        if ( $Param{Item}->{Input}->{Translation} ) {
            $Value = $Self->{LayoutObject}->{LanguageObject}->Get($Value);
        }

        # transform ascii to html
        $Value = $Self->{LayoutObject}->Ascii2Html(
            Text           => $Value,
            HTMLResultMode => 1,
        );
    }

    $String .= "value=\"$Value\" ";

    # add maximum length
    if ( $Param{Item}->{Input}->{MaxLength} ) {
        $String .= "maxlength=\"$Param{Item}->{Input}->{MaxLength}\" ";
    }

    $String .= '/> ';

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Key} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Key!',
        );
        return;
    }

    # get form data
    my $Value;
    if ( $Param{Value} ) {
        $Value = $Param{Value};
    }
    else {
        $Value = $Self->{ParamObject}->GetParam( Param => $Param{Key} );
    }
    return $Value;
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Value = $Self->SearchFormDataGet(%Param);
    if ( !defined $Value ) {
        $Value = '';
    }

    my $String = qq{<input type="text" name="$Param{Key}" value="$Value" class="W50pc" >};

    return $String;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/Output/HTML/ITSMConfigItemLayoutTextArea.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemLayoutTextArea;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::ITSMConfigItemLayoutTextArea - layout backend module

=head1 SYNOPSIS

All layout functions of textarea objects

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::ITSMConfigItemLayoutTextArea->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject MainObject ParamObject LayoutObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    return $Self;
}

=item OutputStringCreate()

create output string

    my $Value = $BackendObject->OutputStringCreate(
        Value => 11,       # (optional)
        Item => $ItemRef,
    );

=cut

sub OutputStringCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    if ( !defined $Param{Value} ) {
        $Param{Value} = '';
    }

    # translate
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Param{Value} = $Self->{LayoutObject}->{LanguageObject}->Get( $Param{Value} );
    }

    my $LinkFeature    = 1;
    my $HTMLResultMode = 1;

    # do not transform links in print view
    if ( $Param{Print} ) {
        $LinkFeature = 0;

        # do not convert whitespace and newlines in PDF mode
        if ( $Self->{ConfigObject}->Get('PDF') ) {
            $HTMLResultMode = 0;
        }
    }

    # transform ascii to html
    $Param{Value} = $Self->{LayoutObject}->Ascii2Html(
        Text           => $Param{Value},
        HTMLResultMode => $HTMLResultMode,
        LinkFeature    => $LinkFeature,
    );

    return $Param{Value};
}

=item FormDataGet()

get form data as hash reference

    my $FormDataRef = $BackendObject->FormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub FormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my %FormData;

    # get form data
    $FormData{Value} = $Self->{ParamObject}->GetParam( Param => $Param{Key} );

    # set invalid param
    if ( $Param{Item}->{Input}->{Required} && !$FormData{Value} ) {
        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
    }

    # value was entered in the form, a regex is defined and the value does not match the regex
    if (
        $FormData{Value}
        && $Param{Item}->{Input}->{RegEx}
        && $FormData{Value} !~ m{ $Param{Item}->{Input}->{RegEx} }xms
        )
    {

        $FormData{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{Invalid} = 1;
        $Param{Item}->{Form}->{ $Param{Key} }->{RegExErrorMessage}
            = $Param{Item}->{Input}->{RegExErrorMessage};
    }

    return \%FormData;
}

=item InputCreate()

create a input string

    my $Value = $BackendObject->InputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,                # (optional)
        Item => $ItemRef,
    );

=cut

sub InputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Cols = $Param{Item}->{Input}->{Cols} || 58;
    my $Rows = $Param{Item}->{Input}->{Rows} || 10;

    my $Value = $Param{Value};
    if ( !defined $Param{Value} ) {
        $Value = $Param{Item}->{Input}->{ValueDefault} || '';
    }

    my $Class    = 'W50pc';
    my $Required = $Param{Required};
    my $Invalid  = $Param{Invalid};
    my $ItemId   = $Param{ItemId};

    if ($Required) {
        $Class .= ' Validate_Required';
    }

    if ($Invalid) {
        $Class .= ' ServerError';
    }

    # translate
    if ( $Param{Item}->{Input}->{Translation} ) {
        $Value = $Self->{LayoutObject}->{LanguageObject}->Get($Value);
    }
    my $String
        = "<textarea name=\"$Param{Key}\" id=\"$ItemId\" cols=\"$Cols\" rows=\"$Rows\" class=\"$Class\">$Value</textarea>";

    return $String;
}

=item SearchFormDataGet()

get search form data

    my $Value = $BackendObject->SearchFormDataGet(
        Key => 'Item::1::Node::3',
    );

=cut

sub SearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Key} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Key!',
        );
        return;
    }

    # get form data
    my $Value;
    if ( $Param{Value} ) {
        $Value = $Param{Value};
    }
    else {
        $Value = $Self->{ParamObject}->GetParam( Param => $Param{Key} );
    }
    return $Value;
}

=item SearchInputCreate()

create a search input string

    my $Value = $BackendObject->SearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub SearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    my $Value = $Self->SearchFormDataGet(%Param);
    if ( !defined $Value ) {
        $Value = '';
    }

    my $String = qq{<input type="text" name="$Param{Key}" value="$Value" class="W50pc">};

    return $String;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9PdXRwdXQvSFRNTC9JVFNNQ29uZmlnSXRlbU1lbnVHZW5lcmljLnBtCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Ok91dHB1dDo6SFRNTDo6SVRTTUNvbmZpZ0l0ZW1NZW51R2VuZXJpYzsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBjaGVjayBuZWVkZWQgb2JqZWN0cwogICAgZm9yIG15ICRPYmplY3QgKAogICAgICAgIHF3KENvbmZpZ09iamVjdCBFbmNvZGVPYmplY3QgTG9nT2JqZWN0IERCT2JqZWN0IExheW91dE9iamVjdCBDb25maWdJdGVtT2JqZWN0IFVzZXJJRCkKICAgICAgICApCiAgICB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9CgpzdWIgUnVuIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGlmICggISRQYXJhbXtDb25maWdJdGVtfSApIHsKICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZyggUHJpb3JpdHkgPT4gJ2Vycm9yJywgTWVzc2FnZSA9PiAnTmVlZCBDb25maWdJdGVtIScgKTsKICAgICAgICByZXR1cm47CiAgICB9CgogICAgIyBncmFudCBhY2Nlc3MgYnkgZGVmYXVsdAogICAgbXkgJEFjY2VzcyA9IDE7CgogICAgIyBnZXQgZ3JvdXBzCiAgICBteSAkQWN0aW9uID0gJFBhcmFte0NvbmZpZ30tPntBY3Rpb259OwogICAgaWYgKCAkQWN0aW9uIGVxICdBZ2VudExpbmtPYmplY3QnICkgewoKICAgICAgICAjIFRoZSBMaW5rLWxpbmsgaXMgYSBzcGVjaWFsIGNhc2UsIGFzIGl0IGlzIG5vdCBzcGVjaWZpYyB0byBJVFNNQ29uZmlnSXRlbS4KICAgICAgICAjIEFzIGEgd29ya2Fyb3VuZCB3ZSBoYXJkY29kZSB0aGF0IEFnZW50TGlua09iamVjdCBpcyB0cmVhdGVkIGxpa2UgQWdlbnRJVFNNQ29uZmlnSXRlbUVkaXQKICAgICAgICAkQWN0aW9uID0gJ0FnZW50SVRTTUNvbmZpZ0l0ZW1FZGl0JzsKICAgIH0KICAgIG15ICRHcm91cHNSbyA9ICRTZWxmLT57Q29uZmlnT2JqZWN0fS0+R2V0KCdGcm9udGVuZDo6TW9kdWxlJyktPnskQWN0aW9ufS0+e0dyb3VwUm99IHx8IFtdOwogICAgbXkgJEdyb3Vwc1J3ID0gJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoJ0Zyb250ZW5kOjpNb2R1bGUnKS0+eyRBY3Rpb259LT57R3JvdXB9ICAgfHwgW107CgogICAgIyBjaGVjayBwZXJtaXNzaW9uCiAgICBpZiAoICRBY3Rpb24gJiYgKCBAeyRHcm91cHNSb30gfHwgQHskR3JvdXBzUnd9ICkgKSB7CgogICAgICAgICMgZGVueSBhY2Nlc3MgYnkgZGVmYXVsdCwgd2hlbiB0aGVyZSBhcmUgZ3JvdXBzIHRvIGNoZWNrCiAgICAgICAgJEFjY2VzcyA9IDA7CgogICAgICAgICMgY2hlY2sgcmVhZCBvbmx5IGdyb3VwcwogICAgICAgIFJPR1JPVVA6CiAgICAgICAgZm9yIG15ICRSb0dyb3VwICggQHskR3JvdXBzUm99ICkgewoKICAgICAgICAgICAgbmV4dCBST0dST1VQIGlmICEkU2VsZi0+e0xheW91dE9iamVjdH0tPnsiVXNlcklzR3JvdXBSb1skUm9Hcm91cF0ifTsKICAgICAgICAgICAgbmV4dCBST0dST1VQIGlmICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+eyJVc2VySXNHcm91cFJvWyRSb0dyb3VwXSJ9IG5lICdZZXMnOwoKICAgICAgICAgICAgIyBzZXQgYWNjZXNzCiAgICAgICAgICAgICRBY2Nlc3MgPSAxOwogICAgICAgICAgICBsYXN0IFJPR1JPVVA7CiAgICAgICAgfQoKICAgICAgICAjIGNoZWNrIHJlYWQgd3JpdGUgZ3JvdXBzCiAgICAgICAgUldHUk9VUDoKICAgICAgICBmb3IgbXkgJFJ3R3JvdXAgKCBAeyRHcm91cHNSd30gKSB7CgogICAgICAgICAgICBuZXh0IFJXR1JPVVAgaWYgISRTZWxmLT57TGF5b3V0T2JqZWN0fS0+eyJVc2VySXNHcm91cFskUndHcm91cF0ifTsKICAgICAgICAgICAgbmV4dCBSV0dST1VQIGlmICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+eyJVc2VySXNHcm91cFskUndHcm91cF0ifSBuZSAnWWVzJzsKCiAgICAgICAgICAgICMgc2V0IGFjY2VzcwogICAgICAgICAgICAkQWNjZXNzID0gMTsKICAgICAgICAgICAgbGFzdCBSV0dST1VQOwogICAgICAgIH0KICAgIH0KCiAgICByZXR1cm4gJFBhcmFte0NvdW50ZXJ9IGlmICEkQWNjZXNzOwoKICAgICMgb3V0cHV0IG1lbnUgYmxvY2sKICAgICRTZWxmLT57TGF5b3V0T2JqZWN0fS0+QmxvY2soIE5hbWUgPT4gJ01lbnUnICk7CgogICAgIyBvdXRwdXQgbWVudSBpdGVtCiAgICAkU2VsZi0+e0xheW91dE9iamVjdH0tPkJsb2NrKAogICAgICAgIE5hbWUgPT4gJ01lbnVJdGVtJywKICAgICAgICBEYXRhID0+IHsKICAgICAgICAgICAgJVBhcmFtLAogICAgICAgICAgICAleyAkUGFyYW17Q29uZmlnSXRlbX0gfSwKICAgICAgICAgICAgJXsgJFBhcmFte0NvbmZpZ30gfSwKICAgICAgICB9LAogICAgKTsKICAgICRQYXJhbXtDb3VudGVyfSsrOwoKICAgIHJldHVybiAkUGFyYW17Q291bnRlcn07Cn0KCjE7Cg==
# --
# Kernel/Output/HTML/ITSMConfigItemOverviewSmall.pm
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::ITSMConfigItemOverviewSmall;

use strict;
use warnings;
use Kernel::System::HTMLUtils;

sub new {
    my ( $Type, %Param ) = @_;

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

    # get needed objects
    for my $Object (
        qw(ConfigObject LogObject DBObject LayoutObject UserID UserObject MainObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    $Self->{HTMLUtilsObject} = Kernel::System::HTMLUtils->new( %{$Self} );

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(PageShown StartHit)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # need ConfigItemIDs
    if ( !$Param{ConfigItemIDs} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need the ConfigItemIDs!',
        );
        return;
    }

    # define incident signals, needed for services
    my %InciSignals = (
        operational => 'greenled',
        warning     => 'yellowled',
        incident    => 'redled',
    );

    # store either ConfigItem IDs Locally
    my @ConfigItemIDs = @{ $Param{ConfigItemIDs} };

    # check ShowColumns parameter
    my @ShowColumns;
    if ( $Param{ShowColumns} && ref $Param{ShowColumns} eq 'ARRAY' ) {
        @ShowColumns = @{ $Param{ShowColumns} };
    }

    # build column header blocks
    if (@ShowColumns) {
        for my $Column (@ShowColumns) {

            # create needed veriables
            my $CSS = 'OverviewHeader';
            my $OrderBy;

            # remove ID if necesary
            if ( $Param{SortBy} ) {
                $Param{SortBy}
                    = ( $Param{SortBy} eq 'InciStateID' )
                    ? 'CurInciState'
                    : ( $Param{SortBy} eq 'DeplStateID' ) ? 'CurDeplState'
                    : ( $Param{SortBy} eq 'ClassID' )     ? 'Class'
                    : ( $Param{SortBy} eq 'ChangeTime' )  ? 'LastChanged'
                    :                                       $Param{SortBy};
            }

            # set the correct Set CSS class and order by link
            if ( $Param{SortBy} && ( $Param{SortBy} eq $Column ) ) {
                if ( $Param{OrderBy} && ( $Param{OrderBy} eq 'Up' ) ) {
                    $OrderBy = 'Down';
                    $CSS .= ' SortDescendingLarge';
                }
                else {
                    $OrderBy = 'Up';
                    $CSS .= ' SortAscendingLarge';
                }
            }
            else {
                $OrderBy = 'Up';
            }

            $Self->{LayoutObject}->Block(
                Name => 'Record' . $Column . 'Header',
                Data => {
                    %Param,
                    CSS     => $CSS,
                    OrderBy => $OrderBy,
                },
            );
        }

        # get the XML column headers only if the filter is not set to 'all'
        # and if there are CIs to show
        if ( $Param{Filter} && $Param{Filter} ne 'All' && @ConfigItemIDs ) {

            # get the version data of the first config item, including all the XML data
            # to get the column header names
            my $ConfigItem = $Self->{ConfigItemObject}->VersionGet(
                ConfigItemID => $ConfigItemIDs[0],
                XMLDataGet   => 1,
            );

            # convert the XML data into a hash
            my $ExtendedVersionData = $Self->_XMLData2Hash(
                XMLDefinition => $ConfigItem->{XMLDefinition},
                XMLData       => $ConfigItem->{XMLData}->[1]->{Version}->[1],
            );

            # get the xml columns (they contain ::)
            my @XMLShowColumns = grep /::/, @ShowColumns;

            COLUMN:
            for my $Column (@XMLShowColumns) {

                # check if column exists in CI-Data
                next COLUMN if !$ExtendedVersionData->{$Column}->{Name};

                # show the xml attribute header
                $Self->{LayoutObject}->Block(
                    Name => 'RecordXMLAttributeHeader',
                    Data => {
                        %Param,
                        XMLAttributeHeader => $ExtendedVersionData->{$Column}->{Name},
                    },
                );
            }
        }
    }

    my $Output  = '';
    my $Counter = 0;

    # show config items if there are some
    if (@ConfigItemIDs) {

        # to store all data
        my %Data;

        CONFIGITEMID:
        for my $ConfigItemID (@ConfigItemIDs) {
            $Counter++;
            if (
                $Counter >= $Param{StartHit}
                && $Counter < ( $Param{PageShown} + $Param{StartHit} )
                )
            {

                # check for access rights
                my $HasAccess = $Self->{ConfigItemObject}->Permission(
                    Scope  => 'Item',
                    ItemID => $ConfigItemID,
                    UserID => $Self->{UserID},
                    Type   => $Self->{Config}->{Permission},
                );

                next CONFIGITEMID if !$HasAccess;

                # get config item data
                my $ConfigItem = $Self->{ConfigItemObject}->VersionGet(
                    ConfigItemID => $ConfigItemID,
                    XMLDataGet   => 1,
                );

                next CONFIGITEMID if !$ConfigItem;

                # convert the XML data into a hash
                my $ExtendedVersionData = $Self->_XMLData2Hash(
                    XMLDefinition => $ConfigItem->{XMLDefinition},
                    XMLData       => $ConfigItem->{XMLData}->[1]->{Version}->[1],
                );

                # get the xml columns (they contain ::)
                my @XMLShowColumns = grep /::/, @ShowColumns;

                # store config item data,
                %Data = %{$ConfigItem};

                # build record block
                $Self->{LayoutObject}->Block(
                    Name => 'Record',
                    Data => {
                        %Param,
                        %Data,
                    },
                );

                # build column record blocks
                if (@ShowColumns) {
                    COLUMN:
                    for my $Column (@ShowColumns) {
                        $Self->{LayoutObject}->Block(
                            Name => 'Record' . $Column,
                            Data => {
                                %Param,
                                %Data,
                                CurInciSignal => $InciSignals{ $Data{CurInciStateType} },
                            },
                        );

                        # show links if available
                        $Self->{LayoutObject}->Block(
                            Name => 'Record' . $Column . 'LinkStart',
                            Data => {
                                %Param,
                                %Data,
                            },
                        );
                        $Self->{LayoutObject}->Block(
                            Name => 'Record' . $Column . 'LinkEnd',
                            Data => {
                                %Param,
                                %Data,
                            },
                        );
                    }

                    COLUMN:
                    for my $Column (@XMLShowColumns) {

                        # check if column exists in CI-Data
                        next COLUMN if !$ExtendedVersionData->{$Column}->{Name};

                        # convert to ascii text in case the value contains html
                        my $Value = $Self->{HTMLUtilsObject}
                            ->ToAscii( String => $ExtendedVersionData->{$Column}->{Value} ) || '';

                        # convert all whitespace and newlines to single spaces
                        $Value =~ s{ \s+ }{ }gxms;

                        # show the xml attribute data
                        $Self->{LayoutObject}->Block(
                            Name => 'RecordXMLAttribute',
                            Data => {
                                %Param,
                                XMLAttributeData => $Value,
                            },
                        );
                    }
                }
            }
        }
    }

    # if there are no config items to show, a no data found message is displayed in the table
    else {
        $Self->{LayoutObject}->Block(
            Name => 'NoDataFoundMsg',
            Data => {
                TotalColumns => scalar @ShowColumns,
            },
        );
    }

    # use template
    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'AgentITSMConfigItemOverviewSmall',
        Data         => {
            %Param,
            Type        => $Self->{ViewType},
            ColumnCount => scalar @ShowColumns,
        },
    );

    return $Output;
}

=over

=item _XMLData2Hash()

returns a hash reference with all xml data of a config item

Return

    $Data = {
        'HardDisk::2' => {
            Value => 'HD2',
            Name  => 'Hard Disk',
         },
        'CPU::1' => {
            Value => '',
            Name  => 'CPU',
        },
        'HardDisk::2::Capacity::1' => {
            Value => '780 GB',
            Name  => 'Capacity',
        },
    };

    my $Data = _XMLData2Hash(
        XMLDefinition => $Version->{XMLDefinition},
        XMLData       => $Version->{XMLData}->[1]->{Version}->[1],
        Data          => \%DataHashRef,                                 # optional
        Prefix        => 'HardDisk::1',                                 # optional
    );

=cut

sub _XMLData2Hash {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLData};
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    # to store the return data
    my $Data = $Param{Data} || {};

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # lookup value
            my $Value = $Self->{ConfigItemObject}->XMLValueLookup(
                Item => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content} || '',
            );

            # only if value is not empty
            if ($Value) {

                # create output string
                $Value = $Self->{LayoutObject}->ITSMConfigItemOutputStringCreate(
                    Value => $Value,
                    Item  => $Item,
                );
            }

            # add prefix
            my $Prefix = $Item->{Key} . '::' . $Counter;
            if ( $Param{Prefix} ) {
                $Prefix = $Param{Prefix} . '::' . $Prefix;
            }

            # store the item in hash
            $Data->{$Prefix} = {
                Name  => $Item->{Name},
                Value => $Value,
            };

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                $Data = $Self->_XMLData2Hash(
                    XMLDefinition => $Item->{Sub},
                    XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                    Prefix        => $Prefix,
                    Data          => $Data,
                );
            }
        }
    }

    return $Data;
}

1;

=back

# --
# Kernel/Output/HTML/LayoutITSMConfigItem.pm - provides generic HTML output for ITSMConfigItem
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::LayoutITSMConfigItem;

use strict;
use warnings;

=head1 NAME

Kernel::Output::HTML::LayoutITSMConfigItem - all ConfigItem-related HTML functions

=head1 SYNOPSIS

All ITSM Configuration Management-related HTML functions

=head1 PUBLIC INTERFACE

=over 4

=item ITSMConfigItemOutputStringCreate()

returns a output string

    my $String = $LayoutObject->ITSMConfigItemOutputStringCreate(
        Value => 11,       # (optional)
        Item  => $ItemRef,
        Print => 1,        # (optional, default 0)
    );

=cut

sub ITSMConfigItemOutputStringCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!'
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_ITSMLoadLayoutBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return '' if !$BackendObject;

    # generate output string
    my $String = $BackendObject->OutputStringCreate(%Param);

    return $String;
}

=item ITSMConfigItemFormDataGet()

returns the values from the html form as hash reference

    my $FormDataRef = $LayoutObject->ITSMConfigItemFormDataGet(
        Key          => 'Item::1::Node::3',
        Item         => $ItemRef,
        ConfigItemID => 123,
    );

=cut

sub ITSMConfigItemFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item ConfigItemID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # load backend
    my $BackendObject = $Self->_ITSMLoadLayoutBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return {} if !$BackendObject;

    # get form data
    my $FormData = $BackendObject->FormDataGet(%Param);

    return $FormData;
}

=item ITSMConfigItemInputCreate()

returns a input field html string

    my $String = $LayoutObject->ITSMConfigItemInputCreate(
        Key => 'Item::1::Node::3',
        Value => 11,                # (optional)
        Item => $ItemRef,
    );

=cut

sub ITSMConfigItemInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # load backend
    my $BackendObject = $Self->_ITSMLoadLayoutBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return '' if !$BackendObject;

    # lookup item value
    my $String = $BackendObject->InputCreate(%Param);

    return $String;
}

=item ITSMConfigItemSearchFormDataGet()

returns the values from the search html form

    my $ArrayRef = $LayoutObject->ITSMConfigItemSearchFormDataGet(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub ITSMConfigItemSearchFormDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # load backend
    my $BackendObject = $Self->_ITSMLoadLayoutBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return [] if !$BackendObject;

    # get form data
    my $Values = $BackendObject->SearchFormDataGet(%Param);

    return $Values;
}

=item ITSMConfigItemSearchInputCreate()

returns a search input field html string

    my $String = $LayoutObject->ITSMConfigItemSearchInputCreate(
        Key => 'Item::1::Node::3',
        Item => $ItemRef,
    );

=cut

sub ITSMConfigItemSearchInputCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # load backend
    my $BackendObject = $Self->_ITSMLoadLayoutBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return '' if !$BackendObject;

    # lookup item value
    my $String = $BackendObject->SearchInputCreate(%Param);

    return $String;
}

=item _ITSMLoadLayoutBackend()

load a input type backend module

    $BackendObject = $LayoutObject->_ITSMLoadLayoutBackend(
        Type => 'GeneralCatalog',
    );

=cut

sub _ITSMLoadLayoutBackend {
    my ( $Self, %Param ) = @_;

    if ( !$Param{Type} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Type!',
        );
        return;
    }

    my $GenericModule = "Kernel::Output::HTML::ITSMConfigItemLayout$Param{Type}";

    # load the backend module
    if ( !$Self->{MainObject}->Require($GenericModule) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't load backend module $Param{Type}!"
        );
        return;
    }

    # create new instance
    my $BackendObject = $GenericModule->new(
        %{$Self},
        %Param,
        LayoutObject => $Self,
    );

    if ( !$BackendObject ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't create a new instance of backend module $Param{Type}!",
        );
        return;
    }

    return $BackendObject;
}

=item ITSMConfigItemListShow()

Returns a list of configuration items as sortable list with pagination.

This function is similar to L<Kernel::Output::HTML::LayoutTicket::TicketListShow()>
in F<Kernel/Output/HTML/LayoutTicket.pm>.

    my $Output = $LayoutObject->ITSMConfigItemListShow(
        ConfigItemIDs => $ConfigItemIDsRef,                  # total list of config item ids, that can be listed
        Total         => scalar @{ $ConfigItemIDsRef },      # total number of list items, config items in this case
        View          => $Self->{View},                      # optional, the default value is 'Small'
        Filter        => 'All',
        Filters       => \%NavBarFilter,
        FilterLink    => $LinkFilter,
        TitleName     => 'Overview: Config Item: Computer',
        TitleValue    => $Self->{Filter},
        Env           => $Self,
        LinkPage      => $LinkPage,
        LinkSort      => $LinkSort,
        Frontend      => 'Agent',                           # optional (Agent|Customer), default: Agent, indicates from which frontend this function was called
    );

=cut

sub ITSMConfigItemListShow {
    my ( $Self, %Param ) = @_;

    # take object ref to local, remove it from %Param (prevent memory leak)
    my $Env = delete $Param{Env};

    # lookup latest used view mode
    if ( !$Param{View} && $Self->{ 'UserITSMConfigItemOverview' . $Env->{Action} } ) {
        $Param{View} = $Self->{ 'UserITSMConfigItemOverview' . $Env->{Action} };
    }

    # set frontend
    my $Frontend = $Param{Frontend} || 'Agent';

    # set defaut view mode to 'small'
    my $View = $Param{View} || 'Small';

    # store latest view mode
    $Self->{SessionObject}->UpdateSessionID(
        SessionID => $Self->{SessionID},
        Key       => 'UserITSMConfigItemOverview' . $Env->{Action},
        Value     => $View,
    );

    # get backend from config
    my $Backends = $Self->{ConfigObject}->Get('ITSMConfigItem::Frontend::Overview');
    if ( !$Backends ) {
        return $Env->{LayoutObject}->FatalError(
            Message => 'Need config option ITSMConfigItem::Frontend::Overview',
        );
    }

    # check for hash-ref
    if ( ref $Backends ne 'HASH' ) {
        return $Env->{LayoutObject}->FatalError(
            Message => 'Config option ITSMConfigItem::Frontend::Overview needs to be a HASH ref!',
        );
    }

    # check for config key
    if ( !$Backends->{$View} ) {
        return $Env->{LayoutObject}->FatalError(
            Message => "No config option found for the view '$View'!",
        );
    }

    # nav bar
    my $StartHit = $Self->{ParamObject}->GetParam(
        Param => 'StartHit',
    ) || 1;

    # get personal page shown count
    my $PageShownPreferencesKey = 'UserConfigItemOverview' . $View . 'PageShown';
    my $PageShown               = $Self->{$PageShownPreferencesKey} || 10;
    my $Group                   = 'ConfigItemOverview' . $View . 'PageShown';

    # check start option, if higher then elements available, set
    # it to the last overview page (Thanks to Stefan Schmidt!)
    if ( $StartHit > $Param{Total} ) {
        my $Pages = int( ( $Param{Total} / $PageShown ) + 0.99999 );
        $StartHit = ( ( $Pages - 1 ) * $PageShown ) + 1;
    }

    # get data selection
    my %Data;
    my $Config = $Self->{ConfigObject}->Get('PreferencesGroups');
    if ( $Config && $Config->{$Group} && $Config->{$Group}->{Data} ) {
        %Data = %{ $Config->{$Group}->{Data} };
    }

    # set page limit and build page nav
    my $Limit = $Param{Limit} || 20_000;
    my %PageNav = $Env->{LayoutObject}->PageNavBar(
        Limit     => $Limit,
        StartHit  => $StartHit,
        PageShown => $PageShown,
        AllHits   => $Param{Total} || 0,
        Action    => 'Action=' . $Env->{LayoutObject}->{Action},
        Link      => $Param{LinkPage},
    );

    # build shown ticket a page
    $Param{RequestedURL}    = "Action=$Self->{Action}";
    $Param{Group}           = $Group;
    $Param{PreferencesKey}  = $PageShownPreferencesKey;
    $Param{PageShownString} = $Self->BuildSelection(
        Name        => $PageShownPreferencesKey,
        SelectedID  => $PageShown,
        Data        => \%Data,
        Translation => 0,
    );

    # build navbar content
    $Env->{LayoutObject}->Block(
        Name => 'OverviewNavBar',
        Data => \%Param,
    );

    # back link
    if ( $Param{LinkBack} ) {
        $Env->{LayoutObject}->Block(
            Name => 'OverviewNavBarPageBack',
            Data => \%Param,
        );
    }

    # get filters
    if ( $Param{Filters} ) {

        # get given filters
        my @NavBarFilters;
        for my $Prio ( sort keys %{ $Param{Filters} } ) {
            push @NavBarFilters, $Param{Filters}->{$Prio};
        }

        # build filter content
        $Env->{LayoutObject}->Block(
            Name => 'OverviewNavBarFilter',
            Data => {
                %Param,
            },
        );

        # loop over filters
        my $Count = 0;
        for my $Filter (@NavBarFilters) {

            # increment filter count and build filter item
            $Count++;
            $Env->{LayoutObject}->Block(
                Name => 'OverviewNavBarFilterItem',
                Data => {
                    %Param,
                    %{$Filter},
                },
            );

            # filter is selected
            if ( $Filter->{Filter} eq $Param{Filter} ) {
                $Env->{LayoutObject}->Block(
                    Name => 'OverviewNavBarFilterItemSelected',
                    Data => {
                        %Param,
                        %{$Filter},
                    },
                );

            }
            else {
                $Env->{LayoutObject}->Block(
                    Name => 'OverviewNavBarFilterItemSelectedNot',
                    Data => {
                        %Param,
                        %{$Filter},
                    },
                );

            }
        }
    }

    # loop over configured backends
    for my $Backend ( sort keys %{$Backends} ) {

        # build navbar view mode
        $Env->{LayoutObject}->Block(
            Name => 'OverviewNavBarViewMode',
            Data => {
                %Param,
                %{ $Backends->{$Backend} },
                Filter => $Param{Filter},
                View   => $Backend,
            },
        );

        # current view is configured in backend
        if ( $View eq $Backend ) {
            $Env->{LayoutObject}->Block(
                Name => 'OverviewNavBarViewModeSelected',
                Data => {
                    %Param,
                    %{ $Backends->{$Backend} },
                    Filter => $Param{Filter},
                    View   => $Backend,
                },
            );
        }
        else {
            $Env->{LayoutObject}->Block(
                Name => 'OverviewNavBarViewModeNotSelected',
                Data => {
                    %Param,
                    %{ $Backends->{$Backend} },
                    Filter => $Param{Filter},
                    View   => $Backend,
                },
            );
        }
    }

    # check if page nav is available
    if (%PageNav) {
        $Env->{LayoutObject}->Block(
            Name => 'OverviewNavBarPageNavBar',
            Data => \%PageNav,
        );

        # don't show context settings in AJAX case (e. g. in customer ticket history),
        #   because the submit with page reload will not work there
        if ( !$Param{AJAX} ) {
            $Env->{LayoutObject}->Block(
                Name => 'ContextSettings',
                Data => {
                    %PageNav,
                    %Param,
                },
            );
        }
    }

    # build html content
    my $OutputNavBar = $Env->{LayoutObject}->Output(
        TemplateFile => 'AgentITSMConfigItemOverviewNavBar',
        Data         => {%Param},
    );

    # create output
    my $OutputRaw = '';
    if ( !$Param{Output} ) {
        $Env->{LayoutObject}->Print(
            Output => \$OutputNavBar,
        );
    }
    else {
        $OutputRaw .= $OutputNavBar;
    }

    # load module
    if ( !$Self->{MainObject}->Require( $Backends->{$View}->{Module} ) ) {
        return $Env->{LayoutObject}->FatalError();
    }

    # check for backend object
    my $Object = $Backends->{$View}->{Module}->new( %{$Env} );
    return if !$Object;

    # run module
    my $Output = $Object->Run(
        %Param,
        Limit     => $Limit,
        StartHit  => $StartHit,
        PageShown => $PageShown,
        AllHits   => $Param{Total} || 0,
        Frontend  => $Frontend,
    );

    # create output
    if ( !$Param{Output} ) {
        $Env->{LayoutObject}->Print(
            Output => \$Output,
        );
    }
    else {
        $OutputRaw .= $Output;
    }

    # create overview nav bar
    $Env->{LayoutObject}->Block(
        Name => 'OverviewNavBar',
        Data => {%Param},
    );

    # return content if available
    return $OutputRaw;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/Output/HTML/LinkObjectITSMConfigItem.pm - layout backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Output::HTML::LinkObjectITSMConfigItem;

use strict;
use warnings;

use Kernel::Output::HTML::Layout;
use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;
use Kernel::System::HTMLUtils;

=head1 NAME

Kernel::Output::HTML::LinkObjectITSMConfigItem - layout backend module

=head1 SYNOPSIS

All layout functions of link object (config item)

=over 4

=cut

=item new()

create an object

    $BackendObject = Kernel::Output::HTML::LinkObjectITSMConfigItem->new(
        %Param,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(ConfigObject LogObject MainObject DBObject UserObject EncodeObject
        QueueObject GroupObject ParamObject TimeObject LanguageObject UserLanguage UserID)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }
    $Self->{LayoutObject}         = Kernel::Output::HTML::Layout->new( %{$Self} );
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );
    $Self->{HTMLUtilsObject}      = Kernel::System::HTMLUtils->new( %{$Self} );

    # define needed variables
    $Self->{ObjectData} = {
        Object   => 'ITSMConfigItem',
        Realname => 'ConfigItem',
    };

    return $Self;
}

=item TableCreateComplex()

return an array with the block data

Return

    @BlockData = (
        {
            Object    => 'ITSMConfigItem',
            Blockname => 'ConfigItem Computer',
            Headline  => [
                {
                    Content => '',
                    Width   => 20,
                },
                {
                    Content => 'ConfigItem#',
                    Width   => 100,
                },
                {
                    Content => 'Name',
                },
                {
                    Content => 'Deployment State',
                    Width   => 130,
                },
                {
                    Content => 'Created',
                    Width   => 130,
                },
            ],
            ItemList => [
                [
                    {
                        Type             => 'CurInciSignal',
                        Key              => '123',
                        Content          => 'Incident',
                        CurInciStateType => 'incident',
                    },
                    {
                        Type    => 'Link',
                        Content => '123',
                        Link    => 'Action=AgentITSMConfigItemZoom;ConfigItemID=123',
                    },
                    {
                        Type      => 'Text',
                        Content   => 'The Name of the Config Item',
                        MaxLength => 50,
                    },
                    {
                        Type      => 'Text',
                        Content   => 'In Repair',
                        Translate => 1,
                    },
                    {
                        Type    => 'TimeLong',
                        Content => '2008-01-01 12:12:00',
                    },
                ],
                [
                    {
                        Type             => 'CurInciSignal',
                        Key              => '234',
                        Content          => 'Incident',
                        CurInciStateType => 'incident',
                    },
                    {
                        Type    => 'Link',
                        Content => '234',
                        Link    => 'Action=AgentITSMConfigItemZoom;ConfigItemID=234',
                    },
                    {
                        Type      => 'Text',
                        Content   => 'The Name of the Config Item 234',
                        MaxLength => 50,
                    },
                    {
                        Type      => 'Text',
                        Content   => 'Productive',
                        Translate => 1,
                    },
                    {
                        Type    => 'TimeLong',
                        Content => '2007-11-11 12:12:00',
                    },
                ],
            ],
        },
    );

    @BlockData = $LinkObject->TableCreateComplex(
        ObjectLinkListWithData => $ObjectLinkListRef,
    );

=cut

sub TableCreateComplex {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ObjectLinkListWithData} || ref $Param{ObjectLinkListWithData} ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ObjectLinkListWithData!',
        );
        return;
    }

    # get the column config
    my $ColumnConfig = $Self->{ConfigObject}->Get('LinkObject::ITSMConfigItem::ShowColumnsByClass');

    # get the configered columns and reorganize them by class name
    my %ColumnByClass;
    if ( $ColumnConfig && ref $ColumnConfig eq 'ARRAY' && @{$ColumnConfig} ) {

        NAME:
        for my $Name ( @{$ColumnConfig} ) {
            my ( $Class, $Column ) = split /::/, $Name, 2;

            next NAME if !$Column;

            push @{ $ColumnByClass{$Class} }, $Column;
        }
    }

    # convert the list
    my %LinkList;
    for my $LinkType ( sort keys %{ $Param{ObjectLinkListWithData} } ) {

        # extract link type List
        my $LinkTypeList = $Param{ObjectLinkListWithData}->{$LinkType};

        for my $Direction ( sort keys %{$LinkTypeList} ) {

            # extract direction list
            my $DirectionList = $Param{ObjectLinkListWithData}->{$LinkType}->{$Direction};

            CONFIGITEMID:
            for my $ConfigItemID ( sort keys %{$DirectionList} ) {

                # extract class
                my $Class = $DirectionList->{$ConfigItemID}->{Class} || '';

                next CONFIGITEMID if !$Class;

                $LinkList{$Class}->{$ConfigItemID}->{Data} = $DirectionList->{$ConfigItemID};
            }
        }
    }

    my @BlockData;
    for my $Class ( sort { lc $a cmp lc $b } keys %LinkList ) {

        # extract config item data
        my $ConfigItemList = $LinkList{$Class};

        # to store the column headline
        my @ShowColumnsHeadlines;

        # create the item list
        my @ItemList;
        for my $ConfigItemID (
            sort { $ConfigItemList->{$a}->{Data}->{Name} cmp $ConfigItemList->{$b}->{Data}->{Name} }
            keys %{$ConfigItemList}
            )
        {

            # extract version data
            my $Version = $ConfigItemList->{$ConfigItemID}->{Data};

            # make sure the column headline array is empty for each loop
            @ShowColumnsHeadlines = ();

            # get the version data, including all the XML data
            my $VersionXMLData = $Self->{ConfigItemObject}->VersionGet(
                ConfigItemID => $ConfigItemID,
                XMLDataGet   => 1,
            );

            # convert the XML data into a hash
            my $ExtendedVersionData = $Self->_XMLData2Hash(
                XMLDefinition => $VersionXMLData->{XMLDefinition},
                XMLData       => $VersionXMLData->{XMLData}->[1]->{Version}->[1],
            );

            my @ItemColumns = (
                {
                    Type             => 'CurInciSignal',
                    Key              => $ConfigItemID,
                    Content          => $Version->{CurInciState},
                    CurInciStateType => $Version->{CurInciStateType},
                },
                {
                    Type    => 'Link',
                    Content => $Version->{Number},
                    Link    => '$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID='
                        . $ConfigItemID,
                    Title => "ConfigItem# $Version->{Number} ($Version->{Class}): $Version->{Name}",
                },
            );

            # these columns will be added if no class based column config is defined
            my @AdditionalDefaultItemColumns = (
                {
                    Type      => 'Text',
                    Content   => $Version->{Name},
                    MaxLength => 50,
                },
                {
                    Type      => 'Text',
                    Content   => $Version->{CurDeplState},
                    Translate => 1,
                },
                {
                    Type    => 'TimeLong',
                    Content => $Version->{CreateTime},
                },
            );

            # individual column config for this class exists
            if ( $ColumnByClass{$Class} ) {

                COLUMN:
                for my $Column ( @{ $ColumnByClass{$Class} } ) {

                    # process some non-xml attributes
                    if ( $Version->{$Column} ) {

                        # handle the CI name
                        if ( $Column eq 'Name' ) {

                            # add the column
                            push @ItemColumns, {
                                Type      => 'Text',
                                Content   => $Version->{Name},
                                MaxLength => 50,
                            };

                            # add the headline
                            push @ShowColumnsHeadlines, {
                                Content => 'Name',
                            };
                        }

                        # special translation handling
                        elsif ( $Column eq 'CurDeplState' ) {

                            # add the column
                            push @ItemColumns, {
                                Type      => 'Text',
                                Content   => $Version->{$Column},
                                Translate => 1,
                            };

                            # add the headline
                            push @ShowColumnsHeadlines, {
                                Content => 'Deployment State',
                            };
                        }

                        # special translation handling
                        elsif ( $Column eq 'CurInciState' ) {

                            # add the column
                            push @ItemColumns, {
                                Type      => 'Text',
                                Content   => $Version->{$Column},
                                Translate => 1,
                            };

                            # add the headline
                            push @ShowColumnsHeadlines, {
                                Content => 'Incident State',
                            };
                        }

                        # special translation handling
                        elsif ( $Column eq 'Class' ) {

                            # add the column
                            push @ItemColumns, {
                                Type      => 'Text',
                                Content   => $Version->{$Column},
                                Translate => 1,
                            };

                            # add the headline
                            push @ShowColumnsHeadlines, {
                                Content => 'Class',
                            };
                        }

                        # special date/time handling
                        elsif ( $Column eq 'CreateTime' ) {

                            # add the column
                            push @ItemColumns, {
                                Type    => 'TimeLong',
                                Content => $Version->{CreateTime},
                            };

                            # add the headline
                            push @ShowColumnsHeadlines, {
                                Content => 'Created',
                            };
                        }

                        next COLUMN;
                    }

                    # convert to ascii text in case the value contains html
                    my $Value = $Self->{HTMLUtilsObject}
                        ->ToAscii( String => $ExtendedVersionData->{$Column}->{Value} ) || '';

                    # convert all whitespace and newlines to single spaces
                    $Value =~ s{ \s+ }{ }gxms;

                    # add the column
                    push @ItemColumns, {
                        Type    => 'Text',
                        Content => $Value,
                    };

                    # add the headline
                    push @ShowColumnsHeadlines, {
                        Content => $ExtendedVersionData->{$Column}->{Name} || '',
                    };
                }
            }

            # individual column config for this class does not exist,
            # so the default columns will be used
            else {

                # add the default columns
                push @ItemColumns, @AdditionalDefaultItemColumns;

                # add the default column headlines
                @ShowColumnsHeadlines = (
                    {
                        Content => 'Name',
                    },
                    {
                        Content => 'Deployment State',
                        Width   => 130,
                    },
                    {
                        Content => 'Created',
                        Width   => 130,
                    },
                );
            }

            push @ItemList, \@ItemColumns;
        }

        return if !@ItemList;

        # define the block data
        my %Block = (
            Object    => $Self->{ObjectData}->{Object},
            Blockname => $Self->{ObjectData}->{Realname} . ' (' . $Class . ')',
            Headline  => [
                {
                    Content => 'Incident State',
                    Width   => 20,
                },
                {
                    Content => 'ConfigItem#',
                    Width   => 100,
                },
            ],
            ItemList => \@ItemList,
        );

        # add the column headlines
        push @{ $Block{Headline} }, @ShowColumnsHeadlines;

        push @BlockData, \%Block;
    }

    return @BlockData;
}

=item TableCreateSimple()

return a hash with the link output data

Return

    %LinkOutputData = (
        Normal::Source => {
            ITSMConfigItem => [
                {
                    Type    => 'Link',
                    Content => 'CI:55555',
                    Title   => 'ConfigItem# 555555: The config item name',
                    Css     => 'style="text-decoration: line-through"',
                },
                {
                    Type    => 'Link',
                    Content => 'CI:22222',
                    Title   => 'ConfigItem# 22222: Title of config name 22222',
                },
            ],
        },
        ParentChild::Target => {
            ITSMConfigItem => [
                {
                    Type    => 'Link',
                    Content => 'CI:77777',
                    Title   => 'ConfigItem# 77777: ConfigItem name',
                },
            ],
        },
    );

    %LinkOutputData = $LinkObject->TableCreateSimple(
        ObjectLinkListWithData => $ObjectLinkListRef,
    );

=cut

sub TableCreateSimple {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ObjectLinkListWithData} || ref $Param{ObjectLinkListWithData} ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ObjectLinkListWithData!',
        );
        return;
    }

    my %LinkOutputData;
    for my $LinkType ( sort keys %{ $Param{ObjectLinkListWithData} } ) {

        # extract link type List
        my $LinkTypeList = $Param{ObjectLinkListWithData}->{$LinkType};

        for my $Direction ( sort keys %{$LinkTypeList} ) {

            # extract direction list
            my $DirectionList = $Param{ObjectLinkListWithData}->{$LinkType}->{$Direction};

            my @ItemList;
            for my $ConfigItemID ( sort { $a <=> $b } keys %{$DirectionList} ) {

                # extract config item data
                my $Version = $DirectionList->{$ConfigItemID};

                # define item data
                my %Item = (
                    Type    => 'Link',
                    Content => 'CI:' . $Version->{Number},
                    Title => "ConfigItem# $Version->{Number} ($Version->{Class}): $Version->{Name}",
                    Link  => '$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID='
                        . $ConfigItemID,
                );

                push @ItemList, \%Item;
            }

            # add item list to link output data
            $LinkOutputData{ $LinkType . '::' . $Direction }->{ITSMConfigItem} = \@ItemList;
        }
    }

    return %LinkOutputData;
}

=item ContentStringCreate()

return a output string

    my $String = $LayoutObject->ContentStringCreate(
        ContentData => $HashRef,
    );

=cut

sub ContentStringCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ContentData} ) {
        $Self->{LogObject}->Log( Priority => 'error', Message => 'Need ContentData!' );
        return;
    }

    # extract content
    my $Content = $Param{ContentData};

    return if $Content->{Type} ne 'CurInciSignal';

    # set incident signal
    my %InciSignals = (
        incident    => 'redled',
        operational => 'greenled',
        unknown     => 'grayled',
        warning     => 'yellowled',
    );

    # investigate current incident signal
    $Content->{CurInciStateType} ||= 'unknown';
    my $CurInciSignal = $InciSignals{ $Content->{CurInciStateType} };
    $CurInciSignal ||= $InciSignals{unknown};

    my $String = $Self->{LayoutObject}->Output(
        Template => '<div class="Flag Small" title="$QData{"CurInciState"}"> '
            . '<span class="$QData{"CurInciSignal"}"></span> </div>',
        Data => {
            CurInciSignal => $CurInciSignal,
            CurInciState => $Content->{Content} || '',
        },
    );

    return $String;
}

=item SelectableObjectList()

return an array hash with selectable objects

Return

    @SelectableObjectList = (
        {
            Key      => '-',
            Value    => 'ConfigItem',
            Disabled => 1,
        },
        {
            Key   => 'ITSMConfigItem::25',
            Value => 'ConfigItem::Computer',
        },
        {
            Key   => 'ITSMConfigItem::26',
            Value => 'ConfigItem::Software',
        },
        {
            Key   => 'ITSMConfigItem::27',
            Value => 'ConfigItem::Network',
        },
    );

    @SelectableObjectList = $LinkObject->SelectableObjectList(
        Selected => $Identifier,  # (optional)
    );

=cut

sub SelectableObjectList {
    my ( $Self, %Param ) = @_;

    # define headline
    my @ObjectSelectList;

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    return if !$ClassList;
    return if ref $ClassList ne 'HASH';

    # get the config with the default subobjects
    my $DefaultSubobject = $Self->{ConfigObject}->Get('LinkObject::DefaultSubObject') || {};

    CLASSID:
    for my $ClassID ( sort { lc $ClassList->{$a} cmp lc $ClassList->{$b} } keys %{$ClassList} ) {

        # show class only if user has access rights
        my $HasAccess = $Self->{ConfigItemObject}->Permission(
            Scope   => 'Class',
            ClassID => $ClassID,
            UserID  => $Self->{UserID},
            Type    => 'ro',
        );

        next CLASSID if !$HasAccess;

        my $Class = $ClassList->{$ClassID} || '';
        my $Identifier = $Self->{ObjectData}->{Object} . '::' . $ClassID;

        # set selected flag
        my $Selected;
        if ( $Param{Selected} ) {

            if ( $Param{Selected} eq $Identifier ) {
                $Selected = 1;
            }
            elsif (
                $Param{Selected} eq $Self->{ObjectData}->{Object}
                && $DefaultSubobject->{ $Self->{ObjectData}->{Object} }
                )
            {

                # extract default class name
                my $DefaultClass = $DefaultSubobject->{ $Self->{ObjectData}->{Object} } || '';

                # check class
                if ( $DefaultClass eq $Class ) {
                    $Selected = 1;
                }
            }
        }

        # create row
        my %Row = (
            Key      => $Identifier,
            Value    => $Self->{ObjectData}->{Realname} . '::' . $Class,
            Selected => $Selected,
        );

        push @ObjectSelectList, \%Row;
    }

    # only add headline if there are configitem classes
    # where the user has the permission to use them
    if (@ObjectSelectList) {

        # add headline as first array element
        unshift @ObjectSelectList, {
            Key      => '-',
            Value    => $Self->{ObjectData}->{Realname},
            Disabled => 1,
        };
    }

    return @ObjectSelectList;
}

=item SearchOptionList()

return an array hash with search options

Return

    @SearchOptionList = (
        {
            Key       => 'Number',
            Name      => 'ConfigItem#',
            InputStrg => $FormString,
            FormData  => '1234',
        },
        {
            Key       => 'Name',
            Name      => 'Name',
            InputStrg => $FormString,
            FormData  => 'BlaBla',
        },
    );

    @SearchOptionList = $LinkObject->SearchOptionList(
        SubObject => '25',  # (optional)
    );

=cut

sub SearchOptionList {
    my ( $Self, %Param ) = @_;

    # search option list
    my @SearchOptionList = (
        {
            Key  => 'Number',
            Name => 'ConfigItem#',
            Type => 'Text',
        },
        {
            Key  => 'Name',
            Name => 'Name',
            Type => 'Text',
        },
        {
            Key  => 'DeplStateIDs',
            Name => 'Deployment State',
            Type => 'List',
        },
        {
            Key  => 'InciStateIDs',
            Name => 'Incident State',
            Type => 'List',
        },
    );

    # add object dependence attributes
    #if ( $Param{SubObject} ) {
    #
    #    # get class list
    #    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
    #        Class => 'ITSM::ConfigItem::Class',
    #    );
    #
    #    if ( $ClassList && $ClassList eq 'HASH' ) {
    #
    #        # add here the search attributes of the subobject!
    #    }
    #}

    # add formkey
    for my $Row (@SearchOptionList) {
        $Row->{FormKey} = 'SEARCH::' . $Row->{Key};
    }

    # add form data and input string
    ROW:
    for my $Row (@SearchOptionList) {

        # prepare text input fields
        if ( $Row->{Type} eq 'Text' ) {

            # get form data
            $Row->{FormData} = $Self->{ParamObject}->GetParam( Param => $Row->{FormKey} );

            # parse the input text block
            $Self->{LayoutObject}->Block(
                Name => 'InputText',
                Data => {
                    Key => $Row->{FormKey},
                    Value => $Row->{FormData} || '',
                },
            );

            # add the input string
            $Row->{InputStrg} = $Self->{LayoutObject}->Output(
                TemplateFile => 'LinkObject',
            );

            next ROW;
        }

        # prepare list boxes
        if ( $Row->{Type} eq 'List' ) {

            # get form data
            my @FormData = $Self->{ParamObject}->GetArray( Param => $Row->{FormKey} );
            $Row->{FormData} = \@FormData;

            # prepare deployment state list
            my %ListData;
            if ( $Row->{Key} eq 'DeplStateIDs' ) {

                # get deployment state list
                my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
                    Class => 'ITSM::ConfigItem::DeploymentState',
                );

                # add list
                if ( $DeplStateList && ref $DeplStateList eq 'HASH' ) {
                    %ListData = %{$DeplStateList};
                }
            }

            # prepare incident state list
            elsif ( $Row->{Key} eq 'InciStateIDs' ) {

                # get incident state list
                my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
                    Class => 'ITSM::Core::IncidentState',
                );

                # add list
                if ( $InciStateList && ref $InciStateList eq 'HASH' ) {
                    %ListData = %{$InciStateList};
                }
            }

            # add the input string
            $Row->{InputStrg} = $Self->{LayoutObject}->BuildSelection(
                Data       => \%ListData,
                Name       => $Row->{FormKey},
                SelectedID => $Row->{FormData},
                Size       => 3,
                Multiple   => 1,
            );

            next ROW;
        }
    }

    return @SearchOptionList;
}

=item _XMLData2Hash()

returns a hash reference with all xml data of a config item

Return

    $Data = {
        'HardDisk::2' => {
            Value => 'HD2',
            Name  => 'Hard Disk',
         },
        'CPU::1' => {
            Value => '',
            Name  => 'CPU',
        },
        'HardDisk::2::Capacity::1' => {
            Value => '780 GB',
            Name  => 'Capacity',
        },
    };

    my $Data = $LinkObject->_XMLData2Hash(
        XMLDefinition => $Version->{XMLDefinition},
        XMLData       => $Version->{XMLData}->[1]->{Version}->[1],
        Data          => \%DataHashRef,                                 # optional
        Prefix        => 'HardDisk::1',                                 # optional
    );

=cut

sub _XMLData2Hash {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLData};
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    # to store the return data
    my $Data = $Param{Data} || {};

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # lookup value
            my $Value = $Self->{ConfigItemObject}->XMLValueLookup(
                Item => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content} || '',
            );

            # create output string
            $Value = $Self->{LayoutObject}->ITSMConfigItemOutputStringCreate(
                Value => $Value,
                Item  => $Item,
            );

            # add prefix
            my $Prefix = $Item->{Key} . '::' . $Counter;
            if ( $Param{Prefix} ) {
                $Prefix = $Param{Prefix} . '::' . $Prefix;
            }

            # store the item in hash
            $Data->{$Prefix} = {
                Name  => $Item->{Name},
                Value => $Value,
            };

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                $Data = $Self->_XMLData2Hash(
                    XMLDefinition => $Item->{Sub},
                    XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                    Prefix        => $Prefix,
                    Data          => $Data,
                );
            }
        }
    }

    return $Data;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEFBQUlUU01Db25maWdJdGVtLmR0bCAtICRUZXh0IHZhcmlhYmxlIGZpbGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgojIENvbW1vbgokVGV4dHsiQWRkcmVzcyJ9CiRUZXh0eyJBZG1pbiBUb29sIn0KJFRleHR7IkJhY2t1cCBEZXZpY2UifQokVGV4dHsiQmVhbWVyIn0KJFRleHR7IkJ1aWxkaW5nIn0KJFRleHR7IkNJSGlzdG9yeTo6Q29uZmlnSXRlbUNyZWF0ZSJ9CiRUZXh0eyJDSUhpc3Rvcnk6OkNvbmZpZ0l0ZW1EZWxldGUifQokVGV4dHsiQ0lIaXN0b3J5OjpEZWZpbml0aW9uVXBkYXRlIn0KJFRleHR7IkNJSGlzdG9yeTo6RGVwbG95bWVudFN0YXRlVXBkYXRlIn0KJFRleHR7IkNJSGlzdG9yeTo6SW5jaWRlbnRTdGF0ZVVwZGF0ZSJ9CiRUZXh0eyJDSUhpc3Rvcnk6OkxpbmtBZGQifQokVGV4dHsiQ0lIaXN0b3J5OjpMaW5rRGVsZXRlIn0KJFRleHR7IkNJSGlzdG9yeTo6TmFtZVVwZGF0ZSJ9CiRUZXh0eyJDSUhpc3Rvcnk6OlZhbHVlVXBkYXRlIn0KJFRleHR7IkNJSGlzdG9yeTo6VmVyc2lvbkNyZWF0ZSJ9CiRUZXh0eyJDSUhpc3Rvcnk6OlZlcnNpb25EZWxldGUifQokVGV4dHsiQ0lIaXN0b3J5OjpBdHRhY2htZW50QWRkIn0KJFRleHR7IkNJSGlzdG9yeTo6QXR0YWNobWVudERlbGV0ZSJ9CiRUZXh0eyJDUFUifQokVGV4dHsiQ2FtZXJhIn0KJFRleHR7IkNhcGFjaXR5In0KJFRleHR7IkNoYW5nZSBEZWZpbml0aW9uIn0KJFRleHR7IkNoYW5nZSBvZiBkZWZpbml0aW9uIGZhaWxlZCEgU2VlIFN5c3RlbSBMb2cgZm9yIGRldGFpbHMuIn0KJFRleHR7IkNsaWVudCBBcHBsaWNhdGlvbiJ9CiRUZXh0eyJDbGllbnQgT1MifQokVGV4dHsiQ29uY3VycmVudCBVc2VycyJ9CiRUZXh0eyJDb25maWcgSXRlbS1BcmVhIn0KJFRleHR7IkNvbmZpZyBJdGVtcyBhdmFpbGFibGUifQokVGV4dHsiQ29uZmlnIEl0ZW1zIHNob3duIn0KJFRleHR7IkNNREIifQokVGV4dHsiRGVtbyJ9CiRUZXh0eyJEZXNrdG9wIn0KJFRleHR7IkRldmVsb3BlciBMaWNlbmNlIn0KJFRleHR7IkRvY2tpbmcgU3RhdGlvbiJ9CiRUZXh0eyJEdXBsaWNhdGUifQokVGV4dHsiRW1iZWRkZWQifQokVGV4dHsiRW1wdHkgZmllbGRzIGluZGljYXRlIHRoYXQgdGhlIGN1cnJlbnQgdmFsdWVzIGFyZSBrZXB0In0KJFRleHR7IkVudGVycHJpc2UgTGljZW5jZSJ9CiRUZXh0eyJFeHBpcmF0aW9uIERhdGUifQokVGV4dHsiRXhwaXJlZCJ9CiRUZXh0eyJGUUROIn0KJFRleHR7IkZsb29yIn0KJFRleHR7IkZyZWV3YXJlIn0KJFRleHR7IkdTTSJ9CiRUZXh0eyJHYXRld2F5In0KJFRleHR7IkdyYXBoaWMgQWRhcHRlciJ9CiRUZXh0eyJIYXJkIERpc2sifQokVGV4dHsiSGFyZCBEaXNrOjpDYXBhY2l0eSJ9CiRUZXh0eyJIaWRlIFZlcnNpb25zIn0KJFRleHR7IklQIEFkZHJlc3MifQokVGV4dHsiSVAgb3ZlciBESENQIn0KJFRleHR7IklUIEZhY2lsaXR5In0KJFRleHR7IkluYWN0aXZlIn0KJFRleHR7IkluY2lkZW50In0KJFRleHR7Ikluc3RhbGwgRGF0ZSJ9CiRUZXh0eyJLZXlib3JkIn0KJFRleHR7IkxBTiJ9CiRUZXh0eyJMYXB0b3AifQokVGV4dHsiTGFzdCBDaGFuZ2UifQokVGV4dHsiTGljZW5jZSBLZXkifQokVGV4dHsiTGljZW5jZSBLZXk6OkV4cGlyYXRpb24gRGF0ZSJ9CiRUZXh0eyJMaWNlbmNlIEtleTo6UXVhbnRpdHkifQokVGV4dHsiTGljZW5jZSBUeXBlIn0KJFRleHR7Ik1haW50ZW5hbmNlIn0KJFRleHR7Ik1heGltdW0gbnVtYmVyIG9mIG9uZSBlbGVtZW50In0KJFRleHR7Ik1lZGlhIn0KJFRleHR7Ik1pZGRsZXdhcmUifQokVGV4dHsiTW9kZWwifQokVGV4dHsiTW9kZW0ifQokVGV4dHsiTW9uaXRvciJ9CiRUZXh0eyJNb3VzZSJ9CiRUZXh0eyJOZXR3b3JrIEFkYXB0ZXIifQokVGV4dHsiTmV0d29yayBBZGFwdGVyOjpJUCBBZGRyZXNzIn0KJFRleHR7Ik5ldHdvcmsgQWRhcHRlcjo6SVAgb3ZlciBESENQIn0KJFRleHR7Ik5ldHdvcmsgQWRkcmVzcyJ9CiRUZXh0eyJOZXR3b3JrIEFkZHJlc3M6OkdhdGV3YXkifQokVGV4dHsiTmV0d29yayBBZGRyZXNzOjpTdWJuZXQgTWFzayJ9CiRUZXh0eyJPcGVuIFNvdXJjZSJ9CiRUZXh0eyJPcGVyYXRpbmcgU3lzdGVtIn0KJFRleHR7Ik9wZXJhdGlvbmFsIn0KJFRleHR7Ik90aGVyIn0KJFRleHR7Ik90aGVyIEVxdWlwbWVudCJ9CiRUZXh0eyJPdXRsZXQifQokVGV4dHsiUENNQ0lBIENhcmQifQokVGV4dHsiUERBIn0KJFRleHR7IlBlciBOb2RlIn0KJFRleHR7IlBlciBQcm9jZXNzb3IifQokVGV4dHsiUGVyIFNlcnZlciJ9CiRUZXh0eyJQZXIgVXNlciJ9CiRUZXh0eyJQaG9uZSAxIn0KJFRleHR7IlBob25lIDIifQokVGV4dHsiUGlsb3QifQokVGV4dHsiUGxhbm5lZCJ9CiRUZXh0eyJQcmludGVyIn0KJFRleHR7IlByb2R1Y3Rpb24ifQokVGV4dHsiUXVhbnRpdHkifQokVGV4dHsiUmFjayJ9CiRUZXh0eyJSYW0ifQokVGV4dHsiUmVwYWlyIn0KJFRleHR7IlJldGlyZWQifQokVGV4dHsiUmV2aWV3In0KJFRleHR7IlJvb20ifQokVGV4dHsiUm91dGVyIn0KJFRleHR7IlNjYW5uZXIifQokVGV4dHsiU2VhcmNoIENvbmZpZyBJdGVtcyJ9CiRUZXh0eyJTZWN1cml0eSBEZXZpY2UifQokVGV4dHsiU2VyaWFsIE51bWJlciJ9CiRUZXh0eyJTZXJ2ZXIifQokVGV4dHsiU2VydmVyIEFwcGxpY2F0aW9uIn0KJFRleHR7IlNlcnZlciBPUyJ9CiRUZXh0eyJTaG93IFZlcnNpb25zIn0KJFRleHR7IlNpbmdsZSBMaWNlbmNlIn0KJFRleHR7IlN1Ym5ldCBNYXNrIn0KJFRleHR7IlN3aXRjaCJ9CiRUZXh0eyJUZWxjbyJ9CiRUZXh0eyJUZXN0L1FBIn0KJFRleHR7IlRoZSBkZXBsb3ltZW50IHN0YXRlIG9mIHRoaXMgY29uZmlnIGl0ZW0ifQokVGV4dHsiVGhlIGluY2lkZW50IHN0YXRlIG9mIHRoaXMgY29uZmlnIGl0ZW0ifQokVGV4dHsiVGltZSBSZXN0cmljdGVkIn0KJFRleHR7IlVTQiBEZXZpY2UifQokVGV4dHsiVW5saW1pdGVkIn0KJFRleHR7IlVzZXIgVG9vbCJ9CiRUZXh0eyJWb2x1bWUgTGljZW5jZSJ9CiRUZXh0eyJXTEFOIn0KJFRleHR7IldMQU4gQWNjZXNzIFBvaW50In0KJFRleHR7IldhcnJhbnR5IEV4cGlyYXRpb24gRGF0ZSJ9CiRUZXh0eyJXb3JrcGxhY2UifQo=
# --
# AdminITSMConfigItem.dtl - provides HTML form for AdminITSMConfigItem
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<!-- dtl:block:Overview -->
<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1>$Text{"Config Item Management"}</h1>

    <div class="SidebarColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>$Text{"Actions"}</h2>
            </div>
            <div class='Content'>
                <ul class="ActionList">
                    <li>
                        <form action="$Env{"CGIHandle"}" method="get">
                            <input type="hidden" name="Action" value="$Env{"Action"}"/>
                            <input type="hidden" name="Subaction" value="DefinitionChange"/>

                            <div>$Data{"ClassOptionStrg"}</div>
                            <button class="CallForAction" type="submit" value="$Text{"Add"}">
                                <span>$Text{"Change class definition"}</span>
                            </button>
                        </form>
                    </li>
<!--dtl:block:ActionOverview-->
                    <li>
                        <a href="$Env{"Baselink"}Action=$Env{"Action"}" class="CallForAction"><span>$Text{"Go to overview"}</span></a>
                    </li>
<!--dtl:block:ActionOverview-->
                </ul>
            </div>
        </div>
    </div>

    <div class="ContentColumn">
        <div class="WidgetSimple">
<!-- dtl:block:OverviewList -->
            <div class="Header">
                <h2>$Text{"List"}</h2>
            </div>
            <div class="Content">
                <table class="DataTable">
                    <thead>
                        <tr>
                            <th>$Text{"Config Item"} $Text{"Class"}</th>
                        </tr>
                    </thead>
                    <tbody>
<!-- dtl:block:OverviewListRow -->
                        <tr>
                            <td>
                                <a class="AsBlock" href="$Env{"Baselink"}Action=$Env{"Action"};Subaction=DefinitionList;ClassID=$LQData{"ClassID"}">$QData{"Name"}</a>
                            </td>
                        </tr>
<!-- dtl:block:OverviewListRow -->
                    </tbody>
                </table>
            </div>
<!-- dtl:block:OverviewList -->
<!-- dtl:block:DefinitionList -->
            <div class="Header">
                <h2>$Text{"List"}</h2>
            </div>
            <div class="Content">
                <table class="DataTable">
                    <thead>
                        <tr>
                            <th class="W50pc">$Text{"Config Item"} $Text{"Class"}</th>
                            <th>$Text{"Version"}</th>
                            <th>$Text{"Created by"}</th>
                            <th>$Text{"Created"}</th>
                        </tr>
                    </thead>
                    <tbody>
<!-- dtl:block:DefinitionListRow -->
                        <tr>
                            <td>
                                <a class="AsBlock" href="$Env{"Baselink"}Action=$Env{"Action"};Subaction=DefinitionView;DefinitionID=$LQData{"DefinitionID"}">$QData{"Class"}</a>
                            </td>
                            <td>$QData{"Version"}</td>
                            <td>$QData{"CreateByUser"}</td>
                            <td>$TimeLong{"$QData{"CreateTime"}"}</td>
                        </tr>
<!-- dtl:block:DefinitionListRow -->
                    </tbody>
                </table>
            </div>
<!-- dtl:block:DefinitionList -->
<!-- dtl:block:DefinitionView -->
            <div class="Header">
                <h2>$Text{"View"}: </h2>
            </div>
            <div class="Content">
                <fieldset class="TableLike">

                    <label>$Text{"Config Item"} $Text{"Class"}: </label>
                    <div class="Field">
                        $QData{"Class"}
                    </div>
                    <div class="Clear"></div>

                    <label>$Text{"Version"}: </label>
                    <div class="Field">
                        $QData{"Version"}
                    </div>
                    <div class="Clear"></div>

                    <label>$Text{"Created by"}: </label>
                    <div class="Field">
                        $QData{"CreateByUser"}
                    </div>
                    <div class="Clear"></div>

                    <label>$Text{"Created"}: </label>
                    <div class="Field">
                        $TimeLong{"$QData{"CreateTime"}"}
                    </div>
                    <div class="Clear"></div>

                    <label>$Text{"Definition"}: </label>
                    <div class="Field">
                        $Data{"DefinitionString"}
                    </div>
                    <div class="Clear"></div>

                </fieldset>
            </div>
<!-- dtl:block:DefinitionView -->
<!-- dtl:block:DefinitionChange -->
            <div class="Header">
                <h2>$Text{"Change"}: </h2>
            </div>
            <div class="Content">
                <form action="$Env{"CGIHandle"}" method="post">
                    <input type="hidden" name="Action" value="$Env{"Action"}"/>
                    <input type="hidden" name="Subaction" value="DefinitionSave"/>
                    <input type="hidden" name="ClassID" value="$QData{"ClassID"}"/>
                    <fieldset class="TableLike">


                        <label>$Text{"Config Item"} $Text{"Class"}: </label>
                        <div class="Field">
                            $QData{"Class"}
                        </div>
                        <div class="Clear"></div>

                        <label for="Definition">$Text{"Definition"}: </label>
                        <div class="Field">
                            <textarea name="Definition" id="Definition" rows="$QData{"Rows"}" cols="80" wrap="off">$QData{"Definition"}</textarea>
                        </div>
                        <div class="Clear"></div>

                        <div class="Field SpacingTop">
                            <button class="Primary" type="submit" id="Submit" value="$Text{"Submit"}">$Text{"Submit"}</button>
                            $Text{"or"}
                            <a href="$Env{"Baselink"}Action=$Env{"Action"}">$Text{"Cancel"}</a>
                        </div>
                        <div class="Clear"></div>

                    </fieldset>
                </form>
            </div>
<!-- dtl:block:DefinitionChange -->
        </div>
    </div>
    <div class="Clear"></div>
</div>
<!-- dtl:block:Overview -->

IyAtLQojIEFnZW50SVRTTUNvbmZpZ0l0ZW1BZGQuZHRsIC0gcHJvdmlkZXMgSFRNTCBmb3JtIGZvciBBZ2VudElUU01Db25maWdJdGVtQWRkCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKPGRpdiBjbGFzcz0iTWFpbkJveCBBUklBUm9sZU1haW4gTGF5b3V0Rml4ZWRTaWRlYmFyIFNpZGViYXJGaXJzdCI+CiAgICA8aDE+JFRleHR7IkFkZCJ9OiAkVGV4dHsiQ29uZmlnIEl0ZW0ifTwvaDE+CgogICAgPGRpdiBjbGFzcz0iU2lkZWJhckNvbHVtbiI+CgogICAgICAgIDxkaXYgY2xhc3M9IldpZGdldFNpbXBsZSI+CiAgICAgICAgICAgIDxkaXYgY2xhc3M9IkhlYWRlciI+CiAgICAgICAgICAgICAgICA8aDI+PGxhYmVsIGZvcj0iRmlsdGVyQ2xhc3NlcyI+JFRleHR7IkZpbHRlciBmb3IgQ2xhc3NlcyJ9PC9sYWJlbD48L2gyPgogICAgICAgICAgICA8L2Rpdj4KICAgICAgICAgICAgPGRpdiBjbGFzcz0iQ29udGVudCI+CiAgICAgICAgICAgICAgICA8aW5wdXQgdHlwZT0idGV4dCIgaWQ9IkZpbHRlckNsYXNzZXMiIGNsYXNzPSJXNTBwYyIgbmFtZT0iRmlsdGVyQ2xhc3NlcyIgdmFsdWU9IiIgdGl0bGU9IiRUZXh0eyJGaWx0ZXIgZm9yIENsYXNzZXMifSIgLz4KICAgICAgICAgICAgPC9kaXY+CiAgICAgICAgPC9kaXY+CgogICAgICAgIDxkaXYgY2xhc3M9IldpZGdldFNpbXBsZSI+CiAgICAgICAgICAgIDxkaXYgY2xhc3M9IkhlYWRlciI+CiAgICAgICAgICAgICAgICA8aDI+JFRleHR7IkhpbnQifTwvaDI+CiAgICAgICAgICAgIDwvZGl2PgogICAgICAgICAgICA8ZGl2IGNsYXNzPSJDb250ZW50Ij4KICAgICAgICAgICAgICAgIDxwIGNsYXNzPSJGaWVsZEV4cGxhbmF0aW9uIj4KICAgICAgICAgICAgICAgICAgICAkVGV4dHsiU2VsZWN0IGEgQ2xhc3MgZnJvbSB0aGUgbGlzdCB0byBjcmVhdGUgYSBuZXcgQ29uZmlnIEl0ZW0uIn0KICAgICAgICAgICAgICAgIDwvcD4KICAgICAgICAgICAgPC9kaXY+CiAgICAgICAgPC9kaXY+CgogICAgPC9kaXY+CgogICAgPGRpdiBjbGFzcz0iQ29udGVudENvbHVtbiI+CiAgICAgICAgPGRpdiBjbGFzcz0iV2lkZ2V0U2ltcGxlIj4KICAgICAgICAgICAgPGRpdiBjbGFzcz0iSGVhZGVyIj4KICAgICAgICAgICAgICAgIDxoMj4kVGV4dHsiTGlzdCJ9PC9oMj4KICAgICAgICAgICAgPC9kaXY+CiAgICAgICAgICAgIDxkaXYgY2xhc3M9IkNvbnRlbnQiPgogICAgICAgICAgICAgICAgPHRhYmxlIGNsYXNzPSJEYXRhVGFibGUiIGlkPSJDbGFzc2VzIj4KICAgICAgICAgICAgICAgICAgICA8dGhlYWQ+CiAgICAgICAgICAgICAgICAgICAgICAgIDx0cj4KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0aCBjbGFzcz0iVzEwMHBjIj4kVGV4dHsiQ2xhc3MifTwvdGg+CiAgICAgICAgICAgICAgICAgICAgICAgIDwvdHI+CiAgICAgICAgICAgICAgICAgICAgPC90aGVhZD4KICAgICAgICAgICAgICAgICAgICA8dGJvZHk+CiAgICAgICAgICAgICAgICAgICAgICAgIDx0ciBjbGFzcz0iRmlsdGVyTWVzc2FnZSBIaWRkZW4iPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPiRUZXh0eyJObyBtYXRjaGVzIGZvdW5kLiJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICAgICAgPC90cj4KPCEtLSBkdGw6YmxvY2s6T3ZlcnZpZXdJdGVtTGlzdCAtLT4KICAgICAgICAgICAgICAgICAgICAgICAgPHRyPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhIGhyZWY9IiRFbnZ7IkJhc2VsaW5rIn1BY3Rpb249QWdlbnRJVFNNQ29uZmlnSXRlbUVkaXQ7Q2xhc3NJRD0kTFFEYXRheyJDbGFzc0lEIn0iPiRUZXh0eyIkRGF0YXsiTmFtZSJ9In08L2E+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPgogICAgICAgICAgICAgICAgICAgICAgICA8L3RyPgo8IS0tIGR0bDpibG9jazpPdmVydmlld0l0ZW1MaXN0IC0tPgogICAgICAgICAgICAgICAgICAgIDwvdGJvZHk+CiAgICAgICAgICAgICAgICA8L3RhYmxlPgogICAgICAgICAgICA8L2Rpdj4KICAgICAgICA8L2Rpdj4KICAgIDwvZGl2PgogICAgPGRpdiBjbGFzcz0iQ2xlYXIiPjwvZGl2Pgo8L2Rpdj4KCjwhLS0gZHRsOmpzX29uX2RvY3VtZW50X2NvbXBsZXRlIC0tPgo8c2NyaXB0IHR5cGU9InRleHQvamF2YXNjcmlwdCI+Ly88IVtDREFUQVsKICAgIENvcmUuVUkuVGFibGUuSW5pdFRhYmxlRmlsdGVyKCQoJyNGaWx0ZXJDbGFzc2VzJyksICQoJyNDbGFzc2VzJykpOwovL11dPjwvc2NyaXB0Pgo8IS0tIGR0bDpqc19vbl9kb2N1bWVudF9jb21wbGV0ZSAtLT4K
# --
# AgentITSMConfigItemEdit.dtl - provides HTML form for AgentITSMConfigItemEdit
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<!--dtl:block:StartNormal-->
<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarLast">
    <h1>$Text{"Edit"}: $Text{"Config Item"}: $Text{"$Data{"Number"}"} - $Text{"Class"}: $QData{"Class"}</h1>
    <div class="ContentColumn">
<!--dtl:block:StartNormal-->
$Include{"AgentITSMCustomerSearch"}
        <form action="$Env{"CGIHandle"}" method="post" enctype="multipart/form-data" name="ClassItem" class="Validate PreventMultipleSubmits" id="ClassItem">
<!--dtl:block:StartSmall-->
            <div class="LayoutPopup ARIARoleMain">
                <div class="Header">
                    <h1>$Text{"Edit"}: $Text{"Config Item"}: $Text{"$Data{"Number"}"} - $Text{"Class"}: $QData{"Class"}</h1>
                    <p>
                        <a class="CancelClosePopup" href="#">$Text{"Cancel & close window"}</a>
                    </p>
                </div>
                <input type="hidden" name="ScreenType" value="Popup"/>
<!--dtl:block:StartSmall-->
                <div class="Content">
                    <input type="hidden" name="Action" value="$Env{"Action"}"/>
                    <input type="hidden" name="Subaction" value="VersionSave"/>
                    <input type="hidden" name="ClassID" value="$QData{"ClassID"}"/>
                    <input type="hidden" name="ConfigItemID" value="$QData{"ConfigItemID"}"/>
                    <input type="hidden" name="DuplicateID" value="$QData{"DuplicateID"}"/>
                    <input type="hidden" name="FormID" value="$QData{"FormID"}"/>
                    <fieldset class="TableLike">
<!-- dtl:block:RowName -->
                        <label class="Mandatory" for="Name"><span class="Marker">*</span> $Text{"Name"}: </label>
                        <div class="Field">
                            <input type="text" name="Name" id="Name" class="W50pc Validate_Required $QData{"RowNameInvalid"}" maxlength="250" value="$QData{"Name"}" title="$Text{"The name of this config item"}"/>
                            <div id="NameError" class="TooltipErrorMessage" ><p>$Text{"This field is required."}</p></div>
<!-- dtl:block:RowNameErrorDefault -->
                            <div id="NameServerError" class="TooltipErrorMessage"><p>$Text{"This field is required."}</p></div>
<!-- dtl:block:RowNameErrorDefault -->
<!-- dtl:block:RowNameErrorDuplicates -->
                            <div id="NameServerError" class="TooltipErrorMessage"><p>$Text{"Name is already in use by the ConfigItems with the following Number(s): %s", "$QData{"Duplicates"}"}</p></div>
<!-- dtl:block:RowNameErrorDuplicates -->
<!-- dtl:block:RowNameErrorRegEx -->
                            <div id="NameServerError" class="TooltipErrorMessage"><p>$Text{"$Data{"RegExErrorMessage"}"}</p></div>
<!-- dtl:block:RowNameErrorRegEx -->
                        </div>
                        <div class="Clear"></div>
<!-- dtl:block:RowName -->
<!-- dtl:block:RowDeplState -->
                        <label class="Mandatory" for="DeplStateID"><span class="Marker">*</span> $Text{"Deployment State"}: </label>
                        <div class="Field">
                            $Data{"DeplStateOptionStrg"}
                            <div id="DeplStateIDError" class="TooltipErrorMessage" ><p>$Text{"This field is required."}</p></div>
                            <div id="DeplStateIDServerError" class="TooltipErrorMessage"><p>$Text{"This field is required."}</p></div>
                        </div>
                        <div class="Clear"></div>
<!-- dtl:block:RowDeplState -->
<!-- dtl:block:RowInciState -->
                        <label class="Mandatory" for="InciStateID"><span class="Marker">*</span> $Text{"Incident State"}: </label>
                        <div class="Field">
                            $Data{"InciStateOptionStrg"}
                            <div id="InciStateIDError" class="TooltipErrorMessage" ><p>$Text{"This field is required."}</p></div>
                            <div id="InciStateIDServerError" class="TooltipErrorMessage"><p>$Text{"This field is required."}</p></div>
                        </div>
                        <div class="Clear"></div>
<!-- dtl:block:RowInciState -->
                    </fieldset>

<!-- dtl:block:XMLRow -->
<!-- dtl:block:XMLRowFieldsetStart -->
                    <fieldset class="TableLike">
<!-- dtl:block:XMLRowFieldsetStart -->
<!-- dtl:block:XMLRowValue -->
                        <label $Data{"LabelClass"} $Data{"LabelFor"}>
<!-- dtl:block:XMLRowValueContentRequired -->
                            <span class="Marker">*</span>
<!-- dtl:block:XMLRowValueContentRequired -->
                            $Text{"$Data{"Name"}"}:
                        </label>
                        <div class="$Data{"Class"} Field">
                            $Data{"InputString"}
<!-- dtl:block:XMLRowValueContentDelete -->
                            <button class="DisableValidation Remove" type="submit" name="$QData{"InputKey"}::Delete" value="$Text{"Delete"}">$Text{"Delete"}</button>
<!-- dtl:block:XMLRowValueContentDelete -->
                            <div id="$QData{"ItemID"}Error" class="TooltipErrorMessage" ><p>$Text{"This field is required."}</p></div>
<!-- dtl:block:XMLRowValueServerError -->
                            <div id="$QData{"ItemID"}ServerError" class="TooltipErrorMessage"><p>$Text{"This field is required."}</p></div>
<!-- dtl:block:XMLRowValueServerError -->
<!-- dtl:block:XMLRowValueRegExError -->
                            <div id="$QData{"ItemID"}ServerError" class="TooltipErrorMessage"><p>$Text{"$Data{"RegExErrorMessage"}"}</p></div>
<!-- dtl:block:XMLRowValueRegExError -->
                        </div>
<!-- dtl:block:XMLRowValue -->

<!-- dtl:block:XMLRowAddContent -->
                        <label $Data{"Class"} for="$QData{"ItemID"}">$Text{"$Data{"Name"}"}: </label>
                        <div class="Field">
                            <button class="DisableValidation Add" id="$QData{"ItemID"}" type="submit" name="$QData{"InputKey"}::Add" value="$Text{"Add"}" title="$Text{"$Data{"Description"}"}" ></button>
                        </div>
<!-- dtl:block:XMLRowAddContent -->

<!-- dtl:block:XMLRowFieldsetEnd -->
                    </fieldset>
<!-- dtl:block:XMLRowFieldsetEnd -->
<!-- dtl:block:XMLRow -->

<!-- dtl:block:AttachmentUpload -->
                    <fieldset class="TableLike">
                        <label>$Text{"Attachment"}:</label>
                        <div class="Field">
                            <ul>
<!-- dtl:block:Attachment -->
                                <li>
                                    $QData{"Filename"} ($QData{"Filesize"})
                                    <button type="submit" id="AttachmentDelete$QData{"FileID"}" name="AttachmentDelete$QData{"FileID"}" value="$Text{"Delete"}">$Text{"Delete"}</button>
<!--dtl:js_on_document_complete-->
<script type="text/javascript">//<![CDATA[
    $('#AttachmentDelete$QData{"FileID"}').bind('click', function () {
        Core.Form.Validate.DisableValidation($('#AttachmentDelete$QData{"FileID"}').closest('form'));
    });
//]]></script>
<!--dtl:js_on_document_complete-->
                                </li>
<!-- dtl:block:Attachment -->
                                <li>
                                    <input name="FileUpload" id="FileUpload" type="file" size="40"/>
                                    <input type="hidden" id="AttachmentUpload" name="AttachmentUpload" value="0" />
                                </li>
                            </ul>
                        </div>
                        <div class="Clear"></div>

<!--dtl:js_on_document_complete-->
<script type="text/javascript">//<![CDATA[
    $('#FileUpload').bind('change', function (Event) {
        var $Form = $('#FileUpload').closest('form');
        Core.Form.Validate.DisableValidation($Form);
        $Form.find('#AttachmentUpload').val('1').end().submit();
    });
//]]></script>
<!--dtl:js_on_document_complete-->

                    </fieldset>
<!-- dtl:block:AttachmentUpload -->

                    <fieldset class="TableLike">
                        <div class="Field SpacingTop">
                            <button name="SubmitSave" class="Primary" type="submit" value="$Text{"Save"}">$Text{"Submit"}</button>
                        </div>
                    </fieldset>
                </div>

<!-- dtl:block:EndSmall -->
            </div>
<!-- dtl:block:EndSmall -->
        </form>
<!-- dtl:block:EndNormal -->
    </div>
    <div class="Clear"></div>
</div>
<!-- dtl:block:EndNormal -->


<!-- dtl:js_on_document_complete -->
        <script type="text/javascript">//<![CDATA[
            $('.DisableValidation').bind('click', function (Event) {
                Core.Form.Validate.DisableValidation($('#ClassItem'));
                // fix for Safari: race condition with submit in Core.Form.Validate.js
                // fixed in OTRS 3.0.5, this line remains here for backwards compatibility reasons
                $('#ClassItem').removeClass('PreventMultipleSubmits');
            });
        //]]></script>
<!-- dtl:js_on_document_complete -->

IyAtLQojIEFnZW50SVRTTUNvbmZpZ0l0ZW1IaXN0b3J5LmR0bCAtIHByb3ZpZGVzIEhUTUwgZm9ybSBmb3IgaGlzdG9yeQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCjwhLS0gc3RhcnQgZm9ybSAtLT4KPGRpdiBjbGFzcz0iTGF5b3V0UG9wdXAgQVJJQVJvbGVNYWluIj4KCiAgICA8ZGl2IGNsYXNzPSJIZWFkZXIiPgogICAgICAgIDxoMT4KICAgICAgICAgICAgJFRleHR7Ikhpc3Rvcnkgb2YifSBDb25maWcgSXRlbTogJERhdGF7Ik5hbWUifQogICAgICAgIDwvaDE+CiAgICAgICAgPHA+CiAgICAgICAgICAgIDxhIGhyZWY9IiMiIGNsYXNzPSJDYW5jZWxDbG9zZVBvcHVwIj4kVGV4dHsiQ2FuY2VsICYgY2xvc2Ugd2luZG93In08L2E+CiAgICAgICAgPC9wPgogICAgPC9kaXY+CgogICAgPGRpdiBjbGFzcz0iQ29udGVudCI+CiAgICAgICAgPGRpdiBjbGFzcz0iV2lkZ2V0U2ltcGxlIj4KICAgICAgICAgICAgPGRpdiBjbGFzcz0iSGVhZGVyIj4KICAgICAgICAgICAgICAgIDxoMj4KICAgICAgICAgICAgICAgICAgICAkVGV4dHsiSGlzdG9yeSBDb250ZW50In0KICAgICAgICAgICAgICAgIDwvaDI+CiAgICAgICAgICAgIDwvZGl2PgogICAgICAgICAgICA8ZGl2IGNsYXNzPSJDb250ZW50Ij4KICAgICAgICAgICAgICAgIDx0YWJsZSBzdW1tYXJ5PSJDb25maWd1cmF0aW9uIEl0ZW0gSGlzdG9yeSIgY2xhc3M9IkRhdGFUYWJsZSI+CiAgICAgICAgICAgICAgICAgICAgPHRoZWFkPgogICAgICAgICAgICAgICAgICAgICAgICA8dHI+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8dGg+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJFRleHR7IkFjdGlvbiJ9CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RoPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRoPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRUZXh0eyJDb21tZW50In0KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGg+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8dGg+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJFRleHR7Ilpvb20ifQogICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90aD4KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0aD4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAkVGV4dHsiVXNlciJ9CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RoPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRoPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRUZXh0eyJDcmVhdGV0aW1lIn0KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGg+CiAgICAgICAgICAgICAgICAgICAgICAgIDwvdHI+CiAgICAgICAgICAgICAgICAgICAgPC90aGVhZD4KICAgICAgICAgICAgICAgICAgICA8dGJvZHk+CjwhLS0gZHRsOmJsb2NrOlJvdyAtLT4KICAgICAgICAgICAgICAgICAgICAgICAgPHRyPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRRdW90ZXsiJERhdGF7Ikhpc3RvcnlUeXBlIn0ifQogICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90ZD4KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDx0ZD4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8ZGl2PiRRRGF0YXsiQ29tbWVudCJ9PC9kaXY+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIGNsYXNzPSJDZW50ZXIiPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhICBjbGFzcz0iTGlua1pvb21WaWV3IEFzQmxvY2siIGhyZWY9IiRFbnZ7IkJhc2VsaW5rIn1BY3Rpb249QWdlbnRJVFNNQ29uZmlnSXRlbVpvb207Q29uZmlnSXRlbUlEPSREYXRheyJDb25maWdJdGVtSUQifTtWZXJzaW9uSUQ9JERhdGF7IlZlcnNpb25JRCJ9Ij4kVGV4dHsiWm9vbSB2aWV3In08L2E+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICRRRGF0YXsiVXNlckZ1bGxuYW1lIn0KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGQ+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQ+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJFRpbWVMb25neyIkRGF0YXsiQ3JlYXRlVGltZSJ9In0KICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvdGQ+CiAgICAgICAgICAgICAgICAgICAgICAgIDwvdHI+CjwhLS0gZHRsOmJsb2NrOlJvdyAtLT4KICAgICAgICAgICAgICAgICAgICA8L3Rib2R5PgogICAgICAgICAgICAgICAgPC90YWJsZT4KICAgICAgICAgICAgPC9kaXY+CiAgICAgICAgPC9kaXY+CjwhLS1kdGw6anNfb25fZG9jdW1lbnRfY29tcGxldGUtLT4KPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPi8vPCFbQ0RBVEFbCiAgICAkKCdhLkxpbmtab29tVmlldycpLmJpbmQoJ2NsaWNrJywgZnVuY3Rpb24gKCkgewogICAgICAgIHdpbmRvdy5vcGVuZXIuQ29yZS5VSS5Qb3B1cC5GaXJlUG9wdXBFdmVudCgnVVJMJywgeyBVUkw6ICQodGhpcykuYXR0cignaHJlZicpfSk7CiAgICAgICAgd2luZG93LmNsb3NlKCk7CiAgICB9KTsKLy9dXT48L3NjcmlwdD4KPCEtLWR0bDpqc19vbl9kb2N1bWVudF9jb21wbGV0ZS0tPgogICAgPC9kaXY+CiAgICA8ZGl2IGNsYXNzPSJGb290ZXIiPgogICAgPC9kaXY+CjwvZGl2Pgo8IS0tIGVuZCBmb3JtIC0tPgo=
# --
# AgentITSMConfigItemOverviewNavBar.dtl - html for configuration item overview table
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --
<!-- dtl:block:OverviewNavBar -->
<div class="OverviewBox ARIARoleMain $QData{"View"}">
    <h1>$Text{"$Data{"TitleName"}"}: $Text{"$Data{"TitleValue"}"}</h1>

    $Data{"DataInTheMiddle"}

    <div class="OverviewControl" id="OverviewControl">
        <div>
            <div class="ControlRow">
<!-- dtl:block:OverviewNavBarFilter -->
                <ul class="Tabs">
<!-- dtl:block:OverviewNavBarFilterItem -->
<!-- dtl:block:OverviewNavBarFilterItemSelected -->
                    <li class="Active $QData{"CSS"}">
                        <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"FilterLink"}Filter=$LQData{"Filter"}">$Text{"$Data{"Name"}"}<span>$QData{"Count"}</span></a>
                    </li>
<!-- dtl:block:OverviewNavBarFilterItemSelected -->
<!-- dtl:block:OverviewNavBarFilterItemSelectedNot -->
                    <li class="$QData{"CSS"}">
                        <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"FilterLink"}Filter=$LQData{"Filter"}">$Text{"$Data{"Name"}"}<span>$QData{"Count"}</span></a>
                    </li>
<!-- dtl:block:OverviewNavBarFilterItemSelectedNot -->
<!-- dtl:block:OverviewNavBarFilterItemSplit -->
                    -
<!-- dtl:block:OverviewNavBarFilterItemSplit -->
<!-- dtl:block:OverviewNavBarFilterItem -->
                </ul>
<!-- dtl:block:OverviewNavBarFilter -->
<!-- dtl:block:OverviewNavBarPageBack -->
                <ul class="Tabs">
                    <li>
                        <a id="ITSMConfigItemSearch" href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkBack"}">$Text{"Change search options"}</a>
                    </li>
                </ul>
<!--dtl:js_on_document_complete-->
<script type="text/javascript">//<![CDATA[
    $('#ITSMConfigItemSearch').bind('click', function (Event) {
        ITSM.Agent.ConfigItem.Search.OpenSearchDialog( 'AgentITSMConfigItemSearch', '$QData{"Profile"}', '$QData{"ClassID"}' );
        return false;
    });
//]]></script>
<!--dtl:js_on_document_complete-->
<!-- dtl:block:OverviewNavBarPageBack -->

<!-- dtl:block:ContextSettings -->
                <ul class="ContextFunctions">
                    <li class="ContextSettings">
                        <a href="#" id="ShowContextSettingsDialog" title="$Text{"Context Settings"}"><span>$Text{"Context Settings"}</span></a>
                    </li>
                </ul>

                <div id="ContextSettingsDialogContainer" class="Hidden">
                    <form action="$Env{"CGIHandle"}" method="post" id="ContextSettingsDialog">
                        <input type="hidden" name="Action" value="AgentPreferences"/>
                        <input type="hidden" name="Subaction" value="Update"/>
                        <input type="hidden" name="Group" value="$QData{"Group"}"/>
                        <input type="hidden" name="RedirectURL" value="$QData{"RequestedURL"}"/>
                        <fieldset class="TableLike">
                            <label for="$QData{"PreferencesKey"}">$Text{"Config Items per page"}:</label>
                            <div class="Field">
                                $Data{"PageShownString"}
                            </div>
                            <div class="Clear"></div>
                        </fieldset>
                    </form>
                </div>

<!-- dtl:js_on_document_complete -->
<script type="text/javascript">//<![CDATA[
    // bind the ContextSettingsDialogContainer
    $('#ShowContextSettingsDialog').bind('click', function (Event) {
        Core.UI.Dialog.ShowContentDialog($('#ContextSettingsDialogContainer'), '$JSText{"Settings"}', '20%', 'Center', true,
            [
                {
                    Label: '$JSText{"Submit"}',
                    Type: 'Submit',
                    Class: 'Primary'
                }
            ]
        );
        Event.preventDefault();
        Event.stopPropagation();
        return false;
    });
//]]></script>
<!-- dtl:js_on_document_complete -->
<!-- dtl:block:ContextSettings -->

            </div>
            <div class="ActionRow">
                <div class="OverviewActions">
                    $Data{"ActionRow"}
                    <ul class="OverviewZoom">

<!-- dtl:block:OverviewNavBarViewMode -->
<!-- dtl:block:OverviewNavBarViewModeSelected -->
                        <li class="Active">
                            <a class="$QData{"Name"}" href="$Env{"Baselink"}Action=$Env{"Action"};Filter=$LQData{"Filter"};View=$LQData{"View"};$Data{"LinkFilter"}" title="$Text{"$Data{"Name"}"}">
                                <span class="ImageMode">
                                    <span class="NameShort">$Text{"$Data{"NameShort"}"}</span>
                                    <span class="NameLong">$Text{"$Data{"Name"}"}</span>
                                </span>
                            </a>
                        </li>
<!-- dtl:block:OverviewNavBarViewModeSelected -->
<!-- dtl:block:OverviewNavBarViewModeNotSelected -->
                        <li>
                            <a class="$QData{"Name"}" name="OverviewControl" href="$Env{"Baselink"}Action=$Env{"Action"};Filter=$LQData{"Filter"};View=$LQData{"View"};$Data{"LinkFilter"}" title="$Text{"$Data{"Name"}"}">
                                <span class="ImageMode">
                                    <span class="NameShort">$Text{"$Data{"NameShort"}"}</span>
                                    <span class="NameLong">$Text{"$Data{"Name"}"}</span>
                                </span>
                            </a>
                        </li>
<!-- dtl:block:OverviewNavBarViewModeNotSelected -->
<!-- dtl:block:OverviewNavBarViewMode -->
                    </ul>
                    <span class="Pagination">
<!-- dtl:block:OverviewNavBarPageNavBar -->
                        $Data{"ResultLong"}
                        $Data{"SiteNavBarLong"}
<!-- dtl:block:OverviewNavBarPageNavBar -->
                    </span>
                    <div class="ClearLeft"></div>
                </div>
# sort order bar if needed
                $Data{"SortOrderBar"}
            </div>
        </div>
    </div>
</div>
<!-- dtl:block:OverviewNavBar -->

# --
# AgentITSMConfigItemOverviewSmall.dtl - html for configuration item overview table
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --
<!-- dtl:js_on_document_complete -->
<script type="text/javascript">//<![CDATA[
    Core.UI.ActionRow.Init();
//]]></script>
<!-- dtl:js_on_document_complete -->

<div id="OverviewBody" class="Overview TicketList">
    <table class="TableSmall" summary="A generic ITSM Configuration Item table">
        <thead>
            <tr>
<!-- dtl:block:RecordCurInciSignalHeader -->
                <th>
                    <span>$Text{"State"}</span>
                </th>
<!-- dtl:block:RecordCurInciSignalHeader -->
<!-- dtl:block:RecordNumberHeader -->
                <th class="Number $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=Number;OrderBy=$LQData{"OrderBy"}">$Config{"ITSMConfigItem::Hook"}</a>
                </th>
<!-- dtl:block:RecordNumberHeader -->
<!-- dtl:block:RecordNameHeader -->
                <th class="Name $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=Name;OrderBy=$LQData{"OrderBy"}">$Text{"Name"}</a>
                </th>
<!-- dtl:block:RecordNameHeader -->
<!-- dtl:block:RecordClassHeader -->
                <th class="Class $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=ClassID;OrderBy=$LQData{"OrderBy"}">$Text{"Class"}</a>
                </th>
<!-- dtl:block:RecordClassHeader -->
<!-- dtl:block:RecordCurDeplStateHeader -->
                <th class="CurDeplState $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=DeplStateID;OrderBy=$LQData{"OrderBy"}">$Text{"Deployment State"}</a>
                </th>
<!-- dtl:block:RecordCurDeplStateHeader -->
<!-- dtl:block:RecordCurDeplStateTypeHeader -->
                <th>
                    <span>$Text{"Deployment State Type"}</span>
                </th>
<!-- dtl:block:RecordCurDeplStateTypeHeader -->
<!-- dtl:block:RecordCurInciStateHeader -->
                <th class="CurInciState $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=InciStateID;OrderBy=$LQData{"OrderBy"}">$Text{"Current Incident State"}</a>
                </th>
<!-- dtl:block:RecordCurInciStateHeader -->
<!-- dtl:block:RecordCurInciStateTypeHeader -->
                <th>
                    <span>$Text{"Current Incident State Type"}</span>
                </th>
<!-- dtl:block:RecordCurInciStateTypeHeader -->
<!-- dtl:block:RecordXMLAttributeHeader -->
                <th>
                    <span>$Text{"$Data{"XMLAttributeHeader"}"}</span>
                </th>
<!-- dtl:block:RecordXMLAttributeHeader -->
<!-- dtl:block:RecordLastChangedHeader -->
                <th class="LastChanged $QData{"CSS"}">
                    <a href="$Env{"Baselink"}Action=$Env{"Action"};$Data{"LinkSort"};SortBy=ChangeTime;OrderBy=$LQData{"OrderBy"}">$Text{"Last changed"}</a>
                </th>
<!-- dtl:block:RecordLastChangedHeader -->
            </tr>
        </thead>
        <tbody>
<!-- dtl:block:NoDataFoundMsg -->
            <tr>
                <td colspan="$QData{"TotalColumns"}">
                    $Text{"No data found."}
                </td>
            </tr>
<!-- dtl:block:NoDataFoundMsg -->
<!-- dtl:block:Record -->
            <tr class="MasterAction">
<!-- dtl:block:RecordCurInciSignal -->
                <td title="$Text{"$Data{"CurInciState"}"}">
                    <div class="Flag Small">
                        <span class="$QData{"CurInciSignal"}">"$Text{"$Data{"CurInciState"}"}"</span>
                    </div>
                </td>
<!-- dtl:block:RecordCurInciSignal -->
<!-- dtl:block:RecordNumber -->
                <td>
<!-- dtl:block:RecordNumberLinkStart -->
                    <a href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"}" title="$LQData{"Number"}" class="MasterActionLink">
<!-- dtl:block:RecordNumberLinkStart -->
                        $QData{"Number"}
<!-- dtl:block:RecordNumberLinkEnd -->
                    </a>
<!-- dtl:block:RecordNumberLinkEnd -->
                </td>
<!-- dtl:block:RecordNumber -->
<!-- dtl:block:RecordName -->
                <td>
<!-- dtl:block:RecordNameLinkStart -->
                    <a href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"}" title="$LQData{"Name"}" class="MasterActionLink">
<!-- dtl:block:RecordNameLinkStart -->
                        <div title="$QData{"Name"}">$QData{"Name","40"}</div>
<!-- dtl:block:RecordNameLinkEnd -->
                    </a>
<!-- dtl:block:RecordNameLinkEnd -->
                </td>
<!-- dtl:block:RecordName -->
<!-- dtl:block:RecordClass -->
                <td>
                    <div title="$Text{"$Data{"Class"}"}">$Text{"$Data{"Class"}"}</div>
                </td>
<!-- dtl:block:RecordClass -->
<!-- dtl:block:RecordCurDeplState -->
                <td>
                    <div title="$Text{"$Data{"CurDeplState"}"}">$Text{"$Data{"CurDeplState"}"}</div>
                </td>
<!-- dtl:block:RecordCurDeplState -->
<!-- dtl:block:RecordCurDeplStateType -->
                <td>
                    <div title="$Text{"$Data{"CurDeplStateType"}"}">$Text{"$Data{"CurDeplStateType"}"}</div>
                </td>
<!-- dtl:block:RecordCurDeplStateType -->
<!-- dtl:block:RecordCurInciState -->
                <td>
                    <div title="$Text{"$Data{"CurInciState"}"}">$Text{"$Data{"CurInciState"}"}</div>
                </td>
<!-- dtl:block:RecordCurInciState -->
<!-- dtl:block:RecordCurInciStateType -->
                <td>
                    <div title="$Text{"$Data{"CurInciStateType"}"}">$Text{"$Data{"CurInciStateType"}"}</div>
                </td>
<!-- dtl:block:RecordCurInciStateType -->
<!-- dtl:block:RecordXMLAttribute -->
                <td>
                    <div title="$QData{"XMLAttributeData"}">$QData{"XMLAttributeData"}</div>
                </td>
<!-- dtl:block:RecordXMLAttribute -->
<!-- dtl:block:RecordLastChanged -->
                <td>
                    <div title="$TimeLong{"$QData{"CreateTime"}"}">$TimeLong{"$QData{"CreateTime"}"}</div>
                </td>
<!-- dtl:block:RecordLastChanged -->
            </tr>
<!-- dtl:block:Record -->
        </tbody>
    </table>
</div>
<!-- dtl:js_on_document_complete -->
<script type="text/javascript">//<![CDATA[
    $('.MasterAction').bind('click', function (Event) {
        var $MasterActionLink = $(this).find('.MasterActionLink');
        // only act if the link was not clicked directly
        if (Event.target !== $MasterActionLink.get(0)) {
            window.location = $MasterActionLink.attr('href');
            return false;
        }
    });
//]]></script>
<!-- dtl:js_on_document_complete -->

# --
# AgentITSMConfigItemPrint.dtl - provides HTML print view
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<table border="0" cellspacing="1" cellpadding="0" width="100%">
    <tr>
        <td class="mainhead">$Text{"ConfigItem"}</td>
    </tr>
</table>
<table border="0" cellspacing="1" cellpadding="10" width="100%">
    <tr>
        <td class="contentkey">
            $Text{"ConfigItem-Info"}:
            <table border="0" cellspacing="3" cellpadding="0" width="100%">
                <tr>
                    <td class="contentkey">$Text{"Class"}:</td>
                    <td class="contentvalue">$QData{"Class"}</td>
                    <td class="contentkey">$Text{"Created"}:</td>
                    <td class="contentvalue">$TimeLong{"$Data{"CreateTime"}"}</td>
                </tr>
                <tr>
                    <td class="contentkey">$Text{"ConfigItem"}:</td>
                    <td class="contentvalue">$QData{"CurrentName"}</td>
                    <td class="contentkey">$Text{"Created by"}:</td>
                    <td class="contentvalue">$QData{"CreateByName"}</td>
                </tr>
                <tr>
                    <td class="contentkey">$Text{"Current Deployment State"}:</td>
                    <td class="contentvalue">$Text{"$Data{"CurDeplState"}"}</td>
                    <td class="contentkey">$Text{"Last changed"}:</td>
                    <td class="contentvalue">$TimeLong{"$Data{"ChangeTime"}"}</td>
                </tr>
                <tr>
                    <td class="contentkey">$Text{"Current Incident State"}:</td>
                    <td class="contentvalue">$Text{"$Data{"CurInciState"}"}</td>
                    <td class="contentkey">$Text{"Last changed by"}:</td>
                    <td class="contentvalue">$QData{"ChangeByName"}</td>
                </tr>
            </table>
        </td>
    </tr>
<!-- dtl:block:Link -->
    <tr>
        <td class="contentkey">
            $Text{"Linked-Object"}:
            <table border="0" cellspacing="0" cellpadding="0" width="100%">
                <tr>
                    <td width="50%" valign="top">
                        <table border="0" cellspacing="3" cellpadding="0" width="100%">
<!-- dtl:block:LinkType -->
                            <tr valign="top">
                                <td class="contentkey" width="20%">$Text{"$Data{"LinkTypeName"}"}:</td>
                                <td class="contentvalue">
<!-- dtl:block:LinkTypeRow -->
                                    $Data{"LinkStrg"}<br>
<!-- dtl:block:LinkTypeRow -->
                                </td>
                            </tr>
<!-- dtl:block:LinkType -->
                        </table>
                    </td>
                </tr>
            </table>
        </td>
    </tr>
<!-- dtl:block:Link -->
</table>
<!-- dtl:block:Version -->
<table border="0" width="640" cellpadding="0" cellspacing="0" bgcolor="#000000" class="container">
    <tr>
        <td>
            <table border="0" width="640" cellpadding="10" cellspacing="1" bgcolor="#ffffff">
                <tr>
                    <td>
                        <table border="0" width="100%" cellspacing="0" cellpadding="3">
                            <tr bgcolor="#ffffff">
                                <td valign="top" width="100%" class="contentkey">
                                    $Text{"Version"}&nbsp;$QData{"VersionNumber"}
                                    <table border="0" width="100%" cellspacing="0" cellpadding="1">
                                        <tr>
                                            <td class="contentkey" width="25%">$Text{"Created"}:</td>
                                            <td class="contentvalue">$TimeLong{"$Data{"CreateTime"}"}</td>
                                        </tr>
                                        <tr>
                                            <td class="contentkey">$Text{"Created by"}:</td>
                                            <td class="contentvalue">$QData{"CreateByName"}</td>
                                        </tr>
                                        <tr>
                                            <td class="contentkey">&nbsp;</td>
                                            <td class="contentvalue">&nbsp;</td>
                                        </tr>
                                        <tr>
                                            <td class="contentkey">$Text{"Name"}:</td>
                                            <td class="contentvalue">$QData{"Name"}</td>
                                        </tr>
                                        <tr>
                                            <td class="contentkey">$Text{"Deployment State"}:</td>
                                            <td class="contentvalue">$Text{"$Data{"DeplState"}"}</td>
                                        </tr>
                                        <tr>
                                            <td class="contentkey">$Text{"Incident State"}:</td>
                                            <td class="contentvalue">$Text{"$Data{"InciState"}"}</td>
                                        </tr>
<!-- dtl:block:VersionRow -->
                                        <tr>
                                            <td class="contentkey">
<!-- dtl:block:VersionRowNamePre -->
                                                &nbsp;&nbsp;&nbsp;&nbsp;
<!-- dtl:block:VersionRowNamePre -->
                                                $Text{"$Data{"Name"}"}:&nbsp;&nbsp;
                                            </td>
                                            <td class="contentvalue">
<!-- dtl:block:VersionRowValuePre -->
                                                &nbsp;&nbsp;&nbsp;&nbsp;
<!-- dtl:block:VersionRowValuePre -->
                                                $Data{"Value"}
                                            </td>
                                        </tr>
<!-- dtl:block:VersionRow -->
<!-- dtl:block:Attachments -->
                                        <tr>
                                            <td>
                                                $Text{"Attachments"}:
                                            </td>
                                            <td>
                                                $QData{"Filename"}
                                            </td>
                                        </tr>
<!-- dtl:block:Attachments -->
<!-- dtl:block:AttachmentRow -->
                                        <tr>
                                            <td>
                                            </td>
                                            <td>
                                                $QData{"Filename"}
                                            </td>
                                        </tr>
<!-- dtl:block:AttachmentRow -->
                                    </table>
                                </td>
                            </tr>
                        </table>
                    </td>
                </tr>
            </table>
        </td>
    </tr>
</table>
<!-- dtl:block:Version -->

# --
# AgentITSMConfigItemSearch.dtl - provides HTML form for AgentITSMConfigItemSearch
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<!-- dtl:block:SearchAJAX -->
<div class="InnerContent">
    <fieldset class="TableLike">
        <div class="Clear"></div>
        <label for="Class">$Text{"Class"}</label>
        <div class="Field" id='DivClassID'>
            $Data{"ClassOptionStrg"}
        </div>
    </fieldset>
</div>

<div class="InnerContent" id="AJAXUpdate">

    <form action="$Env{"CGIHandle"}" method="post" id="SearchForm">
        <input type="hidden" name="Action" value="$Env{"Action"}"/>
        <input type="hidden" name="Subaction" value="Search"/>

        <fieldset class="TableLike Hidden" id='ITSMSearchProfile'>
            <div class="Clear"></div>
            <label>$Text{"Search template"}</label>
            <div class="Field">
                <input type="hidden" id="SearchProfile" name="SearchProfile" value="$QData{"Profile"}"/>

                <button id="SearchProfileNew" value="$Text{"Create New"}">$Text{"Create New"}</button>

                <button id="SearchProfileDelete" class="Hidden" value="$Text{"Delete"}">$Text{"Delete"}</button>

                <div id="SearchProfileAddBlock">
                    <input type="text" name="ProfileName" id="SearchProfileAddName"/>
                    <button type="submit" title="$Text{"Create Template"}" id="SearchProfileAddAction">$Text{"Create New Template"}</button>
                    <input type="hidden" name="SaveProfile" value="1"/>
                </div>
            </div>
        </fieldset>

    </form>
</div>

<div class="ContentFooter Center">
    <button id="SearchFormSubmit" class="Primary Hidden" value="Run Search">$Text{"Run Search"}</button>
</div>
<script type="text/javascript">//<![CDATA[
/*global ITSM: true */
    window.setTimeout(function (){
        $('#SearchClassID').bind('change', function(){
            if ( $('#SearchClassID').val() !== "" ){
                ITSM.Agent.ConfigItem.Search.LoadProfile( $('#SearchProfile').val() );
            }
            else {
                $('#SearchProfile').attr("id", "SearchProfileOld");
            }
        });
    }, 150);
//]]></script>
<!-- dtl:block:SearchAJAX -->

<!-- dtl:block:SearchAJAXSetClass -->
<script type="text/javascript">//<![CDATA[
/*global ITSM: true */
    window.setTimeout(function (){
            ITSM.Agent.ConfigItem.Search.LoadProfile( "$QData{"Profile"}" );
    }, 150);
//]]></script>
<!-- dtl:block:SearchAJAXSetClass -->

<!-- dtl:block:Search -->
<!--dtl:js_on_document_complete-->
<script type="text/javascript">//<![CDATA[
/*global ITSM: true */
    ITSM.Agent.ConfigItem.Search.OpenSearchDialog( '$Env{"Action"}', "$QData{"Profile"}", "$QData{"ClassID"}" );
//]]></script>
<!--dtl:js_on_document_complete-->
<!-- dtl:block:Search -->


<!-- dtl:block:AJAXContent -->
<form action="$Env{"CGIHandle"}" method="post" id="SearchForm">
    <input type="hidden" name="Action" value="$Env{"Action"}"/>
    <input type="hidden" name="Subaction" value="Search"/>
    <input type="hidden" name="ClassID" value="$QData{"ClassID"}">
    <input type="hidden" name="SearchDialog" value='1'>
    <input type="hidden" name="EmptySearch" value="$QData{"EmptySearch"}" id="EmptySearch"/>
    <fieldset class="TableLike Hidden" id='ITSMSearchProfile'>
        <div class="Clear"></div>
        <label>$Text{"Search template"}:</label>
        <div class="Field">
            $Data{"ProfilesStrg"}

            <button id="SearchProfileNew" value="$Text{"Create New"}">$Text{"Create New"}</button>

            <button id="SearchProfileDelete" class="Hidden" value="$Text{"Delete"}">$Text{"Delete"}</button>

            <div id="SearchProfileAddBlock">
                <input type="text" name="ProfileName" id="SearchProfileAddName"/>
                <button type="submit" title="$Text{"Create Template"}" id="SearchProfileAddAction">$Text{"Create New Template"}</button>
            </div>
        </div>
        <div class="Clear"></div>
        <label>$Text{"Save changes in template"}:</label>
        <div class="Field">
            <input type="checkbox" name="SaveProfile" id="SaveProfile" value="1"/>
        </div>

    </fieldset>

    <fieldset class="TableLike Hidden" id='ITSMSearchFields'>
        <fieldset class="TableLike" id="SearchInsert"></fieldset>
        <div class="Clear"></div>
        <label>$Text{"Add another attribute"}:</label>
        <div class="Field">
            $Data{"AttributesStrg"}
            <button type="submit" class="Add" value="Add" title="Add entry">$Text{"Add"}</button>
        </div>

        <div class="Clear"></div>
        <label for="PreviousVersionSearch">$Text{"Also search in previous versions?"}</label>
        <div class="Field">
            $Data{"PreviousVersionOptionStrg"}
        </div>

        <div class="Clear"></div>
        <label>$Text{"Output"}:</label>
        <div class="Field">
            $Data{"ResultFormStrg"}
        </div>
    </fieldset>
</form>
<fieldset class="TableLike Hidden" id="SearchAttributesHidden">
    <div class="Clear"></div>
    <label for="Number" id="LabelNumber">$Text{"Number"} $Text{"(e. g. 10*5155 or 105658*)"}:</label>
    <div class="Field">
        <input type="text" name="Number" value="$QData{"Number"}" class="W50pc" />
        <button type="button" class="Remove" value="Remove" title="$Text{"Remove this entry"}">$Text{"Remove"}</button>
    </div>

    <div class="Clear"></div>
    <label for="Name" id="LabelName">$Text{"Name"}:</label>
    <div class="Field">
        <input type="text" name="Name" value="$QData{"Name"}" class="W50pc" />
        <button type="button" class="Remove" value="Remove" title="$Text{"Remove this entry"}">$Text{"Remove"}</button>
    </div>

    <div class="Clear"></div>
    <label for="DeplStateIDs" id="LabelDeplStateIDs">$Text{"Deployment State"}:</label>
    <div class="Field">
        $Data{"CurDeplStateOptionStrg"}
        <button type="button" class="Remove" value="Remove" title="$Text{"Remove this entry"}">$Text{"Remove"}</button>
    </div>

    <div class="Clear"></div>
    <label for="InciStateIDs" id="LabelInciStateIDs">$Text{"Incident State"}:</label>
    <div class="Field">
        $Data{"CurInciStateOptionStrg"}
        <button type="button" class="Remove" value="Remove" title="$Text{"Remove this entry"}">$Text{"Remove"}</button>
    </div>

<!-- dtl:block:AttributeRow -->
    <div class="Clear"></div>
    <label for="$Text{"$Data{"Key"}"}" id="Label$Data{"Key"}" title="$Text{"$Data{"Description"}"}">$Text{"$Data{"Name"}"}:</label>
    <div class="Field">
        $Data{"InputString"}
        <button type="button" class="Remove" value="Remove" title="$Text{"Remove this entry"}">$Text{"Remove"}</button>
    </div>
<!-- dtl:block:AttributeRow -->
    <div class="Clear"></div>
    $Data{"AttributesOrigStrg"}
</fieldset>

<script type="text/javascript">//<![CDATA[
/*global ITSM: true */
    window.setTimeout(function (){
<!-- dtl:block:SearchAJAXShow -->
        ITSM.Agent.ConfigItem.Search.SearchAttributeAdd('$QData{"Attribute"}');
        ITSM.Agent.ConfigItem.Search.AdditionalAttributeSelectionRebuild();
<!-- dtl:block:SearchAJAXShow -->
    }, 0);
//]]></script>
<!-- dtl:block:AJAXContent -->

IyAtLQojIEFnZW50SVRTTUNvbmZpZ0l0ZW1TZWFyY2hSZXN1bHRQcmludC5kdGwgLSBodG1sIGZvciBjb25maWcgaXRlbSBzZWFyY2ggcmVzdWx0cyAocHJpbnQgb25seSkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgo8IS0tIHN0YXJ0IGZvcm0gLS0+CjxpPiREYXRheyJXYXJuaW5nIn08L2k+Cjx0YWJsZSBib3JkZXI9IjAiIGNlbGxzcGFjaW5nPSIxIiBjZWxscGFkZGluZz0iMCIgd2lkdGg9IjEwMCUiPgogICAgPHRyPgogICAgICAgIDx0ZCBjbGFzcz0ibWFpbmhlYWQiPiRUZXh0eyJTZWFyY2gifTwvdGQ+CiAgICA8L3RyPgo8L3RhYmxlPgo8dGFibGUgYm9yZGVyPSIwIiB3aWR0aD0iMTAwJSIgY2VsbHNwYWNpbmc9IjAiIGNlbGxwYWRkaW5nPSI0Ij4KICAgIDx0cj4KICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnRib2R5Ij4KICAgICAgICAgICAgPHRhYmxlIGJvcmRlcj0iMCIgd2lkdGg9IjEwMCUiIGNlbGxzcGFjaW5nPSIwIiBjZWxscGFkZGluZz0iMyI+CiAgICAgICAgICAgICAgICA8dHI+CiAgICAgICAgICAgICAgICAgICAgPHRkIHdpZHRoPSIxMCUiIGNsYXNzPSJjb250ZW50a2V5Ij4kVGV4dHsiQ2xhc3MifTwvdGQ+CiAgICAgICAgICAgICAgICAgICAgPHRkIHdpZHRoPSIxNSUiIGNsYXNzPSJjb250ZW50a2V5Ij4kVGV4dHsiSW5jaWRlbnQgU3RhdGUifTwvdGQ+CiAgICAgICAgICAgICAgICAgICAgPHRkIHdpZHRoPSIyMCUiIGNsYXNzPSJjb250ZW50a2V5Ij4kVGV4dHsiTmFtZSJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgd2lkdGg9IjE1JSIgY2xhc3M9ImNvbnRlbnRrZXkiPiRUZXh0eyJOdW1iZXIifTwvdGQ+CiAgICAgICAgICAgICAgICAgICAgPHRkIHdpZHRoPSIxNSUiIGNsYXNzPSJjb250ZW50a2V5Ij4kVGV4dHsiRGVwbG95bWVudCBTdGF0ZSJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgd2lkdGg9IjUlIiBjbGFzcz0iY29udGVudGtleSI+JFRleHR7IlZlcnNpb24ifTwvdGQ+CiAgICAgICAgICAgICAgICAgICAgPHRkIHdpZHRoPSIyMCUiIGNsYXNzPSJjb250ZW50a2V5Ij4kVGV4dHsiQ3JlYXRlVGltZSJ9PC90ZD4KICAgICAgICAgICAgICAgIDwvdHI+CjwhLS0gZHRsOmJsb2NrOlJlY29yZCAtLT4KICAgICAgICAgICAgICAgIDx0cj4KICAgICAgICAgICAgICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnR2YWx1ZSI+JFFEYXRheyJDbGFzcyJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnR2YWx1ZSI+JFFEYXRheyJJbmNpU3RhdGUifTwvdGQ+CiAgICAgICAgICAgICAgICAgICAgPHRkIGNsYXNzPSJjb250ZW50dmFsdWUiPiRRRGF0YXsiTmFtZSIsIjMwIn08L3RkPgogICAgICAgICAgICAgICAgICAgIDx0ZCBjbGFzcz0iY29udGVudHZhbHVlIj4kUURhdGF7Ik51bWJlciJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnR2YWx1ZSI+JFFEYXRheyJEZXBsU3RhdGUiLCIzMCJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnR2YWx1ZSI+JFFEYXRheyJWZXJzaW9uSUQiLCIxNSJ9PC90ZD4KICAgICAgICAgICAgICAgICAgICA8dGQgY2xhc3M9ImNvbnRlbnR2YWx1ZSI+JFRpbWVMb25neyIkRGF0YXsiQ3JlYXRlVGltZSJ9In08L3RkPgogICAgICAgICAgICAgICAgPC90cj4KPCEtLSBkdGw6YmxvY2s6UmVjb3JkIC0tPgogICAgICAgICAgICA8L3RhYmxlPgogICAgICAgIDwvdGQ+CiAgICA8L3RyPgo8L3RhYmxlPgo8IS0tIGVuZCBmb3JtIC0tPgo=
# --
# AgentITSMConfigItemZoom.dtl - provides HTML form for AgentITSMConfigItemZoom
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

<div class="MainBox ARIARoleMain">
    <div class="ClearLeft"></div>
    <div class="Headline">
        <div class="Flag" title="$Text{"$Data{"CurInciState"}"}">
            <span class="$QData{"CurInciSignal"}"></span>
        </div>
        <h1 title="$Text{"Configuration Item"}: $QData{"Number"} &ndash; $QData{"Name", "40"}">
            $Text{"Configuration Item"}: $QData{"Number"} <span>&mdash;</span> $QData{"Name", "60"}
        </h1>
    </div>
    <div class="LayoutFixedSidebar SidebarLast">
        <div class="SidebarColumn">
<!-- dtl:block:Meta -->
            <div class="WidgetSimple">
                <div class="Header">
                    <h2>$Text{"Configuration Item Information"}</h2>
                </div>
                <div class="Content">
                    <fieldset class="TableLike FixedLabelSmall Tight">
                        <label>$Text{"Class"}:</label>
                        <p class="Value">$Text{"$Data{"Class"}"}</p>
                        <div class="Clear"></div>
                        <label>$Text{"Name"}:</label>
                        <p class="Value">$QData{"Name","25"}</p>
                        <div class="Clear"></div>
                        <label>$Text{"Current Deployment State"}:</label>
                        <p class="Value">$Text{"$Data{"CurDeplState"}"}</p>
                        <div class="Clear"></div>
                        <label>$Text{"Current Incident State"}:</label>
                        <div class="Value" title="$Text{"$Data{"CurInciState"}"}">
                            <div class="Flag Small">
                                <span class="$QData{"CurInciSignal"}"></span>
                            </div>
                            $Text{"$Data{"CurInciState"}"}
                        </div>
                        <div class="Clear"></div>
                        <label>$Text{"Created"}:</label>
                        <p class="Value">$TimeLong{"$Data{"CreateTime"}"}</p>
                        <div class="Clear"></div>
                        <label>$Text{"Created by"}:</label>
                        <p class="Value">
                            $QData{"CreateByUserFullName"}
                        </p>
                        <div class="Clear"></div>
                        <label>$Text{"Last changed"}:</label>
                        <p class="Value">$TimeLong{"$Data{"ChangeTime"}"}</p>
                        <div class="Clear"></div>
                        <label>$Text{"Last changed by"}:</label>
                        <p class="Value">
                            $QData{"ChangeByUserFullName"}
                        </p>
                        <div class="Clear"></div>
                    </fieldset>
                </div>
            </div>
<!-- dtl:block:Meta -->
<!-- dtl:block:LinkTableSimple -->
            <div class="WidgetSimple DontPrint">
                <div class="Header">
                    <h2>$Text{"Linked Objects"}</h2>
                </div>
                <div class="Content">
                    $Data{"LinkTableStrg"}
                </div>
            </div>
<!-- dtl:block:LinkTableSimple -->
        </div>
        <div class="ContentColumn">
            <div class="ControlRow">
                <h2></h2>
            </div>
            <div class="ActionRow">
                <ul class="Actions">
<!-- dtl:block:Menu -->
<!-- dtl:block:MenuItem -->
                    <li>
                        <a href="$Env{"Baselink"}$Data{"Link"}" class="$QData{"MenuClass"}" title="$Text{"$Data{"Description"}"}">$Text{"$Data{"Name"}"}</a>
                    </li>
<!-- dtl:block:MenuItem -->
<!-- dtl:block:Menu -->
                </ul>
            </div>
            <div id="ITSMTree">
<!-- dtl:block:Tree -->
                <div id="ITSMTable"  class="TicketList">
                    <div class="ControlRow">
                        <div class="ITSMItemView Icons">
<!-- dtl:block:Expand -->
                            <a class="OneITSMItem Active" href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"};ShowVersions=0" title="$Text{"Show one version"}"><i class="icon-minus"></i><span>$Text{"Show one version"}</span></a>
                            <a class="AllITSMItems" href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"};ShowVersions=1" title="$Text{"Show all versions"}"><i class="icon-reorder"></i><span>$Text{"Show all versions"}</span></a>
<!-- dtl:block:Expand -->
<!-- dtl:block:Collapse -->
                            <a class="OneITSMItem" href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"};ShowVersions=0" title="$Text{"Show one version"}"><i class="icon-minus"></i><span>$Text{"Show one version"}</span></a>
                            <a class="AllITSMItems Active" href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"};ShowVersions=1" title="$Text{"Show all versions"}"><i class="icon-reorder"></i><span>$Text{"Show all versions"}</span></a>
<!-- dtl:block:Collapse -->
                        </div>
                    </div>
                    <div id="ITSMTableBody" class="ActionRow">
                        <div class="Scroller">
                            <table class="TableSmall">
                                <thead>
                                    <tr>
                                        <th><span>$Text{"Version Incident State"}</span></th>
                                        <th><span>$Text{"Version Number"}</span></th>
                                        <th><span>$Text{"Name"}</span></th>
                                        <th><span>$Text{"Created by"}</span></th>
                                        <th><span>$Text{"Changed"}</span></th>
                                    </tr>
                                </thead>
                                <tbody>
<!-- dtl:block:TreeItem -->
                                    <tr class="$QData{"Active"} MasterAction">
                                        <td title="$Text{"$Data{"InciState"}"}">
                                            <div class="Flag Small">
                                                <span class="$QData{"InciSignal"}">$QData{"InciState"}</span>
                                            </div>
                                        </td>
                                        <td>
                                            $QData{"Count"}.
                                        </td>
                                        <td>
                                            <a class="AsBlock MasterActionLink" href="$Env{"Baselink"}Action=AgentITSMConfigItemZoom;ConfigItemID=$LQData{"ConfigItemID"};VersionID=$LQData{"VersionID"};ShowVersions=$LQData{"ShowVersions"}">
                                                $QData{"Name"} ($Text{"$Data{"DeplState"}"})
                                            </a>
                                        </td>
                                        <td>
                                            $QData{"CreateByUserFullName"}
                                        </td>
                                        <td>
                                            $TimeLong{"$QData{"CreateTime"}"}
                                        </td>
                                    </tr>
<!-- dtl:block:TreeItem -->
                                </tbody>
                            </table>
                        </div>
                        <div class="Handle ui-resizable-handle ui-resizable-s">
                            <a href="#">$Text{"Resize"}</a>
                        </div>
                    </div>
                </div>
<!-- dtl:block:Tree -->
            </div>
            <div id="ITSMItems">
                <div class="WidgetBox SpacingTop Expanded">
                    <div class="LightRow Header">
                        <div class="WidgetAction Toggle"><a href="#" title="$Text{"Show or hide the content."}"><i class="icon-caret-right"></i><i class="icon-caret-down"></i></a></div>
                        <h2>$Text{"Configuration Item Version Details"}</h2>
                    </div>
                    <div class="WithPadding Content NoDoubleBorders">
                        <table class="DataTable">
                            <thead>
                                <tr>
                                    <th>$Text{"Property"}</th>
                                    <th>$Text{"Value"}</th>
                                </tr>
                            </thead>
                            <tbody>
<!-- dtl:block:Data -->
                                <tr>
                                    <td class="W25pc" style="padding-left: $Text{"$Data{"Indentation"}"}px;" title="$Text{"$Data{"Description"}"}">
                                        $Text{"$Data{"Name"}"}:
                                    </td>
                                    <td style="padding-left: $Text{"$Data{"Indentation"}"}px;">
                                        $Data{"Value"}
                                    </td>
                                </tr>
<!-- dtl:block:Data -->
<!-- dtl:block:Attachments -->
                                <tr>
                                    <td class="W25pc" title="$Text{"Attachments"}">
                                        $Text{"Attachments"}
                                    </td>
                                    <td>
                                        <a href="$Env{"Baselink"}Action=$Env{"Action"};Subaction=DownloadAttachment;Filename=$LQData{"Filename"};ConfigItemID=$LQData{"ConfigItemID"}">
                                            $QData{"Filename"}
                                        </a>
                                        ($QData{"Filesize"})
                                    </td>
                                </tr>
<!-- dtl:block:Attachments -->
<!-- dtl:block:AttachmentRow -->
                                <tr>
                                    <td class="W25pc">
                                    </td>
                                    <td>
                                        <a href="$Env{"Baselink"}Action=$Env{"Action"};Subaction=DownloadAttachment;Filename=$LQData{"Filename"};ConfigItemID=$LQData{"ConfigItemID"}">
                                            $QData{"Filename"}
                                        </a>
                                        ($QData{"Filesize"})
                                    </td>
                                </tr>
<!-- dtl:block:AttachmentRow -->
                            </tbody>
                        </table>
                    </div>
                </div>
            </div>
<!-- dtl:block:LinkTableComplex -->
            <div class="Content">
                $Data{"LinkTableStrg"}
            </div>
<!-- dtl:block:LinkTableComplex -->
        </div>
        <div class="Clear"></div>
    </div>
</div>

<!-- dtl:js_on_document_complete -->
<script type="text/javascript">//<![CDATA[
/*global ITSM: true */
    ITSM.Agent.Zoom.Init($Env{"UserConfigItemZoomTableHeight"});

    $('ul.Actions a.AsPopup').bind('click', function (Event) {
        Core.UI.Popup.OpenPopup($(this).attr('href'), 'Action');
        return false;
    });

    $('ul.Actions a.HistoryBack').bind('click', function (Event) {
        history.back();
        return false;
    });

    $('.MasterAction').bind('click', function (Event) {
        var $MasterActionLink = $(this).find('.MasterActionLink');
        // only act if the link was not clicked directly
        if (Event.target !== $MasterActionLink.get(0)) {
            window.location = $MasterActionLink.attr('href');
            return false;
        }
    });
//]]></script>
<!-- dtl:js_on_document_complete -->

# --
# Kernel/System/ImportExport/ObjectBackend/ITSMConfigItem.pm - import/export backend for ITSMConfigItem
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem;

use strict;
use warnings;

use List::Util qw(min);

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;
use Kernel::System::Time;
use Kernel::System::VariableCheck qw(:all);

=head1 NAME

Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem - import/export backend for ITSMConfigItem

=head1 SYNOPSIS

All functions to import and export ITSM config items.

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::DB;
    use Kernel::System::Log;
    use Kernel::System::Main;
    use Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $BackendObject = Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem->new(
        ConfigObject       => $ConfigObject,
        EncodeObject       => $EncodeObject,
        LogObject          => $LogObject,
        DBObject           => $DBObject,
        MainObject         => $MainObject,
        ImportExportObject => $ImportExportObject,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(ConfigObject EncodeObject LogObject DBObject MainObject ImportExportObject))
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    # create additional objects
    $Self->{TimeObject}           = Kernel::System::Time->new( %{$Self} );
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );

    return $Self;
}

=item ObjectAttributesGet()

get the object attributes of an object as a ref to an array of hash references

    my $Attributes = $ObjectBackend->ObjectAttributesGet(
        UserID => 1,
    );

=cut

sub ObjectAttributesGet {
    my ( $Self, %Param ) = @_;

    # check needed object
    if ( !$Param{UserID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need UserID!',
        );
        return;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    ) || {};

    my $Attributes = [
        {
            Key   => 'ClassID',
            Name  => 'Class',
            Input => {
                Type         => 'Selection',
                Data         => $ClassList,
                Required     => 1,
                Translation  => 0,
                PossibleNone => 1,
            },
        },
        {
            Key   => 'CountMax',
            Name  => 'Maximum number of one element',
            Input => {
                Type         => 'Text',
                ValueDefault => '10',
                Required     => 1,
                Regex        => qr{ \A \d+ \z }xms,
                Translation  => 0,
                Size         => 5,
                MaxLength    => 5,
                DataType     => 'IntegerBiggerThanZero',
            },
        },
        {
            Key   => 'EmptyFieldsLeaveTheOldValues',
            Name  => 'Empty fields indicate that the current values are kept',
            Input => {
                Type => 'Checkbox',
            },
        },
    ];

    return $Attributes;
}

=item MappingObjectAttributesGet()

get the mapping attributes of an object as array/hash reference

    my $Attributes = $ObjectBackend->MappingObjectAttributesGet(
        TemplateID => 123,
        UserID     => 1,
    );

=cut

sub MappingObjectAttributesGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get object data
    my $ObjectData = $Self->{ImportExportObject}->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    return [] if !$ObjectData;
    return [] if ref $ObjectData ne 'HASH';
    return [] if !$ObjectData->{ClassID};

    # get definition
    my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ObjectData->{ClassID},
    );

    return [] if !$XMLDefinition;
    return [] if ref $XMLDefinition ne 'HASH';
    return [] if !$XMLDefinition->{DefinitionRef};
    return [] if ref $XMLDefinition->{DefinitionRef} ne 'ARRAY';

    my $ElementList = [
        {
            Key   => 'Number',
            Value => 'Number',
        },
        {
            Key   => 'Name',
            Value => 'Name',
        },
        {
            Key   => 'DeplState',
            Value => 'Deployment State',
        },
        {
            Key   => 'InciState',
            Value => 'Incident State',
        },
    ];

    # add xml elements
    $Self->_MappingObjectAttributesGet(
        XMLDefinition => $XMLDefinition->{DefinitionRef},
        ElementList   => $ElementList,
        CountMaxLimit => $ObjectData->{CountMax} || 10,
    );

    my $Attributes = [
        {
            Key   => 'Key',
            Name  => 'Key',
            Input => {
                Type         => 'Selection',
                Data         => $ElementList,
                Required     => 1,
                Translation  => 0,
                PossibleNone => 1,
            },
        },
        {
            Key   => 'Identifier',
            Name  => 'Identifier',
            Input => {
                Type => 'Checkbox',
            },
        },
    ];

    return $Attributes;
}

=item SearchAttributesGet()

get the search object attributes of an object as array/hash reference

    my $AttributeList = $ObjectBackend->SearchAttributesGet(
        TemplateID => 123,
        UserID     => 1,
    );

=cut

sub SearchAttributesGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get object data
    my $ObjectData = $Self->{ImportExportObject}->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    return [] if !$ObjectData;
    return [] if ref $ObjectData ne 'HASH';
    return [] if !$ObjectData->{ClassID};

    # get definition
    my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ObjectData->{ClassID},
    );

    return [] if !$XMLDefinition;
    return [] if ref $XMLDefinition ne 'HASH';
    return [] if !$XMLDefinition->{DefinitionRef};
    return [] if ref $XMLDefinition->{DefinitionRef} ne 'ARRAY';

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    ) || {};

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::Core::IncidentState',
    ) || {};

    my $AttributeList = [
        {
            Key   => 'Number',
            Name  => 'Number',
            Input => {
                Type      => 'Text',
                Size      => 80,
                MaxLength => 255,
            },
        },
        {
            Key   => 'Name',
            Name  => 'Name',
            Input => {
                Type      => 'Text',
                Size      => 80,
                MaxLength => 255,
            },
        },
        {
            Key   => 'DeplStateIDs',
            Name  => 'Deployment State',
            Input => {
                Type        => 'Selection',
                Data        => $DeplStateList,
                Translation => 1,
                Size        => 5,
                Multiple    => 1,
            },
        },
        {
            Key   => 'InciStateIDs',
            Name  => 'Incident State',
            Input => {
                Type        => 'Selection',
                Data        => $InciStateList,
                Translation => 1,
                Size        => 5,
                Multiple    => 1,
            },
        },
    ];

    # add xml attributes
    $Self->_SearchAttributesGet(
        XMLDefinition => $XMLDefinition->{DefinitionRef},
        AttributeList => $AttributeList,
    );

    return $AttributeList;
}

=item ExportDataGet()

get export data as 2D-array-hash reference

    my $ExportData = $ObjectBackend->ExportDataGet(
        TemplateID => 123,
        UserID     => 1,
    );

=cut

sub ExportDataGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get object data
    my $ObjectData = $Self->{ImportExportObject}->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check object data
    if ( !$ObjectData || ref $ObjectData ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "No object data found for the template id $Param{TemplateID}",
        );
        return;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    return if !$ClassList || ref $ClassList ne 'HASH';

    # check the class id
    if ( !$ObjectData->{ClassID} || !$ClassList->{ $ObjectData->{ClassID} } ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "No valid class id found for the template id $Param{TemplateID}",
        );
        return;
    }

    # get the mapping list
    my $MappingList = $Self->{ImportExportObject}->MappingList(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check the mapping list
    if ( !$MappingList || ref $MappingList ne 'ARRAY' || !@{$MappingList} ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "No valid mapping list found for the template id $Param{TemplateID}",
        );
        return;
    }

    # create the mapping object list
    my @MappingObjectList;
    for my $MappingID ( @{$MappingList} ) {

        # get mapping object data
        my $MappingObjectData = $Self->{ImportExportObject}->MappingObjectDataGet(
            MappingID => $MappingID,
            UserID    => $Param{UserID},
        );

        # check mapping object data
        if ( !$MappingObjectData || ref $MappingObjectData ne 'HASH' ) {

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "No valid mapping list found for the template id $Param{TemplateID}",
            );
            return;
        }

        push @MappingObjectList, $MappingObjectData;
    }

    # get search data
    my $SearchData = $Self->{ImportExportObject}->SearchDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    return if !$SearchData || ref $SearchData ne 'HASH';

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    );

    # check deployment state list
    if ( !$DeplStateList || ref $DeplStateList ne 'HASH' ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't get the general catalog list ITSM::ConfigItem::DeploymentState!",
        );
        return;
    }

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::Core::IncidentState',
    );

    # check incident state list
    if ( !$InciStateList || ref $InciStateList ne 'HASH' ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't get the general catalog list ITSM::Core::IncidentState!",
        );
        return;
    }

    # get current definition of this class
    my $DefinitionData = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ObjectData->{ClassID},
        UserID  => $Param{UserID},
    );

    my %SearchParams;

    # add number to the search params
    if ( $SearchData->{Number} ) {
        $SearchParams{Number} = delete $SearchData->{Number};
    }

    # add name to the search params
    if ( $SearchData->{Name} ) {
        $SearchParams{Name} = delete $SearchData->{Name};
    }

    # add deployment state to the search params
    if ( $SearchData->{DeplStateIDs} ) {
        my @DeplStateIDs = split '#####', $SearchData->{DeplStateIDs};
        $SearchParams{DeplStateIDs} = \@DeplStateIDs;
        delete $SearchData->{DeplStateIDs};
    }

    # add incident state to the search params
    if ( $SearchData->{InciStateIDs} ) {
        my @InciStateIDs = split '#####', $SearchData->{InciStateIDs};
        $SearchParams{InciStateIDs} = \@InciStateIDs;
        delete $SearchData->{InciStateIDs};
    }

    # add all XML data to the search params
    my @SearchParamsWhat;
    $Self->_ExportXMLSearchDataPrepare(
        XMLDefinition => $DefinitionData->{DefinitionRef},
        What          => \@SearchParamsWhat,
        SearchData    => $SearchData,
    );

    # add XML search params to the search hash
    if (@SearchParamsWhat) {
        $SearchParams{What} = \@SearchParamsWhat;
    }

    # search the config items
    my $ConfigItemList = $Self->{ConfigItemObject}->ConfigItemSearchExtended(
        %SearchParams,
        ClassIDs              => [ $ObjectData->{ClassID} ],
        PreviousVersionSearch => 0,
        UserID                => $Param{UserID},
    );

    my @ExportData;
    CONFIGITEMID:
    for my $ConfigItemID ( @{$ConfigItemList} ) {

        # get last version
        my $VersionData = $Self->{ConfigItemObject}->VersionGet(
            ConfigItemID => $ConfigItemID,
        );

        next CONFIGITEMID if !$VersionData;
        next CONFIGITEMID if ref $VersionData ne 'HASH';

        # translate xmldata to a 2d hash
        my %XMLData2D;
        $Self->_ExportXMLDataPrepare(
            XMLDefinition => $DefinitionData->{DefinitionRef},
            XMLData       => $VersionData->{XMLData}->[1]->{Version}->[1],
            XMLData2D     => \%XMLData2D,
        );

        # add data to the export data array
        my @Item;
        MAPPINGOBJECT:
        for my $MappingObject (@MappingObjectList) {

            # extract key
            my $Key = $MappingObject->{Key};

            # handle empty key
            if ( !$Key ) {
                push @Item, '';
                next MAPPINGOBJECT;
            }

            # handle config item number
            if ( $Key eq 'Number' ) {
                push @Item, $VersionData->{Number};
                next MAPPINGOBJECT;
            }

            # handle current config item name
            if ( $Key eq 'Name' ) {
                push @Item, $VersionData->{Name};
                next MAPPINGOBJECT;
            }

            # handle deployment state
            if ( $Key eq 'DeplState' ) {
                $VersionData->{DeplStateID} ||= 'DUMMY';
                push @Item, $DeplStateList->{ $VersionData->{DeplStateID} };
                next MAPPINGOBJECT;
            }

            # handle incident state
            if ( $Key eq 'InciState' ) {
                $VersionData->{InciStateID} ||= 'DUMMY';
                push @Item, $InciStateList->{ $VersionData->{InciStateID} };
                next MAPPINGOBJECT;
            }

            # handle all XML data elements
            push @Item, $XMLData2D{$Key};
        }

        push @ExportData, \@Item;
    }

    return \@ExportData;
}

=item ImportDataSave()

imports a single entity of the import data. The C<TemplateID> points to the definition
of the current import. C<ImportDataRow> holds the data. C<Counter> is only used in
error messages, for indicating which item was not imported successfully.

The current version of the config item will never be deleted. When there are no
changes in the data, the import will be skipped. When there is new or changed data,
then a new config item or a new version is created.

In the case of changed data, the new version of the config item will contain the
attributes of the C<ImportDataRow> plus the old attributes that are
not part of the import definition.
Thus ImportDataSave() guarantees to not overwrite undeclared attributes.

The behavior when imported attributes are empty depends on the setting in the object data.
When C<EmptyFieldsLeaveTheOldValues> is not set, then empty values will wipe out
the old data. This is the default behavior. When C<EmptyFieldsLeaveTheOldValues> is set,
then empty values will leave the old values.

The decision what constitute an empty value is a bit hairy.
Here are the rules.
Fields that are not even mentioned in the Import definition are empty. These are the 'not defined' fields.
Empty strings and undefined values constitute empty fields.
Fields with with only one or more whitespace characters are not empty.
Fields with the digit '0' are not empty.

    my ( $ConfigItemID, $RetCode ) = $ObjectBackend->ImportDataSave(
        TemplateID    => 123,
        ImportDataRow => $ArrayRef,
        Counter       => 367,
        UserID        => 1,
    );

An empty C<ConfigItemID> indicates failure. Otherwise it indicates the
location of the imported data.
C<RetCode> is either 'Created', 'Updated' or 'Skipped'. 'Created' means that a new
config item has been created. 'Updated' means that a new version has been added to
an existing config item. 'Skipped' means that no new version has been created,
as the new data is identical to the latest version of an existing config item.

No codes have yet been defined for the failure case.

=cut

sub ImportDataSave {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(TemplateID ImportDataRow Counter UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # check import data row
    if ( ref $Param{ImportDataRow} ne 'ARRAY' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "ImportDataRow must be an array reference",
        );
        return;
    }

    # get object data
    my $ObjectData = $Self->{ImportExportObject}->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check object data
    if ( !$ObjectData || ref $ObjectData ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "No object data found for the template id '$Param{TemplateID}'",
        );
        return;
    }

    # just for convenience
    my $EmptyFieldsLeaveTheOldValues = $ObjectData->{EmptyFieldsLeaveTheOldValues};

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # check class list
    if ( !$ClassList || ref $ClassList ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Can't get the general catalog list ITSM::ConfigItem::Class",
        );
        return;
    }

    # check the class id
    if ( !$ObjectData->{ClassID} || !$ClassList->{ $ObjectData->{ClassID} } ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "No class found for the template id '$Param{TemplateID}'",
        );
        return;
    }

    # get the mapping list
    my $MappingList = $Self->{ImportExportObject}->MappingList(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check the mapping list
    if ( !$MappingList || ref $MappingList ne 'ARRAY' || !@{$MappingList} ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "No valid mapping list found for the template id '$Param{TemplateID}'",
        );
        return;
    }

    # create the mapping object list
    my @MappingObjectList;
    for my $MappingID ( @{$MappingList} ) {

        # get mapping object data
        my $MappingObjectData = $Self->{ImportExportObject}->MappingObjectDataGet(
            MappingID => $MappingID,
            UserID    => $Param{UserID},
        );

        # check mapping object data
        if ( !$MappingObjectData || ref $MappingObjectData ne 'HASH' ) {

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    "Can't import entity $Param{Counter}: "
                    . "No mapping object data found for the mapping id '$MappingID'",
            );
            return;
        }

        push @MappingObjectList, $MappingObjectData;
    }

    # check and remember the Identifiers
    # the Identifiers identify the config item that should be updated
    my %Identifier;
    my $RowIndex = 0;
    MAPPINGOBJECTDATA:
    for my $MappingObjectData (@MappingObjectList) {

        next MAPPINGOBJECTDATA if !$MappingObjectData->{Identifier};

        # check if identifier already exists
        if ( $Identifier{ $MappingObjectData->{Key} } ) {

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    "Can't import entity $Param{Counter}: "
                    . "'$MappingObjectData->{Key}' has been used multiple times as an identifier",
            );
            return;
        }

        # set identifier value
        $Identifier{ $MappingObjectData->{Key} } = $Param{ImportDataRow}->[$RowIndex];

        next MAPPINGOBJECTDATA if $MappingObjectData->{Key} && $Param{ImportDataRow}->[$RowIndex];

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Identifier field is empty",
        );

        return;
    }
    continue {
        $RowIndex++;
    }

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    );

    # check deployment state list
    if ( !$DeplStateList || ref $DeplStateList ne 'HASH' ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Can't get the general catalog list ITSM::ConfigItem::DeploymentState!",
        );
        return;
    }

    # reverse the deployment state list
    my %DeplStateListReverse = reverse %{$DeplStateList};

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::Core::IncidentState',
    );

    # check incident state list
    if ( !$InciStateList || ref $InciStateList ne 'HASH' ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Can't get the general catalog list ITSM::Core::IncidentState",
        );
        return;
    }

    # reverse the incident state list
    my %InciStateListReverse = reverse %{$InciStateList};

    # get current definition of this class
    my $DefinitionData = $Self->{ConfigItemObject}->DefinitionGet(
        ClassID => $ObjectData->{ClassID},
        UserID  => $Param{UserID},
    );

    # check definition data
    if ( !$DefinitionData || ref $DefinitionData ne 'HASH' ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Can't get the definition of class id $ObjectData->{ClassID}",
        );
        return;
    }

    # try to get config item ids, when there are identifiers
    my $ConfigItemID;
    if (%Identifier) {

        my %SearchParams;

        # add number to the search params
        if ( $Identifier{Number} ) {
            $SearchParams{Number} = delete $Identifier{Number};
        }

        # add name to the search params
        if ( $Identifier{Name} ) {
            $SearchParams{Name} = delete $Identifier{Name};
        }

        # add deployment state to the search params
        if ( $Identifier{DeplState} ) {

            # extract deployment state id
            my $DeplStateID = $DeplStateListReverse{ $Identifier{DeplState} } || '';

            if ( !$DeplStateID ) {

                $Self->{LogObject}->Log(
                    Priority => 'error',
                    Message =>
                        "Can't import entity $Param{Counter}: "
                        . "The deployment state '$Identifier{DeplState}' is invalid",
                );
                return;
            }

            $SearchParams{DeplStateIDs} = [$DeplStateID];
            delete $Identifier{DeplState};
        }

        # add incident state to the search params
        if ( $Identifier{InciState} ) {

            # extract incident state id
            my $InciStateID = $InciStateListReverse{ $Identifier{InciState} } || '';

            if ( !$InciStateID ) {

                $Self->{LogObject}->Log(
                    Priority => 'error',
                    Message =>
                        "Can't import entity $Param{Counter}: "
                        . "The incident state '$Identifier{InciState}' is invalid",
                );
                return;
            }

            $SearchParams{InciStateIDs} = [$InciStateID];
            delete $Identifier{InciState};
        }

        # add all XML data to the search params
        my @SearchParamsWhat;
        $Self->_ImportXMLSearchDataPrepare(
            XMLDefinition => $DefinitionData->{DefinitionRef},
            What          => \@SearchParamsWhat,
            Identifier    => \%Identifier,
        );

        # add XML search params to the search hash
        if (@SearchParamsWhat) {
            $SearchParams{What} = \@SearchParamsWhat;
        }

        # search existing config item with the same identifiers
        my $ConfigItemList = $Self->{ConfigItemObject}->ConfigItemSearchExtended(
            %SearchParams,
            ClassIDs              => [ $ObjectData->{ClassID} ],
            PreviousVersionSearch => 0,
            UsingWildcards        => 0,
            UserID                => $Param{UserID},
        );

        if ( scalar @{$ConfigItemList} > 1 ) {

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    "Can't import entity $Param{Counter}: "
                    . "Identifier fields NOT unique!",
            );
            return;
        }

        $ConfigItemID = $ConfigItemList->[0];
    }

    # get version data of the config item
    my $VersionData = {};
    if ($ConfigItemID) {

        # get latest version
        $VersionData = $Self->{ConfigItemObject}->VersionGet(
            ConfigItemID => $ConfigItemID,
        );

        # remove empty xml data
        if (
            !$VersionData->{XMLData}
            || ref $VersionData->{XMLData} ne 'ARRAY'
            || !@{ $VersionData->{XMLData} }
            )
        {
            delete $VersionData->{XMLData};
        }
    }

    # set up fields in VersionData and in the XML attributes
    my %XMLData2D;
    $RowIndex = 0;
    for my $MappingObjectData (@MappingObjectList) {

        # just for convenience
        my $Key   = $MappingObjectData->{Key};
        my $Value = $Param{ImportDataRow}->[ $RowIndex++ ];

        if ( $Key eq 'Number' ) {

            # do nothing
            # Import does not override the config item number
        }
        elsif ( $Key eq 'Name' ) {

            if ( $EmptyFieldsLeaveTheOldValues && ( !defined $Value || $Value eq '' ) ) {

                # do nothing, keep the old value
            }
            else {
                if ( !$Value ) {
                    $Self->{LogObject}->Log(
                        Priority => 'error',
                        Message =>
                            "Can't import entity $Param{Counter}: "
                            . "The name '$Value' is invalid!",
                    );
                    return;
                }

                $VersionData->{$Key} = $Value;
            }
        }
        elsif ( $Key eq 'DeplState' ) {

            if ( $EmptyFieldsLeaveTheOldValues && ( !defined $Value || $Value eq '' ) ) {

                # do nothing, keep the old value
            }
            else {

                # extract deployment state id
                my $DeplStateID = $DeplStateListReverse{$Value} || '';
                if ( !$DeplStateID ) {
                    $Self->{LogObject}->Log(
                        Priority => 'error',
                        Message =>
                            "Can't import entity $Param{Counter}: "
                            . "The deployment state '$Value' is invalid!",
                    );
                    return;
                }

                $VersionData->{DeplStateID} = $DeplStateID;
            }
        }
        elsif ( $Key eq 'InciState' ) {

            if ( $EmptyFieldsLeaveTheOldValues && ( !defined $Value || $Value eq '' ) ) {

                # do nothing, keep the old value
            }
            else {

                # extract the deployment state id
                my $InciStateID = $InciStateListReverse{$Value} || '';
                if ( !$InciStateID ) {
                    $Self->{LogObject}->Log(
                        Priority => 'error',
                        Message =>
                            "Can't import entity $Param{Counter}: "
                            . "The incident state '$Value' is invalid!",
                    );
                    return;
                }

                $VersionData->{InciStateID} = $InciStateID;
            }
        }
        else {

            # handle xml data
            $XMLData2D{$Key} = $Value;
        }
    }

    # set up empty container, in case there is no previous data
    $VersionData->{XMLData}->[1]->{Version}->[1] ||= {};

    # Edit XMLDataPrev, so that the values in XMLData2D take precedence.
    my $MergeOk = $Self->_ImportXMLDataMerge(
        XMLDefinition                => $DefinitionData->{DefinitionRef},
        XMLDataPrev                  => $VersionData->{XMLData}->[1]->{Version}->[1],
        XMLData2D                    => \%XMLData2D,
        EmptyFieldsLeaveTheOldValues => $EmptyFieldsLeaveTheOldValues,
    );

    # bail out, when the was a problem in _ImportXMLDataMerge()
    if ( !$MergeOk ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message =>
                "Can't import entity $Param{Counter}: "
                . "Could not prepare the input!",
        );
        return;
    }

    my $RetCode = $ConfigItemID ? 'Changed' : 'Created';

    # check if the feature to check for a unique name is enabled
    if (
        IsStringWithData( $VersionData->{Name} )
        && $Self->{ConfigObject}->Get('UniqueCIName::EnableUniquenessCheck')
        )
    {

        if ( $Self->{ConfigObject}->{Debug} > 0 ) {
            $Self->{LogObject}->Log(
                Priority => 'debug',
                Message  => "Checking for duplicate names (ClassID: $ObjectData->{ClassID}, "
                    . "Name: $VersionData->{Name}, ConfigItemID: " . $ConfigItemID || 'NEW' . ')',
            );
        }

        my $NameDuplicates = $Self->{ConfigItemObject}->UniqueNameCheck(
            ConfigItemID => $ConfigItemID || 'NEW',
            ClassID      => $ObjectData->{ClassID},
            Name         => $VersionData->{Name},
        );

        # stop processing if the name is not unique
        if ( IsArrayRefWithData($NameDuplicates) ) {

            # build a string of all duplicate IDs
            my $NameDuplicatesString = join ', ', @{$NameDuplicates};

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    "The name $VersionData->{Name} is already in use by the ConfigItemID(s): "
                    . $NameDuplicatesString,
            );

            # set the return code to also include the duplicate name
            $RetCode = "DuplicateName '$VersionData->{Name}'";

            # return undef for the config item id so it will be counted as 'Failed'
            return undef, $RetCode;    ## no critic
        }
    }

    my $LatestVersionID = 0;
    if ($ConfigItemID) {

        # the specified config item already exists
        # get id of the latest version, for checking later whether a version was created
        my $VersionList = $Self->{ConfigItemObject}->VersionList(
            ConfigItemID => $ConfigItemID,
        ) || [];
        if ( scalar @{$VersionList} ) {
            $LatestVersionID = $VersionList->[-1];
        }
    }
    else {

        # no config item was found, so add new config item
        $ConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
            ClassID => $ObjectData->{ClassID},
            UserID  => $Param{UserID},
        );

        # check the new config item id
        if ( !$ConfigItemID ) {

            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    "Can't import entity $Param{Counter}: "
                    . "Error when adding the new config item.",
            );
            return;
        }
    }

    # add new version
    my $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $ConfigItemID,
        Name         => $VersionData->{Name},
        DefinitionID => $DefinitionData->{DefinitionID},
        DeplStateID  => $VersionData->{DeplStateID},
        InciStateID  => $VersionData->{InciStateID},
        XMLData      => $VersionData->{XMLData},
        UserID       => $Param{UserID},
    );

    # the import was successful, when we get a version id
    if ($VersionID) {

        # When VersionAdd() returns the previous latest version ID, we know that
        # no new version has been added.
        # The import of this config item has been skipped.
        if ( $LatestVersionID && $VersionID == $LatestVersionID ) {
            $RetCode = 'Skipped';
        }

        return $ConfigItemID, $RetCode;
    }

    if ( $RetCode eq 'Created' ) {

        # delete the new config item
        $Self->{ConfigItemObject}->ConfigItemDelete(
            ConfigItemID => $ConfigItemID,
            UserID       => $Param{UserID},
        );
    }

    $Self->{LogObject}->Log(
        Priority => 'error',
        Message =>
            "Can't import entity $Param{Counter}: "
            . "Error when adding the new config item version.",
    );

    return;
}

=begin Internal:

=item _MappingObjectAttributesGet()

recursion function for MappingObjectAttributesGet().
Definitions for object attributes are passed in C<XMLDefinition>.
The new object attributes are appended to C<ElementList>.
C<CountMaxLimit> limits the max length of importable arrays.

    $ObjectBackend->_MappingObjectAttributesGet(
        XMLDefinition => $ArrayRef,
        ElementList   => $ArrayRef,
        CountMaxLimit => 10,
    );

=cut

sub _MappingObjectAttributesGet {
    my ( $Self, %Param ) = @_;

    return if !$Param{CountMaxLimit};
    return if !$Param{XMLDefinition};
    return if !$Param{ElementList};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{ElementList} ne 'ARRAY';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # limit the length of importable arrays, even if more elements can be set via the GUI
        my $CountMax = min( $Item->{CountMax}, $Param{CountMaxLimit} );

        COUNT:
        for my $Count ( 1 .. $CountMax ) {

            # create key string
            my $Key = $Item->{Key} . '::' . $Count;

            # add prefix to key
            if ( $Param{KeyPrefix} ) {
                $Key = $Param{KeyPrefix} . '::' . $Key;
            }

            # create value string
            my $Value = $Item->{Key};

            # add count if required
            if ( $CountMax > 1 || $Item->{Sub} ) {
                $Value .= '::' . $Count;
            }

            # add prefix to key
            if ( $Param{ValuePrefix} ) {
                $Value = $Param{ValuePrefix} . '::' . $Value;
            }

            # add row
            my %Row = (
                Key   => $Key,
                Value => $Value,
            );
            push @{ $Param{ElementList} }, \%Row;

            next COUNT if !$Item->{Sub};

            # start recursion
            $Self->_MappingObjectAttributesGet(
                XMLDefinition => $Item->{Sub},
                ElementList   => $Param{ElementList},
                KeyPrefix     => $Key,
                ValuePrefix   => $Value,
                CountMaxLimit => $Param{CountMaxLimit} || '10',
            );
        }
    }

    return 1;
}

=item _SearchAttributesGet()

recursion function for MappingObjectAttributesGet()

    $ObjectBackend->_SearchAttributesGet(
        XMLDefinition => $ArrayRef,
        AttributeList => $ArrayRef,
    );

=cut

sub _SearchAttributesGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{AttributeList};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{AttributeList} ne 'ARRAY';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # set prefix
        my $Key  = $Item->{Key};
        my $Name = $Item->{Name};

        if ( $Param{KeyPrefix} ) {
            $Key = $Param{KeyPrefix} . '::' . $Key;
        }

        if ( $Param{NamePrefix} ) {
            $Name = $Param{NamePrefix} . '::' . $Name;
        }

        # add attribute, if marked as searchable
        if ( $Item->{Searchable} ) {

            if ( $Item->{Input}->{Type} eq 'Text' || $Item->{Input}->{Type} eq 'TextArea' ) {

                my %Row = (
                    Key   => $Key,
                    Name  => $Name,
                    Input => {
                        Type        => 'Text',
                        Translation => $Item->{Input}->{Input}->{Translation},
                        Size        => $Item->{Input}->{Input}->{Size} || 60,
                        MaxLength   => $Item->{Input}->{Input}->{MaxLength},
                    },
                );

                push @{ $Param{AttributeList} }, \%Row;
            }
            elsif ( $Item->{Input}->{Type} eq 'GeneralCatalog' ) {

                # get general catalog list
                my $GeneralCatalogList = $Self->{GeneralCatalogObject}->ItemList(
                    Class => $Item->{Input}->{Class},
                ) || {};

                my %Row = (
                    Key   => $Key,
                    Name  => $Name,
                    Input => {
                        Type        => 'Selection',
                        Data        => $GeneralCatalogList,
                        Translation => $Item->{Input}->{Input}->{Translation},
                        Size        => 5,
                        Multiple    => 1,
                    },
                );

                push @{ $Param{AttributeList} }, \%Row;
            }
        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_SearchAttributesGet(
            XMLDefinition => $Item->{Sub},
            AttributeList => $Param{AttributeList},
            KeyPrefix     => $Key,
            NamePrefix    => $Name,
        );
    }

    return 1;
}

=item _ExportXMLSearchDataPrepare()

recursion function to prepare the export XML search params

    $ObjectBackend->_ExportXMLSearchDataPrepare(
        XMLDefinition => $ArrayRef,
        What          => $ArrayRef,
        SearchData    => $HashRef,
    );

=cut

sub _ExportXMLSearchDataPrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{What};
    return if !$Param{SearchData};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{What} ne 'ARRAY';
    return if ref $Param{SearchData} ne 'HASH';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # create key
        my $Key = $Param{Prefix} ? $Param{Prefix} . '::' . $Item->{Key} : $Item->{Key};

        # prepare value
        my $Values = $Self->{ConfigItemObject}->XMLExportSearchValuePrepare(
            Item  => $Item,
            Value => $Param{SearchData}->{$Key},
        );

        if ($Values) {

            # create search key
            my $SearchKey = $Key;
            $SearchKey =~ s{ :: }{\'\}[%]\{\'}xmsg;

            # create search hash
            my $SearchHash = {
                '[1]{\'Version\'}[1]{\'' . $SearchKey . '\'}[%]{\'Content\'}' => $Values,
            };

            push @{ $Param{What} }, $SearchHash;
        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_ExportXMLSearchDataPrepare(
            XMLDefinition => $Item->{Sub},
            What          => $Param{What},
            SearchData    => $Param{SearchData},
            Prefix        => $Key,
        );
    }

    return 1;
}

=item _ExportXMLDataPrepare()

recursion function to prepare the export XML data

    $ObjectBackend->_ExportXMLDataPrepare(
        XMLDefinition => $ArrayRef,
        XMLData       => $HashRef,
        XMLData2D     => $HashRef,
    );

=cut

sub _ExportXMLDataPrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{XMLData};
    return if !$Param{XMLData2D};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{XMLData} ne 'HASH';
    return if ref $Param{XMLData2D} ne 'HASH';

    if ( $Param{Prefix} ) {
        $Param{Prefix} .= '::';
    }
    $Param{Prefix} ||= '';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {
        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # stop loop, if no content was given
            last COUNTER if !defined $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content};

            # create key
            my $Key = $Param{Prefix} . $Item->{Key} . '::' . $Counter;

            # prepare value
            $Param{XMLData2D}->{$Key} = $Self->{ConfigItemObject}->XMLExportValuePrepare(
                Item  => $Item,
                Value => $Param{XMLData}->{ $Item->{Key} }->[$Counter]->{Content},
            );

            next COUNTER if !$Item->{Sub};

            # start recursion, if "Sub" was found
            $Self->_ExportXMLDataPrepare(
                XMLDefinition => $Item->{Sub},
                XMLData       => $Param{XMLData}->{ $Item->{Key} }->[$Counter],
                XMLData2D     => $Param{XMLData2D},
                Prefix        => $Key,
            );
        }
    }

    return 1;
}

=item _ImportXMLSearchDataPrepare()

recursion function to prepare the import XML search params

    $ObjectBackend->_ImportXMLSearchDataPrepare(
        XMLDefinition => $ArrayRef,
        What          => $ArrayRef,
        Identifier    => $HashRef,
    );

=cut

sub _ImportXMLSearchDataPrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{What};
    return if !$Param{Identifier};
    return if ref $Param{XMLDefinition} ne 'ARRAY';
    return if ref $Param{What} ne 'ARRAY';
    return if ref $Param{Identifier} ne 'HASH';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        # create key
        my $Key = $Param{Prefix} ? $Param{Prefix} . '::\d+::' . $Item->{Key} : $Item->{Key};
        $Key .= '::\d+';

        my $IdentifierKey;
        IDENTIFIERKEY:
        for my $IdentKey ( sort keys %{ $Param{Identifier} } ) {

            next IDENTIFIERKEY if $IdentKey !~ m{ \A $Key \z }xms;

            $IdentifierKey = $IdentKey;
        }

        if ($IdentifierKey) {

            # prepare value
            my $Value = $Self->{ConfigItemObject}->XMLImportSearchValuePrepare(
                Item  => $Item,
                Value => $Param{Identifier}->{$IdentifierKey},
            );

            if ($Value) {

                # prepare key
                my $Counter = 0;
                while ( $IdentifierKey =~ m{ :: }xms ) {

                    if ( $Counter % 2 ) {
                        $IdentifierKey =~ s{ :: }{]\{'}xms;
                    }
                    else {
                        $IdentifierKey =~ s{ :: }{'\}[}xms;
                    }

                    $Counter++;
                }

                # create search hash
                my $SearchHash = {
                    '[1]{\'Version\'}[1]{\'' . $IdentifierKey . ']{\'Content\'}' => $Value,
                };

                push @{ $Param{What} }, $SearchHash;
            }
        }

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_ImportXMLSearchDataPrepare(
            XMLDefinition => $Item->{Sub},
            What          => $Param{What},
            Identifier    => $Param{Identifier},
            Prefix        => $Key,
        );
    }

    return 1;
}

=item _ImportXMLDataMerge()

recursive function to inplace edit the import XML data.

    my $MergeOk = $ObjectBackend->_ImportXMLDataMerge(
        XMLDefinition => $ArrayRef,
        XMLDataPrev   => $HashRef,
        XMLData2D     => $HashRef,
    );

The return value indicates wheter the merge was successful.
A merge fails when for example a general catalog item name can't be mapped to an id.

=cut

sub _ImportXMLDataMerge {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{XMLDefinition};
    return if !$Param{XMLData2D};
    return if !$Param{XMLDataPrev};
    return if ref $Param{XMLDefinition} ne 'ARRAY';    # the attributes of the config item class
    return if ref $Param{XMLData2D} ne 'HASH';         # hash with values that should be imported
    return if ref $Param{XMLDataPrev} ne 'HASH';       # hash with current values of the config item

    my $XMLData = $Param{XMLDataPrev};

    # default value for prefix
    $Param{Prefix} ||= '';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        COUNTER:
        for my $Counter ( 1 .. $Item->{CountMax} ) {

            # create inputkey
            my $Key = $Param{Prefix} . $Item->{Key} . '::' . $Counter;

            # start recursion, if "Sub" was found
            if ( $Item->{Sub} ) {
                $XMLData->{ $Item->{Key} }->[$Counter]
                    ||= {};    # empty container, in case there is no previous data
                my $MergeOk = $Self->_ImportXMLDataMerge(
                    XMLDefinition                => $Item->{Sub},
                    XMLData2D                    => $Param{XMLData2D},
                    XMLDataPrev                  => $XMLData->{ $Item->{Key} }->[$Counter],
                    Prefix                       => $Key . '::',
                    EmptyFieldsLeaveTheOldValues => $Param{EmptyFieldsLeaveTheOldValues},
                );

                return if !$MergeOk;
            }

            # When the data point is not part of the input definition,
            # then do not overwrite the previous setting.
            # False values are OK.
            next COUNTER if !exists $Param{XMLData2D}->{$Key};

            if ( $Param{EmptyFieldsLeaveTheOldValues} ) {

                # do not override old value with an empty field is imported
                next COUNTER if !defined $Param{XMLData2D}->{$Key};
                next COUNTER if $Param{XMLData2D}->{$Key} eq '';
            }

            # prepare value
            my $Value = $Self->{ConfigItemObject}->XMLImportValuePrepare(
                Item  => $Item,
                Value => $Param{XMLData2D}->{$Key},
            );

            # let merge fail, when a value cannot be prepared
            return if !defined $Value;

            # save the prepared value
            $XMLData->{ $Item->{Key} }->[$Counter]->{Content} = $Value;
        }
    }

    return 1;
}

1;

=end Internal:

=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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/ITSMConfigItem.pm - all config item function
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem;

use strict;
use warnings;

use Kernel::System::EventHandler;
use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem::Definition;
use Kernel::System::ITSMConfigItem::History;
use Kernel::System::ITSMConfigItem::Number;
use Kernel::System::ITSMConfigItem::Permission;
use Kernel::System::ITSMConfigItem::Version;
use Kernel::System::ITSMConfigItem::XML;
use Kernel::System::LinkObject;
use Kernel::System::Service;
use Kernel::System::Time;
use Kernel::System::User;
use Kernel::System::XML;
use Kernel::System::VirtualFS;
use Kernel::System::VariableCheck qw(:all);

use vars qw(@ISA);

=head1 NAME

Kernel::System::ITSMConfigItem - config item lib

=head1 SYNOPSIS

All config item functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::Log;
    use Kernel::System::DB;
    use Kernel::System::Main;
    use Kernel::System::ITSMConfigItem;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $ConfigItemObject = Kernel::System::ITSMConfigItem->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        DBObject     => $DBObject,
        MainObject   => $MainObject,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(DBObject ConfigObject EncodeObject LogObject MainObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    # create additional objects
    $Self->{TimeObject}           = Kernel::System::Time->new( %{$Self} );
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
    $Self->{LinkObject}           = Kernel::System::LinkObject->new( %{$Self} );
    $Self->{UserObject}           = Kernel::System::User->new( %{$Self} );
    $Self->{ServiceObject}        = Kernel::System::Service->new( %{$Self} );
    $Self->{XMLObject}            = Kernel::System::XML->new( %{$Self} );
    $Self->{VirtualFSObject}      = Kernel::System::VirtualFS->new( %{$Self} );

    @ISA = (
        'Kernel::System::ITSMConfigItem::Definition',
        'Kernel::System::ITSMConfigItem::History',
        'Kernel::System::ITSMConfigItem::Number',
        'Kernel::System::ITSMConfigItem::Permission',
        'Kernel::System::ITSMConfigItem::Version',
        'Kernel::System::ITSMConfigItem::XML',
        'Kernel::System::EventHandler',
    );

    # init of event handler
    $Self->EventHandlerInit(
        Config     => 'ITSMConfigItem::EventModulePost',
        BaseObject => 'ConfigItemObject',
        Objects    => {
            %{$Self},
        },
    );

    return $Self;
}

=item ConfigItemCount()

count all records of a config item class

    my $Count = $ConfigItemObject->ConfigItemCount(
        ClassID => 123,
    );

=cut

sub ConfigItemCount {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ClassID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ClassID!',
        );
        return;
    }

    # get state list
    my $StateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::ConfigItem::DeploymentState',
        Preferences => {
            Functionality => [ 'preproductive', 'productive' ],
        },
    );

    return 0 if !%{$StateList};

    # create state string
    my $DeplStateString = join q{, }, keys %{$StateList};

    # ask database
    $Self->{DBObject}->Prepare(
        SQL => "SELECT COUNT(id) FROM configitem WHERE class_id = ? AND "
            . "cur_depl_state_id IN ( $DeplStateString )",
        Bind  => [ \$Param{ClassID} ],
        Limit => 1,
    );

    # fetch the result
    my $Count = 0;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Count = $Row[0];
    }

    return $Count;
}

=item ConfigItemResultList()

return a config item list as array hash reference

    my $ConfigItemListRef = $ConfigItemObject->ConfigItemResultList(
        ClassID => 123,
        Start   => 100,
        Limit   => 50,
    );

=cut

sub ConfigItemResultList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ClassID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ClassID!',
        );
        return;
    }

    # get state list
    my $StateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::ConfigItem::DeploymentState',
        Preferences => {
            Functionality => [ 'preproductive', 'productive' ],
        },
    );

    # create state string
    my $DeplStateString = join q{, }, keys %{$StateList};

    # ask database
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM configitem "
            . "WHERE class_id = ? AND cur_depl_state_id IN ( $DeplStateString ) "
            . "ORDER BY change_time DESC",
        Bind  => [ \$Param{ClassID} ],
        Start => $Param{Start},
        Limit => $Param{Limit},
    );

    # fetch the result
    my @ConfigItemIDList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @ConfigItemIDList, $Row[0];
    }

    # get last versions data
    my @ConfigItemList;
    for my $ConfigItemID (@ConfigItemIDList) {

        # get version data
        my $LastVersion = $Self->VersionGet(
            ConfigItemID => $ConfigItemID,
            XMLDataGet   => 0,
        );

        push @ConfigItemList, $LastVersion;
    }

    return \@ConfigItemList;
}

=item ConfigItemGet()

return a config item as hash reference

    my $ConfigItem = $ConfigItemObject->ConfigItemGet(
        ConfigItemID => 123,
        Cache        => 0,    # (optional) default 1 (0|1)
    );

A hashref with the following keys is returned:

    $ConfigItem{ConfigItemID}
    $ConfigItem{Number}
    $ConfigItem{ClassID}
    $ConfigItem{Class}
    $ConfigItem{LastVersionID}
    $ConfigItem{CurDeplStateID}
    $ConfigItem{CurDeplState}
    $ConfigItem{CurDeplStateType}
    $ConfigItem{CurInciStateID}
    $ConfigItem{CurInciState}
    $ConfigItem{CurInciStateType}
    $ConfigItem{CreateTime}
    $ConfigItem{CreateBy}
    $ConfigItem{ChangeTime}
    $ConfigItem{ChangeBy}

=cut

sub ConfigItemGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID!',
        );
        return;
    }

    # enable cache per default
    if ( !defined $Param{Cache} ) {
        $Param{Cache} = 1;
    }

    # check if result is already cached
    return $Self->{Cache}->{ConfigItemGet}->{ $Param{ConfigItemID} }
        if $Param{Cache} && $Self->{Cache}->{ConfigItemGet}->{ $Param{ConfigItemID} };

    # ask database
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id, configitem_number, class_id, last_version_id, '
            . 'cur_depl_state_id, cur_inci_state_id, '
            . 'create_time, create_by, change_time, change_by '
            . 'FROM configitem WHERE id = ?',
        Bind  => [ \$Param{ConfigItemID} ],
        Limit => 1,
    );

    # fetch the result
    my %ConfigItem;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $ConfigItem{ConfigItemID}   = $Row[0];
        $ConfigItem{Number}         = $Row[1];
        $ConfigItem{ClassID}        = $Row[2];
        $ConfigItem{LastVersionID}  = $Row[3];
        $ConfigItem{CurDeplStateID} = $Row[4];
        $ConfigItem{CurInciStateID} = $Row[5];
        $ConfigItem{CreateTime}     = $Row[6];
        $ConfigItem{CreateBy}       = $Row[7];
        $ConfigItem{ChangeTime}     = $Row[8];
        $ConfigItem{ChangeBy}       = $Row[9];
    }

    # check config item
    if ( !$ConfigItem{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "No such ConfigItemID ($Param{ConfigItemID})!",
        );
        return;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    $ConfigItem{Class} = $ClassList->{ $ConfigItem{ClassID} };

    return \%ConfigItem if !$ConfigItem{CurDeplStateID} || !$ConfigItem{CurInciStateID};

    # get deployment state functionality
    my $DeplState = $Self->{GeneralCatalogObject}->ItemGet(
        ItemID => $ConfigItem{CurDeplStateID},
    );

    $ConfigItem{CurDeplState}     = $DeplState->{Name};
    $ConfigItem{CurDeplStateType} = $DeplState->{Functionality};

    # get incident state functionality
    my $InciState = $Self->{GeneralCatalogObject}->ItemGet(
        ItemID => $ConfigItem{CurInciStateID},
    );

    $ConfigItem{CurInciState}     = $InciState->{Name};
    $ConfigItem{CurInciStateType} = $InciState->{Functionality};

    # cache the result
    $Self->{Cache}->{ConfigItemGet}->{ $Param{ConfigItemID} } = \%ConfigItem;

    return \%ConfigItem;
}

=item ConfigItemAdd()

add a new config item

    my $ConfigItemID = $ConfigItemObject->ConfigItemAdd(
        Number  => '111',  # (optional)
        ClassID => 123,
        UserID  => 1,
    );

=cut

sub ConfigItemAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    return if !$ClassList;
    return if ref $ClassList ne 'HASH';

    # check the class id
    if ( !$ClassList->{ $Param{ClassID} } ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'No valid class id given!',
        );
        return;
    }

    # create config item number
    if ( $Param{Number} ) {

        # find existing config item number
        my $Exists = $Self->ConfigItemNumberLookup(
            ConfigItemNumber => $Param{Number},
        );

        if ($Exists) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => 'Config item number already exists!',
            );
            return;
        }
    }
    else {

        # create config item number
        $Param{Number} = $Self->ConfigItemNumberCreate(
            Type    => $Self->{ConfigObject}->Get('ITSMConfigItem::NumberGenerator'),
            ClassID => $Param{ClassID},
        );
    }

    # insert new config item
    my $Success = $Self->{DBObject}->Do(
        SQL => 'INSERT INTO configitem '
            . '(configitem_number, class_id, create_time, create_by, change_time, change_by) '
            . 'VALUES (?, ?, current_timestamp, ?, current_timestamp, ?)',
        Bind => [ \$Param{Number}, \$Param{ClassID}, \$Param{UserID}, \$Param{UserID} ],
    );

    return if !$Success;

    # find id of new item
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id FROM configitem WHERE '
            . 'configitem_number = ? AND class_id = ? ORDER BY id DESC',
        Bind => [ \$Param{Number}, \$Param{ClassID} ],
        Limit => 1,
    );

    # fetch the result
    my $ConfigItemID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $ConfigItemID = $Row[0];
    }

    # trigger ConfigItemCreate
    $Self->EventHandler(
        Event => 'ConfigItemCreate',
        Data  => {
            ConfigItemID => $ConfigItemID,
            Comment      => $ConfigItemID . '%%' . $Param{Number},
        },
        UserID => $Param{UserID},
    );

    return $ConfigItemID;
}

=item ConfigItemDelete()

delete an existing config item

    my $True = $ConfigItemObject->ConfigItemDelete(
        ConfigItemID => 123,
        UserID       => 1,
    );

=cut

sub ConfigItemDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ConfigItemID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # delete all links to this config item first, before deleting the versions
    return if !$Self->{LinkObject}->LinkDeleteAll(
        Object => 'ITSMConfigItem',
        Key    => $Param{ConfigItemID},
        UserID => $Param{UserID},
    );

    # delete existing versions
    $Self->VersionDelete(
        ConfigItemID => $Param{ConfigItemID},
        UserID       => $Param{UserID},
    );

    # get a list of all attachments
    my @ExistingAttachments = $Self->ConfigItemAttachmentList(
        ConfigItemID => $Param{ConfigItemID},
    );

    # delete all attachments of this config item
    FILENAME:
    for my $Filename (@ExistingAttachments) {

        # delete the attachment
        my $DeletionSuccess = $Self->ConfigItemAttachmentDelete(
            ConfigItemID => $Param{ConfigItemID},
            Filename     => $Filename,
            UserID       => $Param{UserID},
        );

        if ( !$DeletionSuccess ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Unknown problem when deleting attachment $Filename of ConfigItem "
                    . "$Param{ConfigItemID}. Please check the VirtualFS backend for stale "
                    . "files!",
            );
        }
    }

    # trigger ConfigItemDelete event
    # this must be done before deleting the config item from the database,
    # because of a foreign key constraint in the configitem_history table
    $Self->EventHandler(
        Event => 'ConfigItemDelete',
        Data  => {
            ConfigItemID => $Param{ConfigItemID},
            Comment      => $Param{ConfigItemID},
        },
        UserID => $Param{UserID},
    );

    # delete config item
    my $Success = $Self->{DBObject}->Do(
        SQL  => 'DELETE FROM configitem WHERE id = ?',
        Bind => [ \$Param{ConfigItemID} ],
    );

    return $Success;
}

=item ConfigItemAttachmentAdd()

adds an attachment to a config item

    my $Success = $ConfigItemObject->ConfigItemAttachmentAdd(
        ConfigItemID    => 1,
        Filename        => 'filename',
        Content         => 'content',
        ContentType     => 'text/plain',
        UserID          => 1,
    );

=cut

sub ConfigItemAttachmentAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemID Filename Content ContentType UserID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );

            return;
        }
    }

    # write to virtual fs
    my $Success = $Self->{VirtualFSObject}->Write(
        Filename    => "ConfigItem/$Param{ConfigItemID}/$Param{Filename}",
        Mode        => 'binary',
        Content     => \$Param{Content},
        Preferences => {
            ContentID    => $Param{ContentID},
            ContentType  => $Param{ContentType},
            ConfigItemID => $Param{ConfigItemID},
            UserID       => $Param{UserID},
        },
    );

    # check for error
    if ($Success) {

        # trigger AttachmentAdd-Event
        $Self->EventHandler(
            Event => 'AttachmentAddPost',
            Data  => {
                %Param,
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Param{Filename},
                HistoryType  => 'AttachmentAdd',
            },
            UserID => $Param{UserID},
        );
    }
    else {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Cannot add attachment for config item $Param{ConfigItemID}",
        );

        return;
    }

    return 1;
}

=item ConfigItemAttachmentDelete()

Delete the given file from the virtual filesystem.

    my $Success = $ConfigItemObject->ConfigItemAttachmentDelete(
        ConfigItemID => 123,               # used in event handling, e.g. for logging the history
        Filename     => 'Projectplan.pdf', # identifies the attachment (together with the ConfigItemID)
        UserID       => 1,
    );

=cut

sub ConfigItemAttachmentDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemID Filename UserID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );

            return;
        }
    }

    # add prefix
    my $Filename = 'ConfigItem/' . $Param{ConfigItemID} . '/' . $Param{Filename};

    # delete file
    my $Success = $Self->{VirtualFSObject}->Delete(
        Filename => $Filename,
    );

    # check for error
    if ($Success) {

        # trigger AttachmentDeletePost-Event
        $Self->EventHandler(
            Event => 'AttachmentDeletePost',
            Data  => {
                %Param,
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Param{Filename},
                HistoryType  => 'AttachmentDelete',
            },
            UserID => $Param{UserID},
        );
    }
    else {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Cannot delete attachment $Filename!",
        );

        return;
    }

    return $Success;
}

=item ConfigItemAttachmentGet()

This method returns information about one specific attachment.

    my $Attachment = $ConfigItemObject->ConfigItemAttachmentGet(
        ConfigItemID => 4,
        Filename     => 'test.txt',
    );

returns

    {
        Preferences => {
            AllPreferences => 'test',
        },
        Filename    => 'test.txt',
        Content     => 'content',
        ContentType => 'text/plain',
        Filesize    => '123 KBytes',
        Type        => 'attachment',
    }

=cut

sub ConfigItemAttachmentGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ConfigItemID Filename)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # add prefix
    my $Filename = 'ConfigItem/' . $Param{ConfigItemID} . '/' . $Param{Filename};

    # find all attachments of this config item
    my @Attachments = $Self->{VirtualFSObject}->Find(
        Filename    => $Filename,
        Preferences => {
            ConfigItemID => $Param{ConfigItemID},
        },
    );

    # return error if file does not exist
    if ( !@Attachments ) {
        $Self->{LogObject}->Log(
            Message  => "No such attachment ($Filename)!",
            Priority => 'error',
        );
        return;
    }

    # get data for attachment
    my %AttachmentData = $Self->{VirtualFSObject}->Read(
        Filename => $Filename,
        Mode     => 'binary',
    );

    my $AttachmentInfo = {
        %AttachmentData,
        Filename    => $Param{Filename},
        Content     => ${ $AttachmentData{Content} },
        ContentType => $AttachmentData{Preferences}->{ContentType},
        Type        => 'attachment',
        Filesize    => $AttachmentData{Preferences}->{Filesize},
    };

    return $AttachmentInfo;
}

=item ConfigItemAttachmentList()

Returns an array with all attachments of the given config item.

    my @Attachments = $ConfigItemObject->ConfigItemAttachmentList(
        ConfigItemID => 123,
    );

returns

    @Attachments = (
        'filename.txt',
        'other_file.pdf',
    );

=cut

sub ConfigItemAttachmentList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID!',
        );

        return;
    }

    # find all attachments of this config item
    my @Attachments = $Self->{VirtualFSObject}->Find(
        Preferences => {
            ConfigItemID => $Param{ConfigItemID},
        },
    );

    for my $Filename (@Attachments) {

        # remove extra information from filename
        $Filename =~ s{ \A ConfigItem / \d+ / }{}xms;
    }

    return @Attachments;
}

=item ConfigItemAttachmentExists()

Checks if a file with a given filename exists.

    my $Exists = $ConfigItemObject->ConfigItemAttachmentExists(
        Filename => 'test.txt',
        ConfigItemID => 123,
        UserID   => 1,
    );

=cut

sub ConfigItemAttachmentExists {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(Filename ConfigItemID UserID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );

            return;
        }
    }

    return if !$Self->{VirtualFSObject}->Find(
        Filename => 'ConfigItem/' . $Param{ConfigItemID} . '/' . $Param{Filename},
    );

    return 1;
}

=item ConfigItemSearchExtended()

return a config item list as an array reference

    my $ConfigItemIDs = $ConfigItemObject->ConfigItemSearchExtended(
        Number       => 'The ConfigItem Number',  # (optional)
        Name         => 'The Name',               # (optional)
        ClassIDs     => [9, 8, 7, 6],             # (optional)
        DeplStateIDs => [1, 2, 3, 4],             # (optional)
        InciStateIDs => [1, 2, 3, 4],             # (optional)

        # config items with created time after ...
        ConfigItemCreateTimeNewerDate => '2006-01-09 00:00:01',  # (optional)
        # config items with created time before then ....
        ConfigItemCreateTimeOlderDate => '2006-01-19 23:59:59',  # (optional)

        # config items with changed time after ...
        ConfigItemChangeTimeNewerDate => '2006-01-09 00:00:01',  # (optional)
        # config items with changed time before then ....
        ConfigItemChangeTimeOlderDate => '2006-01-19 23:59:59',  # (optional)

        What => [
            # each array element is a and condition
            {
                # or condition in hash
                "[%]{'ElementA'}[%]{'ElementB'}[%]{'Content'}" => '%contentA%',
                "[%]{'ElementA'}[%]{'ElementC'}[%]{'Content'}" => '%contentA%',
            },
            {
                "[%]{'ElementA'}[%]{'ElementB'}[%]{'Content'}" => '%contentB%',
                "[%]{'ElementA'}[%]{'ElementC'}[%]{'Content'}" => '%contentB%',
            },
            {
                # use array reference if different content with same key was searched
                "[%]{'ElementA'}[%]{'ElementB'}[%]{'Content'}" => ['%contentC%', '%contentD%', '%contentE%'],
                "[%]{'ElementA'}[%]{'ElementC'}[%]{'Content'}" => ['%contentC%', '%contentD%', '%contentE%'],
            },
        ],

        PreviousVersionSearch => 1,  # (optional) default 0 (0|1)

        OrderBy => [ 'ConfigItemID', 'Number' ],                  # (optional)
        # default: [ 'ConfigItemID' ]
        # (ConfigItemID, Number, ClassID, DeplStateID, InciStateID,
        # CreateTime, CreateBy, ChangeTime, ChangeBy)

        # Additional information for OrderBy:
        # The OrderByDirection can be specified for each OrderBy attribute.
        # The pairing is made by the array indices.

        OrderByDirection => [ 'Down', 'Up' ],                    # (optional)
        # default: [ 'Down' ]
        # (Down | Up)

        Limit          => 122,  # (optional)
        UsingWildcards => 0,    # (optional) default 1
    );

=cut

sub ConfigItemSearchExtended {
    my ( $Self, %Param ) = @_;

    # set limit
    my $Limit = $Param{Limit};
    $Param{Limit} = undef;

    # config item search is required if one of these params is given
    my @ConfigItemSearchParams = (
        'ConfigItemCreateTimeNewerDate',
        'ConfigItemCreateTimeOlderDate',
        'ConfigItemChangeTimeNewerDate',
        'ConfigItemChangeTimeOlderDate',
    );

    # check, if config item search is required
    my %RequiredSearch;
    CONFIGITEMPARAM:
    for my $ConfigItemParam (@ConfigItemSearchParams) {
        next CONFIGITEMPARAM if !$Param{$ConfigItemParam};

        $RequiredSearch{ConfigItem} = 1;
        last CONFIGITEMPARAM;
    }

    # special handling for config item number
    # number 0 is allowed but not the empty string
    if ( defined $Param{Number} && $Param{Number} ne '' ) {
        $RequiredSearch{ConfigItem} = 1;
    }

    # version search is required if Name, What or PreviousVersionSearch is given
    if (
        ( defined $Param{Name} && $Param{Name} ne '' )
        || ( defined $Param{What} && $Param{What} ne '' )
        || $Param{PreviousVersionSearch}
        )
    {
        $RequiredSearch{Version} = 1;
    }

    # version search is also required if sorting by name (fix for bug #7072)
    ORDERBY:
    for my $OrderBy ( @{ $Param{OrderBy} } ) {
        if ( $OrderBy eq 'Name' ) {
            $RequiredSearch{Version} = 1;
            last ORDERBY;
        }
    }

    # xml version search is required if What is given
    if ( defined $Param{What} && $Param{What} ne '' ) {
        $RequiredSearch{XMLVersion} = 1;
    }

    # use config item search as fallback
    if ( !%RequiredSearch ) {
        $RequiredSearch{ConfigItem} = 1;
    }

    # start config item search
    my %ConfigItemLists;
    if ( $RequiredSearch{ConfigItem} ) {

        # search config items
        $ConfigItemLists{ConfigItem} = $Self->ConfigItemSearch(%Param);

        return if !$ConfigItemLists{ConfigItem};
        return if ref $ConfigItemLists{ConfigItem} ne 'ARRAY';
        return [] if !@{ $ConfigItemLists{ConfigItem} };
    }

    # start version search
    if ( $RequiredSearch{Version} ) {

        # search versions
        $ConfigItemLists{Version} = $Self->VersionSearch(%Param);

        return if !$ConfigItemLists{Version};
        return if ref $ConfigItemLists{Version} ne 'ARRAY';
        return [] if !@{ $ConfigItemLists{Version} };
    }

    # start xml version search
    if ( $RequiredSearch{XMLVersion} ) {

        # search xml versions
        my $XMLVersionList = $Self->_XMLVersionSearch(%Param);

        return if !$XMLVersionList;
        return if ref $XMLVersionList ne 'HASH';
        return [] if !%{$XMLVersionList};

        # get config item ids
        my %ConfigItemListTmp;
        VERSIONID:
        for my $VersionID ( sort keys %{$XMLVersionList} ) {
            my $ConfigItemID = $Self->VersionConfigItemIDGet(
                VersionID => $VersionID,
            );

            next VERSIONID if !$ConfigItemID;

            $ConfigItemListTmp{$ConfigItemID} = 1;
        }

        # add ids to config item list
        $ConfigItemLists{XMLVersion} = \%ConfigItemListTmp;
    }

    # create the result list
    my @ResultList;
    if ( $RequiredSearch{ConfigItem} && $RequiredSearch{Version} ) {

        my %VersionTempList;
        for my $ConfigItemID ( @{ $ConfigItemLists{Version} } ) {
            $VersionTempList{$ConfigItemID} = 1;
        }

        CONFIGITEMID:
        for my $ConfigItemID ( @{ $ConfigItemLists{ConfigItem} } ) {

            next CONFIGITEMID if !$VersionTempList{$ConfigItemID};

            push @ResultList, $ConfigItemID;
        }
    }
    elsif ( $RequiredSearch{ConfigItem} ) {
        @ResultList = @{ $ConfigItemLists{ConfigItem} };
    }
    elsif ( $RequiredSearch{Version} ) {
        @ResultList = @{ $ConfigItemLists{Version} };
    }

    # consider the XML result
    if ( $RequiredSearch{XMLVersion} ) {
        @ResultList = grep { $ConfigItemLists{XMLVersion}->{$_} } @ResultList;
    }

    # consider limit
    if ( $Limit && $Limit < scalar @ResultList ) {

        # extract the limited ids
        $Limit--;
        @ResultList = @ResultList[ 0 .. $Limit ];
    }

    return \@ResultList;
}

=item ConfigItemSearch()

return a config item list as an array reference

    my $ConfigItemIDs = $ConfigItemObject->ConfigItemSearch(
        Number       => 'The ConfigItem Number',  # (optional)
        ClassIDs     => [9, 8, 7, 6],             # (optional)
        DeplStateIDs => [1, 2, 3, 4],             # (optional)
        InciStateIDs => [1, 2, 3, 4],             # (optional)
        CreateBy     => [1, 2, 3],                # (optional)
        ChangeBy     => [3, 2, 1],                # (optional)

        # config items with created time after ...
        ConfigItemCreateTimeNewerDate => '2006-01-09 00:00:01',  # (optional)
        # config items with created time before then ....
        ConfigItemCreateTimeOlderDate => '2006-01-19 23:59:59',  # (optional)

        # config items with changed time after ...
        ConfigItemChangeTimeNewerDate => '2006-01-09 00:00:01',  # (optional)
        # config items with changed time before then ....
        ConfigItemChangeTimeOlderDate => '2006-01-19 23:59:59',  # (optional)

        OrderBy => [ 'ConfigItemID', 'Number' ],                  # (optional)
        # default: [ 'ConfigItemID' ]
        # (ConfigItemID, Number, ClassID, DeplStateID, InciStateID,
        # CreateTime, CreateBy, ChangeTime, ChangeBy)

        # Additional information for OrderBy:
        # The OrderByDirection can be specified for each OrderBy attribute.
        # The pairing is made by the array indices.

        OrderByDirection => [ 'Down', 'Up' ],                    # (optional)
        # default: [ 'Down' ]
        # (Down | Up)

        Limit          => 122,  # (optional)
        UsingWildcards => 0,    # (optional) default 1
    );

=cut

sub ConfigItemSearch {
    my ( $Self, %Param ) = @_;

    # verify that all passed array parameters contain an arrayref
    ARGUMENT:
    for my $Argument (
        qw(
        OrderBy
        OrderByDirection
        )
        )
    {
        if ( !defined $Param{$Argument} ) {
            $Param{$Argument} ||= [];

            next ARGUMENT;
        }

        if ( ref $Param{$Argument} ne 'ARRAY' ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "$Argument must be an array reference!",
            );
            return;
        }
    }

    # define order table
    my %OrderByTable = (
        ConfigItemID => 'id',
        Number       => 'configitem_number',
        ClassID      => 'class_id',
        DeplStateID  => 'cur_depl_state_id',
        InciStateID  => 'cur_inci_state_id',
        CreateTime   => 'create_time',
        CreateBy     => 'create_by',
        ChangeTime   => 'change_time',
        ChangeBy     => 'change_by',
    );

    # check if OrderBy contains only unique valid values
    my %OrderBySeen;
    ORDERBY:
    for my $OrderBy ( @{ $Param{OrderBy} } ) {

        next ORDERBY if $OrderBy eq 'Name';

        if ( !$OrderBy || !$OrderByTable{$OrderBy} || $OrderBySeen{$OrderBy} ) {

            # found an error
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "OrderBy contains invalid value '$OrderBy' "
                    . 'or the value is used more than once!',
            );
            return;
        }

        # remember the value to check if it appears more than once
        $OrderBySeen{$OrderBy} = 1;
    }

    # check if OrderByDirection array contains only 'Up' or 'Down'
    DIRECTION:
    for my $Direction ( @{ $Param{OrderByDirection} } ) {

        # only 'Up' or 'Down' allowed
        next DIRECTION if $Direction eq 'Up';
        next DIRECTION if $Direction eq 'Down';

        # found an error
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "OrderByDirection can only contain 'Up' or 'Down'!",
        );
        return;
    }

    # set default values
    if ( !defined $Param{UsingWildcards} ) {
        $Param{UsingWildcards} = 1;
    }

    # get like escape string needed for some databases (e.g. oracle)
    my $LikeEscapeString = $Self->{DBObject}->GetDatabaseFunction('LikeEscapeString');

    # assemble the ORDER BY clause
    my @SQLOrderBy;
    my $Count = 0;
    ORDERBY:
    for my $OrderBy ( @{ $Param{OrderBy} } ) {

        next ORDERBY if $OrderBy eq 'Name';

        # set the default order direction
        my $Direction = 'DESC';

        # add the given order direction
        if ( $Param{OrderByDirection}->[$Count] ) {
            if ( $Param{OrderByDirection}->[$Count] eq 'Up' ) {
                $Direction = 'ASC';
            }
            elsif ( $Param{OrderByDirection}->[$Count] eq 'Down' ) {
                $Direction = 'DESC';
            }
        }

        # add SQL
        push @SQLOrderBy, "$OrderByTable{$OrderBy} $Direction";

    }
    continue {
        $Count++;
    }

    # if there is a possibility that the ordering is not determined
    # we add an ascending ordering by id
    if ( !grep { $_ eq 'ConfigItemID' } ( @{ $Param{OrderBy} } ) ) {
        push @SQLOrderBy, "$OrderByTable{ConfigItemID} ASC";
    }

    # add number to sql where array
    my @SQLWhere;
    if ( defined $Param{Number} && $Param{Number} ne '' ) {

        # quote
        $Param{Number} = $Self->{DBObject}->Quote( $Param{Number} );

        if ( $Param{UsingWildcards} ) {

            # prepare like string
            $Self->_PrepareLikeString( \$Param{Number} );

            push @SQLWhere,
                "LOWER(configitem_number) LIKE LOWER('$Param{Number}') $LikeEscapeString";
        }
        else {
            push @SQLWhere, "LOWER(configitem_number) = LOWER('$Param{Number}')";
        }
    }

    # set array params
    my %ArrayParams = (
        ClassIDs     => 'class_id',
        DeplStateIDs => 'cur_depl_state_id',
        InciStateIDs => 'cur_inci_state_id',
        CreateBy     => 'create_by',
        ChangeBy     => 'change_by',
    );

    ARRAYPARAM:
    for my $ArrayParam ( sort keys %ArrayParams ) {

        next ARRAYPARAM if !$Param{$ArrayParam};

        if ( ref $Param{$ArrayParam} ne 'ARRAY' ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "$ArrayParam must be an array reference!",
            );
            return;
        }

        next ARRAYPARAM if !@{ $Param{$ArrayParam} };

        # quote as integer
        for my $OneParam ( @{ $Param{$ArrayParam} } ) {
            $OneParam = $Self->{DBObject}->Quote( $OneParam, 'Integer' );
        }

        # create string
        my $InString = join q{, }, @{ $Param{$ArrayParam} };

        next ARRAYPARAM if !$InString;

        push @SQLWhere, "$ArrayParams{ $ArrayParam } IN ($InString)";
    }

    # set time params
    my %TimeParams = (
        ConfigItemCreateTimeNewerDate => 'create_time >=',
        ConfigItemCreateTimeOlderDate => 'create_time <=',
        ConfigItemChangeTimeNewerDate => 'change_time >=',
        ConfigItemChangeTimeOlderDate => 'change_time <=',
    );

    TIMEPARAM:
    for my $TimeParam ( sort keys %TimeParams ) {

        next TIMEPARAM if !$Param{$TimeParam};

        if ( $Param{$TimeParam} !~ m{ \A \d\d\d\d-\d\d-\d\d \s \d\d:\d\d:\d\d \z }xms ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Invalid date format found!",
            );
            return;
        }

        # quote
        $Param{$TimeParam} = $Self->{DBObject}->Quote( $Param{$TimeParam} );

        push @SQLWhere, "$TimeParams{ $TimeParam } '$Param{ $TimeParam }'";
    }

    # create where string
    my $WhereString = @SQLWhere ? ' WHERE ' . join q{ AND }, @SQLWhere : '';

    # set limit
    if ( $Param{Limit} ) {
        $Param{Limit} = $Self->{DBObject}->Quote( $Param{Limit}, 'Integer' );
    }

    my $SQL = "SELECT id FROM configitem $WhereString ";

    # add the ORDER BY clause
    if (@SQLOrderBy) {
        $SQL .= 'ORDER BY ';
        $SQL .= join ', ', @SQLOrderBy;
        $SQL .= ' ';
    }

    # ask database
    $Self->{DBObject}->Prepare(
        SQL   => $SQL,
        Limit => $Param{Limit},
    );

    # fetch the result
    my @ConfigItemList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @ConfigItemList, $Row[0];
    }

    return \@ConfigItemList;
}

=item ConfigItemLookup()

This method does a lookup for a configitem. If a configitem id is given,
it returns the number of the configitem. If a configitem number is given,
the appropriate id is returned.

    my $Number = $ConfigItemObject->ConfigItemLookup(
        ConfigItemID => 1234,
    );

    my $ID = $ConfigItemObject->ConfigItemLookup(
        ConfigItemNumber => 1000001,
    );

=cut

sub ConfigItemLookup {
    my ( $Self, %Param ) = @_;

    my ($Key) = grep { $Param{$_} } qw(ConfigItemID ConfigItemNumber);

    # check for needed stuff
    if ( !$Key ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID or ConfigItemNumber!',
        );
        return;
    }

    # if result is cached return that result
    return $Self->{Cache}->{ConfigItemLookup}->{$Key}->{ $Param{$Key} }
        if $Self->{Cache}->{ConfigItemLookup}->{$Key}->{ $Param{$Key} };

    # set the appropriate SQL statement
    my $SQL = 'SELECT configitem_number FROM configitem WHERE id = ?';

    if ( $Key eq 'ConfigItemNumber' ) {
        $SQL = 'SELECT id FROM configitem WHERE configitem_number = ?';
    }

    # fetch the requested value
    return if !$Self->{DBObject}->Prepare(
        SQL   => $SQL,
        Bind  => [ \$Param{$Key} ],
        Limit => 1,
    );

    my $Value;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Value = $Row[0];
    }

    $Self->{Cache}->{ConfigItemLookup}->{$Key}->{ $Param{$Key} } = $Value;

    return $Value;
}

=item UniqueNameCheck()

This method checks all already existing config items, whether the given name does already exist
within the same config item class or amongst all classes, depending on the SysConfig value of
UniqueCIName::UniquenessCheckScope (Class or Global).

This method requires 3 parameters: ConfigItemID, Name and Class
"ConfigItemID"  is the ID of the ConfigItem, which is to be checked for uniqueness
"Name"          is the config item name to be checked for uniqueness
"ClassID"       is the ID of the config item's class

All parameters are mandatory.

my $DuplicateNames = $ConfigItemObject->UniqueNameCheck(
    ConfigItemID => '73'
    Name         => 'PC#005',
    ClassID      => '32',
);

The given name is not unique
my $NameDuplicates = [ 5, 35, 48, ];    # IDs of ConfigItems with the same name

The given name is unique
my $NameDuplicates = [];

=cut

sub UniqueNameCheck {
    my ( $Self, %Param ) = @_;

    # check for needed stuff
    for my $Needed (qw(ConfigItemID Name ClassID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Missing parameter $Needed!",
            );
            return;
        }
    }

    # check ConfigItemID param for valid format
    if (
        !IsInteger( $Param{ConfigItemID} )
        && ( IsStringWithData( $Param{ConfigItemID} ) && $Param{ConfigItemID} ne 'NEW' )
        )
    {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "The ConfigItemID parameter needs to be an integer or 'NEW'",
        );
        return;
    }

    # check Name param for valid format
    if ( !IsStringWithData( $Param{Name} ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "The Name parameter needs to be a string!",
        );
        return;
    }

    # check ClassID param for valid format
    if ( !IsInteger( $Param{ClassID} ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "The ClassID parameter needs to be an integer",
        );
        return;
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # check class list for validity
    if ( !IsHashRefWithData($ClassList) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Unable to retrieve a valid class list!",
        );
        return;
    }

    # get the class name from the class list
    my $Class = $ClassList->{ $Param{ClassID} };

    # check class for validity
    if ( !IsStringWithData($Class) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Unable to determine a config item class using the given ClassID!",
        );
        return;
    }
    elsif ( $Self->{ConfigObject}->{Debug} > 0 ) {
        $Self->{LogObject}->Log(
            Priority => 'debug',
            Message  => "Resolved ClassID $Param{ClassID} to class $Class",
        );
    }

    # get the uniqueness scope from SysConfig
    my $Scope = $Self->{ConfigObject}->Get('UniqueCIName::UniquenessCheckScope');

    # check scope for validity
    if ( !IsStringWithData($Scope) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "The configuration of UniqueCIName::UniquenessCheckScope is invalid!",
        );
        return;
    }

    if ( $Scope ne 'global' && $Scope ne 'class' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "UniqueCIName::UniquenessCheckScope is $Scope, but must be either "
                . "'global' or 'class'!",
        );
        return;
    }

    if ( $Self->{ConfigObject}->{Debug} > 0 ) {
        $Self->{LogObject}->Log(
            Priority => 'debug',
            Message  => "The scope for checking the uniqueness is $Scope",
        );
    }

    my %SearchCriteria;

    # add the config item class to the search criteria if the uniqueness scope is not global
    if ( $Scope ne 'global' ) {
        $SearchCriteria{ClassIDs} = [ $Param{ClassID} ];
    }

    $SearchCriteria{Name} = $Param{Name};

    # search for a config item matching the given name
    my $ConfigItem = $Self->ConfigItemSearchExtended(%SearchCriteria);

    # remove the provided ConfigItemID from the results, otherwise the duplicate check would fail
    # because the ConfigItem itself is found as duplicate
    my @Duplicates = map {$_} grep { $_ ne $Param{ConfigItemID} } @{$ConfigItem};

    # if a config item was found, the given name is not unique
    # if no config item was found, the given name is unique

    # return the result of the config item search for duplicates
    return \@Duplicates;
}

=item CurInciStateRecalc()

recalculates the current incident state of this config item and all linked config items

    my $Success = $ConfigItemObject->CurInciStateRecalc(
        ConfigItemID => 123,
    );

=cut

sub CurInciStateRecalc {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID!',
        );
        return;
    }

    # get incident link type from config
    my $LinkType = $Self->{ConfigObject}->Get('ITSM::Core::IncidentLinkType');

    # remember the scanned config items
    my %ScannedConfigItemIDs;

    # find all config items with an incident state
    $Self->_FindInciConfigItems(
        ConfigItemID         => $Param{ConfigItemID},
        LinkType             => $LinkType,
        ScannedConfigItemIDs => \%ScannedConfigItemIDs,
    );

    # investigate all config items with a warning state
    CONFIGITEMID:
    for my $ConfigItemID ( sort keys %ScannedConfigItemIDs ) {

        next CONFIGITEMID if $ScannedConfigItemIDs{$ConfigItemID}->{Type} ne 'incident';

        $Self->_FindWarnConfigItems(
            ConfigItemID         => $ConfigItemID,
            LinkType             => $LinkType,
            ScannedConfigItemIDs => \%ScannedConfigItemIDs,
        );
    }

    # get the incident state list of warnings
    my $WarnStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::Core::IncidentState',
        Preferences => {
            Functionality => 'warning',
        },
    );

    my %ReverseWarnStateList = reverse %{$WarnStateList};
    my @SortedWarnList       = sort keys %ReverseWarnStateList;
    my $WarningStateID
        = $ReverseWarnStateList{Warning} || $ReverseWarnStateList{ $SortedWarnList[0] };

    # to store the relation between services and linked CIs
    my %ServiceCIRelation;

    CONFIGITEMID:
    for my $ConfigItemID ( sort keys %ScannedConfigItemIDs ) {

        # extract incident state type
        my $InciStateType = $ScannedConfigItemIDs{$ConfigItemID}->{Type};

        # find all linked services of this CI
        my %LinkedServiceIDs = $Self->{LinkObject}->LinkKeyListWithData(
            Object1 => 'ITSMConfigItem',
            Key1    => $ConfigItemID,
            Object2 => 'Service',
            State   => 'Valid',
            Type    => $LinkType,
            UserID  => 1,
        );

        SERVICEID:
        for my $ServiceID ( sort keys %LinkedServiceIDs ) {

            # remember the CIs that are linked with this service
            push @{ $ServiceCIRelation{$ServiceID} }, $ConfigItemID;
        }

        next CONFIGITEMID if $InciStateType eq 'incident';

        my $CurInciStateID = $WarningStateID;
        if ( $InciStateType eq 'operational' ) {

            # get last version
            my $LastVersion = $Self->VersionGet(
                ConfigItemID => $ConfigItemID,
                XMLDataGet   => 0,
            );

            $CurInciStateID = $LastVersion->{InciStateID};
        }

        # update current incident state
        $Self->{DBObject}->Do(
            SQL => "UPDATE configitem SET cur_inci_state_id = $CurInciStateID "
                . "WHERE id = $ConfigItemID",
        );
    }

    # set the current incident state type for each service (influenced by linked CIs)
    SERVICEID:
    for my $ServiceID ( sort keys %ServiceCIRelation ) {

        # set default incident state type
        my $CurInciStateTypeFromCIs = 'operational';

        # investigate the current incident state of each config item
        CONFIGITEMID:
        for my $ConfigItemID ( @{ $ServiceCIRelation{$ServiceID} } ) {

            # get config item data
            my $ConfigItemData = $Self->ConfigItemGet(
                ConfigItemID => $ConfigItemID,
                Cache        => 0,
            );

            next CONFIGITEMID if $ConfigItemData->{CurDeplStateType} ne 'productive';
            next CONFIGITEMID if $ConfigItemData->{CurInciStateType} eq 'operational';

            # check if service must be set to 'warning'
            if ( $ConfigItemData->{CurInciStateType} eq 'warning' ) {
                $CurInciStateTypeFromCIs = 'warning';
                next CONFIGITEMID;
            }

            # check if service must be set to 'incident'
            if ( $ConfigItemData->{CurInciStateType} eq 'incident' ) {
                $CurInciStateTypeFromCIs = 'incident';
                last CONFIGITEMID;
            }
        }

        # update the current incident state type from CIs of the service
        $Self->{ServiceObject}->ServicePreferencesSet(
            ServiceID => $ServiceID,
            Key       => 'CurInciStateTypeFromCIs',
            Value     => $CurInciStateTypeFromCIs,
            UserID    => 1,
        );
    }

    return 1;
}

=begin Internal:

=item _FindInciConfigItems()

find all config items with an incident state

    $ConfigItemObject->_FindInciConfigItems(
        ConfigItemID         => $ConfigItemID,
        LinkType             => $LinkType,
        ScannedConfigItemIDs => \%ScannedConfigItemIDs,
    );

=cut

sub _FindInciConfigItems {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{ConfigItemID};

    # ignore already scanned ids (infinite loop protection)
    return if $Param{ScannedConfigItemIDs}->{ $Param{ConfigItemID} };

    $Param{ScannedConfigItemIDs}->{ $Param{ConfigItemID} }->{Type} = 'operational';

    # find all linked config items (childs)
    my %LinkedConfigItemIDs = $Self->{LinkObject}->LinkKeyList(
        Object1   => 'ITSMConfigItem',
        Key1      => $Param{ConfigItemID},
        Object2   => 'ITSMConfigItem',
        State     => 'Valid',
        Type      => $Param{LinkType},
        Direction => 'Both',
        UserID    => 1,
    );

    # add own config item id to list of linked config items
    my @ConfigItemIDs = ( $Param{ConfigItemID}, keys %LinkedConfigItemIDs );

    CONFIGITEMID:
    for my $ConfigItemID (@ConfigItemIDs) {

        # get config item data
        my $ConfigItem = $Self->ConfigItemGet(
            ConfigItemID => $ConfigItemID,
            Cache        => 0,
        );

        # set incident state
        if ( $ConfigItem->{CurInciStateType} eq 'incident' ) {
            $Param{ScannedConfigItemIDs}->{$ConfigItemID}->{Type} = 'incident';
            next CONFIGITEMID;
        }

        # start recursion
        $Self->_FindInciConfigItems(
            ConfigItemID         => $ConfigItemID,
            LinkType             => $Param{LinkType},
            ScannedConfigItemIDs => $Param{ScannedConfigItemIDs},
        );
    }

    return 1;
}

=item _FindWarnConfigItems()

find all config items with a warning

    $ConfigItemObject->_FindWarnConfigItems(
        ConfigItemID         => $ConfigItemID,
        LinkType             => $LinkType,
        ScannedConfigItemIDs => $ScannedConfigItemIDs,
    );

=cut

sub _FindWarnConfigItems {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    return if !$Param{ConfigItemID};

    # ignore already scanned ids (infinite loop protection)
    return if $Param{ScannedConfigItemIDs}->{ $Param{ConfigItemID} }->{FindWarn};
    $Param{ScannedConfigItemIDs}->{ $Param{ConfigItemID} }->{FindWarn} = 1;

    # find all linked config items (parents)
    my %LinkedConfigItemIDs = $Self->{LinkObject}->LinkKeyList(
        Object1   => 'ITSMConfigItem',
        Key1      => $Param{ConfigItemID},
        Object2   => 'ITSMConfigItem',
        State     => 'Valid',
        Type      => $Param{LinkType},
        Direction => 'Both',
        UserID    => 1,
    );

    CONFIGITEMID:
    for my $ConfigItemID ( sort keys %LinkedConfigItemIDs ) {

        # start recursion
        $Self->_FindWarnConfigItems(
            ConfigItemID         => $ConfigItemID,
            LinkType             => $Param{LinkType},
            ScannedConfigItemIDs => $Param{ScannedConfigItemIDs},
        );

        next CONFIGITEMID
            if $Param{ScannedConfigItemIDs}->{$ConfigItemID}->{Type}
            && $Param{ScannedConfigItemIDs}->{$ConfigItemID}->{Type} eq 'incident';

        # set warning state
        $Param{ScannedConfigItemIDs}->{$ConfigItemID}->{Type} = 'warning';
    }

    return 1;
}

=item _PrepareLikeString()

internal function to prepare like strings

    $ConfigItemObject->_PrepareLikeString( $StringRef );

=cut

sub _PrepareLikeString {
    my ( $Self, $Value ) = @_;

    return if !$Value;
    return if ref $Value ne 'SCALAR';

    # Quote
    ${$Value} = $Self->{DBObject}->Quote( ${$Value}, 'Like' );

    # replace * with %
    ${$Value} =~ s{ \*+ }{%}xmsg;

    return;
}

1;

=end Internal:

=back

=head1 ITSM Config Item events:

ConfigItemCreate, VersionCreate, DeploymentStateUpdate, IncidentStateUpdate,
ConfigItemDelete, LinkAdd, LinkDelete, DefinitionUpdate, NameUpdate, ValueUpdate
DefinitionCreate, VersionDelete

=cut

=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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/ITSMConfigItem/Definition.pm - sub module of ITSMConfigItem.pm with definition functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::Definition;

use strict;
use warnings;

=head1 NAME

Kernel::System::ITSMConfigItem::Definition - sub module of Kernel::System::ITSMConfigItem

=head1 SYNOPSIS

All definition functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item DefinitionList()

return a config item definition list as arrayhash reference

    my $DefinitionListRef = $ConfigItemObject->DefinitionList(
        ClassID => 123,
    );

returns

    my $DefinitionListRef = [
          {
            'Version'      => '1',
            'CreateTime'   => '2012-06-12 14:09:43',
            'DefinitionID' => '1',
            'CreateBy'     => '123',
            'Definition'   => '[
                {
                    Key => \'Vendor\',
                    Name => \'Vendor\',
                    Searchable => 1,
                    Input => {
                        Type => \'Text\',
                        Size => 50,
                        MaxLength => 50,
                    },
                },
                {
                    Key => \'Description\',
                    Name => \'Description\',
                    Searchable => 1,
                    Input => {
                        Type => \'TextArea\',
                    },
                },
                {
                    Key => \'Type\',
                    Name => \'Type\',
                    Searchable => 1,
                    Input => {
                        Type => \'GeneralCatalog\',
                        Class => \'ITSM::ConfigItem::Computer::Type\',
                        Translation => 1,
                    },
                },
                ... etc ...
            ];',
          }
        ];

=cut

sub DefinitionList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ClassID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ClassID!',
        );
        return;
    }

    # ask database
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id, configitem_definition, version, create_time, create_by '
            . 'FROM configitem_definition WHERE class_id = ? ORDER BY version',
        Bind => [ \$Param{ClassID} ],
    );

    my @DefinitionList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Definition;
        $Definition{DefinitionID} = $Row[0];
        $Definition{Definition}   = $Row[1];
        $Definition{Version}      = $Row[2];
        $Definition{CreateTime}   = $Row[3];
        $Definition{CreateBy}     = $Row[4];

        push @DefinitionList, \%Definition;
    }

    return \@DefinitionList;
}

=item DefinitionGet()

return a config item definition as hash reference

Return
    $Definition->{DefinitionID}
    $Definition->{ClassID}
    $Definition->{Class}
    $Definition->{Definition}
    $Definition->{DefinitionRef}
    $Definition->{Version}
    $Definition->{CreateTime}
    $Definition->{CreateBy}

    my $DefinitionRef = $ConfigItemObject->DefinitionGet(
        DefinitionID => 123,
    );

    or

    my $DefinitionRef = $ConfigItemObject->DefinitionGet(
        ClassID => 123,
    );

=cut

sub DefinitionGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{DefinitionID} && !$Param{ClassID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need DefinitionID or ClassID!',
        );
        return;
    }

    if ( $Param{DefinitionID} ) {

        # check if result is already cached
        return $Self->{Cache}->{DefinitionGet}->{ $Param{DefinitionID} }
            if $Self->{Cache}->{DefinitionGet}->{ $Param{DefinitionID} };

        # ask database
        $Self->{DBObject}->Prepare(
            SQL => 'SELECT id, class_id, configitem_definition, version, create_time, create_by '
                . 'FROM configitem_definition WHERE id = ?',
            Bind  => [ \$Param{DefinitionID} ],
            Limit => 1,
        );
    }
    else {

        # ask database
        $Self->{DBObject}->Prepare(
            SQL => 'SELECT id, class_id, configitem_definition, version, create_time, create_by '
                . 'FROM configitem_definition '
                . 'WHERE class_id = ? ORDER BY version DESC',
            Bind  => [ \$Param{ClassID} ],
            Limit => 1,
        );
    }

    # fetch the result
    my %Definition;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Definition{DefinitionID} = $Row[0];
        $Definition{ClassID}      = $Row[1];
        $Definition{Definition}   = $Row[2];
        $Definition{Version}      = $Row[3];
        $Definition{CreateTime}   = $Row[4];
        $Definition{CreateBy}     = $Row[5];

        $Definition{DefinitionRef} = eval $Definition{Definition};    ## no critic
    }

    return {} if !$Definition{DefinitionID};

    # prepare definition
    if ( $Definition{DefinitionRef} && ref $Definition{DefinitionRef} eq 'ARRAY' ) {
        $Self->_DefinitionPrepare(
            DefinitionRef => $Definition{DefinitionRef},
        );
    }
    else {
        $Definition{DefinitionRef} = '';
    }

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # add class
    $Definition{Class} = $ClassList->{ $Definition{ClassID} };

    # cache the result
    $Self->{Cache}->{DefinitionGet}->{ $Definition{DefinitionID} } = \%Definition;

    return \%Definition;
}

=item DefinitionAdd()

add a new definition

    my $DefinitionID = $ConfigItemObject->DefinitionAdd(
        ClassID    => 123,
        Definition => 'the definition code',
        UserID     => 1,
    );

=cut

sub DefinitionAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID Definition UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # check definition
    my $Check = $Self->DefinitionCheck(
        Definition => $Param{Definition},
    );

    return if !$Check;

    # get last definition
    my $LastDefinition = $Self->DefinitionGet(
        ClassID => $Param{ClassID},
    );

    # stop add, if definition was not changed
    if ( $LastDefinition->{DefinitionID} && $LastDefinition->{Definition} eq $Param{Definition} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't add new definition! The definition was not changed.",
        );
        return;
    }

    # set version
    my $Version = 1;
    if ( $LastDefinition->{Version} ) {
        $Version = $LastDefinition->{Version};
        $Version++;
    }

    # insert new definition
    my $Success = $Self->{DBObject}->Do(
        SQL => 'INSERT INTO configitem_definition '
            . '(class_id, configitem_definition, version, create_time, create_by) VALUES '
            . '(?, ?, ?, current_timestamp, ?)',
        Bind => [ \$Param{ClassID}, \$Param{Definition}, \$Version, \$Param{UserID} ],
    );

    return if !$Success;

    # get id of new definition
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id FROM configitem_definition WHERE '
            . 'class_id = ? AND version = ? '
            . 'ORDER BY version DESC',
        Bind => [ \$Param{ClassID}, \$Version ],
        Limit => 1,
    );

    # fetch the result
    my $DefinitionID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $DefinitionID = $Row[0];
    }

    # trigger DefinitionCreate event
    $Self->EventHandler(
        Event => 'DefinitionCreate',
        Data  => {
            Comment => $DefinitionID,
        },
        UserID => $Param{UserID},
    );

    return $DefinitionID;
}

=item DefinitionCheck()

check the syntax of a new definition

    my $True = $ConfigItemObject->DefinitionCheck(
        Definition      => 'the definition code',
        CheckSubElement => 1,                 # (optional, default 0, to check sub elements recursively)
    );

=cut

sub DefinitionCheck {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Definition} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Definition!',
        );
        return;
    }

    # if check sub elements is enabled, we must not evaluate the expression
    # because this has been done in an earlier recursion step already
    my $Definition;
    if ( $Param{CheckSubElement} ) {
        $Definition = $Param{Definition};
    }
    else {
        $Definition = eval $Param{Definition};    ## no critic
    }

    # check if definition exists at all
    if ( !$Definition ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Invalid Definition! You have an syntax error in the definition.',
        );
        return;
    }

    # definition must be an array
    if ( ref $Definition ne 'ARRAY' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Invalid Definition! Definition is not an array reference.',
        );
        return;
    }

    # check each definition attribute
    for my $Attribute ( @{$Definition} ) {

        # each definition attribute must be a hash reference with data
        if ( !$Attribute || ref $Attribute ne 'HASH' || !%{$Attribute} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message =>
                    'Invalid Definition! At least one definition attribute is not a hash reference.',
            );
            return;
        }

        # recursion check for Sub-Elements
        for my $Key ( sort keys %{$Attribute} ) {

            my $Value = $Attribute->{$Key};

            if ( $Key eq 'Sub' && ref $Value eq 'ARRAY' ) {

                # check the sub array
                my $Check = $Self->DefinitionCheck(
                    Definition      => $Value,
                    CheckSubElement => 1,
                );

                if ( !$Check ) {
                    $Self->{LogObject}->Log(
                        Priority => 'error',
                        Message =>
                            "Invalid Sub-Definition of element with the key '$Attribute->{Key}'.",
                    );
                    return;
                }
            }
        }
    }

    return 1;
}

=item _DefinitionPrepare()

Prepare the syntax of a new definition

    my $True = $ConfigItemObject->_DefinitionPrepare(
        DefinitionRef => $ArrayRef,
    );

=cut

sub _DefinitionPrepare {
    my ( $Self, %Param ) = @_;

    # check definition
    if ( !$Param{DefinitionRef} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need DefinitionRef!',
        );
        return;
    }

    for my $Item ( @{ $Param{DefinitionRef} } ) {

        # set CountMin
        if ( !defined $Item->{CountMin} ) {
            $Item->{CountMin} = 1;
        }

        # set CountMax
        $Item->{CountMax} ||= 1;

        # set CountMin
        if ( $Item->{CountMin} > $Item->{CountMax} ) {
            $Item->{CountMin} = $Item->{CountMax};
        }

        # set CountDefault
        if ( !defined $Item->{CountDefault} ) {
            $Item->{CountDefault} = 1;
        }
        if ( $Item->{CountDefault} < $Item->{CountMin} ) {
            $Item->{CountDefault} = $Item->{CountMin};
        }
        if ( $Item->{CountDefault} > $Item->{CountMax} ) {
            $Item->{CountDefault} = $Item->{CountMax};
        }

        # start recursion, if "Sub" is defined.
        if ( $Item->{Sub} && ref $Item->{Sub} eq 'ARRAY' ) {
            $Self->_DefinitionPrepare(
                DefinitionRef => $Item->{Sub},
            );
        }
        else {
            delete $Item->{Sub};
        }
    }

    return 1;
}

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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/ITSMConfigItem/History.pm - module for ITSMConfigItem.pm with history functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::History;

use strict;
use warnings;

=head1 NAME

Kernel::System::ITSMConfigItem::History - module for ITSMConfigItem.pm with history functions

=head1 SYNOPSIS

All history functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item HistoryGet()

Returns an array reference with all history entries for the given config item.
Each array element is a hash reference representing one history entry.

These hash references contain information about:

    $Info{HistoryEntryID}
    $Info{ConfigItemID}
    $Info{HistoryType}
    $Info{HistoryTypeID}
    $Info{Comment}
    $Info{CreatedBy}
    $Info{CreateTime}
    $Info{UserID}
    $Info{UserLogin}
    $Info{UserLastname}
    $Info{UserFirstname}
    $Info{UserFullname}

    my $Info = $ConfigItemObject->HistoryGet(
        ConfigItemID => 1234,
    );

=cut

sub HistoryGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # if cached result exists, return that result
    return $Self->{Cache}->{CIVersions}->{ $Param{ConfigItemID} }
        if $Self->{Cache}->{CIVersions}->{ $Param{ConfigItemID} };

    # fetch some data from history for given config item
    return if !$Self->{DBObject}->Prepare(
        SQL => 'SELECT ch.id, ch.configitem_id, ch.content, ch.type_id, '
            . 'ch.create_by, ch.create_time, cht.name '
            . 'FROM configitem_history ch, configitem_history_type cht '
            . 'WHERE ch.type_id = cht.id AND ch.configitem_id = ? '
            . 'ORDER BY ch.id',
        Bind => [ \$Param{ConfigItemID} ],
    );

    # save data from history in array
    my @Entries;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Tmp = (
            HistoryEntryID => $Row[0],
            ConfigItemID   => $Row[1],
            Comment        => $Row[2],
            HistoryTypeID  => $Row[3],
            CreateBy       => $Row[4],
            CreateTime     => $Row[5],
            HistoryType    => $Row[6],
        );

        push @Entries, \%Tmp;
    }

    # get more information about user who created history entries
    for my $Entry (@Entries) {

        # get user information
        my %UserInfo = $Self->{UserObject}->GetUserData(
            UserID => $Entry->{CreateBy},
            Cached => 1,
        );

        # save additional information for history entry
        $Entry->{UserID}        = $UserInfo{UserID};
        $Entry->{UserLogin}     = $UserInfo{UserLogin};
        $Entry->{UserFirstname} = $UserInfo{UserFirstname};
        $Entry->{UserLastname}  = $UserInfo{UserLastname};
        $Entry->{UserFullname}  = $UserInfo{UserFullname};
    }

    # save result in cache
    $Self->{Cache}->{CIVersions}->{ $Param{ConfigItemID} } = \@Entries;

    return \@Entries;
}

=item HistoryEntryGet()

Returns a hash reference with information about a single history entry.
The hash reference contain information about:

    $Info{HistoryEntryID}
    $Info{ConfigItemID}
    $Info{HistoryType}
    $Info{HistoryTypeID}
    $Info{Comment}
    $Info{CreateBy}
    $Info{CreateTime}
    $Info{UserID}
    $Info{UserLogin}
    $Info{UserLastname}
    $Info{UserFirstname}

    my $Info = $ConfigItemObject->HistoryEntryGet(
        HistoryEntryID => 1234,
    );

=cut

sub HistoryEntryGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(HistoryEntryID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # if cached result exists, return that result
    if ( $Self->{Cache}->{Versions}->{ $Param{HistoryEntryID} } ) {
        my ($ConfigItemID) = keys %{ $Self->{Cache}->{Versions}->{ $Param{HistoryEntryID} } };
        return $Self->{Cache}->{Versions}->{ $Param{HistoryEntryID} }->{$ConfigItemID};
    }

    # fetch a single entry from history
    return if !$Self->{DBObject}->Prepare(
        SQL => 'SELECT ch.id, ch.configitem_id, ch.content, ch.type_id, '
            . 'ch.create_by, ch.create_time, cht.name '
            . 'FROM configitem_history ch, configitem_history_type cht '
            . 'WHERE ch.type_id = cht.id AND ch.id = ?',
        Bind  => [ \$Param{HistoryEntryID} ],
        Limit => 1,
    );

    my %Entry;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {

        %Entry = (
            HistoryEntryID => $Row[0],
            ConfigItemID   => $Row[1],
            Comment        => $Row[2],
            HistoryTypeID  => $Row[3],
            CreateBy       => $Row[4],
            CreateTime     => $Row[5],
            HistoryType    => $Row[6],
        );
    }

    # get user data for this entry
    my %UserInfo = $Self->{UserObject}->GetUserData(
        UserID => $Entry{CreateBy},
        Cached => 1,
    );

    $Entry{UserID}        = $UserInfo{UserID};
    $Entry{UserLogin}     = $UserInfo{UserLogin};
    $Entry{UserFirstname} = $UserInfo{UserFirstname};
    $Entry{UserLastname}  = $UserInfo{UserLastname};

    $Self->{Cache}->{Versions}->{ $Param{HistoryEntryID} }->{ $Entry{ConfigItemID} } = \%Entry;

    return \%Entry;
}

=item HistoryAdd()

Adds a single history entry to the history.

    $ConfigItemObject->HistoryAdd(
        ConfigItemID  => 1234,
        HistoryType   => 'NewConfigItem', # either HistoryType or HistoryTypeID is needed
        HistoryTypeID => 1,
        UserID        => 1,
        Comment       => 'Any useful information',
    );

=cut

sub HistoryAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemID UserID Comment)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    if ( !( $Param{HistoryType} || $Param{HistoryTypeID} ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need HistoryType or HistoryTypeID!',
        );
        return;
    }

    # get history type id from history type if history type is given.
    if ( $Param{HistoryType} ) {
        my $Id = $Self->HistoryTypeLookup( HistoryType => $Param{HistoryType} );

        if ( !$Id ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => 'Invalid history type given!',
            );
            return;
        }

        $Param{HistoryTypeID} = $Id;
    }

    # if history type is given
    elsif ( $Param{HistoryTypeID} ) {
        my $Name = $Self->HistoryTypeLookup( HistoryTypeID => $Param{HistoryTypeID} );

        if ( !$Name ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => 'Invalid history type id given!',
            );
            return;
        }
    }

    # check if given config item id points to an existing config item number
    if ( $Param{ConfigItemID} ) {

        my $Number = $Self->ConfigItemLookup(
            ConfigItemID => $Param{ConfigItemID},
        );

        if ( !$Number ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => 'Invalid config item id given!',
            );
            return;
        }
    }

    # delete cached results
    delete $Self->{Cache}->{CIVersions}->{ $Param{ConfigItemID} };

    # shorten the comment if it is bigger than max length
    if ( length( $Param{Comment} ) > 255 ) {

        my ( $Field, $Old, $New ) = split '%%', $Param{Comment}, 3;

        my $Length = int( ( 255 - length($Field) - 4 ) / 2 );

        if ( length($Old) > $Length ) {
            my $Index = int( $Length / 2 );
            $Old
                = substr( $Old, 0, $Index - 2 ) . '...' . substr( $Old, length($Old) - $Index + 2 );
        }
        if ( length($New) > $Length ) {
            my $Index = int( $Length / 2 );
            $New
                = substr( $New, 0, $Index - 2 ) . '...' . substr( $New, length($New) - $Index + 2 );
        }
        my $NewComment = $Field . '%%' . $Old . '%%' . $New;

        $Param{Comment} = $NewComment;
    }

    # insert history entry
    return $Self->{DBObject}->Do(
        SQL => 'INSERT INTO configitem_history ( configitem_id, content, create_by, '
            . 'create_time, type_id ) VALUES ( ?, ?, ?, current_timestamp, ? )',
        Bind => [
            \$Param{ConfigItemID},
            \$Param{Comment},
            \$Param{UserID},
            \$Param{HistoryTypeID},
        ],
    );
}

=item HistoryDelete()

Deletes complete history for a given config item

    $ConfigItemObject->HistoryDelete(
        ConfigItemID => 123,
    );

=cut

sub HistoryDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # delete cached results
    delete $Self->{Cache}->{CIVersion}->{ $Param{ConfigItemID} };
    for my $VersionNr ( sort keys %{ $Self->{Cache}->{Versions} } ) {
        my ($CacheConfigItem) = keys %{ $Self->{Cache}->{Versions}->{$VersionNr} };
        delete $Self->{Cache}->{Versions}->{$VersionNr} if $CacheConfigItem eq $Param{ConfigItemID};
    }

    # delete history for given config item
    return $Self->{DBObject}->Do(
        SQL  => 'DELETE FROM configitem_history WHERE configitem_id = ?',
        Bind => [ \$Param{ConfigItemID} ],
    );
}

=item HistoryEntryDelete()

Deletes a single history entry.

    $ConfigItemObject->HistoryEntryDelete(
        HistoryEntryID => 123,
    );

=cut

sub HistoryEntryDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(HistoryEntryID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # delete single entry
    return $Self->{DBObject}->Do(
        SQL  => 'DELETE FROM configitem_history WHERE id = ?',
        Bind => [ \$Param{HistoryEntryID} ],
    );
}

=item HistoryTypeLookup()

This method does a lookup for a history type. If a history type id is given,
it returns the name of the history type. If a history type is given, the appropriate
id is returned.

    my $Name = $ConfigItemObject->HistoryTypeLookup(
        HistoryTypeID => 1234,
    );

    my $Id = $ConfigItemObject->HistoryTypeLookup(
        HistoryType => 'ConfigItemCreate',
    );

=cut

sub HistoryTypeLookup {
    my ( $Self, %Param ) = @_;

    my ($Key) = grep { $Param{$_} } qw(HistoryTypeID HistoryType);

    # check for needed stuff
    if ( !$Key ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need HistoryTypeID or HistoryType!',
        );
        return;
    }

    # if result is cached return that result
    return $Self->{Cache}->{HistoryTypeLookup}->{ $Param{$Key} }
        if $Self->{Cache}->{HistoryTypeLookup}->{ $Param{$Key} };

    # set the appropriate SQL statement
    my $SQL = 'SELECT name FROM configitem_history_type WHERE id = ?';

    if ( $Key eq 'HistoryType' ) {
        $SQL = 'SELECT id FROM configitem_history_type WHERE name = ?';
    }

    # fetch the requested value
    return if !$Self->{DBObject}->Prepare(
        SQL   => $SQL,
        Bind  => [ \$Param{$Key} ],
        Limit => 1,
    );

    my $Value;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Value = $Row[0];
    }

    # save value in cache
    $Self->{Cache}->{HistoryTypeLookup}->{ $Param{$Key} } = $Value;

    return $Value;
}

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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/ITSMConfigItem/Number.pm - sub module of ITSMConfigItem.pm with number functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::Number;

use strict;
use warnings;

=head1 NAME

Kernel::System::ITSMConfigItem::Number - sub module of Kernel::System::ITSMConfigItem

=head1 SYNOPSIS

All config item number functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item ConfigItemNumberLookup()

return config item id or config item number

    my $ConfigItemNumber = $ConfigItemObject->ConfigItemNumberLookup(
        ConfigItemID => 123,
    );

    or

    my $ConfigItemID = $ConfigItemObject->ConfigItemNumberLookup(
        ConfigItemNumber => '123454321',
    );

=cut

sub ConfigItemNumberLookup {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} && !$Param{ConfigItemNumber} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID or ConfigItemNumber!',
        );
        return;
    }

    if ( $Param{ConfigItemID} ) {

        # check if result is already cached
        return $Self->{Cache}->{ConfigItemNumberLookup}->{ID}->{ $Param{ConfigItemID} }
            if $Self->{Cache}->{ConfigItemNumberLookup}->{ID}->{ $Param{ConfigItemID} };

        # ask database
        $Self->{DBObject}->Prepare(
            SQL   => 'SELECT configitem_number FROM configitem WHERE id = ?',
            Bind  => [ \$Param{ConfigItemID} ],
            Limit => 1,
        );

        # fetch the result
        my $ConfigItemNumber;
        while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
            $ConfigItemNumber = $Row[0];
        }

        # cache the result
        $Self->{Cache}->{ConfigItemNumberLookup}->{ID}->{ $Param{ConfigItemID} }
            = $ConfigItemNumber;

        return $ConfigItemNumber;
    }

    # check if result is already cached
    return $Self->{Cache}->{ConfigItemNumberLookup}->{Number}->{ $Param{ConfigItemNumber} }
        if $Self->{Cache}->{ConfigItemNumberLookup}->{Number}->{ $Param{ConfigItemNumber} };

    # ask database
    $Self->{DBObject}->Prepare(
        SQL   => 'SELECT id FROM configitem WHERE configitem_number = ?',
        Bind  => [ \$Param{ConfigItemNumber} ],
        Limit => 1,
    );

    # fetch the result
    my $ConfigItemID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $ConfigItemID = $Row[0];
    }

    # cache the result
    $Self->{Cache}->{ConfigItemNumberLookup}->{Number}->{ $Param{ConfigItemNumber} }
        = $ConfigItemID;

    return $ConfigItemID;
}

=item ConfigItemNumberCreate()

create a new config item number

    my $Number = $ConfigItemObject->ConfigItemNumberCreate(
        Type    => 'AutoIncrement',
        ClassID => 123,
    );

=cut

sub ConfigItemNumberCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Type ClassID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # load backend
    if ( !$Self->{MainObject}->Require( $Param{Type} ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't load config item number generator backend module $Param{Type}! $@",
        );
        return;
    }

    # load backend
    return if !$Self->{MainObject}->RequireBaseClass( $Param{Type} );

    # create number
    my $Number = $Self->_ConfigItemNumberCreate(%Param);

    return $Number;
}

=item CurrentCounterGet()

return the current counter of a class

    my $Counter = $ConfigItemObject->CurrentCounterGet(
        ClassID => 123,
        Type    => 'AutoIncrement',
    );

=cut

sub CurrentCounterGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID Type)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # ask the database
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT counter FROM configitem_counter WHERE '
            . 'class_id = ? AND counter_type = ?',
        Bind => [ \$Param{ClassID}, \$Param{Type} ],
        Limit => 1,
    );

    # fetch the result
    my $Number;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Number = $Row[0];
    }

    return $Number;
}

=item CurrentCounterSet()

set the current counter of a class

    my $True = $ConfigItemObject->CurrentCounterSet(
        ClassID => 123,
        Type    => 'AutoIncrement',
        Counter => '12',
    );

=cut

sub CurrentCounterSet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID Type Counter)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # delete old counter
    $Self->{DBObject}->Do(
        SQL  => 'DELETE FROM configitem_counter WHERE class_id = ?',
        Bind => [ \$Param{ClassID} ],
    );

    # set new counter
    $Self->{DBObject}->Do(
        SQL => 'INSERT INTO configitem_counter '
            . '(class_id, counter_type, counter) VALUES (?, ?, ?)',
        Bind => [ \$Param{ClassID}, \$Param{Type}, \$Param{Counter} ],
    );

    return 1;
}

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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vUGVybWlzc2lvbi5wbSAtIG1vZHVsZSBmb3IgSVRTTUNvbmZpZ0l0ZW0ucG0gd2l0aCBQZXJtaXNzaW9uIGZ1bmN0aW9ucwojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKPWhlYWQxIE5BTUUKCktlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6UGVybWlzc2lvbiAtIG1vZHVsZSBmb3IgSVRTTUNvbmZpZ0l0ZW0ucG0gd2l0aCBQZXJtaXNzaW9uIGZ1bmN0aW9ucwoKPWhlYWQxIFNZTk9QU0lTCgpBbGwgUGVybWlzc2lvbiBmdW5jdGlvbnMuCgo9aGVhZDEgUFVCTElDIElOVEVSRkFDRQoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gUGVybWlzc2lvbigpCgpyZXR1cm5zIHdoZXRoZXIgdGhlIHVzZXIgaGFzIHBlcm1pc3Npb25zIG9yIG5vdAoKICAgIG15ICRBY2Nlc3MgPSAkQ29uZmlnSXRlbU9iamVjdC0+UGVybWlzc2lvbigKICAgICAgICBUeXBlICAgICA9PiAncm8nLAogICAgICAgIFNjb3BlICAgID0+ICdDbGFzcycsICMgQ2xhc3MgfHwgSXRlbQogICAgICAgIENsYXNzSUQgID0+IDEyMywgICAgICMgaWYgU2NvcGUgaXMgJ0NsYXNzJwogICAgICAgIEl0ZW1JRCAgID0+IDEyMywgICAgICMgaWYgU2NvcGUgaXMgJ0l0ZW0nCiAgICAgICAgVXNlcklEICAgPT4gMTIzLAogICAgKTsKCm9yIHdpdGhvdXQgbG9nZ2luZywgZm9yIGV4YW1wbGUgZm9yIHRvIGNoZWNrIGlmIGEgbGluay9hY3Rpb24gc2hvdWxkIGJlIHNob3duCgogICAgbXkgJEFjY2VzcyA9ICRDb25maWdJdGVtT2JqZWN0LT5QZXJtaXNzaW9uKAogICAgICAgIFR5cGUgICAgID0+ICdybycsCiAgICAgICAgU2NvcGUgICAgPT4gJ0NsYXNzJywgIyBDbGFzcyB8fCBJdGVtCiAgICAgICAgQ2xhc3NJRCAgPT4gMTIzLCAgICAgIyBpZiBTY29wZSBpcyAnQ2xhc3MnCiAgICAgICAgSXRlbUlEICAgPT4gMTIzLCAgICAgIyBpZiBTY29wZSBpcyAnSXRlbScKICAgICAgICBMb2dObyAgICA9PiAxLAogICAgICAgIFVzZXJJRCAgID0+IDEyMywKICAgICk7Cgo9Y3V0CgpzdWIgUGVybWlzc2lvbiB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJE5lZWRlZCAocXcoVHlwZSBTY29wZSBVc2VySUQpKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyROZWVkZWR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkTmVlZGVkISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgIyBjaGVjayBmb3IgZXhpc3RlbmNlIG9mIEl0ZW1JRCBvciBDbGFzc0lEIGRlcGVuZGVudAogICAgIyBvbiB0aGUgU2NvcGUKICAgIGlmICgKICAgICAgICAoICRQYXJhbXtTY29wZX0gZXEgJ0NsYXNzJyAmJiAhJFBhcmFte0NsYXNzSUR9ICkKICAgICAgICB8fCAoICRQYXJhbXtTY29wZX0gZXEgJ0l0ZW0nICYmICEkUGFyYW17SXRlbUlEfSApCiAgICAgICAgKQogICAgewogICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCBDbGFzc0lEIGlmIFNjb3BlIGlzICdDbGFzcycgb3IgSXRlbUlEIGlmIFNjb3BlIGlzICdJdGVtJyEiLAogICAgICAgICk7CiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgICMgcnVuIGFsbCBJVFNNQ29uZmlnSXRlbSBQZXJtaXNzaW9uIG1vZHVsZXMKICAgIGlmICgKICAgICAgICByZWYgJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoICdJVFNNQ29uZmlnSXRlbTo6UGVybWlzc2lvbjo6JyAuICRQYXJhbXtTY29wZX0gKSBlcSAnSEFTSCcKICAgICAgICApCiAgICB7CiAgICAgICAgbXkgJU1vZHVsZXMKICAgICAgICAgICAgPSAleyAkU2VsZi0+e0NvbmZpZ09iamVjdH0tPkdldCggJ0lUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOjonIC4gJFBhcmFte1Njb3BlfSApIH07CiAgICAgICAgZm9yIG15ICRNb2R1bGUgKCBzb3J0IGtleXMgJU1vZHVsZXMgKSB7CgogICAgICAgICAgICAjIGxvYWQgbW9kdWxlCiAgICAgICAgICAgIG5leHQgaWYgISRTZWxmLT57TWFpbk9iamVjdH0tPlJlcXVpcmUoICRNb2R1bGVzeyRNb2R1bGV9LT57TW9kdWxlfSApOwoKICAgICAgICAgICAgIyBjcmVhdGUgb2JqZWN0CiAgICAgICAgICAgIG15ICRNb2R1bGVPYmplY3QgPSAkTW9kdWxlc3skTW9kdWxlfS0+e01vZHVsZX0tPm5ldygKICAgICAgICAgICAgICAgIENvbmZpZ09iamVjdCAgICAgICAgID0+ICRTZWxmLT57Q29uZmlnT2JqZWN0fSwKICAgICAgICAgICAgICAgIExvZ09iamVjdCAgICAgICAgICAgID0+ICRTZWxmLT57TG9nT2JqZWN0fSwKICAgICAgICAgICAgICAgIERCT2JqZWN0ICAgICAgICAgICAgID0+ICRTZWxmLT57REJPYmplY3R9LAogICAgICAgICAgICAgICAgTWFpbk9iamVjdCAgICAgICAgICAgPT4gJFNlbGYtPntNYWluT2JqZWN0fSwKICAgICAgICAgICAgICAgIEVuY29kZU9iamVjdCAgICAgICAgID0+ICRTZWxmLT57RW5jb2RlT2JqZWN0fSwKICAgICAgICAgICAgICAgIENvbmZpZ0l0ZW1PYmplY3QgICAgID0+ICRTZWxmLAogICAgICAgICAgICAgICAgVXNlck9iamVjdCAgICAgICAgICAgPT4gJFNlbGYtPntVc2VyT2JqZWN0fSwKICAgICAgICAgICAgICAgIERlYnVnICAgICAgICAgICAgICAgID0+ICRTZWxmLT57RGVidWd9LAogICAgICAgICAgICAgICAgR2VuZXJhbENhdGFsb2dPYmplY3QgPT4gJFNlbGYtPntHZW5lcmFsQ2F0YWxvZ09iamVjdH0sCiAgICAgICAgICAgICk7CgogICAgICAgICAgICAjIGV4ZWN1dGUgUnVuKCkKICAgICAgICAgICAgbXkgJEFjY2Vzc09rID0gJE1vZHVsZU9iamVjdC0+UnVuKCVQYXJhbSk7CgogICAgICAgICAgICAjIGNoZWNrIGdyYW50ZWQgb3B0aW9uIChzaG91bGQgSSBzYXkgb2spCiAgICAgICAgICAgIGlmICggJEFjY2Vzc09rICYmICRNb2R1bGVzeyRNb2R1bGV9LT57R3JhbnRlZH0gKSB7CgogICAgICAgICAgICAgICAgIyBhY2Nlc3Mgb2sKICAgICAgICAgICAgICAgIHJldHVybiAxOwogICAgICAgICAgICB9CgogICAgICAgICAgICAjIHJldHVybiBiZWNhdXNlIGFjY2VzcyBpcyBmYWxzZSBidXQgaXQncyByZXF1aXJlZAogICAgICAgICAgICBpZiAoICEkQWNjZXNzT2sgJiYgJE1vZHVsZXN7JE1vZHVsZX0tPntSZXF1aXJlZH0gKSB7CiAgICAgICAgICAgICAgICBpZiAoICEkUGFyYW17TG9nTm99ICkgewogICAgICAgICAgICAgICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnbm90aWNlJywKICAgICAgICAgICAgICAgICAgICAgICAgTWVzc2FnZSAgPT4gIlBlcm1pc3Npb24gZGVuaWVkIGJlY2F1c2UgbW9kdWxlICIKICAgICAgICAgICAgICAgICAgICAgICAgICAgIC4gIigkTW9kdWxlc3skTW9kdWxlfS0+e01vZHVsZX0pIGlzIHJlcXVpcmVkICIKICAgICAgICAgICAgICAgICAgICAgICAgICAgIC4gIihVc2VySUQ6ICRQYXJhbXtVc2VySUR9ICckUGFyYW17VHlwZX0nICIKICAgICAgICAgICAgICAgICAgICAgICAgICAgIC4gIm9uICRQYXJhbXtTY29wZX06ICIgLiAkUGFyYW17ICRQYXJhbXtTY29wZX0gLiAnSUQnIH0gLiAiKSEiLAogICAgICAgICAgICAgICAgICAgICk7CiAgICAgICAgICAgICAgICB9CgogICAgICAgICAgICAgICAgIyBhY2Nlc3Mgbm90IG9rCiAgICAgICAgICAgICAgICByZXR1cm47CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CgogICAgIyBkb24ndCBncmFudCBhY2Nlc3MKICAgIGlmICggISRQYXJhbXtMb2dOb30gKSB7CiAgICAgICAgJFNlbGYtPntMb2dPYmplY3R9LT5Mb2coCiAgICAgICAgICAgIFByaW9yaXR5ID0+ICdub3RpY2UnLAogICAgICAgICAgICBNZXNzYWdlICA9PiAiUGVybWlzc2lvbiBkZW5pZWQgKFVzZXJJRDogJFBhcmFte1VzZXJJRH0gJyRQYXJhbXtUeXBlfScgIgogICAgICAgICAgICAgICAgLiAib24gJFBhcmFte1Njb3BlfTogIiAuICRQYXJhbXsgJFBhcmFte1Njb3BlfSAuICdJRCcgfSAuICIpISIsCiAgICAgICAgKTsKICAgIH0KCiAgICByZXR1cm47Cn0KCjE7Cgo9YmFjawoKPWhlYWQxIFRFUk1TIEFORCBDT05ESVRJT05TCgpUaGlzIHNvZnR3YXJlIGlzIHBhcnQgb2YgdGhlIE9UUlMgcHJvamVjdCAoaHR0cDovL290cnMub3JnLykuCgpUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQp0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CmRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBMPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dD4uCgo9Y3V0Cg==
# --
# Kernel/System/ITSMConfigItem/Version.pm - sub module of ITSMConfigItem.pm with version functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::Version;

use strict;
use warnings;
use Kernel::System::VariableCheck qw(:all);

use Storable;

=head1 NAME

Kernel::System::ITSMConfigItem::Version - sub module of Kernel::System::ITSMConfigItem

=head1 SYNOPSIS

All version functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item VersionZoomList()

return a config item version list as arrayhash reference

    my $VersionListRef = $ConfigItemObject->VersionZoomList(
        ConfigItemID => 123,
    );

=cut

sub VersionZoomList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID!',
        );
        return;
    }

    # get config item
    my $ConfigItem = $Self->ConfigItemGet(
        ConfigItemID => $Param{ConfigItemID},
    );

    # get version zoom list
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id, name, depl_state_id, inci_state_id, create_time, create_by '
            . 'FROM configitem_version WHERE configitem_id = ? ORDER BY id',
        Bind => [ \$Param{ConfigItemID} ],
    );

    # fetch the result
    my @VersionList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Version;
        $Version{VersionID}   = $Row[0];
        $Version{Name}        = $Row[1];
        $Version{DeplStateID} = $Row[2];
        $Version{InciStateID} = $Row[3];
        $Version{CreateTime}  = $Row[4];
        $Version{CreateBy}    = $Row[5];

        push @VersionList, \%Version;
    }

    for my $Version (@VersionList) {

        # get deployment state functionality
        my $DeplState = $Self->{GeneralCatalogObject}->ItemGet(
            ItemID => $Version->{DeplStateID},
        );

        $Version->{DeplState}     = $DeplState->{Name};
        $Version->{DeplStateType} = $DeplState->{Functionality};

        # get incident state functionality
        my $InciState = $Self->{GeneralCatalogObject}->ItemGet(
            ItemID => $Version->{InciStateID},
        );

        $Version->{InciState}     = $InciState->{Name};
        $Version->{InciStateType} = $InciState->{Functionality};

        # add config item data
        $Version->{ClassID}          = $ConfigItem->{ClassID};
        $Version->{Class}            = $ConfigItem->{Class};
        $Version->{Number}           = $ConfigItem->{Number};
        $Version->{CurDeplStateID}   = $ConfigItem->{CurDeplStateID};
        $Version->{CurDeplState}     = $ConfigItem->{CurDeplState};
        $Version->{CurDeplStateType} = $ConfigItem->{CurDeplStateType};
        $Version->{CurInciStateID}   = $ConfigItem->{CurInciStateID};
        $Version->{CurInciState}     = $ConfigItem->{CurInciState};
        $Version->{CurInciStateType} = $ConfigItem->{CurInciStateType};
    }

    return \@VersionList;
}

=item VersionList()

return a config item version list as array reference

    my $VersionListRef = $ConfigItemObject->VersionList(
        ConfigItemID => 123,
    );

=cut

sub VersionList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need ConfigItemID!',
        );
        return;
    }

    # get version list
    $Self->{DBObject}->Prepare(
        SQL  => 'SELECT id FROM configitem_version WHERE configitem_id = ? ORDER BY id',
        Bind => [ \$Param{ConfigItemID} ],
    );

    # fetch the result
    my @VersionList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @VersionList, $Row[0];
    }

    return \@VersionList;
}

=item VersionGet()

returns a version of a config item as hash reference.
The returned hash contains following attributes.

    $Version{VersionID}
    $Version{ConfigItemID}
    $Version{Number}
    $Version{ClassID}
    $Version{Class}
    $Version{LastVersionID}
    $Version{Name}
    $Version{DefinitionID}
    $Version{DeplStateID}
    $Version{DeplState}
    $Version{DeplStateType}
    $Version{CurDeplStateID}
    $Version{CurDeplState}
    $Version{CurDeplStateType}
    $Version{InciStateID}
    $Version{InciState}
    $Version{InciStateType}
    $Version{CurInciStateID}
    $Version{CurInciState}
    $Version{CurInciStateType}
    $Version{XMLDefinition}
    $Version{XMLData}
    $Version{CreateTime}
    $Version{CreateBy}

    my $VersionRef = $ConfigItemObject->VersionGet(
        VersionID  => 123,
        XMLDataGet => 1,    # (optional) default 1 (0|1)
    );

    or

    my $VersionRef = $ConfigItemObject->VersionGet(
        ConfigItemID => 123,
    );

When the date from the XML storage is not needed then fetching the XML data can be
explicitly turned off by passing XMLDataGet => 0.

    my $VersionRef = $ConfigItemObject->VersionGet(
        ConfigItemID => 123,
        XMLDataGet   => 0,
    );

The result of this call is not cached, as the next call to VersionGet() might need
the XML data. On the other hand, when the cache is already filled, the cached
version hash is returned with the XML data. So you get more than you asked for, which isn't
a bad thing.

=cut

sub VersionGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{VersionID} && !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need VersionID or ConfigItemID!',
        );
        return;
    }

    if ( !defined $Param{XMLDataGet} ) {
        $Param{XMLDataGet} = 1;
    }

    if ( $Param{VersionID} ) {

        # check if result is already cached
        if ( $Self->{Cache}->{VersionGet}->{ $Param{VersionID} } ) {

            # return a clone of the cache, as the caller should not be able do change the cache
            return Storable::dclone( $Self->{Cache}->{VersionGet}->{ $Param{VersionID} } );
        }

        # get version
        $Self->{DBObject}->Prepare(
            SQL => 'SELECT id, configitem_id, name, definition_id, '
                . 'depl_state_id, inci_state_id, create_time, create_by '
                . 'FROM configitem_version WHERE id = ?',
            Bind  => [ \$Param{VersionID} ],
            Limit => 1,
        );
    }
    else {

        # get version
        $Self->{DBObject}->Prepare(
            SQL => 'SELECT id, configitem_id, name, definition_id, '
                . 'depl_state_id, inci_state_id, create_time, create_by '
                . 'FROM configitem_version '
                . 'WHERE configitem_id = ? ORDER BY id DESC',
            Bind  => [ \$Param{ConfigItemID} ],
            Limit => 1,
        );
    }

    # fetch the result
    my %Version;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Version{VersionID}    = $Row[0];
        $Version{ConfigItemID} = $Row[1];
        $Version{Name}         = $Row[2];
        $Version{DefinitionID} = $Row[3];
        $Version{DeplStateID}  = $Row[4];
        $Version{InciStateID}  = $Row[5];
        $Version{CreateTime}   = $Row[6];
        $Version{CreateBy}     = $Row[7];
    }

    # check version
    if ( !$Version{VersionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'No such config item version!',
        );
        return;
    }

    # get deployment state functionality
    my $DeplState = $Self->{GeneralCatalogObject}->ItemGet(
        ItemID => $Version{DeplStateID},
    );

    $Version{DeplState}     = $DeplState->{Name};
    $Version{DeplStateType} = $DeplState->{Functionality};

    # get incident state functionality
    my $InciState = $Self->{GeneralCatalogObject}->ItemGet(
        ItemID => $Version{InciStateID},
    );

    $Version{InciState}     = $InciState->{Name};
    $Version{InciStateType} = $InciState->{Functionality};

    # get config item
    my $ConfigItem = $Self->ConfigItemGet(
        ConfigItemID => $Version{ConfigItemID},
        Cache        => 0,
    );

    # check config item data
    if ( !$ConfigItem || ref $ConfigItem ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't get config item $Version{ConfigItemID}!",
        );
        return;
    }

    $Version{ClassID}          = $ConfigItem->{ClassID};
    $Version{Class}            = $ConfigItem->{Class};
    $Version{LastVersionID}    = $ConfigItem->{LastVersionID};
    $Version{Number}           = $ConfigItem->{Number};
    $Version{CurDeplStateID}   = $ConfigItem->{CurDeplStateID};
    $Version{CurDeplState}     = $ConfigItem->{CurDeplState};
    $Version{CurDeplStateType} = $ConfigItem->{CurDeplStateType};
    $Version{CurInciStateID}   = $ConfigItem->{CurInciStateID};
    $Version{CurInciState}     = $ConfigItem->{CurInciState};
    $Version{CurInciStateType} = $ConfigItem->{CurInciStateType};

    # do not cache the version without the XML data,
    # the next caller might need the XML data
    return \%Version if !$Param{XMLDataGet};

    # get xml definition
    my $Definition = $Self->DefinitionGet(
        DefinitionID => $Version{DefinitionID},
    );
    $Version{XMLDefinition} = $Definition->{DefinitionRef};

    # get xml data
    $Version{XMLData} = $Self->_XMLVersionGet(
        ClassID   => $ConfigItem->{ClassID},
        VersionID => $Version{VersionID},
    );

    # cache the result
    $Self->{Cache}->{VersionGet}->{ $Version{VersionID} } = \%Version;

    # return a clone of the cache, as the caller should not be able to change the cache
    return Storable::dclone( $Self->{Cache}->{VersionGet}->{ $Version{VersionID} } );
}

=item VersionConfigItemIDGet()

return the config item id of a version

    my $ConfigItemID = $ConfigItemObject->VersionConfigItemIDGet(
        VersionID => 123,
    );

=cut

sub VersionConfigItemIDGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{VersionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need VersionID!',
        );
        return;
    }

    # check if result is already cached
    return $Self->{Cache}->{VersionConfigItemIDGet}->{ $Param{VersionID} }
        if $Self->{Cache}->{VersionConfigItemIDGet}->{ $Param{VersionID} };

    # get config item id
    $Self->{DBObject}->Prepare(
        SQL   => 'SELECT configitem_id FROM configitem_version WHERE id = ?',
        Bind  => [ \$Param{VersionID} ],
        Limit => 1,
    );

    # fetch the result
    my $ConfigItemID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $ConfigItemID = $Row[0];
    }

    # cache the result
    $Self->{Cache}->{VersionConfigItemIDGet}->{ $Param{VersionID} } = $ConfigItemID;

    return $ConfigItemID;
}

=item VersionAdd()

add a new version

    my $VersionID = $ConfigItemObject->VersionAdd(
        ConfigItemID => 123,
        Name         => 'The Name',
        DefinitionID => 1212,
        DeplStateID  => 8,
        InciStateID  => 4,
        XMLData      => $ArrayHashRef,  # (optional)
        UserID       => 1,
    );

=cut

sub VersionAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Attribute (qw(ConfigItemID Name DefinitionID DeplStateID InciStateID UserID)) {
        if ( !$Param{$Attribute} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Attribute!",
            );
            return;
        }
    }

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    );

    return if !$DeplStateList;
    return if ref $DeplStateList ne 'HASH';

    # check the deployment state id
    if ( !$DeplStateList->{ $Param{DeplStateID} } ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'No valid deployment state id given!',
        );
        return;
    }

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::Core::IncidentState',
    );

    return if !$InciStateList;
    return if ref $InciStateList ne 'HASH';

    # check the incident state id
    if ( !$InciStateList->{ $Param{InciStateID} } ) {

        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'No valid incident state id given!',
        );
        return;
    }

    # get VersionList
    my $VersionList = $Self->VersionList(
        ConfigItemID => $Param{ConfigItemID},
    );

    my $ConfigItemInfo = {};

    if ( @{$VersionList} ) {

        # get old version info for comparisons with current version
        # this is needed to trigger some events
        $ConfigItemInfo = $Self->VersionGet(
            ConfigItemID => $Param{ConfigItemID},
            XMLDataGet   => 0,
        );
    }
    else {

        # get config item
        $ConfigItemInfo = $Self->ConfigItemGet(
            ConfigItemID => $Param{ConfigItemID},
        );
    }

    return if !$ConfigItemInfo;
    return if ref $ConfigItemInfo ne 'HASH';

    # check, whether the feature to check for a unique name is enabled
    if ( $Self->{ConfigObject}->Get('UniqueCIName::EnableUniquenessCheck') ) {

        my $NameDuplicates = $Self->UniqueNameCheck(
            ConfigItemID => $Param{ConfigItemID},
            ClassID      => $ConfigItemInfo->{ClassID},
            Name         => $Param{Name},
        );

        # stop processing if the name is not unique
        if ( IsArrayRefWithData($NameDuplicates) ) {

            # build a string of all duplicate IDs
            my $Duplicates = join ', ', @{$NameDuplicates};

            # write an error log message containing all the duplicate IDs
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "The name $Param{Name} is already in use (ConfigItemIDs: $Duplicates)!",
            );
            return;
        }
    }

    my $Events = $Self->_GetEvents(
        Param          => \%Param,
        ConfigItemInfo => $ConfigItemInfo,
    );

    my $ReturnVersionID = scalar @{$VersionList} ? $VersionList->[-1] : 0;
    return $ReturnVersionID if !( $Events && keys %{$Events} );

    # insert new version
    my $Success = $Self->{DBObject}->Do(
        SQL => 'INSERT INTO configitem_version '
            . '(configitem_id, name, definition_id, '
            . 'depl_state_id, inci_state_id, create_time, create_by) VALUES '
            . '(?, ?, ?, ?, ?, current_timestamp, ?)',
        Bind => [
            \$Param{ConfigItemID},
            \$Param{Name},
            \$Param{DefinitionID},
            \$Param{DeplStateID},
            \$Param{InciStateID},
            \$Param{UserID},
        ],
    );

    return if !$Success;

    # delete cache
    for my $VersionID ( @{$VersionList} ) {
        delete $Self->{Cache}->{VersionGet}->{$VersionID};
    }

    # get id of new version
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id, create_time FROM configitem_version WHERE '
            . 'configitem_id = ? ORDER BY id DESC',
        Bind  => [ \$Param{ConfigItemID} ],
        Limit => 1,
    );

    # fetch the result
    my $VersionID;
    my $CreateTime;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $VersionID  = $Row[0];
        $CreateTime = $Row[1];
    }

    # check version id
    if ( !$VersionID ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't get the new version id!",
        );
        return;
    }

    # add xml data
    if ( $Param{XMLData} && ref $Param{XMLData} eq 'ARRAY' ) {
        $Self->_XMLVersionAdd(
            ClassID      => $ConfigItemInfo->{ClassID},
            ConfigItemID => $Param{ConfigItemID},
            VersionID    => $VersionID,
            XMLData      => $Param{XMLData},
        );
    }

    # update last_version_id, cur_depl_state_id, cur_inci_state_id, change_time and change_by
    $Self->{DBObject}->Do(
        SQL => 'UPDATE configitem SET last_version_id = ?, '
            . 'cur_depl_state_id = ?, cur_inci_state_id = ?, '
            . 'change_time = ?, change_by = ? '
            . 'WHERE id = ?',
        Bind => [
            \$VersionID,
            \$Param{DeplStateID},
            \$Param{InciStateID},
            \$CreateTime,
            \$Param{UserID},
            \$Param{ConfigItemID},
        ],
    );

    # trigger VersionCreate event
    $Self->EventHandler(
        Event => 'VersionCreate',
        Data  => {
            ConfigItemID => $Param{ConfigItemID},
            Comment      => $VersionID,
        },
        UserID => $Param{UserID},
    );

    # compare current and old values
    if ( $Events->{ValueUpdate} ) {
        $Self->_EventHandlerForChangedXMLValues(
            ConfigItemID => $Param{ConfigItemID},
            UpdateValues => $Events->{ValueUpdate},
            UserID       => $Param{UserID},
        );
    }

    # trigger definition update event
    if ( $Events->{DefinitionUpdate} ) {
        $Self->EventHandler(
            Event => 'DefinitionUpdate',
            Data  => {
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Events->{DefinitionUpdate},
            },
            UserID => $Param{UserID},
        );
    }

    # check old and new name
    if ( $Events->{NameUpdate} ) {
        $Self->EventHandler(
            Event => 'NameUpdate',
            Data  => {
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Events->{NameUpdate},
            },
            UserID => $Param{UserID},
        );
    }

    # trigger incident state update event
    if ( $Events->{IncidentStateUpdate} ) {
        $Self->EventHandler(
            Event => 'IncidentStateUpdate',
            Data  => {
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Events->{IncidentStateUpdate},
            },
            UserID => $Param{UserID},
        );
    }

    # trigger deployment state update event
    if ( $Events->{DeploymentStateUpdate} ) {
        $Self->EventHandler(
            Event => 'DeploymentStateUpdate',
            Data  => {
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Events->{DeploymentStateUpdate},
            },
            UserID => $Param{UserID},
        );
    }

    # recalculate the current incident state of all linked config items
    $Self->CurInciStateRecalc(
        ConfigItemID => $Param{ConfigItemID},
    );

    return $VersionID;
}

=item VersionDelete()

delete an existing version or versions

    my $True = $ConfigItemObject->VersionDelete(
        VersionID => 123,
        UserID    => 1,
    );

    or

    my $True = $ConfigItemObject->VersionDelete(
        ConfigItemID => 321,
        UserID       => 1,
    );

=cut

sub VersionDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{UserID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need UserID!',
        );
        return;
    }
    if ( !$Param{VersionID} && !$Param{ConfigItemID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need VersionID or ConfigItemID!',
        );
        return;
    }

    my $VersionList = [];
    if ( $Param{VersionID} ) {

        push @{$VersionList}, $Param{VersionID};
    }
    else {

        # get version list
        $VersionList = $Self->VersionList(
            ConfigItemID => $Param{ConfigItemID},
        );
    }

    return 1 if !scalar @{$VersionList};

    my $Success;
    for my $VersionID ( @{$VersionList} ) {

        # get config item id for version (needed for event handling)
        my $ConfigItemID = $Param{ConfigItemID};
        if ( $Param{VersionID} ) {
            $ConfigItemID = $Self->VersionConfigItemIDGet(
                VersionID => $Param{VersionID},
            );
        }

        # delete the xml version data
        $Self->_XMLVersionDelete(
            VersionID => $VersionID,
            UserID    => $Param{UserID},
        );

        # delete version
        $Success = $Self->{DBObject}->Do(
            SQL  => "DELETE FROM configitem_version WHERE id = ?",
            Bind => [ \$VersionID ],
        );

        # trigger VersionDelete event when deletion was successful
        if ($Success) {

            $Self->EventHandler(
                Event => 'VersionDelete',
                Data  => {
                    ConfigItemID => $ConfigItemID,
                    Comment      => $VersionID,
                },
                UserID => $Param{UserID},
            );

            # delete cache
            delete $Self->{Cache}->{VersionGet}->{$VersionID};
            delete $Self->{Cache}->{VersionConfigItemIDGet}->{$VersionID};
        }
    }

    return $Success;
}

=item VersionSearch()

return a config item list as an array reference

    my $ConfigItemIDs = $ConfigItemObject->VersionSearch(
        Name         => 'The Name',      # (optional)
        ClassIDs     => [ 9, 8, 7, 6 ],  # (optional)
        DeplStateIDs => [ 321, 123 ],    # (optional)
        InciStateIDs => [ 321, 123 ],    # (optional)

        PreviousVersionSearch => 1,  # (optional) default 0 (0|1)

        OrderBy => [ 'ConfigItemID', 'Number' ],                  # (optional)
        # default: [ 'ConfigItemID' ]
        # (ConfigItemID, Name, Number, ClassID, DeplStateID, InciStateID
        # CreateTime, CreateBy, ChangeTime, ChangeBy)

        # Additional information for OrderBy:
        # The OrderByDirection can be specified for each OrderBy attribute.
        # The pairing is made by the array indices.

        OrderByDirection => [ 'Up', 'Down' ],                    # (optional)
        # default: [ 'Up' ]
        # (Down | Up)

        Limit          => 122,  # (optional)
        UsingWildcards => 0,    # (optional) default 1
    );

=cut

sub VersionSearch {
    my ( $Self, %Param ) = @_;

    # set default values
    if ( !defined $Param{UsingWildcards} ) {
        $Param{UsingWildcards} = 1;
    }

    # verify that all passed array parameters contain an arrayref
    ARGUMENT:
    for my $Argument (
        qw(
        OrderBy
        OrderByDirection
        )
        )
    {
        if ( !defined $Param{$Argument} ) {
            $Param{$Argument} ||= [];

            next ARGUMENT;
        }

        if ( ref $Param{$Argument} ne 'ARRAY' ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "$Argument must be an array reference!",
            );
            return;
        }
    }

    # set default order and order direction
    if ( !@{ $Param{OrderBy} } ) {
        $Param{OrderBy} = ['ConfigItemID'];
    }
    if ( !@{ $Param{OrderByDirection} } ) {
        $Param{OrderByDirection} = ['Up'];
    }

    # define order table
    my %OrderByTable = (
        ConfigItemID => 'vr.configitem_id',
        Name         => 'vr.name',
        Number       => 'ci.configitem_number',
        ClassID      => 'ci.class_id',
        DeplStateID  => 'vr.depl_state_id',
        InciStateID  => 'vr.inci_state_id',
        CreateTime   => 'ci.create_time',
        CreateBy     => 'ci.create_by',

        # the change time of the CI is the same as the create time of the version!
        ChangeTime => 'vr.create_time',

        ChangeBy => 'ci.change_by',
    );

    # check if OrderBy contains only unique valid values
    my %OrderBySeen;
    for my $OrderBy ( @{ $Param{OrderBy} } ) {

        if ( !$OrderBy || !$OrderByTable{$OrderBy} || $OrderBySeen{$OrderBy} ) {

            # found an error
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "OrderBy contains invalid value '$OrderBy' "
                    . 'or the value is used more than once!',
            );
            return;
        }

        # remember the value to check if it appears more than once
        $OrderBySeen{$OrderBy} = 1;
    }

    # check if OrderByDirection array contains only 'Up' or 'Down'
    DIRECTION:
    for my $Direction ( @{ $Param{OrderByDirection} } ) {

        # only 'Up' or 'Down' allowed
        next DIRECTION if $Direction eq 'Up';
        next DIRECTION if $Direction eq 'Down';

        # found an error
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "OrderByDirection can only contain 'Up' or 'Down'!",
        );
        return;
    }

    # assemble the ORDER BY clause
    my @SQLOrderBy;
    my $Count = 0;
    my @OrderBySelectColumns;
    for my $OrderBy ( @{ $Param{OrderBy} } ) {

        # set the default order direction
        my $Direction = 'DESC';

        # add the given order direction
        if ( $Param{OrderByDirection}->[$Count] ) {
            if ( $Param{OrderByDirection}->[$Count] eq 'Up' ) {
                $Direction = 'ASC';
            }
            elsif ( $Param{OrderByDirection}->[$Count] eq 'Down' ) {
                $Direction = 'DESC';
            }
        }

        # add SQL
        push @SQLOrderBy,           "$OrderByTable{$OrderBy} $Direction";
        push @OrderBySelectColumns, $OrderByTable{$OrderBy};

    }
    continue {
        $Count++;
    }

    # get like escape string needed for some databases (e.g. oracle)
    my $LikeEscapeString = $Self->{DBObject}->GetDatabaseFunction('LikeEscapeString');

    # add name to sql where array
    my @SQLWhere;
    if ( defined $Param{Name} && $Param{Name} ne '' ) {

        # duplicate the name
        my $Name = $Param{Name};

        # quote
        $Name = $Self->{DBObject}->Quote($Name);

        if ( $Param{UsingWildcards} ) {

            # prepare like string
            $Self->_PrepareLikeString( \$Name );

            push @SQLWhere, "LOWER(vr.name) LIKE LOWER('$Name') $LikeEscapeString";
        }
        else {
            push @SQLWhere, "LOWER(vr.name) = LOWER('$Name')";
        }
    }

    # set array params
    my %ArrayParams = (
        ClassIDs     => 'ci.id = vr.configitem_id AND ci.class_id',
        DeplStateIDs => 'vr.depl_state_id',
        InciStateIDs => 'vr.inci_state_id',
    );

    ARRAYPARAM:
    for my $ArrayParam ( sort keys %ArrayParams ) {

        next ARRAYPARAM if !$Param{$ArrayParam};

        if ( ref $Param{$ArrayParam} ne 'ARRAY' ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "$ArrayParam must be an array reference!",
            );
            return;
        }

        next ARRAYPARAM if !@{ $Param{$ArrayParam} };

        # quote as integer
        for my $OneParam ( @{ $Param{$ArrayParam} } ) {
            $OneParam = $Self->{DBObject}->Quote( $OneParam, 'Integer' );
        }

        # create string
        my $InString = join q{, }, @{ $Param{$ArrayParam} };

        push @SQLWhere, "$ArrayParams{ $ArrayParam } IN ($InString)";
    }

    # add previous version param
    if ( !$Param{PreviousVersionSearch} ) {
        push @SQLWhere, 'ci.last_version_id = vr.id';
    }

    # create where string
    my $WhereString = @SQLWhere ? ' WHERE ' . join q{ AND }, @SQLWhere : '';

    # set limit, quote as integer
    if ( $Param{Limit} ) {
        $Param{Limit} = $Self->{DBObject}->Quote( $Param{Limit}, 'Integer' );
    }

    # add the order by columns also to the selected columns
    my $OrderBySelectString = '';
    if (@OrderBySelectColumns) {
        $OrderBySelectString = join ', ', @OrderBySelectColumns;
        $OrderBySelectString = ', ' . $OrderBySelectString;
    }

    # build SQL
    my $SQL = "SELECT DISTINCT vr.configitem_id $OrderBySelectString "
        . 'FROM configitem ci, configitem_version vr '
        . $WhereString;

    # add the ORDER BY clause
    if (@SQLOrderBy) {
        $SQL .= ' ORDER BY ';
        $SQL .= join ', ', @SQLOrderBy;
        $SQL .= ' ';
    }

    # ask the database
    $Self->{DBObject}->Prepare(
        SQL   => $SQL,
        Limit => $Param{Limit},
    );

    # fetch the result
    my @ConfigItemList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @ConfigItemList, $Row[0];
    }

    return \@ConfigItemList;
}

=begin Internal:

=item _GetEvents()

This method checks what values were changed and what events have to be triggered.
It returns a hash reference with all event names as keys that should be triggered.

    my $Events = $CIObject->_GetEvents(
        Param => {
            DeplStateID => 123,
        },
        ConfigItemInfo => {
            DeplStateID => 234,
        },
    );

    print keys %{$Events}; # prints "DeploymentStateUpdate"

=cut

sub _GetEvents {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(ConfigItemInfo Param)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    my $Events = {};

    # check old and new name
    my $OldName = $Param{ConfigItemInfo}->{Name} || '';
    my $NewName = $Param{Param}->{Name}          || '';

    if ( $OldName ne $NewName ) {
        $Events->{NameUpdate} = $NewName . '%%' . $OldName;
    }

    # if depl_state is updated
    my $LastDeplStateID = $Param{ConfigItemInfo}->{DeplStateID} || '';
    my $CurDeplStateID  = $Param{Param}->{DeplStateID}          || '';

    if ( $LastDeplStateID ne $CurDeplStateID ) {
        $Events->{DeploymentStateUpdate} = $CurDeplStateID . '%%' . $LastDeplStateID;
    }

    # if incistate is updated
    my $LastInciStateID = $Param{ConfigItemInfo}->{InciStateID} || '';
    my $CurInciStateID  = $Param{Param}->{InciStateID}          || '';

    if ( $LastInciStateID ne $CurInciStateID ) {
        $Events->{IncidentStateUpdate} = $CurInciStateID . '%%' . $LastInciStateID;
    }

    # check old and new definition_id
    my $OldDefinitionID = $Param{ConfigItemInfo}->{DefinitionID} || '';
    my $NewDefinitionID = $Param{Param}->{DefinitionID}          || '';

    if ( $OldDefinitionID ne $NewDefinitionID ) {
        $Events->{DefinitionUpdate} = $NewDefinitionID;
    }

    # check for changes in XML data
    if ( $Param{Param}->{XMLData} && ref $Param{Param}->{XMLData} eq 'ARRAY' ) {
        my %UpdateValues = $Self->_FindChangedXMLValues(
            ConfigItemID => $Param{Param}->{ConfigItemID},
            NewXMLData   => $Param{Param}->{XMLData},
        );
        if ( keys %UpdateValues ) {
            $Events->{ValueUpdate} = \%UpdateValues;
        }
    }

    return $Events;
}

=item _EventHandlerForChangedXMLValues()

This method calls the event handler for each changed value of the config item.
The changed values are passed in C<UpdateValues> as an hashref with tagkeys as keys.
Please note that this only handles values inside the XML structure, not general
attributes like C<CurInciState>.

    my $Success = $ConfigItemObject->_EventHandlerForChangedXMLValues(
        ConfigItemID => 123,
        UpdateValues =>
            {
               "[1]{'Version'}[1]{'Vendor'}[1]" => 'OldVendor%%NewVendor',
               "[1]{'Version'}[1]{'Type'}[1]"   => '127%%128',
            }
        UserID       => 1,
    );

=cut

sub _EventHandlerForChangedXMLValues {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Needed (qw(UpdateValues ConfigItemID UserID)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # trigger ValueUpdate event for each changed value
    for my $Key ( sort keys %{ $Param{UpdateValues} } ) {
        $Self->EventHandler(
            Event => 'ValueUpdate',
            Data  => {
                ConfigItemID => $Param{ConfigItemID},
                Comment      => $Key . '%%' . $Param{UpdateValues}->{$Key},
            },
            UserID => $Param{UserID},
        );
    }

    return 1;
}

=item _FindChangedXMLValues()

compares the new xml data C<NewXMLData> with the xml data of the latest version
of the config item C<ConfigItemID>. Note that the new XML data does not contain tag keys.
All values of the two data sets are compared.
When a changed value is encountered, the tag key and the old and the new value are stored in a hash.
The hash with the updata values is returned.

    my %UpdateValues = $ConfigItemObject->_FindChangedXMLValues(
        ConfigItemID => 123,
        NewXMLData   =>
            [
                undef,
                {
                    'Version' =>
                        [
                            undef,
                            {
                                'Owner' =>
                                    [
                                       undef,
                                       {
                                           'Content' => ''
                                       },
                                    ],
                            },
                        ],
                },
            ],
    );

The returned hash looks like:

    %UpdateValues = (
       "[1]{'Version'}[1]{'Vendor'}[1]" => 'OldVendor%%NewVendor',
       "[1]{'Version'}[1]{'Type'}[1]"   => '127%%128',
    );

The key is a tag key. The values contains the old and the new XML value.

=cut

sub _FindChangedXMLValues {
    my ( $Self, %Param ) = @_;

    # check for needed stuff
    for my $Needed (qw(ConfigItemID NewXMLData)) {
        if ( !$Param{$Needed} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Needed!",
            );
            return;
        }
    }

    # get a list with all versionnumbers that exist for the
    # given config item
    my $VersionList = $Self->VersionList(
        ConfigItemID => $Param{ConfigItemID},
    );

    # skip the check if this is the first version of the item
    return if !@{$VersionList};

    # get old version
    my $OldVersion = $Self->VersionGet(
        VersionID => $VersionList->[-1],
    );

    # the short names for new and old xml data are used in the 'eval' below
    my $NewXMLData = $Param{NewXMLData};
    my $OldXMLData = $OldVersion->{XMLData};

    # get all tagkeys in new and old XML data
    # use a side effect of XMLHash2D(), which adds the tag keys to the passed in data structure
    $Self->{XMLObject}->XMLHash2D( XMLHash => $NewXMLData );
    my @TagKeys = $Self->_GrabTagKeys( Data => [ $OldXMLData, $NewXMLData ] );

    # get an unique list of all tag keys
    my %UniqueTagKeys = map { $_ => 1 } @TagKeys;

    # do the check
    my %UpdateValues;
    for my $TagKey ( sort keys %UniqueTagKeys ) {
        my $NewContent = eval '$NewXMLData->' . $TagKey . '->{Content}' || '';    ## no critic
        my $OldContent = eval '$OldXMLData->' . $TagKey . '->{Content}' || '';    ## no critic

        if ( $NewContent ne $OldContent ) {

            # a change was found
            $UpdateValues{$TagKey} = join '%%', $OldContent, $NewContent;
        }
    }

    return %UpdateValues;
}

=item _GrabTagKeys()

recursively scans a perl datastructure for the hash key 'TagKey' and returns a
list of all the values for that key.

    my @TagKeys = $ConfigItemObject->_GrabTagKeys(
        Data => $XMLHashReferenz,
    );

=cut

sub _GrabTagKeys {
    my ( $Self, %Param ) = @_;

    return () if !$Param{Data};

    my @TagKeys;
    if ( ref $Param{Data} eq 'ARRAY' ) {

        ELEM:
        for my $Elem ( @{ $Param{Data} } ) {

            next ELEM if !$Elem;
            next ELEM if !ref $Elem;

            push @TagKeys, $Self->_GrabTagKeys( Data => $Elem );
        }
    }
    elsif ( ref $Param{Data} eq 'HASH' ) {

        for my $Key ( sort keys %{ $Param{Data} } ) {

            if ( $Key eq 'TagKey' ) {
                push @TagKeys, $Param{Data}->{$Key};
            }
            elsif ( ref $Param{Data}->{$Key} ) {
                push @TagKeys, $Self->_GrabTagKeys( Data => $Param{Data}->{$Key} );
            }
        }
    }

    return @TagKeys;
}

1;

=end Internal:

=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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

# --
# Kernel/System/ITSMConfigItem/XML.pm - sub module of ITSMConfigItem.pm with xml functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::XML;

use strict;
use warnings;

=head1 NAME

Kernel::System::ITSMConfigItem::XML - sub module of Kernel::System::ITSMConfigItem

=head1 SYNOPSIS

All xml functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item XMLValueLookup()

lookup a xml value

    my $Value = $ConfigItemObject->XMLValueLookup(
        Item  => $ItemRef,
        Value => 5,
    );

=cut

sub XMLValueLookup {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} || ( $Param{Item} && ref $Param{Item} ne 'HASH' ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return '' if !$BackendObject;

    # lookup item value
    my $Value = $BackendObject->ValueLookup(%Param);

    return $Value;
}

=item XMLStatsAttributeCreate()

create a attribute array for the stats framework

    my $Value = $ConfigItemObject->XMLStatsAttributeCreate(
        Item => $ItemRef,
    );

=cut

sub XMLStatsAttributeCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return if !$BackendObject;

    # create stats attribute array
    my $Attribute = $BackendObject->StatsAttributeCreate(%Param);

    return $Attribute;
}

=item XMLExportSearchValuePrepare()

prepare xml search data for export

    my $ArrayRef = $ConfigItemObject->XMLExportSearchValuePrepare(
        Item  => $ItemRef,
        Value => 5,
    );

=cut

sub XMLExportSearchValuePrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} || ( $Param{Item} && ref $Param{Item} ne 'HASH' ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return if !$BackendObject;

    # prepare value
    my $Array = $BackendObject->ExportSearchValuePrepare(%Param);

    return $Array;
}

=item XMLExportValuePrepare()

prepare xml data for export

    my $Value = $ConfigItemObject->XMLExportValuePrepare(
        Item  => $ItemRef,
        Value => 5,
    );

=cut

sub XMLExportValuePrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} || ( $Param{Item} && ref $Param{Item} ne 'HASH' ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return if !$BackendObject;

    # prepare value
    my $Value = $BackendObject->ExportValuePrepare(%Param);

    return $Value;
}

=item XMLImportSearchValuePrepare()

prepare xml search data for import

    my $ArrayRef = $ConfigItemObject->XMLImportSearchValuePrepare(
        Item  => $ItemRef,
        Value => 5,
    );

=cut

sub XMLImportSearchValuePrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} || ( $Param{Item} && ref $Param{Item} ne 'HASH' ) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return if !$BackendObject;

    # prepare value
    my $Array = $BackendObject->ImportSearchValuePrepare(%Param);

    return $Array;
}

=item XMLImportValuePrepare()

prepare xml data for import

    my $Value = $ConfigItemObject->XMLImportValuePrepare(
        Item  => $ItemRef,
        Value => 5,
    );

=cut

sub XMLImportValuePrepare {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} || ref $Param{Item} ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    # load backend
    my $BackendObject = $Self->_LoadXMLTypeBackend(
        Type => $Param{Item}->{Input}->{Type},
    );

    return if !$BackendObject;

    # prepare value
    my $Value = $BackendObject->ImportValuePrepare(%Param);

    return $Value;
}

=item _XMLVersionSearch()

Search xml data of a version and return a hash reference.
The C<What> parameter is a bit like the parameter used in L<SQL::Abstract>.
The returned hash reference has C<VersionID>s as keys and C<1> as value.

    my $VersionIDs = $ConfigItemObject->_XMLVersionSearch(
        ClassIDs => [1, 2, 3],  # (optional)

        What => [
            # each array element is a and condition
            {
                # or condition in hash
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => '%contentA%',
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => '%contentA%',
            },
            {
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => '%contentB%',
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => '%contentB%',
            },
            {
                # use array reference if different content with same key was searched
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => [
                    '%contentC%',
                    '%contentD%',
                    '%contentE%',
                ],
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => [
                    '%contentC%',
                    '%contentD%',
                    '%contentE%',
                ],
            },
            {
                # use hash reference for specifying comparison ops, apart from the default 'LIKE'
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '<'        => 'alphabetically_lower_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '<='       => 'alphabetically_less_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '='        => 'exact_match' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '>='       => 'alphabetically_larger_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '>'        => 'alphabetically_larger' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '-between' => [ 'lower_bound', 'upper_bound' ] },
            },
        ],

        PreviousVersionSearch => 1,  # (optional) default 0 (0|1)
    );

=cut

sub _XMLVersionSearch {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{What} || ref $Param{What} ne 'ARRAY' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Need What as array reference!",
        );
        return;
    }

    if ( !$Param{ClassIDs} || ref $Param{ClassIDs} ne 'ARRAY' || !@{ $Param{ClassIDs} } ) {

        # get class list
        my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::Class',
        );

        @{ $Param{ClassIDs} } = keys %{$ClassList};
    }

    # search in active versions
    my %VersionIDs;
    for my $ClassID ( @{ $Param{ClassIDs} } ) {

        # start xml search
        my @Keys = $Self->_XMLHashSearch(
            Type => "ITSM::ConfigItem::$ClassID",
            What => $Param{What},
        );

        # add all ids to version id hash
        for my $VersionID (@Keys) {
            $VersionIDs{$VersionID} = 1;
        }
    }

    return \%VersionIDs if !$Param{PreviousVersionSearch};

    # search also in old versions (archiv)
    for my $ClassID ( @{ $Param{ClassIDs} } ) {

        # start xml search
        my @Keys = $Self->_XMLHashSearch(
            Type => "ITSM::ConfigItem::Archiv::$ClassID",
            What => $Param{What},
        );

        # add all ids to version id hash
        for my $VersionID (@Keys) {
            $VersionIDs{$VersionID} = 1;
        }
    }

    return \%VersionIDs;
}

=item _XMLVersionGet()

get the xml data of a version

    my $ArrayRef = $ConfigItemObject->_XMLVersionGet(
        ClassID   => 1,
        VersionID => 123,
    );

=cut

sub _XMLVersionGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID VersionID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # get version
    my @XML = $Self->{XMLObject}->XMLHashGet(
        Type => "ITSM::ConfigItem::$Param{ClassID}",
        Key  => $Param{VersionID},
    );

    return \@XML if @XML;

    # get version from archiv
    @XML = $Self->{XMLObject}->XMLHashGet(
        Type => "ITSM::ConfigItem::Archiv::$Param{ClassID}",
        Key  => $Param{VersionID},
    );

    return \@XML;
}

=item _XMLVersionAdd()

add the xml data of a new version and move old xml versions in archiv class

    my $XMLID = $ConfigItemObject->_XMLVersionAdd(
        ClassID      => 1,
        ConfigItemID => 222,
        VersionID    => 123,
        XMLData      => $ArrayRef,
    );

=cut

sub _XMLVersionAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassID ConfigItemID VersionID XMLData)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # add xml version
    my $XMLID = $Self->{XMLObject}->XMLHashAdd(
        Type    => "ITSM::ConfigItem::$Param{ClassID}",
        Key     => $Param{VersionID},
        XMLHash => $Param{XMLData},
    );

    # get last versions
    my $OldVersionIDs = $Self->VersionList(
        ConfigItemID => $Param{ConfigItemID},
    );

    # Find Version to move
    my $MoveVersion;
    OLDVERSIONID:
    for my $OldVersionID ( @{$OldVersionIDs} ) {
        last OLDVERSIONID if $OldVersionID eq $Param{VersionID};

        $MoveVersion = $OldVersionID;
    }

    return $XMLID if !$MoveVersion;

    # move old version in archiv
    $Self->{XMLObject}->XMLHashMove(
        OldType => "ITSM::ConfigItem::$Param{ClassID}",
        OldKey  => $MoveVersion,
        NewType => "ITSM::ConfigItem::Archiv::$Param{ClassID}",
        NewKey  => $MoveVersion,
    );

    return $XMLID;
}

=item _XMLVersionDelete()

delete the xml data of a version

    my $True = $ConfigItemObject->_XMLVersionDelete(
        VersionID => 123,
        UserID    => 1,
    );

=cut

sub _XMLVersionDelete {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(VersionID UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!"
            );
            return;
        }
    }

    # get version data
    my $Version = $Self->VersionGet(
        VersionID => $Param{VersionID},
    );

    return if !$Version;

    # delete xml data from a version
    $Self->{XMLObject}->XMLHashDelete(
        Type => "ITSM::ConfigItem::$Version->{ClassID}",
        Key  => $Param{VersionID},
    );

    # delete xml data from archiv
    $Self->{XMLObject}->XMLHashDelete(
        Type => "ITSM::ConfigItem::Archiv::$Version->{ClassID}",
        Key  => $Param{VersionID},
    );

    return 1;
}

=item _LoadXMLTypeBackend()

load a xml item module

    $BackendObject = $ConfigItemObject->_LoadXMLTypeBackend(
        Type => 'GeneralCatalog',
    );

=cut

sub _LoadXMLTypeBackend {
    my ( $Self, %Param ) = @_;

    if ( !$Param{Type} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Type!',
        );
        return;
    }

    # check if object is already cached
    return $Self->{Cache}->{LoadXMLTypeBackend}->{ $Param{Type} }
        if $Self->{Cache}->{LoadXMLTypeBackend}->{ $Param{Type} };

    my $GenericModule = "Kernel::System::ITSMConfigItem::XML::Type::$Param{Type}";

    # load the backend module
    if ( !$Self->{MainObject}->Require($GenericModule) ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't load backend module $Param{Type}!"
        );
        return;
    }

    # create new instance
    my $BackendObject = $GenericModule->new(
        %{$Self},
        %Param,
    );

    if ( !$BackendObject ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't create a new instance of backend module $Param{Type}!",
        );
        return;
    }

    # cache the object
    $Self->{Cache}->{LoadXMLTypeBackend}->{ $Param{Type} } = $BackendObject;

    return $BackendObject;
}

=item _XMLHashSearch()

Search a xml hash from database.
This method is based on Kernel::System::XMLHashSearch, but has support for some extra features.
A specific operator can be specified in a hash.
The syntax is based on L<SQL::Abstract>.

    my @Keys = $ConfigItemObject->_XMLHashSearch(
        Type => 'SomeType',
        What => [
            # each array element is a and condition
            {
                # or condition in hash
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => '%contentA%',
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => '%contentA%',
            },
            {
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => '%contentB%',
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => '%contentB%',
            },
            {
                # use array reference if different content with same key was searched
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => ['%contentC%', '%contentD%', '%contentE%'],
                "[%]{'Version'}[%]{'ConfigItemAttrC'}[%]{'Content'}" => ['%contentC%', '%contentD%', '%contentE%'],
            },
            {
                # use hash reference for specifying comparison ops, apart from the default 'LIKE'
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '<'         => 'alphabetically_lower_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '<='        => 'alphabetically_less_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '='         => 'exact_match' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '!='        => 'exact_match' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '>='        => 'alphabetically_larger_or_equal' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '>'         => 'alphabetically_larger' },
                "[%]{'Version'}[%]{'ConfigItemAttrB'}[%]{'Content'}" => { '-between'  => [ 'lower_bound', 'upper_bound' ] },
            },
        ],
    );

=cut

sub _XMLHashSearch {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Type} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Type!',
        );
        return;
    }

    # get like escape string needed for some databases (e.g. oracle)
    my $LikeEscapeString = $Self->{DBObject}->GetDatabaseFunction('LikeEscapeString');

    return if !$Self->{DBObject}->Prepare(
        SQL  => 'SELECT DISTINCT(xml_key) FROM xml_storage WHERE xml_type = ?',
        Bind => [ \$Param{Type} ],
    );

    # the keys of this hash will be returned
    my %Hash;

    # initially all keys with the correct type are possible
    while ( my @Data = $Self->{DBObject}->FetchrowArray() ) {
        $Hash{ $Data[0] } = 1;
    }

    if ( $Param{What} && ref $Param{What} eq 'ARRAY' ) {

        my %OpIsSupported = map { $_ => 1 } ( '<', '<=', '=', '!=', '>=', '>', '-between' );

        # the array elements are 'and' combined
        for my $And ( @{ $Param{What} } ) {

            # the key/value pairs are 'or' combined
            my @OrConditions;
            for my $Key ( sort keys %{$And} ) {
                my $Value = $And->{$Key};

                $Self->_PrepareLikeString( \$Key );

                if ( $Value && ref $Value eq 'ARRAY' ) {

                    # when an array of possible values is given,
                    # we use 'LIKE'-conditions and combine them with 'OR'
                    for my $Element ( @{$Value} ) {

                        $Self->_PrepareLikeString( \$Element );

                        push @OrConditions,
                            " (xml_content_key LIKE '$Key' $LikeEscapeString "
                            . "AND xml_content_value LIKE '$Element' $LikeEscapeString)";
                    }
                }
                elsif ( $Value && ref $Value eq 'HASH' ) {

                    # a hashref indicates a specific comparison op
                    # currently only a single op, with a single value, is supported

                    # Under Oracle the attribute 'xml_content_value' is a CLOB,
                    # a Character Locator Object. While selection with LIKE is possible,
                    # the alphabetical comparison ops are not supported.
                    # See http://download.oracle.com/docs/cd/B12037_01/appdev.101/b10796/\
                    # adlob_sq.htm#1006215
                    # As a workaround we cast the CLOB to a VARCHAR2 with TO_CHAR().
                    my $XMLContentValueColumn = 'xml_content_value';
                    if ( $Self->{DBObject}->GetDatabaseFunction('Type') eq 'oracle' ) {
                        $XMLContentValueColumn = 'TO_CHAR(xml_content_value)';
                    }

                    my ($Op) = keys %{$Value};
                    my $Element = $Value->{$Op};
                    if ( $Op && $Op eq '-between' && ref $Element eq 'ARRAY' ) {
                        my $LowerBound = $Self->{DBObject}->Quote( $Element->[0] );
                        my $UpperBound = $Self->{DBObject}->Quote( $Element->[1] );
                        push @OrConditions,
                            " ( xml_content_key LIKE '$Key' $LikeEscapeString "
                            . "AND $XMLContentValueColumn >= '$LowerBound' "
                            . "AND $XMLContentValueColumn <= '$UpperBound' )";
                    }
                    elsif ( $Op && $OpIsSupported{$Op} && !ref $Element ) {
                        $Element = $Self->{DBObject}->Quote($Element);
                        push @OrConditions,
                            " ( xml_content_key LIKE '$Key' $LikeEscapeString "
                            . "AND $XMLContentValueColumn $Op '$Element' )";
                    }
                    else {
                        $Self->{LogObject}->Log(
                            Priority => 'error',
                            Message  => 'Got unexpected data in search!',
                        );
                        push @OrConditions, '( 1 = 1 )';
                    }
                }
                else {

                    # when a single  possible value is given,
                    # we use a 'LIKE'-condition
                    $Self->_PrepareLikeString( \$Value );

                    push @OrConditions,
                        " (xml_content_key LIKE '$Key' $LikeEscapeString "
                        . "AND xml_content_value LIKE '$Value' $LikeEscapeString)";
                }
            }

            # assemble the SQL
            my $SQL = 'SELECT DISTINCT(xml_key) FROM xml_storage WHERE xml_type = ? ';
            if (@OrConditions) {
                $SQL .= 'AND ( ' . join( ' OR ', @OrConditions ) . ' )';
            }

            # execute
            $Self->{DBObject}->Prepare(
                SQL  => $SQL,
                Bind => [ \$Param{Type} ],
            );

            # intersection between the current key set, and the keys from the last 'SELECT'
            # only the keys which are in all results survive
            my %HashNew;
            while ( my @Data = $Self->{DBObject}->FetchrowArray() ) {
                if ( $Hash{ $Data[0] } ) {
                    $HashNew{ $Data[0] } = 1;
                }
            }
            %Hash = %HashNew;
        }
    }

    my @Keys = keys %Hash;

    return @Keys;
}

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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vRXZlbnQvRG9IaXN0b3J5LnBtIC0gYSBldmVudCBtb2R1bGUgZm9yIGNvbmZpZyBpdGVtcwojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpFdmVudDo6RG9IaXN0b3J5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OkV2ZW50OjpEb0hpc3RvcnkgLSBFdmVudCBoYW5kbGVyIHRoYXQgZG9lcyB0aGUgaGlzdG9yeQoKPWhlYWQxIFNZTk9QU0lTCgpBbGwgZXZlbnQgaGFuZGxlciBmdW5jdGlvbnMgZm9yIGhpc3RvcnkuCgo9aGVhZDEgUFVCTElDIElOVEVSRkFDRQoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICB1c2UgS2VybmVsOjpDb25maWc7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkVuY29kZTsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TG9nOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpEQjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TWFpbjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6VGltZTsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OkV2ZW50OjpEb0hpc3Rvcnk7CgogICAgbXkgJENvbmZpZ09iamVjdCA9IEtlcm5lbDo6Q29uZmlnLT5uZXcoKTsKICAgIG15ICRFbmNvZGVPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICApOwogICAgbXkgJExvZ09iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpMb2ctPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICk7CiAgICBteSAkVGltZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpUaW1lLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICApOwogICAgbXkgJE1haW5PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6TWFpbi0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICA9PiAkTG9nT2JqZWN0LAogICAgKTsKICAgIG15ICREQk9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpEQi0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICA9PiAkTG9nT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICBteSAkRG9IaXN0b3J5T2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpFdmVudDo6RG9IaXN0b3J5LT5uZXcoCiAgICAgICAgQ29uZmlnSXRlbU9iamVjdCA9PiAkQ29uZmlnSXRlbU9iamVjdCwKICAgICAgICBDb25maWdPYmplY3QgICAgID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgREJPYmplY3QgICAgICAgICA9PiAkREJPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ICAgICA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICAgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgICAgID0+ICRNYWluT2JqZWN0LAogICAgICAgIFRpbWVPYmplY3QgICAgICAgPT4gJFRpbWVPYmplY3QsCiAgICApOwoKPWN1dAoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGdldCBuZWVkZWQgb2JqZWN0cwogICAgZm9yIG15ICROZWVkZWQgKHF3KENvbmZpZ09iamVjdCBMb2dPYmplY3QgREJPYmplY3QgTWFpbk9iamVjdCBFbmNvZGVPYmplY3QgVGltZU9iamVjdCkpIHsKICAgICAgICAkU2VsZi0+eyROZWVkZWR9ID0gJFBhcmFteyROZWVkZWR9IHx8IGRpZSAiR290IG5vICROZWVkZWQhIjsKICAgIH0KCiAgICAjIGNyZWF0ZSBuZWVkZWQgb2JqZWN0cwogICAgJFNlbGYtPntDb25maWdJdGVtT2JqZWN0fSA9IEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbS0+bmV3KCAleyRTZWxmfSApOwoKICAgIHJldHVybiAkU2VsZjsKfQoKPWl0ZW0gUnVuKCkKClRoaXMgbWV0aG9kIGhhbmRsZXMgdGhlIGV2ZW50LgoKICAgICREb0hpc3RvcnlPYmplY3QtPlJ1bigKICAgICAgICBFdmVudCA9PiAnQ29uZmlnSXRlbUNyZWF0ZScsCiAgICAgICAgRGF0YSAgPT4gewogICAgICAgICAgICBDb21tZW50ICAgICAgPT4gJ25ldyB2YWx1ZTogMScsCiAgICAgICAgICAgIENvbmZpZ0l0ZW1JRCA9PiAxMjMsCiAgICAgICAgfSwKICAgICAgICBVc2VySUQgPT4gMSwKICAgICk7Cgo9Y3V0CgpzdWIgUnVuIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBhcyBEZWZpbml0aW9uQ3JlYXRlIGRvZXMgbm90IGJlbG9uZyB0byBhbiBpdGVtLCB3ZSBkb24ndCBjcmVhdGUKICAgICMgYSBoaXN0b3J5IGVudHJ5CiAgICBpZiAoICRQYXJhbXtFdmVudH0gJiYgJFBhcmFte0V2ZW50fSBlcSAnRGVmaW5pdGlvbkNyZWF0ZScgKSB7CiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJE5lZWRlZCAocXcoRGF0YSBFdmVudCBVc2VySUQpKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyROZWVkZWR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkTmVlZGVkISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgIyBkdWUgdG8gY29uc2lzdGVuY3kgd2l0aCB0aWNrZXQgaGlzdG9yeSwgd2UgbmVlZCBIaXN0b3J5VHlwZQogICAgJFBhcmFte0hpc3RvcnlUeXBlfSA9ICRQYXJhbXtFdmVudH07CgogICAgIyBkaXNwYXRjaCB0YWJsZSBmb3IgYWxsIGV2ZW50cwogICAgbXkgJURpc3BhdGNoZXIgPSAoCiAgICAgICAgQ29uZmlnSXRlbUNyZWF0ZSAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgQ29uZmlnSXRlbURlbGV0ZSAgICAgID0+IFwmX0NvbmZpZ0l0ZW1EZWxldGUsCiAgICAgICAgTGlua0FkZCAgICAgICAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgTGlua0RlbGV0ZSAgICAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgTmFtZVVwZGF0ZSAgICAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgSW5jaWRlbnRTdGF0ZVVwZGF0ZSAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgRGVwbG95bWVudFN0YXRlVXBkYXRlID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgRGVmaW5pdGlvblVwZGF0ZSAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgVmVyc2lvbkNyZWF0ZSAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgVmFsdWVVcGRhdGUgICAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgRGVmaW5pdGlvbkNyZWF0ZSAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgVmVyc2lvbkRlbGV0ZSAgICAgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgQXR0YWNobWVudEFkZFBvc3QgICAgID0+IFwmX0hpc3RvcnlBZGQsCiAgICAgICAgQXR0YWNobWVudERlbGV0ZVBvc3QgID0+IFwmX0hpc3RvcnlBZGQsCiAgICApOwoKICAgICMgZXJyb3IgaGFuZGxpbmcKICAgIGlmICggIWV4aXN0cyAkRGlzcGF0Y2hlcnsgJFBhcmFte0V2ZW50fSB9ICkgewogICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICBNZXNzYWdlICA9PiAnbm9uIGV4aXN0YW50IGhpc3RvcnkgdHlwZTogJyAuICRQYXJhbXtFdmVudH0sCiAgICAgICAgKTsKCiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgICMgY2FsbCBjYWxsYmFjawogICAgbXkgJFN1YiA9ICREaXNwYXRjaGVyeyAkUGFyYW17RXZlbnR9IH07CiAgICAkU2VsZi0+JFN1YigKICAgICAgICAlUGFyYW0sCiAgICAgICAgJXsgJFBhcmFte0RhdGF9IH0sCiAgICApOwoKICAgIHJldHVybiAxOwp9Cgo9aXRlbSBfQ29uZmlnSXRlbURlbGV0ZSgpCgpoaXN0b3J5J3MgZXZlbnQgaGFuZGxlciBmb3IgQ29uZmlnSXRlbURlbGV0ZQoKPWN1dAoKc3ViIF9Db25maWdJdGVtRGVsZXRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBkZWxldGUgaGlzdG9yeQogICAgJFNlbGYtPntDb25maWdJdGVtT2JqZWN0fS0+SGlzdG9yeURlbGV0ZSgKICAgICAgICBDb25maWdJdGVtSUQgPT4gJFBhcmFte0NvbmZpZ0l0ZW1JRH0sCiAgICApOwoKICAgIHJldHVybiAxOwp9Cgo9aXRlbSBfSGlzdG9yeUFkZCgpCgpoaXN0b3J5J3MgZGVmYXVsdCBldmVudCBoYW5kbGVyLgoKPWN1dAoKc3ViIF9IaXN0b3J5QWRkIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBhZGQgaGlzdG9yeSBlbnRyeQogICAgJFNlbGYtPntDb25maWdJdGVtT2JqZWN0fS0+SGlzdG9yeUFkZCgKICAgICAgICAlUGFyYW0sCiAgICApOwoKICAgIHJldHVybiAxOwp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKGh0dHA6Ly9vdHJzLm9yZy8pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vTnVtYmVyL0F1dG9JbmNyZW1lbnQucG0gLSBjb25maWcgaXRlbSBudW1iZXIgYmFja2VuZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6TnVtYmVyOjpBdXRvSW5jcmVtZW50OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKPWhlYWQxIE5BTUUKCktlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6TnVtYmVyOjpBdXRvSW5jcmVtZW50IC0gY29uZmlnIGl0ZW0gbnVtYmVyIGJhY2tlbmQgbW9kdWxlCgo9aGVhZDEgU1lOT1BTSVMKCkFsbCBhdXRvIGluY3JlbWVudCBjb25maWcgaXRlbSBudW1iZXIgZnVuY3Rpb25zCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBfQ29uZmlnSXRlbU51bWJlckNyZWF0ZSgpCgpjcmVhdGUgYSBuZXcgY29uZmlnIGl0ZW0gbnVtYmVyCgogICAgbXkgJE51bWJlciA9ICRCYWNrZW5kT2JqZWN0LT5fQ29uZmlnSXRlbU51bWJlckNyZWF0ZSgKICAgICAgICBDbGFzc0lEID0+IDEyMywKICAgICk7Cgo9Y3V0CgpzdWIgX0NvbmZpZ0l0ZW1OdW1iZXJDcmVhdGUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGNoZWNrIG5lZWRlZCBzdHVmZgogICAgaWYgKCAhJFBhcmFte0NsYXNzSUR9ICkgewogICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICBNZXNzYWdlICA9PiAnTmVlZCBDbGFzc0lEIScsCiAgICAgICAgKTsKICAgICAgICByZXR1cm47CiAgICB9CgogICAgIyBnZXQgc3lzdGVtIGlkCiAgICBteSAkU3lzdGVtSUQgPSAkU2VsZi0+e0NvbmZpZ09iamVjdH0tPkdldCgnU3lzdGVtSUQnKTsKCiAgICAjIGdldCBjdXJyZW50IGNvdW50ZXIKICAgIG15ICRDdXJyZW50Q291bnRlciA9ICRTZWxmLT5DdXJyZW50Q291bnRlckdldCgKICAgICAgICBDbGFzc0lEID0+ICRQYXJhbXtDbGFzc0lEfSwKICAgICAgICBUeXBlICAgID0+ICdBdXRvSW5jcmVtZW50JywKICAgICkgfHwgMDsKCiAgICBDSVBIRVI6CiAgICBmb3IgbXkgJENpcGhlciAoIDEgLi4gMV8wMDBfMDAwXzAwMCApIHsKCiAgICAgICAgIyBjcmVhdGUgbmV3IG51bWJlcgogICAgICAgIG15ICROdW1iZXIgPSAkU3lzdGVtSUQgLiAkUGFyYW17Q2xhc3NJRH0gLiBzcHJpbnRmKCAiJTA2ZCIsICggJEN1cnJlbnRDb3VudGVyICsgJENpcGhlciApICk7CgogICAgICAgICMgZmluZCBleGlzdGluZyBudW1iZXIKICAgICAgICBteSAkRHVwbGljYXRlID0gJFNlbGYtPkNvbmZpZ0l0ZW1OdW1iZXJMb29rdXAoCiAgICAgICAgICAgIENvbmZpZ0l0ZW1OdW1iZXIgPT4gJE51bWJlciwKICAgICAgICApOwoKICAgICAgICBuZXh0IENJUEhFUiBpZiAkRHVwbGljYXRlOwoKICAgICAgICAjIHNldCBjb3VudGVyCiAgICAgICAgJFNlbGYtPkN1cnJlbnRDb3VudGVyU2V0KAogICAgICAgICAgICBDbGFzc0lEID0+ICRQYXJhbXtDbGFzc0lEfSwKICAgICAgICAgICAgVHlwZSAgICA9PiAnQXV0b0luY3JlbWVudCcsCiAgICAgICAgICAgIENvdW50ZXIgPT4gKCAkQ3VycmVudENvdW50ZXIgKyAkQ2lwaGVyICksCiAgICAgICAgKTsKCiAgICAgICAgcmV0dXJuICROdW1iZXI7CiAgICB9CgogICAgcmV0dXJuOwp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKGh0dHA6Ly9vdHJzLm9yZy8pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vUGVybWlzc2lvbi9DbGFzc0dyb3VwQ2hlY2sucG0gLSBjaGVjayBpZiBhIHVzZXIgYmVsb25ncyB0byBhIGdyb3VwCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlBlcm1pc3Npb246OkNsYXNzR3JvdXBDaGVjazsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSBLZXJuZWw6OlN5c3RlbTo6R3JvdXA7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOjpDbGFzc0dyb3VwQ2hlY2sgLSBjaGVjayBpZiBhIHVzZXIgYmVsb25ncyB0byBhIGdyb3VwCgo9aGVhZDEgU1lOT1BTSVMKCj1oZWFkMSBQVUJMSUMgSU5URVJGQUNFCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpHZW5lcmFsQ2F0YWxvZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW07CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOjpDbGFzc0dyb3VwQ2hlY2s7CgogICAgbXkgJENvbmZpZ09iamVjdCA9IEtlcm5lbDo6Q29uZmlnLT5uZXcoKTsKICAgIG15ICRFbmNvZGVPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICApOwogICAgbXkgJExvZ09iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpMb2ctPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICk7CiAgICBteSAkTWFpbk9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpNYWluLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICApOwogICAgbXkgJERCT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkRCLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgID0+ICRNYWluT2JqZWN0LAogICAgKTsKICAgIG15ICRDb25maWdJdGVtT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgREJPYmplY3QgICAgID0+ICREQk9iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJEdlbmVyYWxDYXRhbG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkdlbmVyYWxDYXRhbG9nLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgREJPYmplY3QgICAgID0+ICREQk9iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENoZWNrT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOjpDbGFzc0dyb3VwQ2hlY2stPm5ldygKICAgICAgICBDb25maWdPYmplY3QgICAgICAgICA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCAgICAgICAgID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgICAgICAgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgICAgICAgICA9PiAkREJPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgICAgICAgICAgPT4gJE1haW5PYmplY3QsCiAgICAgICAgQ29uZmlnSXRlbU9iamVjdCAgICAgPT4gJENvbmZpZ0l0ZW1PYmplY3QsCiAgICAgICAgR2VuZXJhbENhdGFsb2dPYmplY3QgPT4gJEdlbmVyYWxDYXRhbG9nT2JqZWN0LAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBnZXQgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0ICgKICAgICAgICBxdyhDb25maWdPYmplY3QgTG9nT2JqZWN0IERCT2JqZWN0IE1haW5PYmplY3QgRW5jb2RlT2JqZWN0IENvbmZpZ0l0ZW1PYmplY3QgR2VuZXJhbENhdGFsb2dPYmplY3QpCiAgICAgICAgKQogICAgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQoKICAgICRTZWxmLT57R3JvdXBPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06Okdyb3VwLT5uZXcoICV7JFNlbGZ9ICk7CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBSdW4oKQoKdGhpcyBtZXRob2QgZG9lcyB0aGUgY2hlY2sgaWYgdGhlIHVzZSBiZWxvbmdzIHRvIGEgZ2l2ZW4gZ3JvdXAKCiAgICBteSAkSGFzQWNjZXNzID0gJENoZWNrT2JqZWN0LT5SdW4oCiAgICAgICAgVXNlcklEICA9PiAxMjMsCiAgICAgICAgVHlwZSAgICA9PiAncm8nLAogICAgICAgIENsYXNzSUQgPT4gJ0lUU006OkNvbmZpZ0l0ZW06OkNsYXNzOjpDb21wdXRlcicsCiAgICApOwoKPWN1dAoKc3ViIFJ1biB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJE5lZWRlZCAocXcoVXNlcklEIFR5cGUgQ2xhc3NJRCkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JE5lZWRlZH0gKSB7CiAgICAgICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICROZWVkZWQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICAjIGdldCBDbGFzcyBkYXRhCiAgICBteSAkQ2xhc3NJdGVtID0gJFNlbGYtPntHZW5lcmFsQ2F0YWxvZ09iamVjdH0tPkl0ZW1HZXQoIEl0ZW1JRCA9PiAkUGFyYW17Q2xhc3NJRH0gKTsKCiAgICAjIGdldCB1c2VyIGdyb3VwcwogICAgbXkgQEdyb3VwSURzID0gJFNlbGYtPntHcm91cE9iamVjdH0tPkdyb3VwTWVtYmVyTGlzdCgKICAgICAgICBVc2VySUQgPT4gJFBhcmFte1VzZXJJRH0sCiAgICAgICAgVHlwZSAgID0+ICRQYXJhbXtUeXBlfSwKICAgICAgICBSZXN1bHQgPT4gJ0lEJywKICAgICAgICBDYWNoZWQgPT4gMSwKICAgICk7CgogICAgIyBsb29raW5nIGZvciBncm91cCBpZCwgcmV0dXJuIGFjY2VzcyBpZiB1c2VyIGlzIGluIGdyb3VwCiAgICBmb3IgbXkgJEdyb3VwSUQgKEBHcm91cElEcykgewogICAgICAgIHJldHVybiAxIGlmICRDbGFzc0l0ZW0tPntQZXJtaXNzaW9ufSAmJiAkR3JvdXBJRCBlcSAkQ2xhc3NJdGVtLT57UGVybWlzc2lvbn07CiAgICB9CgogICAgIyByZXR1cm4gbm8gYWNjZXNzCiAgICByZXR1cm47Cn0KCjE7Cgo9YmFjawoKPWhlYWQxIFRFUk1TIEFORCBDT05ESVRJT05TCgpUaGlzIFNvZnR3YXJlIGlzIHBhcnQgb2YgdGhlIE9UUlMgcHJvamVjdCAoTDxodHRwOi8vb3Rycy5vcmcvPikuCgpUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQp0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CmRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBMPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dD4uCgo9Y3V0Cg==
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vUGVybWlzc2lvbi9JdGVtQ2xhc3NHcm91cENoZWNrLnBtIC0gY2hlY2sgaWYgYSB1c2VyIGNhbiBhY2Nlc3MgYW4gaXRlbQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpQZXJtaXNzaW9uOjpJdGVtQ2xhc3NHcm91cENoZWNrOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIEtlcm5lbDo6U3lzdGVtOjpHcm91cDsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlBlcm1pc3Npb246Okl0ZW1DbGFzc0dyb3VwQ2hlY2sgLSBjaGVjayBpZiBhIHVzZXIgY2FuIGFjY2VzcyBhbiBpdGVtCgo9aGVhZDEgU1lOT1BTSVMKCkFsbCBjb25maWcgaXRlbSBmdW5jdGlvbnMuCgo9aGVhZDEgUFVCTElDIElOVEVSRkFDRQoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICB1c2UgS2VybmVsOjpDb25maWc7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkVuY29kZTsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TG9nOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpEQjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TWFpbjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6R2VuZXJhbENhdGFsb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6UGVybWlzc2lvbjo6SXRlbUNsYXNzR3JvdXBDaGVjazsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICBteSAkR2VuZXJhbENhdGFsb2dPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6R2VuZXJhbENhdGFsb2ctPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICBteSAkQ2hlY2tPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlBlcm1pc3Npb246Okl0ZW1DbGFzc0dyb3VwQ2hlY2stPm5ldygKICAgICAgICBDb25maWdPYmplY3QgICAgICAgICA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCAgICAgICAgID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgICAgICAgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgICAgICAgICA9PiAkREJPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgICAgICAgICAgPT4gJE1haW5PYmplY3QsCiAgICAgICAgQ29uZmlnSXRlbU9iamVjdCAgICAgPT4gJENvbmZpZ0l0ZW1PYmplY3QsCiAgICAgICAgR2VuZXJhbENhdGFsb2dPYmplY3QgPT4gJEdlbmVyYWxDYXRhbG9nT2JqZWN0LAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBnZXQgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0ICgKICAgICAgICBxdyhDb25maWdPYmplY3QgTG9nT2JqZWN0IERCT2JqZWN0IE1haW5PYmplY3QgRW5jb2RlT2JqZWN0IENvbmZpZ0l0ZW1PYmplY3QgR2VuZXJhbENhdGFsb2dPYmplY3QpCiAgICAgICAgKQogICAgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQoKICAgICRTZWxmLT57R3JvdXBPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06Okdyb3VwLT5uZXcoICV7JFNlbGZ9ICk7CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBSdW4oKQoKdGhpcyBtZXRob2QgZG9lcyB0aGUgY2hlY2sgaWYgdGhlIHVzZXIgY2FuIGFjY2VzcyBhbiBpdGVtCgogICAgbXkgJEhhc0FjY2VzcyA9ICRDaGVja09iamVjdC0+UnVuKAogICAgICAgIFVzZXJJRCA9PiAxMjMsCiAgICAgICAgVHlwZSAgID0+ICdybycsCiAgICAgICAgSXRlbUlEID0+IDM0NSwKICAgICk7Cgo9Y3V0CgpzdWIgUnVuIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGZvciBteSAkTmVlZGVkIChxdyhVc2VySUQgVHlwZSBJdGVtSUQpKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyROZWVkZWR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkTmVlZGVkISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgIyBnZXQgY29uZmlnIGl0ZW0gZGF0YQogICAgbXkgJENvbmZpZ0l0ZW0gPSAkU2VsZi0+e0NvbmZpZ0l0ZW1PYmplY3R9LT5Db25maWdJdGVtR2V0KAogICAgICAgIENvbmZpZ0l0ZW1JRCA9PiAkUGFyYW17SXRlbUlEfSwKICAgICk7CgogICAgIyBnZXQgQ2xhc3MgZGF0YQogICAgbXkgJENsYXNzSXRlbSA9ICRTZWxmLT57R2VuZXJhbENhdGFsb2dPYmplY3R9LT5JdGVtR2V0KAogICAgICAgIEl0ZW1JRCA9PiAkQ29uZmlnSXRlbS0+e0NsYXNzSUR9CiAgICApOwoKICAgICMgZ2V0IHVzZXIgZ3JvdXBzCiAgICBteSBAR3JvdXBJRHMgPSAkU2VsZi0+e0dyb3VwT2JqZWN0fS0+R3JvdXBNZW1iZXJMaXN0KAogICAgICAgIFVzZXJJRCA9PiAkUGFyYW17VXNlcklEfSwKICAgICAgICBUeXBlICAgPT4gJFBhcmFte1R5cGV9LAogICAgICAgIFJlc3VsdCA9PiAnSUQnLAogICAgICAgIENhY2hlZCA9PiAxLAogICAgKTsKCiAgICAjIGxvb2tpbmcgZm9yIGdyb3VwIGlkLCByZXR1cm4gYWNjZXNzIGlmIHVzZXIgaXMgaW4gZ3JvdXAKICAgIGZvciBteSAkR3JvdXBJRCAoQEdyb3VwSURzKSB7CiAgICAgICAgcmV0dXJuIDEgaWYgJENsYXNzSXRlbS0+e1Blcm1pc3Npb259ICYmICRHcm91cElEIGVxICRDbGFzc0l0ZW0tPntQZXJtaXNzaW9ufTsKICAgIH0KCiAgICAjIHJldHVybiBubyBhY2Nlc3MKICAgIHJldHVybjsKfQoKMTsKCj1iYWNrCgo9aGVhZDEgVEVSTVMgQU5EIENPTkRJVElPTlMKClRoaXMgU29mdHdhcmUgaXMgcGFydCBvZiB0aGUgT1RSUyBwcm9qZWN0IChMPGh0dHA6Ly9vdHJzLm9yZy8+KS4KClRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCnRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIEw8aHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0Pi4KCj1jdXQK
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvQ3VzdG9tZXIucG0gLSB4bWwgYmFja2VuZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6WE1MOjpUeXBlOjpDdXN0b21lcjsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSBLZXJuZWw6OlN5c3RlbTo6Q3VzdG9tZXJVc2VyOwoKPWhlYWQxIE5BTUUKCktlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6WE1MOjpUeXBlOjpDdXN0b21lciAtIHhtbCBiYWNrZW5kIG1vZHVsZQoKPWhlYWQxIFNZTk9QU0lTCgpBbGwgeG1sIGZ1bmN0aW9ucyBvZiBjdXN0b21lciBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICAkQmFja2VuZE9iamVjdCA9ICRDb25maWdJdGVtT2JqZWN0LT5fTG9hZFhNTFR5cGVCYWNrZW5kKAogICAgICAgIFR5cGUgPT4gJ0N1c3RvbWVyJywKICAgICk7Cgo9Y3V0CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0IChxdyhEQk9iamVjdCBDb25maWdPYmplY3QgRW5jb2RlT2JqZWN0IExvZ09iamVjdCBNYWluT2JqZWN0KSkgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQogICAgJFNlbGYtPntDdXN0b21lclVzZXJPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06OkN1c3RvbWVyVXNlci0+bmV3KCAleyRTZWxmfSApOwoKICAgIHJldHVybiAkU2VsZjsKfQoKPWl0ZW0gVmFsdWVMb29rdXAoKQoKZ2V0IHRoZSB4bWwgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBWYWx1ZUxvb2t1cCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiAnJyBpZiAhJFBhcmFte1ZhbHVlfTsKCiAgICBteSAlQ3VzdG9tZXJTZWFyY2hMaXN0ID0gJFNlbGYtPntDdXN0b21lclVzZXJPYmplY3R9LT5DdXN0b21lclNlYXJjaCgKICAgICAgICBTZWFyY2ggPT4gJFBhcmFte1ZhbHVlfSwKICAgICk7CgogICAgcmV0dXJuICRDdXN0b21lclNlYXJjaExpc3R7ICRQYXJhbXtWYWx1ZX0gfSB8fCAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSgpCgpjcmVhdGUgYSBhdHRyaWJ1dGUgYXJyYXkgZm9yIHRoZSBzdGF0cyBmcmFtZXdvcmsKCiAgICBteSAkQXR0cmlidXRlID0gJEJhY2tlbmRPYmplY3QtPlN0YXRzQXR0cmlidXRlQ3JlYXRlKAogICAgICAgIEtleSA9PiAnS2V5OjpTdWJrZXknLAogICAgICAgIE5hbWUgPT4gJ05hbWUnLAogICAgICAgIEl0ZW0gPT4gJEl0ZW1SZWYsCiAgICApOwoKPWN1dAoKc3ViIFN0YXRzQXR0cmlidXRlQ3JlYXRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGZvciBteSAkQXJndW1lbnQgKHF3KEtleSBOYW1lIEl0ZW0pKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyRBcmd1bWVudH0gKSB7CiAgICAgICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICRBcmd1bWVudCEiLAogICAgICAgICAgICApOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgfQoKICAgICMgY3JlYXRlIGFycnRpYnV0ZQogICAgbXkgJEF0dHJpYnV0ZSA9IFsKICAgICAgICB7CiAgICAgICAgICAgIE5hbWUgICAgICAgICAgICAgPT4gJFBhcmFte05hbWV9LAogICAgICAgICAgICBVc2VBc1h2YWx1ZSAgICAgID0+IDAsCiAgICAgICAgICAgIFVzZUFzVmFsdWVTZXJpZXMgPT4gMCwKICAgICAgICAgICAgVXNlQXNSZXN0cmljdGlvbiA9PiAxLAogICAgICAgICAgICBFbGVtZW50ICAgICAgICAgID0+ICRQYXJhbXtLZXl9LAogICAgICAgICAgICBCbG9jayAgICAgICAgICAgID0+ICdJbnB1dEZpZWxkJywKICAgICAgICB9LAogICAgXTsKCiAgICByZXR1cm4gJEF0dHJpYnV0ZTsKfQoKPWl0ZW0gRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgc2VhcmNoIHZhbHVlIGZvciBleHBvcnQKCiAgICBteSAkQXJyYXlSZWYgPSAkQmFja2VuZE9iamVjdC0+RXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gRXhwb3J0VmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGltcG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5JbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCjE7Cgo9YmFjawoKPWhlYWQxIFRFUk1TIEFORCBDT05ESVRJT05TCgpUaGlzIHNvZnR3YXJlIGlzIHBhcnQgb2YgdGhlIE9UUlMgcHJvamVjdCAoaHR0cDovL290cnMub3JnLykuCgpUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQp0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CmRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBMPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dD4uCgo9Y3V0Cg==
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvQ3VzdG9tZXJDb21wYW55LnBtIC0geG1sIGJhY2tlbmQgbW9kdWxlCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTQgT1RSUyBBRywgaHR0cDovL290cnMuY29tLwojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlhNTDo6VHlwZTo6Q3VzdG9tZXJDb21wYW55OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIEtlcm5lbDo6U3lzdGVtOjpDdXN0b21lckNvbXBhbnk7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OkN1c3RvbWVyQ29tcGFueSAtIHhtbCBiYWNrZW5kIG1vZHVsZQoKPWhlYWQxIFNZTk9QU0lTCgpBbGwgeG1sIGZ1bmN0aW9ucyBvZiBjdXN0b21lciBjb21wYW55IG9iamVjdHMKCj1vdmVyIDQKCj1jdXQKCj1pdGVtIG5ldygpCgpjcmVhdGUgYW4gb2JqZWN0CgogICAgdXNlIEtlcm5lbDo6Q29uZmlnOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpFbmNvZGU7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkxvZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6REI7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06Ok1haW47CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOwoKICAgIG15ICRDb25maWdPYmplY3QgPSBLZXJuZWw6OkNvbmZpZy0+bmV3KCk7CiAgICBteSAkRW5jb2RlT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkVuY29kZS0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgKTsKICAgIG15ICRMb2dPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6TG9nLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICApOwogICAgbXkgJE1haW5PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6TWFpbi0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICA9PiAkTG9nT2JqZWN0LAogICAgKTsKICAgIG15ICREQk9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpEQi0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICA9PiAkTG9nT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICBteSAkQ29uZmlnSXRlbU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbS0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgICAgIExvZ09iamVjdCAgICA9PiAkTG9nT2JqZWN0LAogICAgICAgIERCT2JqZWN0ICAgICA9PiAkREJPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgID0+ICRNYWluT2JqZWN0LAogICAgKTsKICAgICRCYWNrZW5kT2JqZWN0ID0gJENvbmZpZ0l0ZW1PYmplY3QtPl9Mb2FkWE1MVHlwZUJhY2tlbmQoCiAgICAgICAgVHlwZSA9PiAnQ3VzdG9tZXJDb21wYW55JywKICAgICk7Cgo9Y3V0CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0IChxdyhEQk9iamVjdCBDb25maWdPYmplY3QgRW5jb2RlT2JqZWN0IExvZ09iamVjdCBNYWluT2JqZWN0KSkgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQogICAgJFNlbGYtPntDdXN0b21lckNvbXBhbnlPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06OkN1c3RvbWVyQ29tcGFueS0+bmV3KCAleyRTZWxmfSApOwoKICAgIHJldHVybiAkU2VsZjsKfQoKPWl0ZW0gVmFsdWVMb29rdXAoKQoKZ2V0IHRoZSB4bWwgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBWYWx1ZUxvb2t1cCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiAnJyBpZiAhJFBhcmFte1ZhbHVlfTsKCiAgICBteSAlQ3VzdG9tZXJDb21wYW55ID0gJFNlbGYtPntDdXN0b21lckNvbXBhbnlPYmplY3R9LT5DdXN0b21lckNvbXBhbnlHZXQoCiAgICAgICAgQ3VzdG9tZXJJRCA9PiAkUGFyYW17VmFsdWV9LAogICAgKTsKCiAgICByZXR1cm4gJEN1c3RvbWVyQ29tcGFueXtDdXN0b21lckNvbXBhbnlOYW1lfSB8fCAnJzsKfQoKPWl0ZW0gU3RhdHNBdHRyaWJ1dGVDcmVhdGUoKQoKY3JlYXRlIGEgYXR0cmlidXRlIGFycmF5IGZvciB0aGUgc3RhdHMgZnJhbWV3b3JrCgogICAgbXkgJEF0dHJpYnV0ZSA9ICRCYWNrZW5kT2JqZWN0LT5TdGF0c0F0dHJpYnV0ZUNyZWF0ZSgKICAgICAgICBLZXkgPT4gJ0tleTo6U3Via2V5JywKICAgICAgICBOYW1lID0+ICdOYW1lJywKICAgICAgICBJdGVtID0+ICRJdGVtUmVmLAogICAgKTsKCj1jdXQKCnN1YiBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhLZXkgTmFtZSBJdGVtKSkgewogICAgICAgIGlmICggISRQYXJhbXskQXJndW1lbnR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkQXJndW1lbnQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICAjIGNyZWF0ZSBhdHRyaWJ1dGUKICAgIG15ICRBdHRyaWJ1dGUgPSBbCiAgICAgICAgewogICAgICAgICAgICBOYW1lICAgICAgICAgICAgID0+ICRQYXJhbXtOYW1lfSwKICAgICAgICAgICAgVXNlQXNYdmFsdWUgICAgICA9PiAwLAogICAgICAgICAgICBVc2VBc1ZhbHVlU2VyaWVzID0+IDAsCiAgICAgICAgICAgIFVzZUFzUmVzdHJpY3Rpb24gPT4gMSwKICAgICAgICAgICAgRWxlbWVudCAgICAgICAgICA9PiAkUGFyYW17S2V5fSwKICAgICAgICAgICAgQmxvY2sgICAgICAgICAgICA9PiAnSW5wdXRGaWVsZCcsCiAgICAgICAgfSwKICAgIF07CgogICAgcmV0dXJuICRBdHRyaWJ1dGU7Cn0KCj1pdGVtIEV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHNlYXJjaCB2YWx1ZSBmb3IgZXhwb3J0CgogICAgbXkgJEFycmF5UmVmID0gJEJhY2tlbmRPYmplY3QtPkV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEV4cG9ydFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHZhbHVlIGZvciBleHBvcnQKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+RXhwb3J0VmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgRXhwb3J0VmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gSW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgc2VhcmNoIHZhbHVlIGZvciBpbXBvcnQKCiAgICBteSAkQXJyYXlSZWYgPSAkQmFja2VuZE9iamVjdC0+SW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgSW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gSW1wb3J0VmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgdmFsdWUgZm9yIGltcG9ydAoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5JbXBvcnRWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBJbXBvcnRWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKGh0dHA6Ly9vdHJzLm9yZy8pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvRGF0ZS5wbSAtIHhtbCBiYWNrZW5kIG1vZHVsZQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OkRhdGU7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OkRhdGUgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgZGF0ZSBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICAkQmFja2VuZE9iamVjdCA9ICRDb25maWdJdGVtT2JqZWN0LT5fTG9hZFhNTFR5cGVCYWNrZW5kKAogICAgICAgIFR5cGUgPT4gJ0RhdGUnLAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBjaGVjayBuZWVkZWQgb2JqZWN0cwogICAgZm9yIG15ICRPYmplY3QgKHF3KERCT2JqZWN0IENvbmZpZ09iamVjdCBFbmNvZGVPYmplY3QgTG9nT2JqZWN0IE1haW5PYmplY3QpKSB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBWYWx1ZUxvb2t1cCgpCgpnZXQgdGhlIGRhdGUgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gJzIwMDctMDMtMjYnLCAgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIFZhbHVlTG9va3VwIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX0gfHwgJyc7Cn0KCj1pdGVtIFN0YXRzQXR0cmlidXRlQ3JlYXRlKCkKCmNyZWF0ZSBhIGF0dHJpYnV0ZSBhcnJheSBmb3IgdGhlIHN0YXRzIGZyYW1ld29yawoKICAgIG15ICRBdHRyaWJ1dGUgPSAkQmFja2VuZE9iamVjdC0+U3RhdHNBdHRyaWJ1dGVDcmVhdGUoKTsKCj1jdXQKCnN1YiBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgIHJldHVybjsKfQoKPWl0ZW0gRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgc2VhcmNoIHZhbHVlIGZvciBleHBvcnQKCiAgICBteSAkQXJyYXlSZWYgPSAkQmFja2VuZE9iamVjdC0+RXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gRXhwb3J0VmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGltcG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5JbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCjE7Cgo9YmFjawoKPWhlYWQxIFRFUk1TIEFORCBDT05ESVRJT05TCgpUaGlzIHNvZnR3YXJlIGlzIHBhcnQgb2YgdGhlIE9UUlMgcHJvamVjdCAoaHR0cDovL290cnMub3JnLykuCgpUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQp0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CmRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBMPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dD4uCgo9Y3V0Cg==
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvRGF0ZVRpbWUucG0gLSB4bWwgYmFja2VuZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6WE1MOjpUeXBlOjpEYXRlVGltZTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlhNTDo6VHlwZTo6RGF0ZVRpbWUgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgZGF0ZSBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICAkQmFja2VuZE9iamVjdCA9ICRDb25maWdJdGVtT2JqZWN0LT5fTG9hZFhNTFR5cGVCYWNrZW5kKAogICAgICAgIFR5cGUgPT4gJ0RhdGVUaW1lJywKICAgICk7Cgo9Y3V0CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0IChxdyhEQk9iamVjdCBDb25maWdPYmplY3QgRW5jb2RlT2JqZWN0IExvZ09iamVjdCBNYWluT2JqZWN0KSkgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQoKICAgIHJldHVybiAkU2VsZjsKfQoKPWl0ZW0gVmFsdWVMb29rdXAoKQoKZ2V0IHRoZSBkYXRlIHRpbWUgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gJzIwMDctMDMtMjYgMjI6MDEnLCAgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIFZhbHVlTG9va3VwIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX0gfHwgJyc7Cn0KCj1pdGVtIFN0YXRzQXR0cmlidXRlQ3JlYXRlKCkKCmNyZWF0ZSBhIGF0dHJpYnV0ZSBhcnJheSBmb3IgdGhlIHN0YXRzIGZyYW1ld29yawoKICAgIG15ICRBdHRyaWJ1dGUgPSAkQmFja2VuZE9iamVjdC0+U3RhdHNBdHRyaWJ1dGVDcmVhdGUoKTsKCj1jdXQKCnN1YiBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgIHJldHVybjsKfQoKPWl0ZW0gRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgc2VhcmNoIHZhbHVlIGZvciBleHBvcnQKCiAgICBteSAkQXJyYXlSZWYgPSAkQmFja2VuZE9iamVjdC0+RXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgRXhwb3J0U2VhcmNoVmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gRXhwb3J0VmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGltcG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5JbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBJbXBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBJbXBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCjE7Cgo9YmFjawoKPWhlYWQxIFRFUk1TIEFORCBDT05ESVRJT05TCgpUaGlzIHNvZnR3YXJlIGlzIHBhcnQgb2YgdGhlIE9UUlMgcHJvamVjdCAoaHR0cDovL290cnMub3JnLykuCgpUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQp0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CmRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBMPGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dD4uCgo9Y3V0Cg==
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvRHVtbXkucG0gLSB4bWwgYmFja2VuZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6WE1MOjpUeXBlOjpEdW1teTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlhNTDo6VHlwZTo6RHVtbXkgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgZHVtbXkgb2JqZWN0cwoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICB1c2UgS2VybmVsOjpDb25maWc7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkVuY29kZTsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TG9nOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpEQjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TWFpbjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW07CgogICAgbXkgJENvbmZpZ09iamVjdCA9IEtlcm5lbDo6Q29uZmlnLT5uZXcoKTsKICAgIG15ICRFbmNvZGVPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICApOwogICAgbXkgJExvZ09iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpMb2ctPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICk7CiAgICBteSAkTWFpbk9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpNYWluLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICApOwogICAgbXkgJERCT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkRCLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgID0+ICRNYWluT2JqZWN0LAogICAgKTsKICAgIG15ICRDb25maWdJdGVtT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgREJPYmplY3QgICAgID0+ICREQk9iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgJEJhY2tlbmRPYmplY3QgPSAkQ29uZmlnSXRlbU9iamVjdC0+X0xvYWRYTUxUeXBlQmFja2VuZCgKICAgICAgICBUeXBlID0+ICdEdW1teScsCiAgICApOwoKPWN1dAoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGNoZWNrIG5lZWRlZCBvYmplY3RzCiAgICBmb3IgbXkgJE9iamVjdCAocXcoREJPYmplY3QgQ29uZmlnT2JqZWN0IEVuY29kZU9iamVjdCBMb2dPYmplY3QgTWFpbk9iamVjdCkpIHsKICAgICAgICAkU2VsZi0+eyRPYmplY3R9ID0gJFBhcmFteyRPYmplY3R9IHx8IGRpZSAiR290IG5vICRPYmplY3QhIjsKICAgIH0KCiAgICByZXR1cm4gJFNlbGY7Cn0KCj1pdGVtIFZhbHVlTG9va3VwKCkKCmdldCB0aGUgZHVtbXkgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoKTsKCj1jdXQKCnN1YiBWYWx1ZUxvb2t1cCB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgIHJldHVybiAnJzsKfQoKPWl0ZW0gU3RhdHNBdHRyaWJ1dGVDcmVhdGUoKQoKY3JlYXRlIGEgYXR0cmlidXRlIGFycmF5IGZvciB0aGUgc3RhdHMgZnJhbWV3b3JrCgogICAgbXkgJEF0dHJpYnV0ZSA9ICRCYWNrZW5kT2JqZWN0LT5TdGF0c0F0dHJpYnV0ZUNyZWF0ZSgpOwoKPWN1dAoKc3ViIFN0YXRzQXR0cmlidXRlQ3JlYXRlIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgcmV0dXJuOwp9Cgo9aXRlbSBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBFeHBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgZXhwb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkV4cG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEV4cG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHNlYXJjaCB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJEFycmF5UmVmID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHZhbHVlIGZvciBpbXBvcnQKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+SW1wb3J0VmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgSW1wb3J0VmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKMTsKCj1iYWNrCgo9aGVhZDEgVEVSTVMgQU5EIENPTkRJVElPTlMKClRoaXMgc29mdHdhcmUgaXMgcGFydCBvZiB0aGUgT1RSUyBwcm9qZWN0IChodHRwOi8vb3Rycy5vcmcvKS4KClRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCnRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIEw8aHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0Pi4KCj1jdXQK
# --
# Kernel/System/ITSMConfigItem/XML/Type/GeneralCatalog.pm - xml backend module
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::ITSMConfigItem::XML::Type::GeneralCatalog;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;

=head1 NAME

Kernel::System::ITSMConfigItem::XML::Type::GeneralCatalog - xml backend module

=head1 SYNOPSIS

All xml functions of general catalog objects

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::Log;
    use Kernel::System::DB;
    use Kernel::System::Main;
    use Kernel::System::ITSMConfigItem;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $ConfigItemObject = Kernel::System::ITSMConfigItem->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        DBObject     => $DBObject,
        MainObject   => $MainObject,
    );
    $BackendObject = $ConfigItemObject->_LoadXMLTypeBackend(
        Type => 'GeneralCatalog',
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (qw(DBObject ConfigObject EncodeObject LogObject MainObject)) {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );

    return $Self;
}

=item ValueLookup()

get the xml data of a version

    my $Value = $BackendObject->ValueLookup(
        Item  => $ItemRef,
        Value => 11,        # (optional)
    );

=cut

sub ValueLookup {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Item} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Item!',
        );
        return;
    }

    return if !$Param{Value};

    # get item list
    my $ItemList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    return if !$ItemList;
    return if ref $ItemList ne 'HASH';

    my $Value = $ItemList->{ $Param{Value} };

    return $Value;
}

=item StatsAttributeCreate()

create a attribute array for the stats framework

    my $Attribute = $BackendObject->StatsAttributeCreate(
        Key  => 'Key::Subkey',
        Name => 'Name',
        Item => $ItemRef,
    );

=cut

sub StatsAttributeCreate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Name Item)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get item list
    my $ItemList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    # create arrtibute
    my $Attribute = [
        {
            Name             => $Param{Name},
            UseAsXvalue      => 1,
            UseAsValueSeries => 1,
            UseAsRestriction => 1,
            Element          => $Param{Key},
            Block            => 'MultiSelectField',
            Values           => $ItemList || {},
        },
    ];

    return $Attribute;
}

=item ExportSearchValuePrepare()

prepare search value for export

    my $ArrayRef = $BackendObject->ExportSearchValuePrepare(
        Value => 11, # (optional)
    );

=cut

sub ExportSearchValuePrepare {
    my ( $Self, %Param ) = @_;

    return if !defined $Param{Value};

    my @Values = split '#####', $Param{Value};
    @Values = grep {$_} @Values;

    return \@Values;
}

=item ExportValuePrepare()

prepare value for export

    my $Value = $BackendObject->ExportValuePrepare(
        Value => 11, # (optional)
    );

=cut

sub ExportValuePrepare {
    my ( $Self, %Param ) = @_;

    return if !defined $Param{Value};

    # get item list
    my $ItemList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    return $ItemList->{ $Param{Value} } || $Param{Value};
}

=item ImportSearchValuePrepare()

prepare search value for import

    my $ArrayRef = $BackendObject->ImportSearchValuePrepare(
        Value => 11, # (optional)
    );

=cut

sub ImportSearchValuePrepare {
    my ( $Self, %Param ) = @_;

    return if !defined $Param{Value};

    my @Values = split '#####', $Param{Value};
    @Values = grep {$_} @Values;

    return \@Values;
}

=item ImportValuePrepare()

prepare value for import

    my $Value = $BackendObject->ImportValuePrepare(
        Value => 11, # (optional)
    );

=cut

sub ImportValuePrepare {
    my ( $Self, %Param ) = @_;

    return if !defined $Param{Value};

    # get item list
    my $ItemList = $Self->{GeneralCatalogObject}->ItemList(
        Class => $Param{Item}->{Input}->{Class} || '',
    );

    # reverse the list
    my %Name2ID = reverse %{$ItemList};

    my $GeneralCatalogID = $Name2ID{ $Param{Value} };

    if ( !$GeneralCatalogID ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "General catalog lookup of'$Param{Value}' failed!",
        );
        return;
    }

    return $GeneralCatalogID;
}

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 (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvSW50ZWdlci5wbSAtIHhtbCBiYWNrZW5kIG1vZHVsZQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OkludGVnZXI7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OkludGVnZXIgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgaW50ZWdlciBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICAkQmFja2VuZE9iamVjdCA9ICRDb25maWdJdGVtT2JqZWN0LT5fTG9hZFhNTFR5cGVCYWNrZW5kKAogICAgICAgIFR5cGUgPT4gJ0ludGVnZXInLAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBjaGVjayBuZWVkZWQgb2JqZWN0cwogICAgZm9yIG15ICRPYmplY3QgKHF3KERCT2JqZWN0IENvbmZpZ09iamVjdCBFbmNvZGVPYmplY3QgTG9nT2JqZWN0IE1haW5PYmplY3QpKSB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBWYWx1ZUxvb2t1cCgpCgpnZXQgdGhlIGludGVnZXIgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gMTEsICAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgVmFsdWVMb29rdXAgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gU3RhdHNBdHRyaWJ1dGVDcmVhdGUoKQoKY3JlYXRlIGEgYXR0cmlidXRlIGFycmF5IGZvciB0aGUgc3RhdHMgZnJhbWV3b3JrCgogICAgbXkgJEF0dHJpYnV0ZSA9ICRCYWNrZW5kT2JqZWN0LT5TdGF0c0F0dHJpYnV0ZUNyZWF0ZSgpOwoKPWN1dAoKc3ViIFN0YXRzQXR0cmlidXRlQ3JlYXRlIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgcmV0dXJuOwp9Cgo9aXRlbSBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBFeHBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgZXhwb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkV4cG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEV4cG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHNlYXJjaCB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJEFycmF5UmVmID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHZhbHVlIGZvciBpbXBvcnQKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+SW1wb3J0VmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgSW1wb3J0VmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKMTsKCj1iYWNrCgo9aGVhZDEgVEVSTVMgQU5EIENPTkRJVElPTlMKClRoaXMgc29mdHdhcmUgaXMgcGFydCBvZiB0aGUgT1RSUyBwcm9qZWN0IChodHRwOi8vb3Rycy5vcmcvKS4KClRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCnRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIEw8aHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0Pi4KCj1jdXQK
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvVGV4dC5wbSAtIHhtbCBiYWNrZW5kIG1vZHVsZQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OlRleHQ7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtOjpYTUw6OlR5cGU6OlRleHQgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgdGV4dCBvYmplY3RzCgo9b3ZlciA0Cgo9Y3V0Cgo9aXRlbSBuZXcoKQoKY3JlYXRlIGFuIG9iamVjdAoKICAgIHVzZSBLZXJuZWw6OkNvbmZpZzsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpMb2c7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkRCOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpNYWluOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTsKCiAgICBteSAkQ29uZmlnT2JqZWN0ID0gS2VybmVsOjpDb25maWctPm5ldygpOwogICAgbXkgJEVuY29kZU9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpFbmNvZGUtPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICk7CiAgICBteSAkTG9nT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkxvZy0+bmV3KAogICAgICAgIENvbmZpZ09iamVjdCA9PiAkQ29uZmlnT2JqZWN0LAogICAgICAgIEVuY29kZU9iamVjdCA9PiAkRW5jb2RlT2JqZWN0LAogICAgKTsKICAgIG15ICRNYWluT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06Ok1haW4tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICk7CiAgICBteSAkREJPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6REItPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgbXkgJENvbmZpZ0l0ZW1PYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW0tPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICAgICBMb2dPYmplY3QgICAgPT4gJExvZ09iamVjdCwKICAgICAgICBEQk9iamVjdCAgICAgPT4gJERCT2JqZWN0LAogICAgICAgIE1haW5PYmplY3QgICA9PiAkTWFpbk9iamVjdCwKICAgICk7CiAgICAkQmFja2VuZE9iamVjdCA9ICRDb25maWdJdGVtT2JqZWN0LT5fTG9hZFhNTFR5cGVCYWNrZW5kKAogICAgICAgIFR5cGUgPT4gJ1RleHQnLAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBjaGVjayBuZWVkZWQgb2JqZWN0cwogICAgZm9yIG15ICRPYmplY3QgKHF3KERCT2JqZWN0IENvbmZpZ09iamVjdCBFbmNvZGVPYmplY3QgTG9nT2JqZWN0IE1haW5PYmplY3QpKSB7CiAgICAgICAgJFNlbGYtPnskT2JqZWN0fSA9ICRQYXJhbXskT2JqZWN0fSB8fCBkaWUgIkdvdCBubyAkT2JqZWN0ISI7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBWYWx1ZUxvb2t1cCgpCgpnZXQgdGhlIHRleHQgZGF0YSBvZiBhIHZlcnNpb24KCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+VmFsdWVMb29rdXAoCiAgICAgICAgVmFsdWUgPT4gMTEsICAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgVmFsdWVMb29rdXAgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gU3RhdHNBdHRyaWJ1dGVDcmVhdGUoKQoKY3JlYXRlIGEgYXR0cmlidXRlIGFycmF5IGZvciB0aGUgc3RhdHMgZnJhbWV3b3JrCgogICAgbXkgJEF0dHJpYnV0ZSA9ICRCYWNrZW5kT2JqZWN0LT5TdGF0c0F0dHJpYnV0ZUNyZWF0ZSgKICAgICAgICBLZXkgID0+ICdLZXk6OlN1YmtleScsCiAgICAgICAgTmFtZSA9PiAnTmFtZScsCiAgICAgICAgSXRlbSA9PiAkSXRlbVJlZiwKICAgICk7Cgo9Y3V0CgpzdWIgU3RhdHNBdHRyaWJ1dGVDcmVhdGUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGNoZWNrIG5lZWRlZCBzdHVmZgogICAgZm9yIG15ICRBcmd1bWVudCAocXcoS2V5IE5hbWUgSXRlbSkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JEFyZ3VtZW50fSApIHsKICAgICAgICAgICAgJFNlbGYtPntMb2dPYmplY3R9LT5Mb2coCiAgICAgICAgICAgICAgICBQcmlvcml0eSA9PiAnZXJyb3InLAogICAgICAgICAgICAgICAgTWVzc2FnZSAgPT4gIk5lZWQgJEFyZ3VtZW50ISIsCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgIyBjcmVhdGUgYXR0cmlidXRlCiAgICBteSAkQXR0cmlidXRlID0gWwogICAgICAgIHsKICAgICAgICAgICAgTmFtZSAgICAgICAgICAgICA9PiAkUGFyYW17TmFtZX0sCiAgICAgICAgICAgIFVzZUFzWHZhbHVlICAgICAgPT4gMCwKICAgICAgICAgICAgVXNlQXNWYWx1ZVNlcmllcyA9PiAwLAogICAgICAgICAgICBVc2VBc1Jlc3RyaWN0aW9uID0+IDEsCiAgICAgICAgICAgIEVsZW1lbnQgICAgICAgICAgPT4gJFBhcmFte0tleX0sCiAgICAgICAgICAgIEJsb2NrICAgICAgICAgICAgPT4gJ0lucHV0RmllbGQnLAogICAgICAgIH0sCiAgICBdOwoKICAgIHJldHVybiAkQXR0cmlidXRlOwp9Cgo9aXRlbSBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSBzZWFyY2ggdmFsdWUgZm9yIGV4cG9ydAoKICAgIG15ICRBcnJheVJlZiA9ICRCYWNrZW5kT2JqZWN0LT5FeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBFeHBvcnRTZWFyY2hWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBFeHBvcnRWYWx1ZVByZXBhcmUoKQoKcHJlcGFyZSB2YWx1ZSBmb3IgZXhwb3J0CgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkV4cG9ydFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEV4cG9ydFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHNlYXJjaCB2YWx1ZSBmb3IgaW1wb3J0CgogICAgbXkgJEFycmF5UmVmID0gJEJhY2tlbmRPYmplY3QtPkltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEltcG9ydFNlYXJjaFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEltcG9ydFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHZhbHVlIGZvciBpbXBvcnQKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+SW1wb3J0VmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgSW1wb3J0VmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKMTsKCj1iYWNrCgo9aGVhZDEgVEVSTVMgQU5EIENPTkRJVElPTlMKClRoaXMgc29mdHdhcmUgaXMgcGFydCBvZiB0aGUgT1RSUyBwcm9qZWN0IChodHRwOi8vb3Rycy5vcmcvKS4KClRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCnRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIEw8aHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0Pi4KCj1jdXQK
IyAtLQojIEtlcm5lbC9TeXN0ZW0vSVRTTUNvbmZpZ0l0ZW0vWE1ML1R5cGUvVGV4dEFyZWEucG0gLSB4bWwgYmFja2VuZCBtb2R1bGUKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxNCBPVFJTIEFHLCBodHRwOi8vb3Rycy5jb20vCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpJVFNNQ29uZmlnSXRlbTo6WE1MOjpUeXBlOjpUZXh0QXJlYTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCj1oZWFkMSBOQU1FCgpLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW06OlhNTDo6VHlwZTo6VGV4dEFyZWEgLSB4bWwgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBTWU5PUFNJUwoKQWxsIHhtbCBmdW5jdGlvbnMgb2YgdGV4dGFyZWEgb2JqZWN0cwoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICB1c2UgS2VybmVsOjpDb25maWc7CiAgICB1c2UgS2VybmVsOjpTeXN0ZW06OkVuY29kZTsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TG9nOwogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpEQjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6TWFpbjsKICAgIHVzZSBLZXJuZWw6OlN5c3RlbTo6SVRTTUNvbmZpZ0l0ZW07CgogICAgbXkgJENvbmZpZ09iamVjdCA9IEtlcm5lbDo6Q29uZmlnLT5uZXcoKTsKICAgIG15ICRFbmNvZGVPYmplY3QgPSBLZXJuZWw6OlN5c3RlbTo6RW5jb2RlLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICApOwogICAgbXkgJExvZ09iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpMb2ctPm5ldygKICAgICAgICBDb25maWdPYmplY3QgPT4gJENvbmZpZ09iamVjdCwKICAgICAgICBFbmNvZGVPYmplY3QgPT4gJEVuY29kZU9iamVjdCwKICAgICk7CiAgICBteSAkTWFpbk9iamVjdCA9IEtlcm5lbDo6U3lzdGVtOjpNYWluLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICApOwogICAgbXkgJERCT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OkRCLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgTWFpbk9iamVjdCAgID0+ICRNYWluT2JqZWN0LAogICAgKTsKICAgIG15ICRDb25maWdJdGVtT2JqZWN0ID0gS2VybmVsOjpTeXN0ZW06OklUU01Db25maWdJdGVtLT5uZXcoCiAgICAgICAgQ29uZmlnT2JqZWN0ID0+ICRDb25maWdPYmplY3QsCiAgICAgICAgRW5jb2RlT2JqZWN0ID0+ICRFbmNvZGVPYmplY3QsCiAgICAgICAgTG9nT2JqZWN0ICAgID0+ICRMb2dPYmplY3QsCiAgICAgICAgREJPYmplY3QgICAgID0+ICREQk9iamVjdCwKICAgICAgICBNYWluT2JqZWN0ICAgPT4gJE1haW5PYmplY3QsCiAgICApOwogICAgJEJhY2tlbmRPYmplY3QgPSAkQ29uZmlnSXRlbU9iamVjdC0+X0xvYWRYTUxUeXBlQmFja2VuZCgKICAgICAgICBUeXBlID0+ICdUZXh0QXJlYScsCiAgICApOwoKPWN1dAoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGNoZWNrIG5lZWRlZCBvYmplY3RzCiAgICBmb3IgbXkgJE9iamVjdCAocXcoREJPYmplY3QgQ29uZmlnT2JqZWN0IEVuY29kZU9iamVjdCBMb2dPYmplY3QgTWFpbk9iamVjdCkpIHsKICAgICAgICAkU2VsZi0+eyRPYmplY3R9ID0gJFBhcmFteyRPYmplY3R9IHx8IGRpZSAiR290IG5vICRPYmplY3QhIjsKICAgIH0KCiAgICByZXR1cm4gJFNlbGY7Cn0KCj1pdGVtIFZhbHVlTG9va3VwKCkKCmdldCB0aGUgdGV4dCBkYXRhIG9mIGEgdmVyc2lvbgoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5WYWx1ZUxvb2t1cCgKICAgICAgICBWYWx1ZSA9PiAxMSwgICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBWYWx1ZUxvb2t1cCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9Cgo9aXRlbSBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSgpCgpjcmVhdGUgYSBhdHRyaWJ1dGUgYXJyYXkgZm9yIHRoZSBzdGF0cyBmcmFtZXdvcmsKCiAgICBteSAkQXR0cmlidXRlID0gJEJhY2tlbmRPYmplY3QtPlN0YXRzQXR0cmlidXRlQ3JlYXRlKAogICAgICAgIEtleSAgPT4gJ0tleTo6U3Via2V5JywKICAgICAgICBOYW1lID0+ICdOYW1lJywKICAgICAgICBJdGVtID0+ICRJdGVtUmVmLAogICAgKTsKCj1jdXQKCnN1YiBTdGF0c0F0dHJpYnV0ZUNyZWF0ZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhLZXkgTmFtZSBJdGVtKSkgewogICAgICAgIGlmICggISRQYXJhbXskQXJndW1lbnR9ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkQXJndW1lbnQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICAjIGNyZWF0ZSBhcnJ0aWJ1dGUKICAgIG15ICRBdHRyaWJ1dGUgPSBbCiAgICAgICAgewogICAgICAgICAgICBOYW1lICAgICAgICAgICAgID0+ICRQYXJhbXtOYW1lfSwKICAgICAgICAgICAgVXNlQXNYdmFsdWUgICAgICA9PiAwLAogICAgICAgICAgICBVc2VBc1ZhbHVlU2VyaWVzID0+IDAsCiAgICAgICAgICAgIFVzZUFzUmVzdHJpY3Rpb24gPT4gMSwKICAgICAgICAgICAgRWxlbWVudCAgICAgICAgICA9PiAkUGFyYW17S2V5fSwKICAgICAgICAgICAgQmxvY2sgICAgICAgICAgICA9PiAnSW5wdXRGaWVsZCcsCiAgICAgICAgfSwKICAgIF07CgogICAgcmV0dXJuICRBdHRyaWJ1dGU7Cn0KCj1pdGVtIEV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHNlYXJjaCB2YWx1ZSBmb3IgZXhwb3J0CgogICAgbXkgJEFycmF5UmVmID0gJEJhY2tlbmRPYmplY3QtPkV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSgKICAgICAgICBWYWx1ZSA9PiAxMSwgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEV4cG9ydFNlYXJjaFZhbHVlUHJlcGFyZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiBpZiAhZGVmaW5lZCAkUGFyYW17VmFsdWV9OwogICAgcmV0dXJuICRQYXJhbXtWYWx1ZX07Cn0KCj1pdGVtIEV4cG9ydFZhbHVlUHJlcGFyZSgpCgpwcmVwYXJlIHZhbHVlIGZvciBleHBvcnQKCiAgICBteSAkVmFsdWUgPSAkQmFja2VuZE9iamVjdC0+RXhwb3J0VmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgRXhwb3J0VmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gSW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgc2VhcmNoIHZhbHVlIGZvciBpbXBvcnQKCiAgICBteSAkQXJyYXlSZWYgPSAkQmFja2VuZE9iamVjdC0+SW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlKAogICAgICAgIFZhbHVlID0+IDExLCAjIChvcHRpb25hbCkKICAgICk7Cgo9Y3V0CgpzdWIgSW1wb3J0U2VhcmNoVmFsdWVQcmVwYXJlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIGlmICFkZWZpbmVkICRQYXJhbXtWYWx1ZX07CiAgICByZXR1cm4gJFBhcmFte1ZhbHVlfTsKfQoKPWl0ZW0gSW1wb3J0VmFsdWVQcmVwYXJlKCkKCnByZXBhcmUgdmFsdWUgZm9yIGltcG9ydAoKICAgIG15ICRWYWx1ZSA9ICRCYWNrZW5kT2JqZWN0LT5JbXBvcnRWYWx1ZVByZXBhcmUoCiAgICAgICAgVmFsdWUgPT4gMTEsICMgKG9wdGlvbmFsKQogICAgKTsKCj1jdXQKCnN1YiBJbXBvcnRWYWx1ZVByZXBhcmUgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gaWYgIWRlZmluZWQgJFBhcmFte1ZhbHVlfTsKICAgIHJldHVybiAkUGFyYW17VmFsdWV9Owp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKGh0dHA6Ly9vdHJzLm9yZy8pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
# --
# Kernel/System/LinkObject/ITSMConfigItem.pm - to link config item objects
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::LinkObject::ITSMConfigItem;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;

=head1 NAME

Kernel/System/LinkObject/ITSMConfigItem.pm- LinkObject module for ITSMConfigItem

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::Log;
    use Kernel::System::Time;
    use Kernel::System::Main;
    use Kernel::System::DB;
    use Kernel::System::LinkObject::ITSMConfigItem;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $TimeObject = Kernel::System::Time->new(
        ConfigObject => $ConfigObject,
        LogObject    => $LogObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $ITSMConfigItemObject = Kernel::System::LinkObject::ITSMConfigItem->new(
        ConfigObject       => $ConfigObject,
        LogObject          => $LogObject,
        DBObject           => $DBObject,
        MainObject         => $MainObject,
        TimeObject         => $TimeObject,
        EncodeObject       => $EncodeObject,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(DBObject ConfigObject EncodeObject LogObject MainObject TimeObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );

    return $Self;
}

=item LinkListWithData()

fill up the link list with data

    $Success = $LinkObjectBackend->LinkListWithData(
        LinkList => $HashRef,
        UserID   => 1,
    );

=cut

sub LinkListWithData {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(LinkList UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # check link list
    if ( ref $Param{LinkList} ne 'HASH' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'LinkList must be a hash reference!',
        );
        return;
    }

    for my $LinkType ( sort keys %{ $Param{LinkList} } ) {

        for my $Direction ( sort keys %{ $Param{LinkList}->{$LinkType} } ) {

            CONFIGITEMID:
            for my $ConfigItemID ( sort keys %{ $Param{LinkList}->{$LinkType}->{$Direction} } ) {

                # get last version data
                my $VersionData = $Self->{ConfigItemObject}->VersionGet(
                    ConfigItemID => $ConfigItemID,
                    XMLDataGet   => 0,
                    UserID       => $Param{UserID},
                );

                # remove id from hash if config item can not get
                if ( !$VersionData || ref $VersionData ne 'HASH' || !%{$VersionData} ) {
                    delete $Param{LinkList}->{$LinkType}->{$Direction}->{$ConfigItemID};
                    next CONFIGITEMID;
                }

                # add version data
                $Param{LinkList}->{$LinkType}->{$Direction}->{$ConfigItemID} = $VersionData;
            }
        }
    }

    return 1;
}

=item ObjectPermission()

checks read permission for a given object and UserID.

    $Permission = $LinkObject->ObjectPermission(
        Object  => 'ITSMConfigItem',
        Key     => 123,
        UserID  => 1,
    );

=cut

sub ObjectPermission {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Object Key UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get config of configitem zoom frontend module
    $Self->{Config}
        = $Self->{ConfigObject}->Get('ITSMConfigItem::Frontend::AgentITSMConfigItemZoom');

    # check for access rights
    my $Access = $Self->{ConfigItemObject}->Permission(
        Scope  => 'Item',
        ItemID => $Param{Key},
        UserID => $Param{UserID},
        Type   => $Self->{Config}->{Permission},
    );

    return $Access;
}

=item ObjectDescriptionGet()

return a hash of object descriptions

Return
    %Description = (
        Normal => "ConfigItem# 1234455",
        Long   => "ConfigItem# 1234455: The Config Item Title",
    );

    %Description = $LinkObject->ObjectDescriptionGet(
        Key     => 123,
        UserID  => 1,
    );

=cut

sub ObjectDescriptionGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Object Key UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # create description
    my %Description = (
        Normal => 'ConfigItem',
        Long   => 'ConfigItem',
    );

    return %Description if $Param{Mode} && $Param{Mode} eq 'Temporary';

    # get last version data
    my $VersionData = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $Param{Key},
        XMLDataGet   => 0,
        UserID       => $Param{UserID},
    );

    return if !$VersionData;
    return if ref $VersionData ne 'HASH';
    return if !%{$VersionData};

    # create description
    %Description = (
        Normal => "ConfigItem# $VersionData->{Number}",
        Long   => "ConfigItem# $VersionData->{Number}: $VersionData->{Name}",
    );

    return %Description;
}

=item ObjectSearch()

return a hash list of the search results

Return
    $SearchList = {
        NOTLINKED => {
            Source => {
                12  => $DataOfItem12,
                212 => $DataOfItem212,
                332 => $DataOfItem332,
            },
        },
    };

    $SearchList = $LinkObjectBackend->ObjectSearch(
        SubObject    => '25',        # (optional)
        SearchParams => $HashRef,    # (optional)
        UserID       => 1,
    );

=cut

sub ObjectSearch {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{UserID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need UserID!',
        );
        return;
    }

    # set default params
    $Param{SearchParams} ||= {};

    # set focus
    my %Search;
    for my $Element (qw(Number Name)) {
        if ( $Param{SearchParams}->{$Element} ) {
            $Search{$Element} = '*' . $Param{SearchParams}->{$Element} . '*';
        }
    }

    if ( !$Param{SubObject} ) {

        # get the config with the default subobjects
        my $DefaultSubobject = $Self->{ConfigObject}->Get('LinkObject::DefaultSubObject') || {};

        # extract default class name
        my $DefaultClass = $DefaultSubobject->{ITSMConfigItem} || '';

        # get class list
        my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
            Class => 'ITSM::ConfigItem::Class',
        );

        return if !$ClassList;
        return if ref $ClassList ne 'HASH';

        # lookup the class id
        my %ClassListReverse = reverse %{$ClassList};
        $Param{SubObject} = $ClassListReverse{$DefaultClass} || '';
    }

    return if !$Param{SubObject};

    # search the config items
    my $ConfigItemIDs = $Self->{ConfigItemObject}->ConfigItemSearchExtended(
        %{ $Param{SearchParams} },
        %Search,
        ClassIDs              => [ $Param{SubObject} ],
        PreviousVersionSearch => 0,
        UsingWildcards        => 1,
        OrderBy               => ['Number'],
        OrderByDirection      => ['Up'],
        Limit                 => 50,
        UserID                => $Param{UserID},
    );

    my %SearchList;
    CONFIGITEMID:
    for my $ConfigItemID ( @{$ConfigItemIDs} ) {

        # get last version data
        my $VersionData = $Self->{ConfigItemObject}->VersionGet(
            ConfigItemID => $ConfigItemID,
            XMLDataGet   => 0,
            UserID       => $Param{UserID},
        );

        next CONFIGITEMID if !$VersionData;
        next CONFIGITEMID if ref $VersionData ne 'HASH';
        next CONFIGITEMID if !%{$VersionData};

        # add version data
        $SearchList{NOTLINKED}->{Source}->{$ConfigItemID} = $VersionData;
    }

    return \%SearchList;
}

=item LinkAddPre()

link add pre event module

    $True = $LinkObject->LinkAddPre(
        Key          => 123,
        SourceObject => 'ITSMConfigItem',
        SourceKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

    or

    $True = $LinkObject->LinkAddPre(
        Key          => 123,
        TargetObject => 'ITSMConfigItem',
        TargetKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

=cut

sub LinkAddPre {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Type State UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # do not trigger event for temporary links
    return 1 if $Param{State} eq 'Temporary';

    return 1;
}

=item LinkAddPost()

link add pre event module

    $True = $LinkObject->LinkAddPost(
        Key          => 123,
        SourceObject => 'ITSMConfigItem',
        SourceKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

    or

    $True = $LinkObject->LinkAddPost(
        Key          => 123,
        TargetObject => 'ITSMConfigItem',
        TargetKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

=cut

sub LinkAddPost {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Type State UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # do not trigger event for temporary links
    return 1 if $Param{State} eq 'Temporary';

    # get information about linked object
    my $ID     = $Param{TargetKey}    || $Param{SourceKey};
    my $Object = $Param{TargetObject} || $Param{SourceObject};

    # recalculate the current incident state of this CI
    $Self->{ConfigItemObject}->CurInciStateRecalc(
        ConfigItemID => $Param{Key},
    );

    # trigger LinkAdd event
    $Self->{ConfigItemObject}->EventHandler(
        Event => 'LinkAdd',
        Data  => {
            ConfigItemID => $Param{Key},
            Comment      => $ID . '%%' . $Object,
        },
        UserID => $Param{UserID},
    );

    return 1;
}

=item LinkDeletePre()

link delete pre event module

    $True = $LinkObject->LinkDeletePre(
        Key          => 123,
        SourceObject => 'ITSMConfigItem',
        SourceKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

    or

    $True = $LinkObject->LinkDeletePre(
        Key          => 123,
        TargetObject => 'ITSMConfigItem',
        TargetKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

=cut

sub LinkDeletePre {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Type State UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # do not trigger event for temporary links
    return 1 if $Param{State} eq 'Temporary';

    return 1;
}

=item LinkDeletePost()

link delete post event module

    $True = $LinkObject->LinkDeletePost(
        Key          => 123,
        SourceObject => 'ITSMConfigItem',
        SourceKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

    or

    $True = $LinkObject->LinkDeletePost(
        Key          => 123,
        TargetObject => 'ITSMConfigItem',
        TargetKey    => 321,
        Type         => 'Normal',
        State        => 'Valid',
        UserID       => 1,
    );

=cut

sub LinkDeletePost {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Key Type State UserID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # do not trigger event for temporary links
    return 1 if $Param{State} eq 'Temporary';

    # get information about linked object
    my $ID     = $Param{TargetKey}    || $Param{SourceKey};
    my $Object = $Param{TargetObject} || $Param{SourceObject};

    # recalculate the current incident state of this CI
    $Self->{ConfigItemObject}->CurInciStateRecalc(
        ConfigItemID => $Param{Key},
    );

    # trigger LinkDelete event
    $Self->{ConfigItemObject}->EventHandler(
        Event => 'LinkDelete',
        Data  => {
            ConfigItemID => $Param{Key},
            Comment      => $ID . '%%' . $Object,
        },
        UserID => $Param{UserID},
    );

    return 1;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIEtlcm5lbC9TeXN0ZW0vU2VydmljZS9QcmVmZXJlbmNlc0RCLnBtIC0gc29tZSB1c2VyIGZ1bmN0aW9ucwojIENvcHlyaWdodCAoQykgMjAwMS0yMDE0IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojICRvcmlnaW46IGh0dHBzOi8vZ2l0aHViLmNvbS9PVFJTL290cnMvYmxvYi83MDRkNjg1NTNiM2IyOGYyYmM5NjFiMzJjNWEyOTMyMTcwZWZmZmJkL0tlcm5lbC9TeXN0ZW0vU2VydmljZS9QcmVmZXJlbmNlc0RCLnBtCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpTZXJ2aWNlOjpQcmVmZXJlbmNlc0RCOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIEtlcm5lbDo6U3lzdGVtOjpDYWNoZUludGVybmFsOwoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGNoZWNrIG5lZWRlZCBvYmplY3RzCiAgICBmb3IgKHF3KERCT2JqZWN0IENvbmZpZ09iamVjdCBMb2dPYmplY3QgRW5jb2RlT2JqZWN0IE1haW5PYmplY3QpKSB7CiAgICAgICAgJFNlbGYtPnskX30gPSAkUGFyYW17JF99IHx8IGRpZSAiR290IG5vICRfISI7CiAgICB9CgogICAgJFNlbGYtPntDYWNoZUludGVybmFsT2JqZWN0fSA9IEtlcm5lbDo6U3lzdGVtOjpDYWNoZUludGVybmFsLT5uZXcoCiAgICAgICAgJXskU2VsZn0sCiAgICAgICAgVHlwZSA9PiAnU2VydmljZVByZWZlcmVuY2VzREInLAogICAgICAgIFRUTCAgPT4gNjAgKiA2MCAqIDI0ICogMjAsCiAgICApOwoKICAgICMgcHJlZmVyZW5jZXMgdGFibGUgZGF0YQogICAgJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlfSAgICAgICAgICA9ICdzZXJ2aWNlX3ByZWZlcmVuY2VzJzsKICAgICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUtleX0gICAgICAgPSAncHJlZmVyZW5jZXNfa2V5JzsKICAgICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVZhbHVlfSAgICAgPSAncHJlZmVyZW5jZXNfdmFsdWUnOwogICAgJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlU2VydmljZUlEfSA9ICdzZXJ2aWNlX2lkJzsKCiAgICAjIGNyZWF0ZSBjYWNoZSBwcmVmaXgKICAgICRTZWxmLT57Q2FjaGVQcmVmaXh9ID0gJ1NlcnZpY2VQcmVmZXJlbmNlc0RCJwogICAgICAgIC4gJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlfQogICAgICAgIC4gJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlS2V5fQogICAgICAgIC4gJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlVmFsdWV9CiAgICAgICAgLiAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVTZXJ2aWNlSUR9OwoKICAgIHJldHVybiAkU2VsZjsKfQoKc3ViIFNlcnZpY2VQcmVmZXJlbmNlc1NldCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgKHF3KFNlcnZpY2VJRCBLZXkgVmFsdWUpKSB7CiAgICAgICAgaWYgKCAhZGVmaW5lZCAkUGFyYW17JF99ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkXyEiCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgogICAgIyBkZWxldGUgb2xkIGRhdGEKICAgIHJldHVybiBpZiAhJFNlbGYtPntEQk9iamVjdH0tPkRvKAogICAgICAgIFNRTCA9PiAiREVMRVRFIEZST00gJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlfSBXSEVSRSAiCiAgICAgICAgICAgIC4gIiRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVNlcnZpY2VJRH0gPSA/IEFORCAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVLZXl9ID0gPyIsCiAgICAgICAgQmluZCA9PiBbIFwkUGFyYW17U2VydmljZUlEfSwgXCRQYXJhbXtLZXl9IF0sCiAgICApOwoKICAgICMgaW5zZXJ0IG5ldyBkYXRhCiAgICByZXR1cm4gaWYgISRTZWxmLT57REJPYmplY3R9LT5EbygKICAgICAgICBTUUwgPT4gIklOU0VSVCBJTlRPICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZX0gKCRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVNlcnZpY2VJRH0sICIKICAgICAgICAgICAgLiAiICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUtleX0sICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVZhbHVlfSkgIgogICAgICAgICAgICAuICIgVkFMVUVTICg/LCA/LCA/KSIsCiAgICAgICAgQmluZCA9PiBbIFwkUGFyYW17U2VydmljZUlEfSwgXCRQYXJhbXtLZXl9LCBcJFBhcmFte1ZhbHVlfSBdLAogICAgKTsKCiAgICAjIGRlbGV0ZSBjYWNoZQogICAgJFNlbGYtPntDYWNoZUludGVybmFsT2JqZWN0fS0+RGVsZXRlKAogICAgICAgIEtleSA9PiAkU2VsZi0+e0NhY2hlUHJlZml4fSAuICRQYXJhbXtTZXJ2aWNlSUR9LAogICAgKTsKCiAgICByZXR1cm4gMTsKfQoKc3ViIFNlcnZpY2VQcmVmZXJlbmNlc0dldCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgKHF3KFNlcnZpY2VJRCkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JF99ICkgewogICAgICAgICAgICAkU2VsZi0+e0xvZ09iamVjdH0tPkxvZygKICAgICAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgICAgICBNZXNzYWdlICA9PiAiTmVlZCAkXyEiCiAgICAgICAgICAgICk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICB9CgojIC0tLQojIElUU00KIyAtLS0KIyAgICAjIGNoZWNrIGlmIHNlcnZpY2UgcHJlZmVyZW5jZXMgYXJlIGF2YWlsYWJsZQojICAgIHJldHVybiBpZiAhJFNlbGYtPntDb25maWdPYmplY3R9LT5HZXQoJ1NlcnZpY2VQcmVmZXJlbmNlcycpOwojCiMgICAgIyByZWFkIGNhY2hlCiMgICAgbXkgJENhY2hlID0gJFNlbGYtPntDYWNoZUludGVybmFsT2JqZWN0fS0+R2V0KAojICAgICAgICBLZXkgPT4gJFNlbGYtPntDYWNoZVByZWZpeH0gLiAkUGFyYW17U2VydmljZUlEfSwKIyAgICApOwojICAgIHJldHVybiAleyRDYWNoZX0gaWYgJENhY2hlOwojIC0tLQoKICAgICMgZ2V0IHByZWZlcmVuY2VzCiAgICByZXR1cm4gaWYgISRTZWxmLT57REJPYmplY3R9LT5QcmVwYXJlKAogICAgICAgIFNRTCA9PiAiU0VMRUNUICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUtleX0sICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVZhbHVlfSAiCiAgICAgICAgICAgIC4gIiBGUk9NICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZX0gV0hFUkUgJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlU2VydmljZUlEfSA9ID8iLAogICAgICAgIEJpbmQgPT4gWyBcJFBhcmFte1NlcnZpY2VJRH0gXSwKICAgICk7CgogICAgbXkgJURhdGE7CiAgICB3aGlsZSAoIG15IEBSb3cgPSAkU2VsZi0+e0RCT2JqZWN0fS0+RmV0Y2hyb3dBcnJheSgpICkgewogICAgICAgICREYXRheyAkUm93WzBdIH0gPSAkUm93WzFdOwogICAgfQoKICAgICMgc2V0IGNhY2hlCiAgICAkU2VsZi0+e0NhY2hlSW50ZXJuYWxPYmplY3R9LT5TZXQoCiAgICAgICAgS2V5ICAgPT4gJFNlbGYtPntDYWNoZVByZWZpeH0gLiAkUGFyYW17U2VydmljZUlEfSwKICAgICAgICBWYWx1ZSA9PiBcJURhdGEsCiAgICApOwoKICAgIHJldHVybiAlRGF0YTsKfQoKMTsK
# --
# Kernel/System/Stats/Dynamic/ITSMConfigItem.pm - all dynamic itsm config item stats functions
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::Stats::Dynamic::ITSMConfigItem;

use strict;
use warnings;

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(DBObject ConfigObject EncodeObject LogObject UserObject MainObject TimeObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );

    return $Self;
}

sub GetObjectName {
    my $Self = shift;

    return 'ITSMConfigItem';
}

sub GetObjectAttributes {
    my ( $Self, %Param ) = @_;

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # get deployment state list
    my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::DeploymentState',
    );

    # get incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::Core::IncidentState',
    );

    # get current time to fix bug#3830
    my $TimeStamp = $Self->{TimeObject}->CurrentTimestamp();
    my ($Date) = split /\s+/, $TimeStamp;
    my $Today = sprintf "%s 23:59:59", $Date;

    # create object attribute array
    my @ObjectAttributes = (
        {
            Name                => 'Class',
            UseAsXvalue         => 1,
            UseAsValueSeries    => 1,
            UseAsRestriction    => 1,
            Element             => 'ClassIDs',
            Block               => 'MultiSelectField',
            LanguageTranslation => 0,
            Values              => $ClassList,
        },
        {
            Name             => 'Deployment State',
            UseAsXvalue      => 1,
            UseAsValueSeries => 1,
            UseAsRestriction => 1,
            Element          => 'DeplStateIDs',
            Block            => 'MultiSelectField',
            Values           => $DeplStateList,
        },
        {
            Name             => 'Incident State',
            UseAsXvalue      => 1,
            UseAsValueSeries => 1,
            UseAsRestriction => 1,
            Element          => 'InciStateIDs',
            Block            => 'MultiSelectField',
            Values           => $InciStateList,
        },
        {
            Name             => 'Number',
            UseAsXvalue      => 0,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'Number',
            Block            => 'InputField',
        },
        {
            Name             => 'Name',
            UseAsXvalue      => 0,
            UseAsValueSeries => 0,
            UseAsRestriction => 1,
            Element          => 'Name',
            Block            => 'InputField',
        },
        {
            Name             => 'Create Time',
            UseAsXvalue      => 1,
            UseAsValueSeries => 1,
            UseAsRestriction => 1,
            Element          => 'CreateTime',
            TimePeriodFormat => 'DateInputFormat',
            Block            => 'Time',
            Values           => {
                TimeStart => 'ConfigItemCreateTimeNewerDate',
                TimeStop  => 'ConfigItemCreateTimeOlderDate',
            },
        },
        {
            Name             => 'Change Time',
            UseAsXvalue      => 1,
            UseAsValueSeries => 1,
            UseAsRestriction => 1,
            Element          => 'ChangeTime',
            TimePeriodFormat => 'DateInputFormat',
            Block            => 'Time',
            TimeStop         => $TimeStamp,
            Values           => {
                TimeStart => 'ConfigItemChangeTimeNewerDate',
                TimeStop  => 'ConfigItemChangeTimeOlderDate',
            },
        },
    );

    # add the xml data
    CLASSID:
    for my $ClassID ( sort keys %{$ClassList} ) {

        # get xml definition hash
        my $XMLDefinition = $Self->{ConfigItemObject}->DefinitionGet(
            ClassID => $ClassID,
        );

        next CLASSID if !$XMLDefinition->{DefinitionID};

        $Self->_XMLAttributeAdd(
            ObjectAttributes => \@ObjectAttributes,
            XMLDefinition    => $XMLDefinition->{DefinitionRef},
            Prefix           => 'XML::' . $ClassID,
            PrefixName       => $ClassList->{$ClassID},
        );
    }

    return @ObjectAttributes;
}

sub _XMLAttributeAdd {
    my ( $Self, %Param ) = @_;

    return if !$Param{ObjectAttributes};
    return if !$Param{XMLDefinition};
    return if ref $Param{XMLDefinition} ne 'ARRAY';

    if ( $Param{Prefix} ) {
        $Param{Prefix} .= '::';
    }
    if ( $Param{PrefixName} ) {
        $Param{PrefixName} .= '::';
    }

    $Param{Level}      ||= 0;
    $Param{Prefix}     ||= '';
    $Param{PrefixName} ||= '';

    ITEM:
    for my $Item ( @{ $Param{XMLDefinition} } ) {

        next ITEM if !$Item->{Searchable} && !$Item->{Sub};

        # create key and name
        my $Key  = $Param{Prefix} . $Item->{Key};
        my $Name = $Param{PrefixName} . $Item->{Name};

        # add attribute
        my $Attribute = $Self->{ConfigItemObject}->XMLStatsAttributeCreate(
            Key  => $Key,
            Item => $Item,
            Name => $Name,
        );

        next ITEM if !$Attribute;
        next ITEM if ref $Attribute ne 'ARRAY';
        next ITEM if !scalar @{$Attribute};

        # add attributes to object array
        push @{ $Param{ObjectAttributes} }, @{$Attribute};

        next ITEM if !$Item->{Sub};

        # start recursion, if "Sub" was found
        $Self->_XMLAttributeAdd(
            XMLDefinition => $Item->{Sub},
            Level         => $Param{Level} + 1,
            Prefix        => $Key,
            PrefixName    => $Name,
        );
    }

    return 1;
}

sub GetStatElement {
    my ( $Self, %Param ) = @_;

    # set limit
    $Param{Limit} = 1_000_000;

    # extract all xml param keys from the param hash
    my @XMLParams = grep { $_ =~ m{\A XML::}xms } keys %Param;

    if (@XMLParams) {
        return 'You must define a class in one axis.' if !$Param{ClassIDs};
        return 'You must define a class in one axis.' if ref $Param{ClassIDs} ne 'ARRAY';
    }

    my %XMLClassIDs;
    for my $ParamKey (@XMLParams) {

        # extract search values
        my $SearchValues = $Param{$ParamKey};

        # prepare param value
        if ( !ref $SearchValues ) {
            $SearchValues = [$SearchValues];
        }

        next if !@{$SearchValues};

        # split param key
        my ( $ClassID, $SearchKey ) = $ParamKey =~ m{ \A XML:: ( \d+ ) :: (.+) \z }xms;

        # prepare search key
        $SearchKey =~ s[ :: ]['}[%]{']xmsg;

        # Add class id to xml class id hash
        $XMLClassIDs{$ClassID} = 1;

        # create search hash
        my $SearchHash = {
            '[1]{\'Version\'}[1]{\'' . $SearchKey . '\'}[%]{\'Content\'}' => $SearchValues,
        };

        push @{ $Param{What} }, $SearchHash;
    }

    if (%XMLClassIDs) {
        my @Exists = grep { $XMLClassIDs{$_} } @{ $Param{ClassIDs} };

        return 0 if !@Exists;
    }

    # start config item extended search
    my $ConfigItemIDs = $Self->{ConfigItemObject}->ConfigItemSearchExtended(%Param);

    return scalar @{$ConfigItemIDs};
}

sub ExportWrapper {
    my ( $Self, %Param ) = @_;

    return \%Param;
}

sub ImportWrapper {
    my ( $Self, %Param ) = @_;

    return \%Param;
}

1;

# --
# ImportExportObjectITSMConfigItem.t - all import export tests for the ITSMConfigItem object backend
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars qw($Self);

use Kernel::System::Encode;
use Kernel::System::GeneralCatalog;
use Kernel::System::ImportExport;
use Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem;
use Kernel::System::ITSMConfigItem;
use Kernel::System::XML;

$Self->{EncodeObject}         = Kernel::System::Encode->new( %{$Self} );
$Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
$Self->{ImportExportObject}   = Kernel::System::ImportExport->new( %{$Self} );
$Self->{ObjectBackendObject}
    = Kernel::System::ImportExport::ObjectBackend::ITSMConfigItem->new( %{$Self} );
$Self->{ConfigItemObject} = Kernel::System::ITSMConfigItem->new( %{$Self} );
$Self->{XMLObject}        = Kernel::System::XML->new( %{$Self} );

# ------------------------------------------------------------ #
# make preparations
# ------------------------------------------------------------ #

# add some test templates for later checks
my @TemplateIDs;
for ( 1 .. 30 ) {

    # add a test template for later checks
    my $TemplateID = $Self->{ImportExportObject}->TemplateAdd(
        Object  => 'ITSMConfigItem',
        Format  => 'UnitTest' . int rand 1_000_000,
        Name    => 'UnitTest' . int rand 1_000_000,
        ValidID => 1,
        UserID  => 1,
    );

    push @TemplateIDs, $TemplateID;
}

# ------------------------------------------------------------ #
# ObjectList test 1 (check CSV item)
# ------------------------------------------------------------ #

# get object list
my $ObjectList1 = $Self->{ImportExportObject}->ObjectList();

# check object list
$Self->True(
    $ObjectList1 && ref $ObjectList1 eq 'HASH' && $ObjectList1->{ITSMConfigItem},
    "ObjectList() - ITSMConfigItem exists",
);

# ------------------------------------------------------------ #
# ObjectAttributesGet test 1 (check attribute hash)
# ------------------------------------------------------------ #

{

    # get object attributes
    my $ObjectAttributesGet1 = $Self->{ImportExportObject}->ObjectAttributesGet(
        TemplateID => $TemplateIDs[0],
        UserID     => 1,
    );

    # check object attribute reference
    $Self->True(
        $ObjectAttributesGet1 && ref $ObjectAttributesGet1 eq 'ARRAY',
        "ObjectAttributesGet() - check array reference",
    );

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # define the reference hash
    my $ObjectAttributesGet1Reference = [
        {
            Key   => 'ClassID',
            Name  => 'Class',
            Input => {
                Type         => 'Selection',
                Data         => $ClassList,
                Required     => 1,
                Translation  => 0,
                PossibleNone => 1,
            },
        },
        {
            Key   => 'CountMax',
            Name  => 'Maximum number of one element',
            Input => {
                Type         => 'Text',
                ValueDefault => '10',
                Required     => 1,
                Regex        => qr{ \A \d+ \z }xms,
                Translation  => 0,
                Size         => 5,
                MaxLength    => 5,
                DataType     => 'IntegerBiggerThanZero',
            },
        },
        {
            'Input' => {
                'Type' => 'Checkbox'
            },
            'Name' => 'Empty fields indicate that the current values are kept',
            'Key'  => 'EmptyFieldsLeaveTheOldValues',
        }
    ];

    $Self->IsDeeply(
        $ObjectAttributesGet1,
        $ObjectAttributesGet1Reference,
        "ObjectAttributesGet() - attributes of the row are identical",
    );
}

# ------------------------------------------------------------ #
# ObjectAttributesGet test 2 (check with non existing template)
# ------------------------------------------------------------ #

# get object attributes
my $ObjectAttributesGet2 = $Self->{ImportExportObject}->ObjectAttributesGet(
    TemplateID => $TemplateIDs[-1] + 1,
    UserID     => 1,
);

# check false return
$Self->False(
    $ObjectAttributesGet2,
    "ObjectAttributesGet() - check false return",
);

# ------------------------------------------------------------ #
# MappingObjectAttributesGet test 1 (check attribute hash)
# ------------------------------------------------------------ #

# get mapping object attributes
my $MappingObjectAttributesGet1 = $Self->{ImportExportObject}->MappingObjectAttributesGet(
    TemplateID => $TemplateIDs[0],
    UserID     => 1,
);

# check mapping object attribute reference
$Self->True(
    $MappingObjectAttributesGet1 && ref $MappingObjectAttributesGet1 eq 'ARRAY',
    "MappingObjectAttributesGet() - check array reference",
);

# ------------------------------------------------------------ #
# MappingObjectAttributesGet test 2 (check with non existing template)
# ------------------------------------------------------------ #

# get mapping object attributes
my $MappingObjectAttributesGet2 = $Self->{ImportExportObject}->MappingObjectAttributesGet(
    TemplateID => $TemplateIDs[-1] + 1,
    UserID     => 1,
);

# check false return
$Self->False(
    $MappingObjectAttributesGet2,
    "MappingObjectAttributesGet() - check false return",
);

# ------------------------------------------------------------ #
# make preparations to test ExportDataGet() and ImportDataSave()
# ------------------------------------------------------------ #

my $GeneralCatalogClass = 'UnitTest' . int rand 1_000_000;

# add a general catalog test list
for my $Name (qw(Test1 Test2 Test3 Test4)) {

    # add a new item
    my $ItemID = $Self->{GeneralCatalogObject}->ItemAdd(
        Class   => $GeneralCatalogClass,
        Name    => $Name,
        ValidID => 1,
        UserID  => 1,
    );

    # check item id
    if ( !$ItemID ) {

        $Self->True(
            0,
            "Can't add new general catalog item.",
        );
    }
}

# define the first test definition (all provided data types)
my @ConfigItemDefinitions;
$ConfigItemDefinitions[0] = " [
    {
        Key        => 'Customer1',
        Name       => 'Customer 1',
        Searchable => 1,
        Input      => {
            Type => 'Customer',
        },
    },
    {
        Key        => 'Date1',
        Name       => 'Date 1',
        Searchable => 1,
        Input      => {
            Type => 'Date',
        },
    },
    {
        Key        => 'DateTime1',
        Name       => 'Date Time 1',
        Searchable => 1,
        Input      => {
            Type => 'DateTime',
        },
    },
    {
        Key   => 'Dummy1',
        Name  => 'Dummy 1',
        Input => {
            Type => 'Dummy',
        },
    },
    {
        Key        => 'GeneralCatalog1',
        Name       => 'GeneralCatalog 1',
        Searchable => 1,
        Input      => {
            Type  => 'GeneralCatalog',
            Class => '$GeneralCatalogClass',
        },
    },
    {
        Key        => 'Integer1',
        Name       => 'Integer 1',
        Searchable => 1,
        Input      => {
            Type => 'Integer',
        },
    },
    {
        Key        => 'Text1',
        Name       => 'Text 1',
        Searchable => 1,
        Input      => {
            Type      => 'Text',
            Size      => 50,
            MaxLength => 50,
        },
    },
    {
        Key        => 'TextArea1',
        Name       => 'TextArea 1',
        Searchable => 1,
        Input      => {
            Type => 'TextArea',
        },
    },
] ";

# define the second test definition (sub data types)
$ConfigItemDefinitions[1] = " [
    {
        Key        => 'Main1',
        Name       => 'Main 1',
        Searchable => 1,
        Input      => {
            Type      => 'Text',
            Size      => 50,
            MaxLength => 50,
        },
        CountMax => 10,
        Sub => [
            {
                Key        => 'Main1Sub1',
                Name       => 'Main 1 Sub 1',
                Searchable => 1,
                Input      => {
                    Type      => 'Text',
                    Size      => 50,
                    MaxLength => 50,
                },
                CountMax => 10,
                Sub => [
                    {
                        Key        => 'Main1Sub1SubSub1',
                        Name       => 'Main 1 Sub 1 SubSub 1',
                        Searchable => 1,
                        Input      => {
                            Type      => 'Text',
                            Size      => 50,
                            MaxLength => 50,
                        },
                        CountMax => 10,
                    },
                    {
                        Key        => 'Main1Sub1SubSub2',
                        Name       => 'Main 1 Sub 1 SubSub 2',
                        Searchable => 1,
                        Input      => {
                            Type => 'TextArea',
                        },
                        CountMax => 10,
                    },
                ],
            },
            {
                Key        => 'Main1Sub2',
                Name       => 'Main 1 Sub 2',
                Searchable => 1,
                Input      => {
                    Type => 'TextArea',
                },
                CountMax => 10,
            },
        ],
    },
    {
        Key        => 'Main2',
        Name       => 'Main 2',
        Searchable => 1,
        Input      => {
            Type => 'TextArea',
        },
        CountMax => 10,
        Sub => [
            {
                Key        => 'Main2Sub1',
                Name       => 'Main 2 Sub 1',
                Searchable => 1,
                Input      => {
                    Type      => 'Text',
                    Size      => 50,
                    MaxLength => 50,
                },
                CountMax => 10,
            },
            {
                Key        => 'Main2Sub2',
                Name       => 'Main 2 Sub 2',
                Searchable => 1,
                Input      => {
                    Type => 'TextArea',
                },
                CountMax => 10,
            },
        ],
    },
] ";

# add the test classes
my @ConfigItemClassIDs;
my @ConfigItemDefinitionIDs;
for my $Definition (@ConfigItemDefinitions) {

    # generate a random name
    my $ClassName = 'UnitTest' . int rand 1_000_000;

    # add an unittest config item class
    my $ClassID = $Self->{GeneralCatalogObject}->ItemAdd(
        Class   => 'ITSM::ConfigItem::Class',
        Name    => $ClassName,
        ValidID => 1,
        UserID  => 1,
    );

    # check class id
    if ( !$ClassID ) {

        $Self->True(
            0,
            "Can't add new config item class.",
        );
    }

    push @ConfigItemClassIDs, $ClassID;

    # add a definition to the class
    my $DefinitionID = $Self->{ConfigItemObject}->DefinitionAdd(
        ClassID    => $ClassID,
        Definition => $Definition,
        UserID     => 1,
    );

    # check definition id
    if ( !$DefinitionID ) {

        $Self->True(
            0,
            "Can't add new config item definition.",
        );
    }

    push @ConfigItemDefinitionIDs, $DefinitionID;
}

# create some random numbers
my @ConfigItemNumbers;
for ( 1 .. 10 ) {
    push @ConfigItemNumbers, int rand 1_000_000;
}

# get deployment state list
my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::DeploymentState',
);
my %DeplStateListReverse = reverse %{$DeplStateList};

# get incident state list
my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::Core::IncidentState',
);
my %InciStateListReverse = reverse %{$InciStateList};

# get general catalog test list
my $GeneralCatalogList = $Self->{GeneralCatalogObject}->ItemList(
    Class => $GeneralCatalogClass,
);
my %GeneralCatalogListReverse = reverse %{$GeneralCatalogList};

# define the test config items
my @ConfigItems = (

    # config item for all provided data types
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[0],
            ClassID => $ConfigItemClassIDs[0],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 1 Version 1',
                DefinitionID => $ConfigItemDefinitionIDs[0],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Customer1 => [
                                    undef,
                                    {
                                        Content => 'UnitTest',
                                    },
                                ],
                                Date1 => [
                                    undef,
                                    {
                                        Content => '2008-02-01',
                                    },
                                ],
                                DateTime1 => [
                                    undef,
                                    {
                                        Content => '2008-02-01 03:59',
                                    },
                                ],
                                GeneralCatalog1 => [
                                    undef,
                                    {
                                        Content => $GeneralCatalogListReverse{Test1},
                                    },
                                ],
                                Integer1 => [
                                    undef,
                                    {
                                        Content => '1',
                                    },
                                ],
                                Text1 => [
                                    undef,
                                    {
                                        Content => 'Test Text Test',
                                    },
                                ],
                                TextArea1 => [
                                    undef,
                                    {
                                        Content => "Test\nText Array\nTest",
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },

    # a second config item for all provided data types
    # (duplicate name of first version for search checks)
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[1],
            ClassID => $ConfigItemClassIDs[0],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 1 Version 1',    # duplicate name for tests
                DefinitionID => $ConfigItemDefinitionIDs[0],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Customer1 => [
                                    undef,
                                    {
                                        Content => 'UnitTest',
                                    },
                                ],
                                Date1 => [
                                    undef,
                                    {
                                        Content => '2008-02-01',
                                    },
                                ],
                                DateTime1 => [
                                    undef,
                                    {
                                        Content => '2008-02-01 03:59',
                                    },
                                ],
                                GeneralCatalog1 => [
                                    undef,
                                    {
                                        Content => $GeneralCatalogListReverse{Test1},
                                    },
                                ],
                                Integer1 => [
                                    undef,
                                    {
                                        Content => '1',
                                    },
                                ],
                                Text1 => [
                                    undef,
                                    {
                                        Content => 'Test Text Test',
                                    },
                                ],
                                TextArea1 => [
                                    undef,
                                    {
                                        Content => "Test\nText Array\nTest",
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
            {
                Name         => 'UnitTest - ConfigItem 2 Version 2',
                DefinitionID => $ConfigItemDefinitionIDs[0],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Customer1 => [
                                    undef,
                                    {
                                        Content => 'UnitTest2',
                                    },
                                ],
                                Date1 => [
                                    undef,
                                    {
                                        Content => '2008-02-02',
                                    },
                                ],
                                DateTime1 => [
                                    undef,
                                    {
                                        Content => '2008-02-02 03:59',
                                    },
                                ],
                                GeneralCatalog1 => [
                                    undef,
                                    {
                                        Content => $GeneralCatalogListReverse{Test2},
                                    },
                                ],
                                Integer1 => [
                                    undef,
                                    {
                                        Content => '2',
                                    },
                                ],
                                Text1 => [
                                    undef,
                                    {
                                        Content => 'Test Text Test2',
                                    },
                                ],
                                TextArea1 => [
                                    undef,
                                    {
                                        Content => "Test2\nText Array\nTest 2",
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },

    # config item for sub element tests
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[2],
            ClassID => $ConfigItemClassIDs[1],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 3 Version 1',
                DefinitionID => $ConfigItemDefinitionIDs[1],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Main1 => [
                                    undef,
                                    {
                                        Content   => 'Main1 (1)',
                                        Main1Sub1 => [
                                            undef,
                                            {
                                                Content          => 'Main1 (1) Sub1 (1)',
                                                Main1Sub1SubSub1 => [
                                                    undef,
                                                    {
                                                        Content => 'Main1 (1) Sub1 (1) SubSub1 (1)',
                                                    },
                                                    {
                                                        Content => 'Main1 (1) Sub1 (1) SubSub1 (2)',
                                                    },
                                                    {
                                                        Content => 'Main1 (1) Sub1 (1) SubSub1 (3)',
                                                    },
                                                ],
                                                Main1Sub1SubSub2 => [
                                                    undef,
                                                    {
                                                        Content => 'Main1 (1) Sub1 (1) SubSub2 (1)',
                                                    },
                                                ],
                                            },
                                            {
                                                Content          => 'Main1 (1) Sub1 (2)',
                                                Main1Sub1SubSub1 => [
                                                    undef,
                                                    {
                                                        Content => 'Main1 (1) Sub1 (2) SubSub1 (1)',
                                                    },
                                                ],
                                                Main1Sub1SubSub2 => [
                                                    undef,
                                                    {
                                                        Content => 'Main1 (1) Sub1 (2) SubSub2 (1)',
                                                    },
                                                    {
                                                        Content => 'Main1 (1) Sub1 (2) SubSub2 (2)',
                                                    },
                                                ],
                                            },
                                        ],
                                        Main1Sub2 => [
                                            undef,
                                            {
                                                Content => 'Main1 (1) Sub2 (1)',
                                            },
                                            {
                                                Content => 'Main1 (1) Sub2 (2)',
                                            },
                                        ],
                                    },
                                ],
                                Main2 => [
                                    undef,
                                    {
                                        Content   => 'Main2 (1)',
                                        Main2Sub1 => [
                                            undef,
                                            {
                                                Content => 'Main2 (1) Sub1 (1)',
                                            },
                                        ],
                                        Main2Sub2 => [
                                            undef,
                                            {
                                                'Content' => 'Main2 (1) Sub2 (1)',
                                            },
                                            {
                                                'Content' => 'Main2 (1) Sub2 (2)',
                                            },
                                        ],
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },

    # config item for sub element tests
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[3],
            ClassID => $ConfigItemClassIDs[1],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 4 Version 1',
                DefinitionID => $ConfigItemDefinitionIDs[1],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Main1 => [
                                    undef,
                                    {
                                        Content   => '',
                                        Main1Sub1 => [
                                            undef,
                                            {
                                                Content          => '',
                                                Main1Sub1SubSub1 => [
                                                    undef,
                                                    {
                                                        Content => '',
                                                    },
                                                ],
                                                Main1Sub1SubSub2 => [
                                                    undef,
                                                    {
                                                        Content => '',
                                                    },
                                                ],
                                            },
                                        ],
                                        Main1Sub2 => [
                                            undef,
                                            {
                                                Content => '',
                                            },
                                        ],
                                    },
                                ],
                                Main2 => [
                                    undef,
                                    {
                                        Content   => '',
                                        Main2Sub1 => [
                                            undef,
                                            {
                                                Content => '',
                                            },
                                        ],
                                        Main2Sub2 => [
                                            undef,
                                            {
                                                Content => '',
                                            },
                                        ],
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },

    # config item for special character tests
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[4],
            ClassID => $ConfigItemClassIDs[1],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 5 Version 1',
                DefinitionID => $ConfigItemDefinitionIDs[1],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Main1 => [
                                    undef,
                                    {
                                        Content   => '"";;::..--__##',
                                        Main1Sub1 => [
                                            undef,
                                            {
                                                Content => 'Test;:_°^!"§$%&/()=?´`*+Test',
                                                Main1Sub1SubSub1 => [
                                                    undef,
                                                    {
                                                        Content => '><@~\'}{[]\\',
                                                    },
                                                ],
                                                Main1Sub1SubSub2 => [
                                                    undef,
                                                    {
                                                        Content => '><@~\'}{[]\\',
                                                    },
                                                ],
                                            },
                                        ],
                                        Main1Sub2 => [
                                            undef,
                                            {
                                                Content => 'Test;:_°^!"§$%&/()=?´`*+Test',
                                            },
                                        ],
                                    },
                                ],
                                Main2 => [
                                    undef,
                                    {
                                        Content   => '"";;::..--__##',
                                        Main2Sub1 => [
                                            undef,
                                            {
                                                Content => 'Test Test',
                                            },
                                        ],
                                        Main2Sub2 => [
                                            undef,
                                            {
                                                Content => "Test\nTest\tTest",
                                            },
                                        ],
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },

    # config item for UTF-8 tests
    {
        ConfigItem => {
            Number  => $ConfigItemNumbers[5],
            ClassID => $ConfigItemClassIDs[1],
            UserID  => 1,
        },
        Versions => [
            {
                Name         => 'UnitTest - ConfigItem 6 Version 1',
                DefinitionID => $ConfigItemDefinitionIDs[1],
                DeplStateID  => $DeplStateListReverse{Production},
                InciStateID  => $InciStateListReverse{Operational},
                XMLData      => [
                    undef,
                    {
                        Version => [
                            undef,
                            {
                                Main1 => [
                                    undef,
                                    {
                                        Content   => 'ↂ ⅻ ⅛',
                                        Main1Sub1 => [
                                            undef,
                                            {
                                                Content          => '☄ ↮ ↹ →',
                                                Main1Sub1SubSub1 => [
                                                    undef,
                                                    {
                                                        Content => '₤ ₡ ₩ ₯ ₵',
                                                    },
                                                ],
                                                Main1Sub1SubSub2 => [
                                                    undef,
                                                    {
                                                        Content => '♊ ♈ ♉ ♊ ♋ ♍ ♑',
                                                    },
                                                ],
                                            },
                                        ],
                                        Main1Sub2 => [
                                            undef,
                                            {
                                                Content => '✈ ❤ ☮',
                                            },
                                        ],
                                    },
                                ],
                                Main2 => [
                                    undef,
                                    {
                                        Content   => 'Պ Մ Հ',
                                        Main2Sub1 => [
                                            undef,
                                            {
                                                Content => '® ©',
                                            },
                                        ],
                                        Main2Sub2 => [
                                            undef,
                                            {
                                                Content => 'か げ を',
                                            },
                                        ],
                                    },
                                ],
                            },
                        ],
                    },
                ],
                UserID => 1,
            },
        ],
    },
);

# add the test config items
my @ConfigItemIDs;
for my $ConfigItem (@ConfigItems) {

    # add a config item
    my $ConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
        %{ $ConfigItem->{ConfigItem} },
    );

    # check config item id
    if ( !$ConfigItemID ) {

        $Self->True(
            0,
            "Can't add new config item.",
        );
    }

    push @ConfigItemIDs, $ConfigItemID;

    # add the versions
    for my $Version ( @{ $ConfigItem->{Versions} } ) {

        # add a version
        my $VersionID = $Self->{ConfigItemObject}->VersionAdd(
            %{$Version},
            ConfigItemID => $ConfigItemID,
        );

        # check version id
        if ( !$VersionID ) {

            $Self->True(
                0,
                "Can't add new version.",
            );
        }
    }
}

# ------------------------------------------------------------ #
# define general ExportDataGet tests
# ------------------------------------------------------------ #

my @ExportDataTests = (

    # ImportDataGet doesn't contains all data (check required attributes)
    {
        SourceExportData => {
            ExportDataGet => {
                UserID => 1,
            },
        },
    },

    # ImportDataGet doesn't contains all data (check required attributes)
    {
        SourceExportData => {
            ExportDataGet => {
                TemplateID => $TemplateIDs[1],
            },
        },
    },

    # no existing template id is given (check return false)
    {
        SourceExportData => {
            ExportDataGet => {
                TemplateID => $TemplateIDs[-1] + 1,
                UserID     => 1,
            },
        },
    },

    # no class id is given (check return false)
    {
        SourceExportData => {
            ExportDataGet => {
                TemplateID => $TemplateIDs[2],
                UserID     => 1,
            },
        },
    },

    # invalid class id is given (check return false)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[-1] + 1,
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[2],
                UserID     => 1,
            },
        },
    },

    # mapping list is empty (check return false)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[3],
                UserID     => 1,
            },
        },
    },

    # all required values are given (number search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[0],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (name search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Name => 'UnitTest - ConfigItem 1 Version 1',
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (case insensitive name search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Name => 'unittest - configitem 1 version 1',
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (name and number search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[0],
                Name   => 'UnitTest - ConfigItem 1 Version 1',
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (deployment state search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                DeplStateIDs => $DeplStateListReverse{Production},
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
            [ $ConfigItemNumbers[1] ],
        ],
    },

    # all required values are given (incident state search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                InciStateIDs => $InciStateListReverse{Operational},
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
            [ $ConfigItemNumbers[1] ],
        ],
    },

    # all required values are given (combined search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Number       => $ConfigItemNumbers[0],
                Name         => 'UnitTest - ConfigItem 1 Version 1',
                DeplStateIDs => $DeplStateListReverse{Production},
                InciStateIDs => $InciStateListReverse{Operational},
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (XML data search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Date1           => '2008-02-01',
                TextArea1       => "Test\nText Array\nTest",
                Customer1       => 'UnitTest',
                Text1           => 'Test Text Test',
                DateTime1       => '2008-02-01 03:59',
                Integer1        => '1',
                GeneralCatalog1 => $GeneralCatalogListReverse{Test1},
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (combined all search check)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
            ],
            SearchData => {
                Number          => $ConfigItemNumbers[0],
                Name            => 'UnitTest - ConfigItem 1 Version 1',
                DeplStateIDs    => $DeplStateListReverse{Production},
                InciStateIDs    => $InciStateListReverse{Operational},
                Date1           => '2008-02-01',
                TextArea1       => "Test\nText Array\nTest",
                Customer1       => 'UnitTest',
                Text1           => 'Test Text Test',
                DateTime1       => '2008-02-01 03:59',
                Integer1        => '1',
                GeneralCatalog1 => $GeneralCatalogListReverse{Test1},
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[5],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [ $ConfigItemNumbers[0] ],
        ],
    },

    # all required values are given (check the returned array)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'Dummy1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[0],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[6],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[0],
                'UnitTest - ConfigItem 1 Version 1',
                'Production',
                'Operational',
                'UnitTest',
                '2008-02-01',
                '2008-02-01 03:59',
                undef,
                'Test1',
                '1',
                'Test Text Test',
                "Test\nText Array\nTest",
            ],
        ],
    },

    # all required values are given (double element checks)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'Dummy1::1',
                },
                {
                    Key => 'Dummy1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[0],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[6],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[0],
                $ConfigItemNumbers[0],
                'UnitTest - ConfigItem 1 Version 1',
                'UnitTest - ConfigItem 1 Version 1',
                'Production',
                'Production',
                'Operational',
                'Operational',
                'UnitTest',
                'UnitTest',
                '2008-02-01',
                '2008-02-01',
                '2008-02-01 03:59',
                '2008-02-01 03:59',
                undef,
                undef,
                'Test1',
                'Test1',
                '1',
                '1',
                'Test Text Test',
                'Test Text Test',
                "Test\nText Array\nTest",
                "Test\nText Array\nTest",
            ],
        ],
    },

    # all required values are given (sub element checks)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::2',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::2',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[2],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[7],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[2],
                'UnitTest - ConfigItem 3 Version 1',
                'Production',
                'Operational',
                'Main1 (1)',
                'Main1 (1) Sub1 (1)',
                'Main1 (1) Sub1 (1) SubSub1 (1)',
                'Main1 (1) Sub1 (1) SubSub1 (2)',
                'Main1 (1) Sub1 (1) SubSub1 (3)',
                'Main1 (1) Sub1 (1) SubSub2 (1)',
                'Main1 (1) Sub1 (2)',
                'Main1 (1) Sub1 (2) SubSub1 (1)',
                'Main1 (1) Sub1 (2) SubSub2 (1)',
                'Main1 (1) Sub1 (2) SubSub2 (2)',
                'Main1 (1) Sub2 (1)',
                'Main1 (1) Sub2 (2)',
                'Main2 (1)',
                'Main2 (1) Sub1 (1)',
                'Main2 (1) Sub2 (1)',
                'Main2 (1) Sub2 (2)',
            ],
        ],
    },

    # all required values are given (sub element checks with undef values)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::4',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::3',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub2::3',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::2',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::2',
                },
                {
                    Key => 'Main2::1::Main2Sub2::3',
                },
                {
                    Key => 'Main2::2',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[2],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[7],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[2],
                'UnitTest - ConfigItem 3 Version 1',
                'Production',
                'Operational',
                'Main1 (1)',
                'Main1 (1) Sub1 (1)',
                'Main1 (1) Sub1 (1) SubSub1 (1)',
                'Main1 (1) Sub1 (1) SubSub1 (2)',
                'Main1 (1) Sub1 (1) SubSub1 (3)',
                undef,
                'Main1 (1) Sub1 (1) SubSub2 (1)',
                undef,
                'Main1 (1) Sub1 (2)',
                'Main1 (1) Sub1 (2) SubSub1 (1)',
                undef,
                'Main1 (1) Sub1 (2) SubSub2 (1)',
                'Main1 (1) Sub1 (2) SubSub2 (2)',
                undef,
                'Main1 (1) Sub2 (1)',
                'Main1 (1) Sub2 (2)',
                undef,
                'Main2 (1)',
                'Main2 (1) Sub1 (1)',
                undef,
                'Main2 (1) Sub2 (1)',
                'Main2 (1) Sub2 (2)',
                undef,
                undef,
            ],
        ],
    },

    # all required values are given (sub element checks with undef values and empty strings)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::4',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::3',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub2::3',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::2',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::2',
                },
                {
                    Key => 'Main2::1::Main2Sub2::3',
                },
                {
                    Key => 'Main2::2',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[3],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[7],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[3],
                'UnitTest - ConfigItem 4 Version 1',
                'Production',
                'Operational',
                '',
                '',
                '',
                undef,
                undef,
                undef,
                '',
                undef,
                undef,
                undef,
                undef,
                undef,
                undef,
                undef,
                '',
                undef,
                undef,
                '',
                '',
                undef,
                '',
                undef,
                undef,
                undef,
            ],
        ],
    },

    # all required values are given (special character checks)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[4],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[8],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[4],
                'UnitTest - ConfigItem 5 Version 1',
                'Production',
                'Operational',
                '"";;::..--__##',
                'Test;:_°^!"§$%&/()=?´`*+Test',
                '><@~\'}{[]\\',
                '><@~\'}{[]\\',
                'Test;:_°^!"§$%&/()=?´`*+Test',
                '"";;::..--__##',
                'Test Test',
                "Test\nTest\tTest",
            ],
        ],
    },

    # all required values are given (UTF-8 checks)
    {
        SourceExportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key => 'Number',
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
            ],
            SearchData => {
                Number => $ConfigItemNumbers[5],
            },
            ExportDataGet => {
                TemplateID => $TemplateIDs[9],
                UserID     => 1,
            },
        },
        ReferenceExportData => [
            [
                $ConfigItemNumbers[5],
                'UnitTest - ConfigItem 6 Version 1',
                'Production',
                'Operational',
                'ↂ ⅻ ⅛',
                '☄ ↮ ↹ →',
                '₤ ₡ ₩ ₯ ₵',
                '♊ ♈ ♉ ♊ ♋ ♍ ♑',
                '✈ ❤ ☮',
                'Պ Մ Հ',
                '® ©',
                'か げ を',
            ],
        ],
    },
);

# ------------------------------------------------------------ #
# run general ExportDataGet tests
# ------------------------------------------------------------ #

my $ExportTestCount = 1;
TEST:
for my $Test (@ExportDataTests) {

    # check SourceExportData attribute
    if ( !$Test->{SourceExportData} || ref $Test->{SourceExportData} ne 'HASH' ) {

        $Self->True(
            0,
            "ExportTest $ExportTestCount: No SourceExportData found for this test."
        );

        next TEST;
    }

    # set the object data
    if (
        $Test->{SourceExportData}->{ObjectData}
        && ref $Test->{SourceExportData}->{ObjectData} eq 'HASH'
        && $Test->{SourceExportData}->{ExportDataGet}->{TemplateID}
        )
    {

        # save object data
        $Self->{ImportExportObject}->ObjectDataSave(
            TemplateID => $Test->{SourceExportData}->{ExportDataGet}->{TemplateID},
            ObjectData => $Test->{SourceExportData}->{ObjectData},
            UserID     => 1,
        );
    }

    # set the mapping object data
    if (
        $Test->{SourceExportData}->{MappingObjectData}
        && ref $Test->{SourceExportData}->{MappingObjectData} eq 'ARRAY'
        && $Test->{SourceExportData}->{ExportDataGet}->{TemplateID}
        )
    {

        # delete all existing mapping data
        $Self->{ImportExportObject}->MappingDelete(
            TemplateID => $Test->{SourceExportData}->{ExportDataGet}->{TemplateID},
            UserID     => 1,
        );

        # add the mapping object rows
        MAPPINGOBJECTDATA:
        for my $MappingObjectData ( @{ $Test->{SourceExportData}->{MappingObjectData} } ) {

            # add a new mapping row
            my $MappingID = $Self->{ImportExportObject}->MappingAdd(
                TemplateID => $Test->{SourceExportData}->{ExportDataGet}->{TemplateID},
                UserID     => 1,
            );

            # add the mapping object data
            $Self->{ImportExportObject}->MappingObjectDataSave(
                MappingID         => $MappingID,
                MappingObjectData => $MappingObjectData,
                UserID            => 1,
            );
        }
    }

    # add the search data
    if (
        $Test->{SourceExportData}->{SearchData}
        && ref $Test->{SourceExportData}->{SearchData} eq 'HASH'
        && $Test->{SourceExportData}->{ExportDataGet}->{TemplateID}
        )
    {

        # save search data
        $Self->{ImportExportObject}->SearchDataSave(
            TemplateID => $Test->{SourceExportData}->{ExportDataGet}->{TemplateID},
            SearchData => $Test->{SourceExportData}->{SearchData},
            UserID     => 1,
        );
    }

    # get export data
    my $ExportData = $Self->{ObjectBackendObject}->ExportDataGet(
        %{ $Test->{SourceExportData}->{ExportDataGet} },
    );

    if ( !$Test->{ReferenceExportData} ) {

        $Self->False(
            $ExportData,
            "ExportTest $ExportTestCount: ExportDataGet() - return false",
        );

        next TEST;
    }

    if ( ref $ExportData ne 'ARRAY' ) {

        # check array reference
        $Self->True(
            0,
            "ExportTest $ExportTestCount: ExportDataGet() - return value is an array reference",
        );

        next TEST;
    }

    # check number of rows
    $Self->Is(
        scalar @{$ExportData},
        scalar @{ $Test->{ReferenceExportData} },
        "ExportTest $ExportTestCount: ExportDataGet() - correct number of rows",
    );

    # check content of export data
    my $CounterRow = 0;
    ROW:
    for my $ExportRow ( @{$ExportData} ) {

        # extract reference row
        my $ReferenceRow = $Test->{ReferenceExportData}->[$CounterRow];

        if ( ref $ExportRow ne 'ARRAY' || ref $ReferenceRow ne 'ARRAY' ) {

            # check array reference
            $Self->True(
                0,
                "ExportTest $ExportTestCount: ExportDataGet() - export row and reference row matched",
            );

            next TEST;
        }

        # check number of columns
        $Self->Is(
            scalar @{$ExportRow},
            scalar @{$ReferenceRow},
            "ExportTest $ExportTestCount: ExportDataGet() - correct number of columns",
        );

        my $CounterColumn = 0;
        for my $Cell ( @{$ExportRow} ) {

            # set content if values are undef
            if ( !defined $Cell ) {
                $Cell = 'UNDEF-unittest';
            }
            if ( !defined $ReferenceRow->[$CounterColumn] ) {
                $ReferenceRow->[$CounterColumn] = 'UNDEF-unittest';
            }

            # check cell data
            $Self->Is(
                $Cell,
                $ReferenceRow->[$CounterColumn],
                "ExportTest $ExportTestCount: ExportDataGet() ",
            );

            $CounterColumn++;
        }

        $CounterRow++;
    }
}
continue {
    $ExportTestCount++;
}

# ------------------------------------------------------------ #
# define general ImportDataSave tests
# ------------------------------------------------------------ #

my @ImportDataTests = (

    # ImportDataSave doesn't contains all data (check required attributes)
    {
        SourceImportData => {
            ImportDataSave => {
                ImportDataRow => [],
                UserID        => 1,
            },
        },
    },

    # ImportDataSave doesn't contains all data (check required attributes)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID => $TemplateIDs[20],
                UserID     => 1,
            },
        },
    },

    # ImportDataSave doesn't contains all data (check required attributes)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID    => $TemplateIDs[20],
                ImportDataRow => [],
            },
        },
    },

    # import data row must be an array reference (check return false)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID    => $TemplateIDs[20],
                ImportDataRow => '',
                UserID        => 1,
            },
        },
    },

    # import data row must be an array reference (check return false)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID    => $TemplateIDs[20],
                ImportDataRow => {},
                UserID        => 1,
            },
        },
    },

    # no existing template id is given (check return false)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID    => $TemplateIDs[-1] + 1,
                ImportDataRow => ['Dummy'],
                UserID        => 1,
            },
        },
    },

    # no class id is given (check return false)
    {
        SourceImportData => {
            ImportDataSave => {
                TemplateID    => $TemplateIDs[21],
                ImportDataRow => ['Dummy'],
                UserID        => 1,
            },
        },
    },

    # invalid class id is given (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[-1] + 1,
            },
            ImportDataSave => {
                TemplateID    => $TemplateIDs[22],
                ImportDataRow => ['Dummy'],
                UserID        => 1,
            },
        },
    },

    # mapping list is empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => ['Dummy'],
                UserID        => 1,
            },
        },
    },

    # more than one identifier with the same name (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '123', '321' ],
                UserID        => 1,
            },
        },
    },

    # identifier is empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [''],
                UserID        => 1,
            },
        },
    },

    # identifier is undef (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [undef],
                UserID        => 1,
            },
        },
    },

    # both identifiers are empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '', '' ],
                UserID        => 1,
            },
        },
    },

    # both identifiers are undef (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ undef, undef ],
                UserID        => 1,
            },
        },
    },

    # one identifiers is empty, one is undef (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '', undef ],
                UserID        => 1,
            },
        },
    },

    # one of the identifiers is empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '123', '' ],
                UserID        => 1,
            },
        },
    },

    # one of the identifiers is undef (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '123', undef ],
                UserID        => 1,
            },
        },
    },

    # one of the identifiers is empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ '', '123' ],
                UserID        => 1,
            },
        },
    },

    # one of the identifiers is empty (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[23],
                ImportDataRow => [ undef, '123' ],
                UserID        => 1,
            },
        },
    },

    # TODO Add some identifier tests

    # empty name is given (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[24],
                ImportDataRow => [ '', 'Production', 'Operational' ],
                UserID        => 1,
            },
        },
    },

    # invalid deployment state is given (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[24],
                ImportDataRow => [ 'UnitTest - Importtest 1', 'Dummy', 'Operational' ],
                UserID        => 1,
            },
        },
    },

    # invalid incident state is given (check return false)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[24],
                ImportDataRow => [ 'UnitTest - Importtest 2', 'Production', 'Dummy' ],
                UserID        => 1,
            },
        },
    },

    # all required values are given (a NEW config item must be created)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 3',
                    'Production',
                    'Operational',
                    'UnitTest',
                    '2008-06-05',
                    '2008-08-05 04:50',
                    'Test3',
                    '3',
                    'Test3 Text3 Test3',
                    "Test3\nTextArray3\nTest3",
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 1,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 3',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Customer1::1'       => 'UnitTest',
                'Date1::1'           => '2008-06-05',
                'DateTime1::1'       => '2008-08-05 04:50',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test3},
                'Integer1::1'        => '3',
                'Text1::1'           => 'Test3 Text3 Test3',
                'TextArea1::1'       => "Test3\nTextArray3\nTest3",
            },
        },
    },

    # all required values are given (a second NEW config item must be created)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 4',
                    'Production',
                    'Operational',
                    'UnitTest',
                    '2008-09-05',
                    '2008-12-05 04:50',
                    'Test4',
                    '4',
                    'Test4 Text4 Test4',
                    "Test4\nTextArray4\nTest4",
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 1,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 4',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Customer1::1'       => 'UnitTest',
                'Date1::1'           => '2008-09-05',
                'DateTime1::1'       => '2008-12-05 04:50',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test4},
                'Integer1::1'        => '4',
                'Text1::1'           => 'Test4 Text4 Test4',
                'TextArea1::1'       => "Test4\nTextArray4\nTest4",
            },
        },
    },

    # all required values are given (a new version must be added to first test config item)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[26],
                ImportDataRow => [
                    $ConfigItemNumbers[0],
                    'UnitTest - ConfigItem 1 Version 2',
                    'Pilot',
                    'Incident',
                    'UnitTest',
                    '2008-02-02',
                    '2008-02-02 03:59',
                    'Test2',
                    '2',
                    'Test Text UPDATE1 Test',
                    "Test\nText Array UPDATE1\nTest",
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 2,
            LastVersion   => {
                Name                 => 'UnitTest - ConfigItem 1 Version 2',
                DeplState            => 'Pilot',
                InciState            => 'Incident',
                'Customer1::1'       => 'UnitTest',
                'Date1::1'           => '2008-02-02',
                'DateTime1::1'       => '2008-02-02 03:59',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test2},
                'Integer1::1'        => '2',
                'Text1::1'           => 'Test Text UPDATE1 Test',
                'TextArea1::1'       => "Test\nText Array UPDATE1\nTest",
            },
        },
    },

    # all required values are given (a new version must be added to first test config item again)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Customer1::1',
                },
                {
                    Key => 'Date1::1',
                },
                {
                    Key => 'DateTime1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
                {
                    Key => 'Integer1::1',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'TextArea1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[27],
                ImportDataRow => [
                    $ConfigItemNumbers[0],
                    'UnitTest - ConfigItem 1 Version 3',
                    'Repair',
                    'Operational',
                    'UnitTest',
                    '2008-02-03',
                    '2008-02-03 03:59',
                    'Test3',
                    '3',
                    'Test Text UPDATE2 Test',
                    "Test\nText Array UPDATE2\nTest",
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 3,
            LastVersion   => {
                Name                 => 'UnitTest - ConfigItem 1 Version 3',
                DeplState            => 'Repair',
                InciState            => 'Operational',
                'Customer1::1'       => 'UnitTest',
                'Date1::1'           => '2008-02-03',
                'DateTime1::1'       => '2008-02-03 03:59',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test3},
                'Integer1::1'        => '3',
                'Text1::1'           => 'Test Text UPDATE2 Test',
                'TextArea1::1'       => "Test\nText Array UPDATE2\nTest",
            },
        },
    },

    # all required values are given (a new version must be added to third test config item)
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::2',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::2',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[27],
                ImportDataRow => [
                    $ConfigItemNumbers[2],
                    'UnitTest - ConfigItem 3 Version 2',
                    'Production',
                    'Operational',
                    'Main1 (1)',
                    'Main1 (1) Main1Sub1 (1)',
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (1)',
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (2)',
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (3)',
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub2 (1)',
                    'Main1 (1) Main1Sub1 (2)',
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub1 (1)',
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (1)',
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (2)',
                    'Main1 (1) Main1Sub2 (1)',
                    'Main1 (1) Main1Sub2 (2)',
                    'Main2 (1)',
                    'Main2 (1) Main2Sub1 (1)',
                    'Main2 (1) Main2Sub2 (1)',
                    'Main2 (1) Main2Sub2 (2)',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 2,
            LastVersion   => {
                Name                     => 'UnitTest - ConfigItem 3 Version 2',
                DeplState                => 'Production',
                InciState                => 'Operational',
                'Main1::1'               => 'Main1 (1)',
                'Main1::1::Main1Sub1::1' => 'Main1 (1) Main1Sub1 (1)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (1)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (2)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (3)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub2 (1)',
                'Main1::1::Main1Sub1::2' => 'Main1 (1) Main1Sub1 (2)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub1 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (2)',
                'Main1::1::Main1Sub2::1' => 'Main1 (1) Main1Sub2 (1)',
                'Main1::1::Main1Sub2::2' => 'Main1 (1) Main1Sub2 (2)',
                'Main2::1'               => 'Main2 (1)',
                'Main2::1::Main2Sub1::1' => 'Main2 (1) Main2Sub1 (1)',
                'Main2::1::Main2Sub2::1' => 'Main2 (1) Main2Sub2 (1)',
                'Main2::1::Main2Sub2::2' => 'Main2 (1) Main2Sub2 (2)',
            },
        },
    },

    # all required values are given (special character checks)
    # In 'UnitTest - ConfigItem 3 Version 2' 16 Attributes were imported,
    # so there will be 8 lingering attributes.
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[27],
                ImportDataRow => [
                    $ConfigItemNumbers[2],
                    'UnitTest - ConfigItem 3 Version 3',
                    'Production',
                    'Operational',
                    '"";;::..--__##',
                    'Test;:_°^!"§$%&/()=?´`*+Test',
                    '><@~\'}{[]\\',
                    '><@~\'}{[]\\',
                    'Test;:_°^!"§$%&/()=?´`*+Test',
                    '"";;::..--__##',
                    'Test Test',
                    "Test\nTest\tTest",
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 3,
            LastVersion   => {
                Name                     => 'UnitTest - ConfigItem 3 Version 3',
                DeplState                => 'Production',
                InciState                => 'Operational',
                'Main1::1'               => '"";;::..--__##',
                'Main1::1::Main1Sub1::1' => 'Test;:_°^!"§$%&/()=?´`*+Test',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1' => '><@~\'}{[]\\',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1' => '><@~\'}{[]\\',
                'Main1::1::Main1Sub2::1'                      => 'Test;:_°^!"§$%&/()=?´`*+Test',
                'Main2::1'                                    => '"";;::..--__##',
                'Main2::1::Main2Sub1::1'                      => 'Test Test',
                'Main2::1::Main2Sub2::1'                      => "Test\nTest\tTest",

                # lingering from 'UnitTest - ConfigItem 3 Version 2',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (2)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (3)',
                'Main1::1::Main1Sub1::2' => 'Main1 (1) Main1Sub1 (2)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub1 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (2)',
                'Main1::1::Main1Sub2::2' => 'Main1 (1) Main1Sub2 (2)',
                'Main2::1::Main2Sub2::2' => 'Main2 (1) Main2Sub2 (2)',
            },
        },
    },

    # all required values are given (UTF-8 checks)
    # In 'UnitTest - ConfigItem 3 Version 2' 16 Attributes were imported,
    # so there will be 8 lingering attributes.
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[1],
            },
            MappingObjectData => [
                {
                    Key        => 'Number',
                    Identifier => 1,
                },
                {
                    Key => 'Name',
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Main1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1',
                },
                {
                    Key => 'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1',
                },
                {
                    Key => 'Main1::1::Main1Sub2::1',
                },
                {
                    Key => 'Main2::1',
                },
                {
                    Key => 'Main2::1::Main2Sub1::1',
                },
                {
                    Key => 'Main2::1::Main2Sub2::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[27],
                ImportDataRow => [
                    $ConfigItemNumbers[2],
                    'UnitTest - ConfigItem 3 Version 4',
                    'Production',
                    'Operational',
                    'Ϋ δ λ',
                    'π χ Ϙ',
                    'Ϻ ϱ Ϯ',
                    'ɯ ʓ ʠ',
                    'ʬ ʯ',
                    'й ф щ',
                    'њ ё',
                    'Ѭ Ѧ',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 4,
            LastVersion   => {
                Name                     => 'UnitTest - ConfigItem 3 Version 4',
                DeplState                => 'Production',
                InciState                => 'Operational',
                'Main1::1'               => 'Ϋ δ λ',
                'Main1::1::Main1Sub1::1' => 'π χ Ϙ',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::1' => 'Ϻ ϱ Ϯ',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub2::1' => 'ɯ ʓ ʠ',
                'Main1::1::Main1Sub2::1'                      => 'ʬ ʯ',
                'Main2::1'                                    => 'й ф щ',
                'Main2::1::Main2Sub1::1'                      => 'њ ё',
                'Main2::1::Main2Sub2::1'                      => 'Ѭ Ѧ',

                # lingering from 'UnitTest - ConfigItem 3 Version 2',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::2' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (2)',
                'Main1::1::Main1Sub1::1::Main1Sub1SubSub1::3' =>
                    'Main1 (1) Main1Sub1 (1) Main1Sub1SubSub1 (3)',
                'Main1::1::Main1Sub1::2' => 'Main1 (1) Main1Sub1 (2)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub1::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub1 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::1' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (1)',
                'Main1::1::Main1Sub1::2::Main1Sub1SubSub2::2' =>
                    'Main1 (1) Main1Sub1 (2) Main1Sub1SubSub2 (2)',
                'Main1::1::Main1Sub2::2' => 'Main1 (1) Main1Sub2 (2)',
                'Main2::1::Main2Sub2::2' => 'Main2 (1) Main2Sub2 (2)',
            },
        },
    },

    # a simple import for testing the overriding behavior of empty values
    {
        SourceImportData => {
            ObjectData => {
                ClassID => $ConfigItemClassIDs[0],
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    'Importtest 5 for behavior of empty values',
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 1,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => 'Importtest 5 for behavior of empty values',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an empty value for Text1, with EmptyFieldsLeaveTheOldValues turned on
    # no new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '',
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 1,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => 'Importtest 5 for behavior of empty values',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import undef for Text1, with EmptyFieldsLeaveTheOldValues turned on
    # no new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    undef,
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 1,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => 'Importtest 5 for behavior of empty values',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an empty value for Text1, with EmptyFieldsLeaveTheOldValues turned off
    # a new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => '',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '',
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 2,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => '',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import a single space value for Text1, with EmptyFieldsLeaveTheOldValues turned on
    # a new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => '',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    ' ',
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 3,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => ' ',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import the string '0' value for Text1, with EmptyFieldsLeaveTheOldValues turned on
    # a new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => '',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '0',
                    'Test1',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 4,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => '0',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an empty value for GeneralCatalog1, with EmptyFieldsLeaveTheOldValues turned on
    # no new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '',
                    '',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 4,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => '0',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an invalid value for GeneralCatalog1, with EmptyFieldsLeaveTheOldValues turned on
    # the import should fail
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '',
                    'non-existent general catalog entry',
                ],
                UserID => 1,
            },
        },
    },

    # import an invalid value for GeneralCatalog1, with EmptyFieldsLeaveTheOldValues turned off
    # the import should fail
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => '',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'Operational',
                    '',
                    'non-existent general catalog entry',
                ],
                UserID => 1,
            },
        },
    },

    # import an empty value for DeplState, with EmptyFieldsLeaveTheOldValues turned on
    # no new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    '',
                    'Operational',
                    '',
                    '',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 4,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => '0',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an invalid value for DeplState, with EmptyFieldsLeaveTheOldValues turned on
    # an error should be generated
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'invalid deployment state',
                    'Operational',
                    '',
                    '',
                ],
                UserID => 1,
            },
        },
    },

    # import an empty value for InciState, with EmptyFieldsLeaveTheOldValues turned on
    # no new version should be created
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    '',
                    '',
                    '',
                ],
                UserID => 1,
            },
        },
        ReferenceImportData => {
            VersionNumber => 4,
            LastVersion   => {
                Name                 => 'UnitTest - Importtest 5',
                DeplState            => 'Production',
                InciState            => 'Operational',
                'Text1::1'           => '0',
                'GeneralCatalog1::1' => $GeneralCatalogListReverse{Test1},
            },
        },
    },

    # import an invalid value for InciState, with EmptyFieldsLeaveTheOldValues turned on
    # an error should be generated
    {
        SourceImportData => {
            ObjectData => {
                ClassID                      => $ConfigItemClassIDs[0],
                EmptyFieldsLeaveTheOldValues => 'on',
            },
            MappingObjectData => [
                {
                    Key        => 'Name',
                    Identifier => 1,
                },
                {
                    Key => 'DeplState',
                },
                {
                    Key => 'InciState',
                },
                {
                    Key => 'Text1::1',
                },
                {
                    Key => 'GeneralCatalog1::1',
                },
            ],
            ImportDataSave => {
                TemplateID    => $TemplateIDs[25],
                ImportDataRow => [
                    'UnitTest - Importtest 5',
                    'Production',
                    'invalid incident state',
                    '',
                    '',
                ],
                UserID => 1,
            },
        },
    },
);

# ------------------------------------------------------------ #
# run general ExportDataGet tests
# ------------------------------------------------------------ #

my $ImportTestCount = 1;
TEST:
for my $Test (@ImportDataTests) {

    # check SourceImportData attribute
    if ( !$Test->{SourceImportData} || ref $Test->{SourceImportData} ne 'HASH' ) {

        $Self->True(
            0,
            "ImportTest $ImportTestCount: No SourceImportData found for this test."
        );

        next TEST;
    }

    # set the object data
    if (
        $Test->{SourceImportData}->{ObjectData}
        && ref $Test->{SourceImportData}->{ObjectData} eq 'HASH'
        && $Test->{SourceImportData}->{ImportDataSave}->{TemplateID}
        )
    {

        # save object data
        $Self->{ImportExportObject}->ObjectDataSave(
            TemplateID => $Test->{SourceImportData}->{ImportDataSave}->{TemplateID},
            ObjectData => $Test->{SourceImportData}->{ObjectData},
            UserID     => 1,
        );
    }

    # set the mapping object data
    if (
        $Test->{SourceImportData}->{MappingObjectData}
        && ref $Test->{SourceImportData}->{MappingObjectData} eq 'ARRAY'
        && $Test->{SourceImportData}->{ImportDataSave}->{TemplateID}
        )
    {

        # delete all existing mapping data
        $Self->{ImportExportObject}->MappingDelete(
            TemplateID => $Test->{SourceImportData}->{ImportDataSave}->{TemplateID},
            UserID     => 1,
        );

        # add the mapping object rows
        MAPPINGOBJECTDATA:
        for my $MappingObjectData ( @{ $Test->{SourceImportData}->{MappingObjectData} } ) {

            # add a new mapping row
            my $MappingID = $Self->{ImportExportObject}->MappingAdd(
                TemplateID => $Test->{SourceImportData}->{ImportDataSave}->{TemplateID},
                UserID     => 1,
            );

            # add the mapping object data
            $Self->{ImportExportObject}->MappingObjectDataSave(
                MappingID         => $MappingID,
                MappingObjectData => $MappingObjectData,
                UserID            => 1,
            );
        }
    }

    # import data save
    my ( $ConfigItemID, $RetCode ) = $Self->{ObjectBackendObject}->ImportDataSave(
        %{ $Test->{SourceImportData}->{ImportDataSave} },
        Counter => $ImportTestCount,
    );

    if ( !$Test->{ReferenceImportData} ) {

        $Self->False(
            $ConfigItemID,
            "ImportTest $ImportTestCount: ImportDataSave() - return no ConfigItemID"
        );
        $Self->False(
            $RetCode,
            "ImportTest $ImportTestCount: ImportDataSave() - return no RetCode"
        );

        next TEST;
    }

    $Self->True(
        $ConfigItemID,
        "ImportTest $ImportTestCount: ImportDataSave() - return ConfigItemID"
    );
    $Self->True(
        $RetCode,
        "ImportTest $ImportTestCount: ImportDataSave() - return RetCode"
    );

    # get the version list
    my $VersionList = $Self->{ConfigItemObject}->VersionList(
        ConfigItemID => $ConfigItemID,
    );

    # check number of versions
    $Self->Is(
        scalar @{$VersionList},
        $Test->{ReferenceImportData}->{VersionNumber} || 0,
        "ImportTest $ImportTestCount: ImportDataSave() - correct number of versions",
    );

    # get the last version
    my $VersionData = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $ConfigItemID,
        XMLDataGet   => 1,
    );

    # translate xmldata in a 2d hash
    my %XMLHash = $Self->{XMLObject}->XMLHash2D(
        XMLHash => $VersionData->{XMLData},
    );

    # clean the xml hash
    KEY:
    for my $Key ( sort keys %XMLHash ) {

        next KEY if $Key =~ m{ \{'Content'\} \z }xms;

        delete $XMLHash{$Key};
    }

    # check general elements
    ELEMENT:
    for my $Element (qw(Number Name DeplState InciState)) {

        next ELEMENT if !exists $Test->{ReferenceImportData}->{LastVersion}->{$Element};

        # set content if values are undef
        if ( !defined $Test->{ReferenceImportData}->{LastVersion}->{$Element} ) {
            $Test->{ReferenceImportData}->{LastVersion}->{$Element} = 'UNDEF-unittest';
        }
        if ( !defined $Test->{ReferenceImportData}->{LastVersion}->{$Element} ) {
            $Test->{ReferenceImportData}->{LastVersion}->{$Element} = 'UNDEF-unittest';
        }

        # check element
        $Self->Is(
            $VersionData->{$Element},
            $Test->{ReferenceImportData}->{LastVersion}->{$Element},
            "ImportTest $ImportTestCount: ImportDataSave() $Element is identical",
        );

        delete $Test->{ReferenceImportData}->{LastVersion}->{$Element};
    }

    # check number of XML elements
    $Self->Is(
        scalar keys %XMLHash,
        scalar keys %{ $Test->{ReferenceImportData}->{LastVersion} },
        "ImportTest $ImportTestCount: ImportDataSave() - correct number of XML elements",
    );

    # check XML elements
    ELEMENT:
    for my $Key ( sort keys %{ $Test->{ReferenceImportData}->{LastVersion} } ) {

        # duplicate key
        my $XMLKey = $Key;

        # prepare key
        my $Counter = 0;
        while ( $XMLKey =~ m{ :: }xms ) {

            if ( $Counter % 2 ) {
                $XMLKey =~ s{ :: }{]\{'}xms;
            }
            else {
                $XMLKey =~ s{ :: }{'\}[}xms;
            }

            $Counter++;
        }

        next ELEMENT if !exists $XMLHash{ '[1]{\'Version\'}[1]{\'' . $XMLKey . ']{\'Content\'}' };

        # set content if values are undef
        if ( !defined $XMLHash{ '[1]{\'Version\'}[1]{\'' . $XMLKey . ']{\'Content\'}' } ) {
            $XMLHash{ '[1]{\'Version\'}[1]{\'' . $XMLKey . ']{\'Content\'}' } = 'UNDEF-unittest';
        }
        if ( !defined $Test->{ReferenceImportData}->{LastVersion}->{$Key} ) {
            $Test->{ReferenceImportData}->{LastVersion}->{$Key} = 'UNDEF-unittest';
        }

        # check XML element
        $Self->Is(
            $XMLHash{ '[1]{\'Version\'}[1]{\'' . $XMLKey . ']{\'Content\'}' },
            $Test->{ReferenceImportData}->{LastVersion}->{$Key},
            "ImportTest $ImportTestCount: ImportDataSave() $Key is identical",
        );
    }
}
continue {
    $ImportTestCount++;
}

# ------------------------------------------------------------ #
# clean the system
# ------------------------------------------------------------ #

# delete the test templates
$Self->{ImportExportObject}->TemplateDelete(
    TemplateID => \@TemplateIDs,
    UserID     => 1,
);

# get actual class list
my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::Class',
);

# set unittest classes invalid
ITEMID:
for my $ItemID ( sort keys %{$ClassList} ) {

    next ITEMID if $ClassList->{$ItemID} !~ m{ \A UnitTest }xms;

    # update item
    $Self->{GeneralCatalogObject}->ItemUpdate(
        ItemID  => $ItemID,
        Name    => $ClassList->{$ItemID},
        ValidID => 2,
        UserID  => 1,
    );
}

# delete the test config items
for my $ConfigItemID (@ConfigItemIDs) {
    $Self->{ConfigItemObject}->ConfigItemDelete(
        ConfigItemID => $ConfigItemID,
        UserID       => 1,
    );
}

1;

# --
# ITSMConfigItem.t - config item tests
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars qw($Self);

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;
use Kernel::System::LinkObject;
use Kernel::System::User;

$Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
$Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );
$Self->{LinkObject}           = Kernel::System::LinkObject->new( %{$Self} );
$Self->{UserObject}           = Kernel::System::User->new( %{$Self} );

# ------------------------------------------------------------ #
# make preparations
# ------------------------------------------------------------ #

# perform ConfigItemCount to fill the empty fields
$Self->{ConfigItemObject}->ConfigItemCount();

# create needed users
my @UserIDs;
{

    # disable email checks to create new user
    my $CheckEmailAddressesOrg = $Self->{ConfigObject}->Get('CheckEmailAddresses') || 1;
    $Self->{ConfigObject}->Set(
        Key   => 'CheckEmailAddresses',
        Value => 0,
    );

    for my $Counter ( 1 .. 3 ) {

        # create new users for the tests
        my $UserID = $Self->{UserObject}->UserAdd(
            UserFirstname => 'ITSMConfigItem' . $Counter,
            UserLastname  => 'UnitTest',
            UserLogin     => 'UnitTest-ITSMConfigItem-' . $Counter . int rand 1_000_000,
            UserEmail     => 'UnitTest-ITSMConfigItem-' . $Counter . '@localhost',
            ValidID       => 1,
            ChangeUserID  => 1,
        );

        push @UserIDs, $UserID;
    }

    # restore original email check param
    $Self->{ConfigObject}->Set(
        Key   => 'CheckEmailAddresses',
        Value => $CheckEmailAddressesOrg,
    );
}

my $GeneralCatalogClass = 'UnitTest' . int rand 1_000_000;

# add a general catalog test list
for my $Name (qw(Test1 Test2 Test3 Test4)) {

    # add a new item
    my $ItemID = $Self->{GeneralCatalogObject}->ItemAdd(
        Class   => $GeneralCatalogClass,
        Name    => $Name,
        ValidID => 1,
        UserID  => 1,
    );

    # check item id
    if ( !$ItemID ) {

        $Self->True(
            0,
            "Can't add new general catalog item.",
        );
    }
}

# define the first test definition (all provided data types)
my @ConfigItemDefinitions;
$ConfigItemDefinitions[0] = " [
    {
        Key        => 'Customer1',
        Name       => 'Customer 1',
        Searchable => 1,
        Input      => {
            Type => 'Customer',
        },
    },
    {
        Key        => 'Date1',
        Name       => 'Date 1',
        Searchable => 1,
        Input      => {
            Type => 'Date',
        },
    },
    {
        Key        => 'DateTime1',
        Name       => 'Date Time 1',
        Searchable => 1,
        Input      => {
            Type => 'DateTime',
        },
    },
    {
        Key   => 'Dummy1',
        Name  => 'Dummy 1',
        Input => {
            Type => 'Dummy',
        },
    },
    {
        Key        => 'GeneralCatalog1',
        Name       => 'GeneralCatalog 1',
        Searchable => 1,
        Input      => {
            Type  => 'GeneralCatalog',
            Class => '$GeneralCatalogClass',
        },
    },
    {
        Key        => 'Integer1',
        Name       => 'Integer 1',
        Searchable => 1,
        Input      => {
            Type => 'Integer',
        },
    },
    {
        Key        => 'Text1',
        Name       => 'Text 1',
        Searchable => 1,
        Input      => {
            Type      => 'Text',
            Size      => 50,
            MaxLength => 50,
        },
    },
    {
        Key        => 'TextArea1',
        Name       => 'TextArea 1',
        Searchable => 1,
        Input      => {
            Type => 'TextArea',
        },
    },
] ";

# define the second test definition (sub data types)
$ConfigItemDefinitions[1] = " [
    {
        Key        => 'Main1',
        Name       => 'Main 1',
        Searchable => 1,
        Input      => {
            Type      => 'Text',
            Size      => 50,
            MaxLength => 50,
        },
        CountMax => 10,
        Sub => [
            {
                Key        => 'Main1Sub1',
                Name       => 'Main 1 Sub 1',
                Searchable => 1,
                Input      => {
                    Type      => 'Text',
                    Size      => 50,
                    MaxLength => 50,
                },
                CountMax => 10,
                Sub => [
                    {
                        Key        => 'Main1Sub1SubSub1',
                        Name       => 'Main 1 Sub 1 SubSub 1',
                        Searchable => 1,
                        Input      => {
                            Type      => 'Text',
                            Size      => 50,
                            MaxLength => 50,
                        },
                        CountMax => 10,
                    },
                    {
                        Key        => 'Main1Sub1SubSub2',
                        Name       => 'Main 1 Sub 1 SubSub 2',
                        Searchable => 1,
                        Input      => {
                            Type => 'TextArea',
                        },
                        CountMax => 10,
                    },
                ],
            },
            {
                Key        => 'Main1Sub2',
                Name       => 'Main 1 Sub 2',
                Searchable => 1,
                Input      => {
                    Type => 'TextArea',
                },
                CountMax => 10,
            },
        ],
    },
    {
        Key        => 'Main2',
        Name       => 'Main 2',
        Searchable => 1,
        Input      => {
            Type => 'TextArea',
        },
        CountMax => 10,
        Sub => [
            {
                Key        => 'Main2Sub1',
                Name       => 'Main 2 Sub 1',
                Searchable => 1,
                Input      => {
                    Type      => 'Text',
                    Size      => 50,
                    MaxLength => 50,
                },
                CountMax => 10,
            },
            {
                Key        => 'Main2Sub2',
                Name       => 'Main 2 Sub 2',
                Searchable => 1,
                Input      => {
                    Type => 'TextArea',
                },
                CountMax => 10,
            },
        ],
    },
] ";

# define the third test definition (especially for search tests with XMLData)
$ConfigItemDefinitions[2] = " [
    {
        Key        => 'Customer1',
        Name       => 'Customer 1',
        Searchable => 1,
        Input      => {
            Type => 'Customer',
        },
    },
    {
        Key        => 'Date1',
        Name       => 'Date 1',
        Searchable => 1,
        Input      => {
            Type => 'Date',
        },
    },
    {
        Key        => 'DateTime1',
        Name       => 'Date Time 1',
        Searchable => 1,
        Input      => {
            Type => 'DateTime',
        },
    },
] ";

# define the fourth test definition (only for search tests)
$ConfigItemDefinitions[3] = " [
    {
        Key        => 'Customer1',
        Name       => 'Customer 1',
        Searchable => 1,
        Input      => {
            Type => 'Customer',
        },
    },
] ";

# add the test classes
my @ConfigItemClassIDs;
my @ConfigItemClasses;
my @ConfigItemDefinitionIDs;
for my $Definition (@ConfigItemDefinitions) {

    # generate a random name
    my $ClassName = 'UnitTest' . int rand 1_000_000;

    # add an unittest config item class
    my $ClassID = $Self->{GeneralCatalogObject}->ItemAdd(
        Class   => 'ITSM::ConfigItem::Class',
        Name    => $ClassName,
        ValidID => 1,
        UserID  => 1,
    );

    # check class id
    if ( !$ClassID ) {

        $Self->True(
            0,
            "Can't add new config item class.",
        );
    }

    push @ConfigItemClassIDs, $ClassID;
    push @ConfigItemClasses,  $ClassName;

    # add a definition to the class
    my $DefinitionID = $Self->{ConfigItemObject}->DefinitionAdd(
        ClassID    => $ClassID,
        Definition => $Definition,
        UserID     => 1,
    );

    # check definition id
    if ( !$DefinitionID ) {

        $Self->True(
            0,
            "Can't add new config item definition.",
        );
    }

    push @ConfigItemDefinitionIDs, $DefinitionID;
}

# test DefinitionList for those simple cases
my $Counter = 0;
for my $ClassID (@ConfigItemClassIDs) {
    my $DefinitionListRef = $Self->{ConfigItemObject}->DefinitionList(
        ClassID => $ClassID,
    );

    # expect a single definition per config item class
    $Self->Is(
        scalar @{$DefinitionListRef},
        1,
        "DefinitionList() for class id $ClassID: got a single result",
    );

    # expect the remembered definition id in the first definition
    $Self->Is(
        $DefinitionListRef->[0]->{DefinitionID},
        $ConfigItemDefinitionIDs[$Counter],
        "DefinitionList() for class id $ClassID: got expected definition id",
    );
}
continue {
    $Counter++;
}

# create some random numbers
my @ConfigItemNumbers;
for ( 1 .. 100 ) {
    push @ConfigItemNumbers, int rand 1_000_000;
}

# get class list
my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::Class',
);
my %ClassListReverse = reverse %{$ClassList};

# get deployment state list
my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::DeploymentState',
);
my %DeplStateListReverse = reverse %{$DeplStateList};

# get incident state list
my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::Core::IncidentState',
);
my %InciStateListReverse = reverse %{$InciStateList};

# get general catalog test list
my $GeneralCatalogList = $Self->{GeneralCatalogObject}->ItemList(
    Class => $GeneralCatalogClass,
);
my %GeneralCatalogListReverse = reverse %{$GeneralCatalogList};

# ------------------------------------------------------------ #
# define general config item tests
# ------------------------------------------------------------ #

my $ConfigItemTests = [

    # ConfigItemAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                UserID => 1,
            },
        },
    },

    # ConfigItemAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                ClassID => $ConfigItemClassIDs[0],
            },
        },
    },

    # invalid class id is given (check return false)
    {
        SourceData => {
            ConfigItemAdd => {
                ClassID => $ConfigItemClassIDs[-1] + 1,
                UserID  => 1,
            },
        },
    },

    # all required config item values are given (check returned config item values)
    {
        SourceData => {
            ConfigItemAdd => {
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
        },
        ReferenceData => {
            ConfigItemGet => {
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # all required config item values are given (check number attribute)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[0],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => $UserIDs[1],
            },
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[0],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => $UserIDs[1],
                ChangeBy         => $UserIDs[1],
            },
        },
    },

    # config item with this number already exists (check return false)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[0],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
        },
    },

    # VersionAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[1],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[1],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # VersionAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[2],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name        => 'UnitTest - Class 1 ConfigItem 2 Version 1',
                    DeplStateID => $DeplStateListReverse{Production},
                    InciStateID => $InciStateListReverse{Operational},
                    UserID      => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[2],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # VersionAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[3],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 3 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[3],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # VersionAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[4],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 4 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[4],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # VersionAdd doesn't contains all data (check required attributes)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[5],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => $UserIDs[1],
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 5 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[5],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => $UserIDs[1],
                ChangeBy         => $UserIDs[1],
            },
        },
    },

    # invalid deployment state id is given (check returned values)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[6],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 6 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => 9999999,
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[6],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # invalid incident state id is given (check returned values)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[7],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 7 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => 9999999,
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[7],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                LastVersionID    => undef,
                CurDeplStateID   => undef,
                CurDeplState     => undef,
                CurDeplStateType => undef,
                CurInciStateID   => undef,
                CurInciState     => undef,
                CurInciStateType => undef,
                CreateBy         => 1,
                ChangeBy         => 1,
            },
        },
    },

    # all required values are given (check returned values)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[8],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 8 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[8],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Operational},
                CurInciState     => 'Operational',
                CurInciStateType => 'operational',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[8],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Class 1 ConfigItem 8 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
        },
    },

    # all required values are given (general check with two versions)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[9],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 9 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 9 Version 2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => $UserIDs[1],
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[9],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Operational},
                CurInciState     => 'Operational',
                CurInciStateType => 'operational',
                CreateBy         => 1,
                ChangeBy         => $UserIDs[1],
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[9],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Class 1 ConfigItem 9 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => 1,
                },
                {
                    Number           => $ConfigItemNumbers[9],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Class 1 ConfigItem 9 Version 2',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => $UserIDs[1],
                },
            ],
        },
    },

    # all required values are given (check the calculation of deployment and incident state)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[10],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 10 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Planned},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Class 1 ConfigItem 10 Version 2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[10],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Maintenance},
                CurDeplState     => 'Maintenance',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[10],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Class 1 ConfigItem 10 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Planned},
                    DeplState        => 'Planned',
                    DeplStateType    => 'preproductive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
                {
                    Number           => $ConfigItemNumbers[10],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Class 1 ConfigItem 10 Version 2',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Maintenance},
                    DeplState        => 'Maintenance',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
        },
    },

    # add config item only for later search tests
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[50],
                ClassID => $ConfigItemClassIDs[2],
                UserID  => $UserIDs[2],
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 3 ConfigItem 1 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[2],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => $UserIDs[2],
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[50],
                ClassID          => $ConfigItemClassIDs[2],
                Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => $UserIDs[2],
                ChangeBy         => $UserIDs[2],
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[50],
                    ClassID          => $ConfigItemClassIDs[2],
                    Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                    Name             => 'UnitTest - Class 3 ConfigItem 1 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[2],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => $UserIDs[2],
                },
            ],
        },
    },

    # add config item only for later search tests
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[51],
                ClassID => $ConfigItemClassIDs[2],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 3 ConfigItem 2 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[2],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Class 3 ConfigItem 2 Version 2',
                    DefinitionID => $ConfigItemDefinitionIDs[2],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => $UserIDs[1],
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[51],
                ClassID          => $ConfigItemClassIDs[2],
                Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                CurDeplStateID   => $DeplStateListReverse{Maintenance},
                CurDeplState     => 'Maintenance',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => 1,
                ChangeBy         => $UserIDs[1],
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[51],
                    ClassID          => $ConfigItemClassIDs[2],
                    Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                    Name             => 'UnitTest - Class 3 ConfigItem 2 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[2],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
                {
                    Number           => $ConfigItemNumbers[51],
                    ClassID          => $ConfigItemClassIDs[2],
                    Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                    Name             => 'UnitTest - Class 3 ConfigItem 2 Version 2',
                    DefinitionID     => $ConfigItemDefinitionIDs[2],
                    DeplStateID      => $DeplStateListReverse{Maintenance},
                    DeplState        => 'Maintenance',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => $UserIDs[1],
                },
            ],
        },
    },

    # add config item only for later search tests, including XMLData
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[52],
                ClassID => $ConfigItemClassIDs[2],
                UserID  => $UserIDs[2],
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 3 ConfigItem 3 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[2],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => $UserIDs[2],
                    XMLData      => [
                        undef,
                        {
                            Version => [
                                undef,
                                {
                                    Customer1 => [
                                        undef,
                                        {
                                            Content => 'dummy_customer_for_unitest',
                                        },
                                    ],
                                    Date1 => [
                                        undef,
                                        {
                                            Content => '2010-02-12',
                                        },
                                    ],
                                    DateTime1 => [
                                        undef,
                                        {
                                            Content => '2010-02-12 09:14',
                                        },
                                    ],
                                },
                            ],
                        },
                    ],
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[52],
                ClassID          => $ConfigItemClassIDs[2],
                Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => $UserIDs[2],
                ChangeBy         => $UserIDs[2],
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[52],
                    ClassID          => $ConfigItemClassIDs[2],
                    Class            => $ClassList->{ $ConfigItemClassIDs[2] },
                    Name             => 'UnitTest - Class 3 ConfigItem 3 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[2],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [
                        undef,
                        {
                            'TagKey'  => '[1]',
                            'Version' => [
                                undef,
                                {
                                    'Customer1' => [
                                        undef,
                                        {
                                            'Content' => 'dummy_customer_for_unitest',
                                            'TagKey'  => '[1]{\'Version\'}[1]{\'Customer1\'}[1]',
                                        },
                                    ],
                                    'Date1' => [
                                        undef,
                                        {
                                            'Content' => '2010-02-12',
                                            'TagKey'  => '[1]{\'Version\'}[1]{\'Date1\'}[1]',
                                        },
                                    ],
                                    'DateTime1' => [
                                        undef,
                                        {
                                            'Content' => '2010-02-12 09:14',
                                            'TagKey'  => '[1]{\'Version\'}[1]{\'DateTime1\'}[1]',
                                        },
                                    ],
                                    'TagKey' => '[1]{\'Version\'}[1]',
                                },
                            ],
                        },
                    ],
                    CreateBy => $UserIDs[2],
                },
            ],
        },
    },

    # add config item only for later search tests
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[60],
                ClassID => $ConfigItemClassIDs[3],
                UserID  => $UserIDs[1],
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Class 4 ConfigItem 1 Version 1',
                    DefinitionID => $ConfigItemDefinitionIDs[2],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => $UserIDs[1],
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[60],
                ClassID          => $ConfigItemClassIDs[3],
                Class            => $ClassList->{ $ConfigItemClassIDs[3] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Operational},
                CurInciState     => 'Operational',
                CurInciStateType => 'operational',
                CreateBy         => $UserIDs[1],
                ChangeBy         => $UserIDs[1],
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[60],
                    ClassID          => $ConfigItemClassIDs[3],
                    Class            => $ClassList->{ $ConfigItemClassIDs[3] },
                    Name             => 'UnitTest - Class 4 ConfigItem 1 Version 1',
                    DefinitionID     => $ConfigItemDefinitionIDs[2],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => $UserIDs[1],
                },
            ],
        },
    },

    # added to check history functions
    # all required values are given (check the calculation of deployment and incident state)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[70],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - HistoryTest',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Planned},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - HistoryTest Version 2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[70],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Maintenance},
                CurDeplState     => 'Maintenance',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[70],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - HistoryTest',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Planned},
                    DeplState        => 'Planned',
                    DeplStateType    => 'preproductive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
                {
                    Number           => $ConfigItemNumbers[70],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - HistoryTest Version 2',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Maintenance},
                    DeplState        => 'Maintenance',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
            HistoryGet => [
                {
                    HistoryType   => 'ConfigItemCreate',
                    HistoryTypeID => 1,
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'VersionCreate',
                    HistoryTypeID => 6,
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'DefinitionUpdate',
                    HistoryTypeID => 8,
                    Comment       => $ConfigItemDefinitionIDs[0],
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'NameUpdate',
                    HistoryTypeID => 5,
                    Comment       => 'UnitTest - HistoryTest%%',
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'IncidentStateUpdate',
                    HistoryTypeID => 9,
                    Comment       => $InciStateListReverse{Operational} . '%%',
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'DeploymentStateUpdate',
                    HistoryTypeID => 10,
                    Comment       => $DeplStateListReverse{Planned} . '%%',
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'VersionCreate',
                    HistoryTypeID => 6,
                    CreateBy      => 1,
                },
                {
                    HistoryType   => 'NameUpdate',
                    HistoryTypeID => 5,
                    Comment =>
                        'UnitTest - HistoryTest Version 2%%UnitTest - HistoryTest',
                    CreateBy => 1,
                },
                {
                    HistoryType   => 'IncidentStateUpdate',
                    HistoryTypeID => 9,
                    Comment       => $InciStateListReverse{Incident} . '%%'
                        . $InciStateListReverse{Operational},
                    CreateBy => 1,
                },
                {
                    HistoryType   => 'DeploymentStateUpdate',
                    HistoryTypeID => 10,
                    Comment       => $DeplStateListReverse{Maintenance} . '%%'
                        . $DeplStateListReverse{Planned},
                    CreateBy => 1,
                },
            ],
        },
    },

    # added for Bug4196
    # all required values are given (check the calculation of deployment and incident state)
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[71],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Bugfix4196',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Planned},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Bugfix4196 V2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Bugfix4196 V2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => 1,
                },
                {
                    Name         => 'UnitTest - Bugfix4196 V2',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Maintenance},
                    InciStateID  => $InciStateListReverse{Incident},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[71],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Maintenance},
                CurDeplState     => 'Maintenance',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Incident},
                CurInciState     => 'Incident',
                CurInciStateType => 'incident',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[71],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Bugfix4196',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Planned},
                    DeplState        => 'Planned',
                    DeplStateType    => 'preproductive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
                {
                    Number           => $ConfigItemNumbers[71],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Bugfix4196 V2',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Maintenance},
                    DeplState        => 'Maintenance',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Maintenance},
                    CurDeplState     => 'Maintenance',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Incident},
                    InciState        => 'Incident',
                    InciStateType    => 'incident',
                    CurInciStateID   => $InciStateListReverse{Incident},
                    CurInciState     => 'Incident',
                    CurInciStateType => 'incident',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
        },
    },

    # added for Bug 4377 - CI-A
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[72],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Bugfix4377 - CI-A',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[72],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Operational},
                CurInciState     => 'Operational',
                CurInciStateType => 'operational',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[72],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Bugfix4377 - CI-A',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
        },
    },

    # added for Bug 4377 - CI-B
    {
        SourceData => {
            ConfigItemAdd => {
                Number  => $ConfigItemNumbers[73],
                ClassID => $ConfigItemClassIDs[0],
                UserID  => 1,
            },
            VersionAdd => [
                {
                    Name         => 'UnitTest - Bugfix4377 - CI-B',
                    DefinitionID => $ConfigItemDefinitionIDs[0],
                    DeplStateID  => $DeplStateListReverse{Production},
                    InciStateID  => $InciStateListReverse{Operational},
                    UserID       => 1,
                },
            ],
        },
        ReferenceData => {
            ConfigItemGet => {
                Number           => $ConfigItemNumbers[73],
                ClassID          => $ConfigItemClassIDs[0],
                Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                CurDeplStateID   => $DeplStateListReverse{Production},
                CurDeplState     => 'Production',
                CurDeplStateType => 'productive',
                CurInciStateID   => $InciStateListReverse{Operational},
                CurInciState     => 'Operational',
                CurInciStateType => 'operational',
                CreateBy         => 1,
                ChangeBy         => 1,
            },
            VersionGet => [
                {
                    Number           => $ConfigItemNumbers[73],
                    ClassID          => $ConfigItemClassIDs[0],
                    Class            => $ClassList->{ $ConfigItemClassIDs[0] },
                    Name             => 'UnitTest - Bugfix4377 - CI-B',
                    DefinitionID     => $ConfigItemDefinitionIDs[0],
                    DeplStateID      => $DeplStateListReverse{Production},
                    DeplState        => 'Production',
                    DeplStateType    => 'productive',
                    CurDeplStateID   => $DeplStateListReverse{Production},
                    CurDeplState     => 'Production',
                    CurDeplStateType => 'productive',
                    InciStateID      => $InciStateListReverse{Operational},
                    InciState        => 'Operational',
                    InciStateType    => 'operational',
                    CurInciStateID   => $InciStateListReverse{Operational},
                    CurInciState     => 'Operational',
                    CurInciStateType => 'operational',
                    XMLData          => [],
                    CreateBy         => 1,
                },
            ],
        },
    },

];

# ------------------------------------------------------------ #
# run general config item tests
# ------------------------------------------------------------ #

my $TestCount = 1;
my @ConfigItemIDs;

TEST:
for my $Test ( @{$ConfigItemTests} ) {

    # check SourceData attribute
    if ( !$Test->{SourceData} || ref $Test->{SourceData} ne 'HASH' ) {

        $Self->True(
            0,
            "Test $TestCount: No SourceData found for this test.",
        );

        next TEST;
    }

    # extract source data
    my $SourceData = $Test->{SourceData};

    # add a new config item
    my $ConfigItemID;
    if ( $SourceData->{ConfigItemAdd} ) {

        # add the new config item
        $ConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
            %{ $SourceData->{ConfigItemAdd} },
        );

        if ($ConfigItemID) {
            push @ConfigItemIDs, $ConfigItemID;
        }
    }

    # check the config item
    if ( $Test->{ReferenceData} && $Test->{ReferenceData}->{ConfigItemGet} ) {

        $Self->True(
            $ConfigItemID,
            "Test $TestCount: ConfigItemAdd() - Add new config item. Insert success.",
        );

        next TEST if !$ConfigItemID;
    }
    else {

        $Self->False(
            $ConfigItemID,
            "Test $TestCount: ConfigItemAdd() - Add new config item. Return false.",
        );
    }

    # add all defined versions
    my @VersionIDs;
    my %VersionIDsSeen;
    if ( $SourceData->{VersionAdd} ) {

        for my $Version ( @{ $SourceData->{VersionAdd} } ) {

            if ($ConfigItemID) {
                $Version->{ConfigItemID} = $ConfigItemID;
            }

            # add a new version
            my $VersionID = $Self->{ConfigItemObject}->VersionAdd(
                %{$Version},
            );

            if ($VersionID) {
                push @VersionIDs, $VersionID if !$VersionIDsSeen{$VersionID}++;
            }
        }
    }

    # check the config item
    my $ConfigItemData;
    if ( $Test->{ReferenceData} && $Test->{ReferenceData}->{ConfigItemGet} ) {

        # get the config item data
        $ConfigItemData = $Self->{ConfigItemObject}->ConfigItemGet(
            ConfigItemID => $ConfigItemID,
        );

        if ( !$ConfigItemData ) {

            $Self->True(
                0,
                "Test $TestCount: ConfigItemGet() - get config item data."
            );
        }

        # check all config item attributes
        my $Counter = 0;
        for my $Attribute ( sort keys %{ $Test->{ReferenceData}->{ConfigItemGet} } ) {

            # set content if values are undef
            if ( !defined $ConfigItemData->{$Attribute} ) {
                $ConfigItemData->{$Attribute} = 'UNDEF-unittest';
            }
            if ( !defined $Test->{ReferenceData}->{ConfigItemGet}->{$Attribute} ) {
                $Test->{ReferenceData}->{ConfigItemGet}->{$Attribute} = 'UNDEF-unittest';
            }

            # check attributes
            $Self->Is(
                $ConfigItemData->{$Attribute},
                $Test->{ReferenceData}->{ConfigItemGet}->{$Attribute},
                "Test $TestCount: ConfigItemGet() - $Attribute",
            );

            $Counter++;
        }
    }

    # check the versions
    if (
        $Test->{ReferenceData}
        && $Test->{ReferenceData}->{VersionGet}
        && @{ $Test->{ReferenceData}->{VersionGet} }
        )
    {

        $Self->Is(
            scalar @VersionIDs,
            scalar @{ $Test->{ReferenceData}->{VersionGet} },
            "Test $TestCount: VersionAdd() - correct number of versions",
        );

        next TEST if !$ConfigItemID;
    }
    else {

        $Self->False(
            scalar @VersionIDs,
            "Test $TestCount: VersionAdd() - no versions exits",
        );
    }

    next TEST if !$Test->{ReferenceData};
    next TEST if !$Test->{ReferenceData}->{VersionGet};

    my $Counter           = 0;
    my $LastVersionIDMust = 'UNDEF-unittest';
    VERSIONID:
    for my $VersionID (@VersionIDs) {

        # get this version
        my $VersionData = $Self->{ConfigItemObject}->VersionGet(
            VersionID  => $VersionID,
            XMLDataGet => 1,
        );

        if ( !$VersionData ) {

            $Self->True(
                0,
                "Test $TestCount: VersionGet() - get version data."
            );

            next VERSIONID;
        }

        # save last version id
        $LastVersionIDMust = $VersionData->{VersionID};

        # check all version attributes
        for my $Attribute ( sort keys %{ $Test->{ReferenceData}->{VersionGet}->[$Counter] } ) {

            # extract the needed attributes
            my $VersionAttribute   = $VersionData->{$Attribute};
            my $ReferenceAttribute = $Test->{ReferenceData}->{VersionGet}->[$Counter]->{$Attribute};

            # set content if values are undef
            if ( !defined $VersionAttribute ) {
                $VersionAttribute = 'UNDEF-unittest';
            }
            if ( !defined $ReferenceAttribute ) {
                $ReferenceAttribute = 'UNDEF-unittest';
            }

            # check attributes
            $Self->IsDeeply(
                $VersionAttribute,
                $ReferenceAttribute,
                "Test $TestCount: VersionGet() - $Attribute",
            );
        }

        $Counter++;
    }

    # prepare last version id
    my $LastVersionIDActual = 'UNDEF-unittest';
    if ( $ConfigItemData->{LastVersionID} ) {
        $LastVersionIDActual = $ConfigItemData->{LastVersionID};
    }

    # check last version id
    $Self->Is(
        $ConfigItemData->{LastVersionID},
        $LastVersionIDMust,
        "Test $TestCount: last version id identical",
    );

    # check history entries
    if (
        $Test->{ReferenceData}
        && $Test->{ReferenceData}->{HistoryGet}
        && @{ $Test->{ReferenceData}->{HistoryGet} }
        )
    {
        my $CompleteHistory = $Self->{ConfigItemObject}->HistoryGet(
            ConfigItemID => $ConfigItemID,
        );

        # check nr of history entries
        $Self->Is(
            scalar @{ $Test->{ReferenceData}->{HistoryGet} },
            scalar @{$CompleteHistory},
            "Test $TestCount: nr of history entries",
        );

        CHECKNR: for my $CheckNr ( 0 .. $#{$CompleteHistory} ) {
            my $Check = $Test->{ReferenceData}->{HistoryGet}->[$CheckNr];
            my $Data  = $CompleteHistory->[$CheckNr];

            next CHECKNR if !( $Check && $Data );

            for my $Key ( sort keys %{$Check} ) {

                # check history data
                $Self->Is(
                    $Check->{$Key},
                    $Data->{$Key},
                    "Test $TestCount: $Key",
                );
            }
        }
    }
}
continue {
    $TestCount++;
}

# ------------------------------------------------------------ #
# test for bugfix 4377
# ------------------------------------------------------------ #

{

    my $CI1 = $Self->{ConfigItemObject}->ConfigItemLookup(
        ConfigItemNumber => $ConfigItemNumbers[72],
    );

    my $CI2 = $Self->{ConfigItemObject}->ConfigItemLookup(
        ConfigItemNumber => $ConfigItemNumbers[73],
    );

    # link the CI with a CI
    my $LinkResult = $Self->{LinkObject}->LinkAdd(
        SourceObject => 'ITSMConfigItem',
        SourceKey    => $CI1,
        TargetObject => 'ITSMConfigItem',
        TargetKey    => $CI2,
        Type         => 'DependsOn',
        State        => 'Valid',
        UserID       => 1,
    );

    # update incident state of CI1
    my $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $CI1,
        Name         => 'UnitTest - Bugfix4377 - CI-A',
        DefinitionID => $ConfigItemDefinitionIDs[0],
        DeplStateID  => $DeplStateListReverse{Production},
        InciStateID  => $InciStateListReverse{Incident},
        UserID       => 1,
    );

    # check if version could be added
    $Self->True(
        $VersionID,
        "Test $TestCount: VersionAdd() for $CI1 - Set to 'Incident'",
    );

    # get the latest version for CI1
    my $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI1,
    );

    # check if incident state of CI1 is 'Incident'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Incident',
        "Test $TestCount: Current incident state of CI $CI1",
    );

    # get the latest version for CI2
    $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI2,
    );

    # check if incident state of CI2 is 'Warning'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Warning',
        "Test $TestCount: Current incident state of CI $CI2",
    );

    # update incident state of CI2 to 'Incident'
    $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $CI2,
        Name         => 'UnitTest - Bugfix4377 - CI-B',
        DefinitionID => $ConfigItemDefinitionIDs[0],
        DeplStateID  => $DeplStateListReverse{Production},
        InciStateID  => $InciStateListReverse{Incident},
        UserID       => 1,
    );

    # check if version could be added
    $Self->True(
        $VersionID,
        "Test $TestCount: VersionAdd() for CI $CI2 - Set to 'Incident'",
    );

    # get the latest version for CI2
    $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI2,
    );

    # check if incident state of CI2 is 'Incident'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Incident',
        "Test $TestCount: Current incident state of CI $CI2",
    );

    # update incident state of CI1 to 'Operational'
    $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $CI1,
        Name         => 'UnitTest - Bugfix4377 - CI-A',
        DefinitionID => $ConfigItemDefinitionIDs[0],
        DeplStateID  => $DeplStateListReverse{Production},
        InciStateID  => $InciStateListReverse{Operational},
        UserID       => 1,
    );

    # check if version could be added
    $Self->True(
        $VersionID,
        "Test $TestCount: VersionAdd() for CI $CI1 - Set to 'Operational'",
    );

    # get the latest version for CI1
    $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI1,
    );

    # check if incident state of CI1 is 'Warning' (because of linked CI2 in state 'incident')
    $Self->Is(
        $VersionRef->{CurInciState},
        'Warning',
        "Test $TestCount: Current incident state of CI $CI1",
    );

    # update incident state of CI2 to 'Operational'
    $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $CI2,
        Name         => 'UnitTest - Bugfix4377 - CI-B',
        DefinitionID => $ConfigItemDefinitionIDs[0],
        DeplStateID  => $DeplStateListReverse{Production},
        InciStateID  => $InciStateListReverse{Operational},
        UserID       => 1,
    );

    # check if version could be added
    $Self->True(
        $VersionID,
        "Test $TestCount: VersionAdd() for CI $CI2 - Set to 'Operational'",
    );

    # get the latest version for CI1
    $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI1,
    );

    # check if incident state of CI1 is 'Operational'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Operational',
        "Test $TestCount: Current incident state of CI $CI1",
    );

    # get the latest version for CI2
    $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI2,
    );

    # check if incident state of CI2 is 'Warning'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Operational',
        "Test $TestCount: Current incident state of CI $CI2",
    );

    # increase the test counter
    $TestCount++;
}

# ------------------------------------------------------------ #
# test for bugfix 10356
# ------------------------------------------------------------ #

{

    my $CI1 = $Self->{ConfigItemObject}->ConfigItemLookup(
        ConfigItemNumber => $ConfigItemNumbers[72],
    );

    # add a version, set incident state to incident
    my $VersionID = $Self->{ConfigItemObject}->VersionAdd(
        ConfigItemID => $CI1,
        Name         => 'UnitTest - Bugfix10356',
        DefinitionID => $ConfigItemDefinitionIDs[0],
        DeplStateID  => $DeplStateListReverse{Production},
        InciStateID  => $InciStateListReverse{Incident},
        UserID       => 1,
    );

    # check if version could be added
    $Self->True(
        $VersionID,
        "Test $TestCount: VersionAdd() for $CI1 - Set to 'Incident'",
    );

    # get the latest version for CI1
    my $VersionRef = $Self->{ConfigItemObject}->VersionGet(
        ConfigItemID => $CI1,
    );

    # check if incident state of CI1 is 'Incident'
    $Self->Is(
        $VersionRef->{CurInciState},
        'Incident',
        "Test $TestCount: Current incident state of CI $CI1",
    );

    # delete the last version
    my $VersionDeleteSuccess = $Self->{ConfigItemObject}->VersionDelete(
        VersionID => $VersionRef->{VersionID},
        UserID    => 1,
    );

    # check if version could be deleted
    $Self->True(
        $VersionDeleteSuccess,
        "Test $TestCount: VersionDelete() for $CI1'",
    );

    # get the history
    my $HistoryRef = $Self->{ConfigItemObject}->HistoryGet(
        ConfigItemID => $CI1,
    );

    my $LastHistoryEntry = pop @{$HistoryRef};

    # check if last history entry has the correct history type
    $Self->Is(
        $LastHistoryEntry->{HistoryType},
        'VersionDelete',
        "Test $TestCount: HistoryType of last version of CI $CI1",
    );

    # increase the test counter
    $TestCount++;
}

# ------------------------------------------------------------ #
# define general config item search tests
# ------------------------------------------------------------ #

my @SearchTests = (

    # search ALL config items in the two test classes
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the number param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            Number => $ConfigItemNumbers[50],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
        ],
    },

    # test the number param with wildcards
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            Number => '*' . $ConfigItemNumbers[50] . '*',
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
        ],
    },

    # test the number param with wildcards but with deactivated wildcard feature
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            Number         => '*' . $ConfigItemNumbers[50] . '*',
            UsingWildcards => 0,
        },
        ReferenceData => [],
    },

    # test the deployment state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [ $DeplStateListReverse{Production} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the deployment state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [ $DeplStateListReverse{Maintenance} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
        ],
    },

    # test the deployment state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [
                $DeplStateListReverse{Production},
                $DeplStateListReverse{Maintenance},
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [ $InciStateListReverse{Operational} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [ $InciStateListReverse{Incident} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test the incident state param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [
                $InciStateListReverse{Incident},
                $InciStateListReverse{Operational},
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the order by param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            OrderBy => ['CreateBy'],
            OrderByDirection => ['Up'],
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[60],
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
        ],
    },

    # test the limit param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 100,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the limit param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 3,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test the limit param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 2,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
        ],
    },

    # test the limit param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
        ],
    },

    # test the limit param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 0,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the create by param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            CreateBy => [ $UserIDs[2] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
        ],
    },

    # test the create by param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            CreateBy => [ $UserIDs[1],            $UserIDs[2] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the change by param
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ChangeBy => [ $UserIDs[2] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
        ],
    },

    # test the change by param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            ChangeBy => [1],
        },
        ReferenceData => [],
    },

    # test the change by param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            ChangeBy => [ $UserIDs[1] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[60],
        ],
    },

    # test the change by param in combination of the class id
    {
        Function => [ 'ConfigItemSearchExtended', 'ConfigItemSearch' ],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            ChangeBy => [ $UserIDs[2] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
        ],
    },

    # search ALL config items in the two test classes using the version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the name param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name => 'UnitTest - Class 3 ConfigItem 1 Version 1',
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
        ],
    },

    # test the name param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name => 'UnitTest - Class 3 ConfigItem 3 Version 1',
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test the name param with an wildcard
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name => 'UnitTest - * 1',
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the name param with an wildcard and a previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name                  => 'UnitTest - * 1',
            ClassIDs              => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the name param with wildcards
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name => 'UnitTest - Class 3*',
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test the name param with wildcards but with deactivated wildcard feature
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name           => 'UnitTest - Class 3*',
            ClassIDs       => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            UsingWildcards => 0,
        },
        ReferenceData => [],
    },

    # test the last version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name => 'UnitTest - Class 3 ConfigItem 2 Version 1',
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
        },
        ReferenceData => [],
    },

    # test the PreviousVersionSearch param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            Name                  => 'UnitTest - Class 3 ConfigItem 2 Version 1',
            ClassIDs              => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
        ],
    },

    # test the limit param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 100,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the limit param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 3,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test the limit param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 2,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
        ],
    },

    # test the limit param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            Limit => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
        ],
    },

    # test the deployment state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [
                $DeplStateListReverse{Production},
                $DeplStateListReverse{Maintenance},
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the deployment state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [ $DeplStateListReverse{Production} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the deployment state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [ $DeplStateListReverse{Maintenance} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
        ],
    },

    # test the deployment state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs => [
                $DeplStateListReverse{Production},
                $DeplStateListReverse{Maintenance},
            ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the deployment state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs          => [ $DeplStateListReverse{Production} ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the deployment state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            DeplStateIDs          => [ $DeplStateListReverse{Maintenance} ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
        ],
    },

    # test the incident state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [
                $InciStateListReverse{Operational},
                $InciStateListReverse{Incident},
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [ $InciStateListReverse{Operational} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [ $InciStateListReverse{Incident} ],
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test the incident state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs => [
                $InciStateListReverse{Operational},
                $InciStateListReverse{Incident},
            ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs          => [ $InciStateListReverse{Operational} ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[60],
        ],
    },

    # test the incident state param with activated previous version search
    {
        Function   => ['VersionSearch'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            InciStateIDs          => [ $InciStateListReverse{Incident} ],
            PreviousVersionSearch => 1,
        },
        ReferenceData => [
            $ConfigItemNumbers[50],
            $ConfigItemNumbers[51],
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Customer1)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => [ $ConfigItemClassIDs[2], $ConfigItemClassIDs[3] ],
            ChangeBy => [ $UserIDs[2] ],
            What     => [
                {
                    "[1]{'Version'}[1]{'Customer1'}[1]{'Content'}" => 'dummy_customer_for_unitest',
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}" => '2010-02-12',
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (DateTime1)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'DateTime1'}[1]{'Content'}" => '2010-02-12 09:14',
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Customer1, Date1, DateTime1)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Customer1'}[1]{'Content'}" => 'dummy_customer_for_unitest',
                },
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}" => '2010-02-12',
                },
                {
                    "[1]{'Version'}[1]{'DateTime1'}[1]{'Content'}" => '2010-02-12 09:14',
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, <, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '<' => '2010-02-12', }
                },
            ],

        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, <, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '<' => '2010-02-13', }
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, <=, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '<=' => '2010-02-11', }
                },
            ],

        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, <=, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '<=' => '2010-02-12', }
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, <=, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '<=' => '2010-02-13', }
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, =, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '=' => '2010-02-11', }
                },
            ],
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, =, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '=' => '2010-02-12', }
                },
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, !=, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '!=' => '2010-02-12', }
                },
            ],
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, !=, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '!=' => '2010-02-13', }
                },
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, >=, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '>=' => '2010-02-13', }
                },
            ],
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, >=, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '>=' => '2010-02-12', }
                },
            ],

        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, >=, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '>=' => '2010-02-11', }
                },
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, >, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '>' => '2010-02-12', }
                },
            ],
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, >, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '>' => '2010-02-11', }
                },
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, -between, false)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '-between' => [ '2010-01-01', '2010-01-31' ] }
                },
            ],
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with 'What' (Date1, -between, true)
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            What     => [
                {
                    "[1]{'Version'}[1]{'Date1'}[1]{'Content'}"
                        => { '-between' => [ '2010-02-01', '2010-02-31' ] }
                },
            ],
        },
        ReferenceData => [
            $ConfigItemNumbers[52],
        ],
    },

    # test ConfigItemSearchExtended() with Name = 0 without any wildcards
    # should return no results
    # Bugfix# 8881
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            Name     => 0,
        },
        ReferenceData => [
        ],
    },

    # test ConfigItemSearchExtended() with Number = 0 without any wildcards
    # should return no results
    # Bugfix# 8881
    {
        Function   => ['ConfigItemSearchExtended'],
        SearchData => {
            ClassIDs => \@ConfigItemClassIDs,
            Number   => 0,
        },
        ReferenceData => [
        ],
    },
);

# ------------------------------------------------------------ #
# run general config item search tests
# ------------------------------------------------------------ #

# $SearchTestCount provides grouping of test cases
my $SearchTestCount = 1;

TEST:
for my $Test (@SearchTests) {

    # check SearchData attribute
    if ( !$Test->{SearchData} || ref $Test->{SearchData} ne 'HASH' ) {

        $Self->True(
            0,
            "SearchTest $SearchTestCount: No SearchData found for this test.",
        );

        next TEST;
    }

    if ( !$Test->{Function} || ref $Test->{Function} ne 'ARRAY' || !@{ $Test->{Function} } ) {
        $Test->{Function} = ['ConfigItemSearchExtended'];
    }

    for my $Function ( @{ $Test->{Function} } ) {

        # start search
        my $ConfigItemList = $Self->{ConfigItemObject}->$Function(
            %{ $Test->{SearchData} },
        );

        # check the config item list
        if ( $Test->{ReferenceData} ) {

            $Self->True(
                $ConfigItemList && ref $ConfigItemList eq 'ARRAY',
                "SearchTest $SearchTestCount: $Function() - List is an array reference.",
            );

            next TEST if !$ConfigItemList;
        }
        else {

            $Self->False(
                $ConfigItemList,
                "SearchTest $SearchTestCount: $Function() - Return false.",
            );

            next TEST if !$ConfigItemList;
        }

        # check number of found config items
        $Self->Is(
            scalar @{$ConfigItemList},
            scalar @{ $Test->{ReferenceData} },
            "SearchTest $SearchTestCount: $Function() - correct number of found config items",
        );

        my @ReferenceList;
        for my $Number ( @{ $Test->{ReferenceData} } ) {

            # find id of the item
            $Self->{DBObject}->Prepare(
                SQL => "SELECT id FROM configitem WHERE "
                    . "configitem_number = '$Number' "
                    . "ORDER BY id DESC",
                Limit => 1,
            );

            # fetch the result
            my $ConfigItemID;
            while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
                $ConfigItemID = $Row[0];
            }

            push @ReferenceList, $ConfigItemID;
        }

        # check arrays
        $Self->IsDeeply(
            $ConfigItemList,
            \@ReferenceList,
            "SearchTest $SearchTestCount: $Function() - List",
        );
    }
}
continue {
    $SearchTestCount++;
}

# ------------------------------------------------------------ #
# testing support for attachments
# ------------------------------------------------------------ #

my $AttachmentTestConfigItemID = $ConfigItemIDs[0];

# verify that initialy no attachment exists
my @AttachmentList = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
    ConfigItemID => $AttachmentTestConfigItemID,
);

$Self->Is(
    scalar @AttachmentList,
    0,
    'No attachments initially',
);

my @TestFileList = (
    {
        Filename    => 'first attachment',
        Content     => 'First attachment from ITSMConfigItem.t',
        ContentType => 'text/plain',
    },
    {
        Filename    => 'second attachment',
        Content     => 'Second attachment from ITSMConfigItem.t',
        ContentType => 'text/plain',
    },
);

my $FileCount;
for my $TestFile (@TestFileList) {

    $FileCount++;

    my $AddOk = $Self->{ConfigItemObject}->ConfigItemAttachmentAdd(
        %{$TestFile},
        ConfigItemID => $AttachmentTestConfigItemID,
        UserID       => 1,
    );
    $Self->True(
        $AddOk,
        "Attachment $FileCount: attachment added",
    );

    my @AttachmentList = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
        ConfigItemID => $AttachmentTestConfigItemID,
        UserID       => 1,
    );
    $Self->Is(
        scalar @AttachmentList,
        $FileCount,
        "Attachment $FileCount: number of attachments after adding",
    );

    # check whether the last added attachment is in the list
    my %AttachmentLookup = map { $_ => 1 } @AttachmentList;
    $Self->True(
        $AttachmentLookup{ $TestFile->{Filename} },
        "Attachment $FileCount: filename from ConfigItemAttachmentList()",
    );

    # get the attachment
    my $Attachment = $Self->{ConfigItemObject}->ConfigItemAttachmentGet(
        ConfigItemID => $AttachmentTestConfigItemID,
        Filename     => $TestFile->{Filename},
    );
    $Self->True(
        $Attachment,
        "Attachment $FileCount: ConfigItemAttachmentGet() returned true",
    );

    # check attachment file attributes
    for my $Attribute (qw(Filename Content ContentType)) {
        $Self->Is(
            $Attachment->{$Attribute},
            $TestFile->{$Attribute},
            "Attachment $FileCount: $Attribute from ConfigItemAttachmentGet",
        );
    }

    # check existence of attachment
    my $AttachmentExists = $Self->{ConfigItemObject}->ConfigItemAttachmentExists(
        ConfigItemID => $AttachmentTestConfigItemID,
        Filename     => $TestFile->{Filename},
        UserID       => 1,
    );
    $Self->True(
        $AttachmentExists,
        "Attachment $FileCount: attachment exists",
    );

}

# now delete the attachments
$FileCount = 0;
my $MaxTestFiles = scalar @TestFileList;
for my $TestFile (@TestFileList) {

    $FileCount++;

    my $DeleteOk = $Self->{ConfigItemObject}->ConfigItemAttachmentDelete(
        ConfigItemID => $AttachmentTestConfigItemID,
        Filename     => $TestFile->{Filename},
        UserID       => 1,
    );
    $Self->True(
        $DeleteOk,
        "Attachment $FileCount: attachment deleted",
    );

    my @AttachmentList = $Self->{ConfigItemObject}->ConfigItemAttachmentList(
        ConfigItemID => $AttachmentTestConfigItemID,
        UserID       => 1,
    );

    $Self->Is(
        scalar @AttachmentList,
        $MaxTestFiles - $FileCount,
        "Attachment $FileCount: number of attachments after deletion",
    );

    my $AttachmentExists = $Self->{ConfigItemObject}->ConfigItemAttachmentExists(
        Filename     => $TestFile->{Filename},
        ConfigItemID => $AttachmentTestConfigItemID,
        UserID       => 1,
    );
    $Self->False(
        $AttachmentExists,
        "Attachment $FileCount: attachment is gone",
    );
}

# ------------------------------------------------------------ #
# clean the system
# ------------------------------------------------------------ #

# get current class list
$ClassList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::Class',
);

# set unittest classes invalid
ITEMID:
for my $ItemID ( sort keys %{$ClassList} ) {

    next ITEMID if $ClassList->{$ItemID} !~ m{ \A UnitTest }xms;

    # update item
    $Self->{GeneralCatalogObject}->ItemUpdate(
        ItemID  => $ItemID,
        Name    => $ClassList->{$ItemID},
        ValidID => 2,
        UserID  => 1,
    );
}

# delete the test config items
my $DeleteTestCount = 1;
for my $ConfigItemID (@ConfigItemIDs) {
    my $DeleteOk = $Self->{ConfigItemObject}->ConfigItemDelete(
        ConfigItemID => $ConfigItemID,
        UserID       => 1,
    );
    $Self->True(
        $DeleteOk,
        "DeleteTest $DeleteTestCount - ConfigItemDelete() (ConfigItemID=$ConfigItemID)"
    );

    # double check if config item is really deleted
    my $ConfigItemData = $Self->{ConfigItemObject}->ConfigItemGet(
        ConfigItemID => $ConfigItemID,
        UserID       => 1,
        Cache        => 0,
    );
    $Self->False(
        $ConfigItemData->{ConfigItemID},
        "DeleteTest $DeleteTestCount - double check (ConfigItemID=$ConfigItemID)",
    );
}
continue {
    $DeleteTestCount++;
}

1;

# --
# ITSMConfigItemUniqueCIName.t - tests the functionality for unique CI names
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars qw($Self);

use Kernel::System::GeneralCatalog;
use Kernel::System::ITSMConfigItem;

$Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
$Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );

# ------------------------------------------------------------ #
# make preparations
# ------------------------------------------------------------ #

# add the test classes
my @ConfigItemClassIDs;
my @ConfigItemClasses;
my @ConfigItemDefinitionIDs;

# generate a random name
my $FirstClassName  = 'UnitTestClass1' . int rand 1_000_000;
my $SecondClassName = 'UnitTestClass2' . int rand 1_000_000;

# set a name prefix
my $NamePrefix = 'UnitTestName' . int rand 1_000_000;

# add both unittest config item classes
my $FirstClassID = $Self->{GeneralCatalogObject}->ItemAdd(
    Class   => 'ITSM::ConfigItem::Class',
    Name    => $FirstClassName,
    ValidID => 1,
    UserID  => 1,
);

# check first class id
if ( !$FirstClassID ) {

    $Self->True(
        0,
        "Can't add first config item class.",
    );
}

push @ConfigItemClassIDs, $FirstClassID;
push @ConfigItemClasses,  $FirstClassName;

my $SecondClassID = $Self->{GeneralCatalogObject}->ItemAdd(
    Class   => 'ITSM::ConfigItem::Class',
    Name    => $SecondClassName,
    ValidID => 1,
    UserID  => 1,
);

# check second class id
if ( !$SecondClassID ) {

    $Self->True(
        0,
        "Can't add second config item class.",
    );
}

push @ConfigItemClassIDs, $SecondClassID;
push @ConfigItemClasses,  $SecondClassName;

# add an empty definition to the class. the definition doesn't need any elements, as we're only
# testing the name which isn't part of the definition, but of the configitem itself
my $FirstDefinitionID = $Self->{ConfigItemObject}->DefinitionAdd(
    ClassID    => $FirstClassID,
    Definition => "[]",
    UserID     => 1,
);

# check definition id
if ( !$FirstDefinitionID ) {

    $Self->True(
        0,
        "Can't add first config item definition.",
    );
}

push @ConfigItemDefinitionIDs, $FirstDefinitionID;

my $SecondDefinitionID = $Self->{ConfigItemObject}->DefinitionAdd(
    ClassID    => $SecondClassID,
    Definition => "[]",
    UserID     => 1,
);

# check definition id
if ( !$SecondDefinitionID ) {

    $Self->True(
        0,
        "Can't add second config item definition.",
    );
}

push @ConfigItemDefinitionIDs, $SecondDefinitionID;

my @ConfigItemIDs;

# add a configitem to each class
my $FirstConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
    ClassID => $FirstClassID,
    UserID  => 1,
);

if ( !$FirstConfigItemID ) {
    $Self->True(
        0,
        "Failed to add the first configitem",
    );
}

push @ConfigItemIDs, $FirstConfigItemID;

my $SecondConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
    ClassID => $SecondClassID,
    UserID  => 1,
);

if ( !$SecondConfigItemID ) {
    $Self->True(
        0,
        "Failed to add the second configitem",
    );
}

push @ConfigItemIDs, $SecondConfigItemID;

# create a 3rd configitem in the 2nd class
my $ThirdConfigItemID = $Self->{ConfigItemObject}->ConfigItemAdd(
    ClassID => $SecondClassID,
    UserID  => 1,
);

if ( !$ThirdConfigItemID ) {
    $Self->True(
        0,
        "Failed to add the third configitem",
    );
}

push @ConfigItemIDs, $ThirdConfigItemID;

# get deployment state list
my $DeplStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::DeploymentState',
);
my %DeplStateListReverse = reverse %{$DeplStateList};

# get incident state list
my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::Core::IncidentState',
);
my %InciStateListReverse = reverse %{$InciStateList};

# set a name for each configitem
my $FirstInitialVersionID = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $FirstConfigItemID,
    Name         => $NamePrefix . 'First#001',
    DefinitionID => $FirstDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

if ( !$FirstInitialVersionID ) {
    $Self->True(
        0,
        "Failed to add the initial version for the first configitem",
    );
}

my $SecondInitialVersionID = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $SecondConfigItemID,
    Name         => $NamePrefix . 'Second#001',
    DefinitionID => $SecondDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

if ( !$SecondInitialVersionID ) {
    $Self->True(
        0,
        "Failed to add the initial version for the second configitem",
    );
}

my $ThirdInitialVersionID = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $ThirdConfigItemID,
    Name         => $NamePrefix . 'Second#002',
    DefinitionID => $SecondDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

if ( !$ThirdInitialVersionID ) {
    $Self->True(
        0,
        "Failed to add the initial version for the third configitem",
    );
}

# ------------------------------------------------------------ #
# run the actual tests
# ------------------------------------------------------------ #

# read the original setting for the setting EnableUniquenessCheck
my $OrigEnableSetting = $Self->{ConfigObject}->Get('UniqueCIName::EnableUniquenessCheck');

# enable the uniqueness check
$Self->{ConfigObject}->Set(
    Key   => 'UniqueCIName::EnableUniquenessCheck',
    Value => 1,
);

# read the original setting for the scope of the uniqueness check
my $OrigScope = $Self->{ConfigObject}->Get('UniqueCIName::UniquenessCheckScope');

# make sure, the scope for the uniqueness check is set to 'global'
$Self->{ConfigObject}->Set(
    Key   => 'UniqueCIName::UniquenessCheckScope',
    Value => 'global',
);

my $RenameSuccess;

# try to give the 1st configitem the same name as the 2nd one
$RenameSuccess = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $FirstConfigItemID,
    Name         => $NamePrefix . 'Second#001',
    DefinitionID => $FirstDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

$Self->False(
    $RenameSuccess,
    "Scope => global: Renaming First#001 to already existing Second#001 successfully prevented"
);

# try to give the 2nd configitem the same name as the 3rd one
$RenameSuccess = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $SecondConfigItemID,
    Name         => $NamePrefix . 'Second#002',
    DefinitionID => $FirstDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

$Self->False(
    $RenameSuccess,
    "Scope => global: Renaming Second#001 to already existing Second#002 successfully prevented"
);

# set the scope for the uniqueness check to 'class'
$Self->{ConfigObject}->Set(
    Key   => 'UniqueCIName::UniquenessCheckScope',
    Value => 'class',
);

# try to rename First#001 again to Second#001 which should work now, due to the different class
$RenameSuccess = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $FirstConfigItemID,
    Name         => $NamePrefix . 'Second#001',
    DefinitionID => $FirstDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

$Self->True(
    $RenameSuccess,
    "Scope => class: Renaming First#001 to already existing Second#001 succeeded"
);

# trying now to create a duplicate name within a class
$RenameSuccess = $Self->{ConfigItemObject}->VersionAdd(
    ConfigItemID => $SecondConfigItemID,
    Name         => $NamePrefix . 'Second#002',
    DefinitionID => $SecondDefinitionID,
    DeplStateID  => $DeplStateListReverse{Production},
    InciStateID  => $InciStateListReverse{Operational},
    UserID       => 1,
);

$Self->False(
    $RenameSuccess,
    "Scope => class: Renaming Second#001 to already existing Second#002 successfully prevented"
);

# reset the enabled setting for the uniqueness check to its original value
$Self->{ConfigObject}->Set(
    Key   => 'UniqueCIName::EnableUniquenessCheck',
    Value => $OrigEnableSetting,
);

# reset the scope for the uniqueness check to its original value
$Self->{ConfigObject}->Set(
    Key   => 'UniqueCIName::UniquenessCheckScope',
    Value => $OrigScope,
);

# ------------------------------------------------------------ #
# clean the system
# ------------------------------------------------------------ #

# get current class list
my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
    Class => 'ITSM::ConfigItem::Class',
);

# set unittest classes invalid
ITEMID:
for my $ItemID ( sort keys %{$ClassList} ) {

    next ITEMID if $ClassList->{$ItemID} !~ m{ \A UnitTest }xms;

    # update item
    $Self->{GeneralCatalogObject}->ItemUpdate(
        ItemID  => $ItemID,
        Name    => $ClassList->{$ItemID},
        ValidID => 2,
        UserID  => 1,
    );
}

# delete the test config items
for my $ConfigItemID (@ConfigItemIDs) {
    my $DeleteOk = $Self->{ConfigItemObject}->ConfigItemDelete(
        ConfigItemID => $ConfigItemID,
        UserID       => 1,
    );
}

1;

// --
// ITSM.Agent.ConfigItem.Search.js - provides the special module functions for the global search
// Copyright (C) 2001-2013 OTRS AG, http://otrs.org/\n";
// --
// This software comes with ABSOLUTELY NO WARRANTY. For details, see
// the enclosed file COPYING for license information (AGPL). If you
// did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
// --

"use strict";

var ITSM = ITSM || {};
ITSM.Agent = ITSM.Agent || {};
ITSM.Agent.ConfigItem = ITSM.Agent.ConfigItem || {};

/**
 * @namespace
 * @exports TargetNS as ITSM.Agent.ConfigItem.Search
 * @description
 *      This namespace contains the special module functions for the search.
 */
ITSM.Agent.ConfigItem.Search = (function (TargetNS) {

    /**
     * @function
     * @return nothing
     *      This function rebuild attribute selection, only show available attributes.
     */
    TargetNS.AdditionalAttributeSelectionRebuild = function () {

        // get original selection with all possible fields and clone it
        var $AttributeClone = $('#AttributeOrig').clone().attr('id', 'Attribute');

        // strip all already used attributes
        $AttributeClone.find('option').each(function () {
            $('#SearchInsert label#' + 'Label' + $(this).attr('value')).remove();
        });

        // replace selection with original selection
        $('#Attribute').replaceWith($AttributeClone);

        return true;
    };

    /**
     * @function
     * @param {String} of attribute to add.
     * @return nothing
     *      This function adds one attribute for search
     */
    TargetNS.SearchAttributeAdd = function (Attribute) {

        // escape possible colons (:) in element id because jQuery can not handle it in id attribute selectors
        Attribute = Core.App.EscapeSelector(Attribute);

        var $Label = $('#SearchAttributesHidden label#Label' + Attribute);

        if ($Label.length) {
            $Label.prev().clone().appendTo('#SearchInsert');
            $Label.clone().appendTo('#SearchInsert');
            $Label.next().clone().appendTo('#SearchInsert')

                // bind click function to remove button now
                .find('.Remove').bind('click', function () {
                    var $Element = $(this).parent();
                    TargetNS.SearchAttributeRemove($Element);

                    // rebuild selection
                    TargetNS.AdditionalAttributeSelectionRebuild();

                    return false;
                });

                // set autocomplete to customer type fields
                $('#SearchInsert').find('.ITSMCustomerSearch').each(function() {
                    var InputID = $(this).attr('id') + 'Autocomplete';
                    $(this).removeClass('ITSMCustomerSearch');
                    $(this).attr('id', InputID);
                    $(this).prev().attr('id', InputID + 'Selected');

                    // escape possible colons (:) in element id because jQuery can not handle it in id attribute selectors
                    ITSM.Agent.CustomerSearch.Init( $('#' + Core.App.EscapeSelector(InputID) ) );

                    // prevent dialog closure when select a customer from the list
                    $('ul.ui-autocomplete').bind('click', function(Event) {
                        Event.stopPropagation();
                        return false;
                    });
                });
            }

        return false;
    };

    /**
     * @function
     * @param {jQueryObject} $Element The jQuery object of the form  or any element
     *      within this form check.
     * @return nothing
     *      This function remove attributes from an element.
     */

    TargetNS.SearchAttributeRemove = function ($Element) {
        $Element.prev().prev().remove();
        $Element.prev().remove();
        $Element.remove();
    };

    /**
     * @function
     * @return nothing
     *      This function rebuild attribute selection, only show available attributes.
     */
    TargetNS.AdditionalAttributeSelectionRebuild = function () {

        // get original selection
        var $AttributeClone = $('#AttributeOrig').clone();
        $AttributeClone.attr('id', 'Attribute');

        // strip all already used attributes
        $AttributeClone.find('option').each(function () {
            var $Attribute = $(this);
            $('#SearchInsert label').each(function () {
                if ($(this).attr('id') === 'Label' + $Attribute.attr('value')) {
                    $Attribute.remove();
                }
            });
        });

        // replace selection with original selection
        $('#Attribute').replaceWith($AttributeClone);

        return true;
    };

    /**
     * @function
     * @private
     * @param {String} Profile The profile name that will be delete.
     * @return nothing
     * @description Delete a profile via an ajax requests.
     */
    function SearchProfileDelete(Profile) {
        var Data = {
            Action: 'AgentITSMConfigItemSearch',
            Subaction: 'AJAXProfileDelete',
            Profile: Profile,
            ClassID: $('#SearchClassID').val()
        };
        Core.AJAX.FunctionCall(
            Core.Config.Get('CGIHandle'),
            Data,
            function () {}
        );
    }

    /**
     * @function
     * @private
     * @return nothing
     * @description Shows waiting dialog until search screen is ready.
     */
    function ShowWaitingDialog(){
        Core.UI.Dialog.ShowContentDialog('<div class="Spacing Center"><span class="AJAXLoader" title="' + Core.Config.Get('LoadingMsg') + '"></span></div>', Core.Config.Get('LoadingMsg'), '10px', 'Center', true);
    }

    /**
     * @function
     * @param none
     * @return nothing
     *      This function sets all search dialog settings
     */

    TargetNS.SetSearchDialog = function() {

        // hide add template block
        $('#SearchProfileAddBlock').hide();

        // hide save changes in template block
        $('#SaveProfile').parent().hide().prev().hide().prev().hide();

        // search profile is selected
        if ($('#SearchProfile').val() && $('#SearchProfile').val() !== 'last-search') {

            // show delete button
            $('#SearchProfileDelete').show();

            // show save changes in template block
            $('#SaveProfile').parent().show().prev().show().prev().show();

            // set SaveProfile to 0
            $('#SaveProfile').attr('checked', false);
        }

        // register add of attribute
        $('.Add').bind('click', function () {
            var Attribute = $('#Attribute').val();

            TargetNS.SearchAttributeAdd(Attribute);
            TargetNS.AdditionalAttributeSelectionRebuild();

            return false;
        });

        // register return key
        $('#SearchForm').unbind('keypress.FilterInput').bind('keypress.FilterInput', function (Event) {
            if ((Event.charCode || Event.keyCode) === 13) {
                $('#SearchForm').submit();
                return false;
            }
        });

        // register submit
        $('#SearchFormSubmit').bind('click', function () {
            // Normal results mode will return HTML in the same window
            if ($('#SearchForm #ResultForm').val() === 'Normal') {
                $('#SearchForm').submit();
                ShowWaitingDialog();
            }
            else { // Print and CSV should open in a new window, no waiting dialog
                $('#SearchForm').attr('target', 'SearchResultPage');
                $('#SearchForm').submit();
                $('#SearchForm').attr('target', '');
            }
            return false;
        });

        // load profile
        $('#SearchProfile').bind('change', function () {
            var Profile = $('#SearchProfile').val();
            TargetNS.LoadProfile(Profile);
            return false;
        });

        // show add profile block or not
        $('#SearchProfileNew').bind('click', function (Event) {
            $('#SearchProfileAddBlock').toggle();
            Event.preventDefault();
            return false;
        });

        // add new profile
        $('#SearchProfileAddAction').bind('click', function () {
            var Name, $Element1, $Element2;

            // get name
            Name = $('#SearchProfileAddName').val();
            if (!Name) {
                return false;
            }

            // add name to profile selection
            $Element1 = $('#SearchProfile').children().first().clone();
            $Element1.text(Name);
            $Element1.attr('value', Name);
            $Element1.attr('selected', 'selected');
            $('#SearchProfile').append($Element1);

            // set input box to empty
            $('#SearchProfileAddName').val('');

            // hide add template block
            $('#SearchProfileAddBlock').hide();

            // hide save changes in template block
            $('#SaveProfile').parent().hide().prev().hide().prev().hide();

            // set SaveProfile to 1
            $('#SaveProfile').attr('checked', true);

            $('#SearchProfileDelete').show();

            return false;
        });

        // delete profile
        $('#SearchProfileDelete').bind('click', function (Event) {

            // strip all already used attributes
            $('#SearchProfile').find('option:selected').each(function () {
                if ($(this).attr('value') !== 'last-search') {

                    // rebuild attributes
                    $('#SearchInsert').text('');

                    // remove remote
                    SearchProfileDelete($(this).val());

                    // remove local
                    $(this).remove();

                    // rebuild selection
                    TargetNS.AdditionalAttributeSelectionRebuild();
                }
            });

            if ($('#SearchProfile').val() && $('#SearchProfile').val() === 'last-search') {
                $('#SearchProfileDelete').hide();
            }

            Event.preventDefault();
            return false;
        });

    };

    /**
     * @function
     * @param {Profile} The profile that is set to the search dialog
     * @return nothing
     *      This function refresh the search dialog with the selected profile
     */

    TargetNS.LoadProfile = function (Profile) {
        var BaseLink = Core.Config.Get('Baselink'),
            Action = 'Action=AgentITSMConfigItemSearch;',
            SubAction = 'Subaction=AJAXUpdate;',
            ClassID = 'ClassID=' + $('#SearchClassID').val() + ';',
            SearchProfile = 'Profile=' + Profile,
            URL =  BaseLink + Action + SubAction + ClassID + SearchProfile;

        $('#DivClassID').addClass('ui-autocomplete-loading');
        Core.AJAX.ContentUpdate($('#AJAXUpdate'), URL, function() {
            TargetNS.SetSearchDialog( '$Env{"Action"}' );
            $('#ITSMSearchProfile').removeClass('Hidden');
            $('#ITSMSearchFields').removeClass('Hidden');
            $('#SearchFormSubmit').removeClass('Hidden');
            $('#DivClassID').removeClass('ui-autocomplete-loading');
        });
    };

    /**
     * @function
     * @param {Event} Action
     * @return nothing
     *      This function open the search dialog
     */

    TargetNS.OpenSearchDialog = function (Action, Profile, Class) {

        var Referrer = Core.Config.Get('Action'),
            Data;

        if (!Action) {
            Action ='AgentITSMConfigItemSearch';
        }
        Data = {
            Action: Action,
            Referrer: Referrer,
            Profile: Profile,
            Subaction: 'AJAX',
            ClassID: Class
        };

        ShowWaitingDialog();

        Core.AJAX.FunctionCall(
            Core.Config.Get('CGIHandle'),
            Data,
            function (HTML) {
                // if the waiting dialog was canceled, do not show the search
                //  dialog as well
                if (!$('.Dialog:visible').length) {
                    return;
                }

                Core.UI.Dialog.ShowContentDialog(HTML, Core.Config.Get('SearchMsg'), '10px', 'Center', true);
                TargetNS.SetSearchDialog();
            }, 'html'
        );
    };

    return TargetNS;
}(ITSM.Agent.ConfigItem.Search || {}));

# --
# ITSMConfigurationManagement.pm - code to excecute during package installation
# Copyright (C) 2001-2014 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package var::packagesetup::ITSMConfigurationManagement;    ## no critic

use strict;
use warnings;

use Kernel::Config;
use Kernel::System::SysConfig;
use Kernel::System::CSV;
use Kernel::System::CacheInternal;
use Kernel::System::GeneralCatalog;
use Kernel::System::Group;
use Kernel::System::ITSMConfigItem;
use Kernel::System::LinkObject;
use Kernel::System::State;
use Kernel::System::Stats;
use Kernel::System::Service;
use Kernel::System::Type;
use Kernel::System::User;
use Kernel::System::Valid;

=head1 NAME

ITSMConfigurationManagement.pm - code to excecute during package installation

=head1 SYNOPSIS

Functions for installing the ITSMConfigurationManagement package.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::Log;
    use Kernel::System::Main;
    use Kernel::System::Time;
    use Kernel::System::DB;
    use Kernel::System::XML;
    use var::packagesetup::ITSMConfigurationManagement;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject    = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $TimeObject = Kernel::System::Time->new(
        ConfigObject => $ConfigObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $XMLObject = Kernel::System::XML->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        DBObject     => $DBObject,
        MainObject   => $MainObject,
    );
    my $CodeObject = var::packagesetup::ITSMConfigurationManagement->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
        TimeObject   => $TimeObject,
        DBObject     => $DBObject,
        XMLObject    => $XMLObject,
    );

=cut

sub new {
    my ( $Type, %Param ) = @_;

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

    # check needed objects
    for my $Object (
        qw(ConfigObject EncodeObject LogObject MainObject TimeObject DBObject XMLObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    # create needed sysconfig object
    $Self->{SysConfigObject} = Kernel::System::SysConfig->new( %{$Self} );

    # rebuild ZZZ* files
    $Self->{SysConfigObject}->WriteDefault();

    # define the ZZZ files
    my @ZZZFiles = (
        'ZZZAAuto.pm',
        'ZZZAuto.pm',
    );

    # reload the ZZZ files (mod_perl workaround)
    for my $ZZZFile (@ZZZFiles) {

        PREFIX:
        for my $Prefix (@INC) {
            my $File = $Prefix . '/Kernel/Config/Files/' . $ZZZFile;
            next PREFIX if !-f $File;
            do $File;
            last PREFIX;
        }
    }

    # create additional objects
    $Self->{ConfigObject}         = Kernel::Config->new();
    $Self->{CSVObject}            = Kernel::System::CSV->new( %{$Self} );
    $Self->{GroupObject}          = Kernel::System::Group->new( %{$Self} );
    $Self->{UserObject}           = Kernel::System::User->new( %{$Self} );
    $Self->{StateObject}          = Kernel::System::State->new( %{$Self} );
    $Self->{ServiceObject}        = Kernel::System::Service->new( %{$Self} );
    $Self->{TypeObject}           = Kernel::System::Type->new( %{$Self} );
    $Self->{ValidObject}          = Kernel::System::Valid->new( %{$Self} );
    $Self->{GeneralCatalogObject} = Kernel::System::GeneralCatalog->new( %{$Self} );
    $Self->{ConfigItemObject}     = Kernel::System::ITSMConfigItem->new( %{$Self} );
    $Self->{LinkObject}           = Kernel::System::LinkObject->new( %{$Self} );
    $Self->{StatsObject}          = Kernel::System::Stats->new(
        %{$Self},
        UserID => 1,
    );
    $Self->{CacheInternalObject} = Kernel::System::CacheInternal->new(
        %{$Self},
        Type => 'Group',
        TTL  => 60 * 60 * 3,
    );

    # define file prefix for stats
    $Self->{FilePrefix} = 'ITSMStats';

    return $Self;
}

=item CodeInstall()

run the code install part

    my $Result = $CodeObject->CodeInstall();

=cut

sub CodeInstall {
    my ( $Self, %Param ) = @_;

    # add the group itsm-configitem
    $Self->_GroupAdd(
        Name        => 'itsm-configitem',
        Description => 'Group for ITSM ConfigItem mask access in the agent interface.',
    );

    # install config item definitions
    $Self->_AddConfigItemDefinitions();

    # fillup empty last_version_id rows in configitem table
    $Self->_FillupEmptyLastVersionID();

    # fillup empty inci_state_id rows in configitem_version table
    $Self->_FillupEmptyVersionIncidentStateID();

    # fillup empty cur_depl_state_id or cur_inci_state_id rows in configitem table
    $Self->_FillupEmptyIncidentAndDeploymentStateID();

    # set preferences for some config items
    $Self->_SetPreferences();

    # set default permission group
    $Self->_SetDefaultPermission();

    # fillup empty 'CurInciStateTypeFromCIs' service preferences
    $Self->_FillupEmptyCurInciStateTypeFromCIs();

    # install stats
    $Self->{StatsObject}->StatsInstall(
        FilePrefix => $Self->{FilePrefix},
    );

    # delete the group cache to avoid problems with CI permissions
    $Self->{CacheInternalObject}->CleanUp( OtherType => 'Group' );

    return 1;
}

=item CodeReinstall()

run the code reinstall part

    my $Result = $CodeObject->CodeReinstall();

=cut

sub CodeReinstall {
    my ( $Self, %Param ) = @_;

    # add the group itsm-configitem
    $Self->_GroupAdd(
        Name        => 'itsm-configitem',
        Description => 'Group for ITSM ConfigItem mask access in the agent interface.',
    );

    # install config item definitions
    $Self->_AddConfigItemDefinitions();

    # fillup empty last_version_id rows in configitem table
    $Self->_FillupEmptyLastVersionID();

    # fillup empty inci_state_id rows in configitem_version table
    $Self->_FillupEmptyVersionIncidentStateID();

    # fillup empty cur_depl_state_id or cur_inci_state_id rows in configitem table
    $Self->_FillupEmptyIncidentAndDeploymentStateID();

    # set preferences for some config items
    $Self->_SetPreferences();

    # set default permission group
    $Self->_SetDefaultPermission();

    # fillup empty 'CurInciStateTypeFromCIs' service preferences
    $Self->_FillupEmptyCurInciStateTypeFromCIs();

    # install stats
    $Self->{StatsObject}->StatsInstall(
        FilePrefix => $Self->{FilePrefix},
    );

    return 1;
}

=item CodeUpgrade()

run the code upgrade part

    my $Result = $CodeObject->CodeUpgrade();

=cut

sub CodeUpgrade {
    my ( $Self, %Param ) = @_;

    # install config item definitions
    $Self->_AddConfigItemDefinitions();

    # fillup empty last_version_id rows in configitem table
    $Self->_FillupEmptyLastVersionID();

    # fillup empty inci_state_id rows in configitem_version table
    $Self->_FillupEmptyVersionIncidentStateID();

    # fillup empty cur_depl_state_id or cur_inci_state_id rows in configitem table
    $Self->_FillupEmptyIncidentAndDeploymentStateID();

    # set preferences for some config items
    $Self->_SetPreferences();

    # set default permission group
    $Self->_SetDefaultPermission();

    # fillup empty 'CurInciStateTypeFromCIs' service preferences
    $Self->_FillupEmptyCurInciStateTypeFromCIs();

    # install stats
    $Self->{StatsObject}->StatsInstall(
        FilePrefix => $Self->{FilePrefix},
    );

    # delete the group cache to avoid problems with CI permissions
    $Self->{CacheInternalObject}->CleanUp( OtherType => 'Group' );

    return 1;
}

=item CodeUninstall()

run the code uninstall part

    my $Result = $CodeObject->CodeUninstall();

=cut

sub CodeUninstall {
    my ( $Self, %Param ) = @_;

    # delete all links with config items
    $Self->_LinkDelete();

    # deactivate the group itsm-configitem
    $Self->_GroupDeactivate(
        Name => 'itsm-configitem',
    );

    # delete 'CurInciStateTypeFromCIs' service preferences
    $Self->_DeleteServicePreferences();

    return 1;
}

=item _SetPreferences()

    my $Result = $CodeObject->_SetPreferences()

=cut

sub _SetPreferences {
    my $Self = shift;

    my %Map = (
        Expired     => 'productive',
        Inactive    => 'postproductive',
        Maintenance => 'productive',
        Pilot       => 'productive',
        Planned     => 'preproductive',
        Production  => 'productive',
        Repair      => 'productive',
        Retired     => 'postproductive',
        Review      => 'productive',
        'Test/QA'   => 'preproductive',
    );

    NAME:
    for my $Name ( sort keys %Map ) {
        my $Item = $Self->{GeneralCatalogObject}->ItemGet(
            Name  => $Name,
            Class => 'ITSM::ConfigItem::DeploymentState',
        );

        next NAME if !$Item;

        $Self->{GeneralCatalogObject}->GeneralCatalogPreferencesSet(
            ItemID => $Item->{ItemID},
            Key    => 'Functionality',
            Value  => $Map{$Name},
        );
    }
}

=item _SetDefaultPermission()

set the default group that has access rights

=cut

sub _SetDefaultPermission {
    my $Self = shift;

    # get class list
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );

    # check if group already exists
    my $GroupID = $Self->{GroupObject}->GroupLookup(
        Group  => 'itsm-configitem',
        UserID => 1,
    );

    # check if a permission group is already set. If not, set default permission group
    for my $ClassID ( sort keys %{$ClassList} ) {
        my $Class = $Self->{GeneralCatalogObject}->ItemGet(
            ItemID => $ClassID,
        );

        if ( !$Class->{Permission} ) {
            $Self->{GeneralCatalogObject}->GeneralCatalogPreferencesSet(
                ItemID => $Class->{ItemID},
                Key    => 'Permission',
                Value  => $GroupID,
            );
        }
    }
}

=item _GroupAdd()

add a group

    my $Result = $CodeObject->_GroupAdd(
        Name        => 'the-group-name',
        Description => 'The group description.',
    );

=cut

sub _GroupAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Name Description)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # get valid list
    my %ValidList = $Self->{ValidObject}->ValidList(
        UserID => 1,
    );
    my %ValidListReverse = reverse %ValidList;

    # get list of all groups
    my %GroupList = $Self->{GroupObject}->GroupList();

    # reverse the group list for easier lookup
    my %GroupListReverse = reverse %GroupList;

    # check if group already exists
    my $GroupID = $GroupListReverse{ $Param{Name} };

    # reactivate the group
    if ($GroupID) {

        # get current group data
        my %GroupData = $Self->{GroupObject}->GroupGet(
            ID     => $GroupID,
            UserID => 1,
        );

        # reactivate group
        $Self->{GroupObject}->GroupUpdate(
            %GroupData,
            ValidID => $ValidListReverse{valid},
            UserID  => 1,
        );

        return 1;
    }

    # add the group
    else {
        return if !$Self->{GroupObject}->GroupAdd(
            Name    => $Param{Name},
            Comment => $Param{Description},
            ValidID => $ValidListReverse{valid},
            UserID  => 1,
        );
    }

    # lookup the new group id
    my $NewGroupID = $Self->{GroupObject}->GroupLookup(
        Group  => $Param{Name},
        UserID => 1,
    );

    # add user root to the group
    $Self->{GroupObject}->GroupMemberAdd(
        GID        => $NewGroupID,
        UID        => 1,
        Permission => {
            ro        => 1,
            move_into => 1,
            create    => 1,
            owner     => 1,
            priority  => 1,
            rw        => 1,
        },
        UserID => 1,
    );

    return 1;
}

=item _GroupDeactivate()

deactivate a group

    my $Result = $CodeObject->_GroupDeactivate(
        Name => 'the-group-name',
    );

=cut

sub _GroupDeactivate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Name} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need Name!',
        );
        return;
    }

    # lookup group id
    my $GroupID = $Self->{GroupObject}->GroupLookup(
        Group => $Param{Name},
    );

    return if !$GroupID;

    # get valid list
    my %ValidList = $Self->{ValidObject}->ValidList(
        UserID => 1,
    );
    my %ValidListReverse = reverse %ValidList;

    # get current group data
    my %GroupData = $Self->{GroupObject}->GroupGet(
        ID     => $GroupID,
        UserID => 1,
    );

    # deactivate group
    $Self->{GroupObject}->GroupUpdate(
        %GroupData,
        ValidID => $ValidListReverse{invalid},
        UserID  => 1,
    );

    return 1;
}

=item _AddConfigItemDefinitions()

installs ConfigItem definitions

    my $Result = $CodeObject->_AddConfigItemDefinitions();

=cut

sub _AddConfigItemDefinitions {
    my ( $Self, %Param ) = @_;

    # config item definitions
    my %Definition = (
        Computer => "[
    {
        Key => 'Vendor',
        Name => 'Vendor',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,

            # Example for CI attribute syntax check for text and textarea fields
            #RegEx             => '^ABC.*',
            #RegExErrorMessage => 'Value must start with \"ABC\"!',
        },
    },
    {
        Key => 'Model',
        Name => 'Model',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'Description',
        Name => 'Description',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
        },
    },
    {
        Key => 'Type',
        Name => 'Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Computer::Type',
            Translation => 1,
        },
    },
    {
        Key => 'Owner',
        Name => 'Owner',
        Searchable => 1,
        Input => {
            Type => 'Customer',
        },
    },
    {
        Key => 'SerialNumber',
        Name => 'Serial Number',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'OperatingSystem',
        Name => 'Operating System',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'CPU',
        Name => 'CPU',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
        CountMax => 16,
    },
    {
        Key => 'Ram',
        Name => 'Ram',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
        CountMax => 10,
    },
    {
        Key => 'HardDisk',
        Name => 'Hard Disk',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
        CountMax => 10,
        Sub => [
            {
                Key => 'Capacity',
                Name => 'Capacity',
                Input => {
                    Type => 'Text',
                    Size => 20,
                    MaxLength => 10,
                },
            },
        ],
    },
    {
        Key => 'FQDN',
        Name => 'FQDN',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'NIC',
        Name => 'Network Adapter',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
            Required => 1,
        },
        CountMin => 0,
        CountMax => 10,
        CountDefault => 1,
        Sub => [
            {
                Key => 'IPoverDHCP',
                Name => 'IP over DHCP',
                Input => {
                    Type => 'GeneralCatalog',
                    Class => 'ITSM::ConfigItem::YesNo',
                    Translation => 1,
                    Required => 1,
                },
            },
            {
                Key => 'IPAddress',
                Name => 'IP Address',
                Searchable => 1,
                Input => {
                    Type => 'Text',
                    Size => 40,
                    MaxLength => 40,
                    Required => 1,
                },
                CountMin => 0,
                CountMax => 20,
                CountDefault => 0,
            },
        ],
    },
    {
        Key => 'GraphicAdapter',
        Name => 'Graphic Adapter',
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'OtherEquipment',
        Name => 'Other Equipment',
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountDefault => 0,
    },
    {
        Key => 'WarrantyExpirationDate',
        Name => 'Warranty Expiration Date',
        Searchable => 1,
        Input => {
            Type => 'Date',
            YearPeriodPast => 20,
            YearPeriodFuture => 10,
        },
    },
    {
        Key => 'InstallDate',
        Name => 'Install Date',
        Searchable => 1,
        Input => {
            Type => 'Date',
            Required => 1,
            YearPeriodPast => 20,
            YearPeriodFuture => 10,
        },
        CountMin => 0,
        CountDefault => 0,
    },
    {
        Key => 'Note',
        Name => 'Note',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountDefault => 0,
    },
];",
        Hardware => "[
    {
        Key => 'Vendor',
        Name => 'Vendor',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'Model',
        Name => 'Model',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'Description',
        Name => 'Description',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
        },
    },
    {
        Key => 'Type',
        Name => 'Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Hardware::Type',
            Translation => 1,
        },
    },
    {
        Key => 'Owner',
        Name => 'Owner',
        Searchable => 1,
        Input => {
            Type => 'Customer',
        },
    },
    {
        Key => 'SerialNumber',
        Name => 'Serial Number',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'WarrantyExpirationDate',
        Name => 'Warranty Expiration Date',
        Searchable => 1,
        Input => {
            Type => 'Date',
            YearPeriodPast => 20,
            YearPeriodFuture => 10,
        },
    },
    {
        Key => 'InstallDate',
        Name => 'Install Date',
        Searchable => 1,
        Input => {
            Type => 'Date',
            Required => 1,
            YearPeriodPast => 20,
            YearPeriodFuture => 10,
        },
        CountMin => 0,
        CountMax => 1,
        CountDefault => 0,
    },
    {
        Key => 'Note',
        Name => 'Note',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountMax => 1,
        CountDefault => 0,
    },
];",
        Location => "[
    {
        Key => 'Type',
        Name => 'Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Location::Type',
            Translation => 1,
        },
    },
    {
        Key => 'Phone1',
        Name => 'Phone 1',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'Phone2',
        Name => 'Phone 2',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'Fax',
        Name => 'Fax',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'E-Mail',
        Name => 'E-Mail',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 100,
        },
    },
    {
        Key => 'Address',
        Name => 'Address',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
        },
    },
    {
        Key => 'Note',
        Name => 'Note',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountDefault => 0,
    },
];",
        Network => "[
    {
        Key => 'Description',
        Name => 'Description',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
        },
    },
    {
        Key => 'Type',
        Name => 'Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Network::Type',
            Translation => 1,
        },
    },
    {
        Key => 'NetworkAddress',
        Name => 'Network Address',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 30,
            MaxLength => 20,
            Required => 1,
        },
        CountMin => 0,
        CountMax => 100,
        CountDefault => 1,
        Sub => [
            {
                Key => 'SubnetMask',
                Name => 'Subnet Mask',
                Input => {
                    Type => 'Text',
                    Size => 30,
                    MaxLength => 20,
                    ValueDefault => '255.255.255.0',
                    Required => 1,
                },
                CountMin => 0,
                CountMax => 1,
                CountDefault => 0,
            },
            {
                Key => 'Gateway',
                Name => 'Gateway',
                Input => {
                    Type => 'Text',
                    Size => 30,
                    MaxLength => 20,
                    Required => 1,
                },
                CountMin => 0,
                CountMax => 10,
                CountDefault => 0,
            },
        ],
    },
    {
        Key => 'Note',
        Name => 'Note',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountMax => 1,
        CountDefault => 0,
    },
];",
        Software => "[
    {
        Key => 'Vendor',
        Name => 'Vendor',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'Version',
        Name => 'Version',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'Description',
        Name => 'Description',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
        },
    },
    {
        Key => 'Type',
        Name => 'Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Software::Type',
            Translation => 1,
        },
    },
    {
        Key => 'Owner',
        Name => 'Owner',
        Searchable => 1,
        Input => {
            Type => 'Customer',
        },
    },
    {
        Key => 'SerialNumber',
        Name => 'Serial Number',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
        },
    },
    {
        Key => 'LicenceType',
        Name => 'Licence Type',
        Searchable => 1,
        Input => {
            Type => 'GeneralCatalog',
            Class => 'ITSM::ConfigItem::Software::LicenceType',
            Translation => 1,
        },
    },
    {
        Key => 'LicenceKey',
        Name => 'Licence Key',
        Searchable => 1,
        Input => {
            Type => 'Text',
            Size => 50,
            MaxLength => 50,
            Required => 1,
        },
        CountMin => 0,
        CountMax => 100,
        CountDefault => 0,
        Sub => [
            {
                Key => 'Quantity',
                Name => 'Quantity',
                Input => {
                    Type => 'Integer',
                    ValueMin => 1,
                    ValueMax => 1000,
                    ValueDefault => 1,
                    Required => 1,
                },
                CountMin => 0,
                CountMax => 1,
                CountDefault => 0,
            },
            {
                Key => 'ExpirationDate',
                Name => 'Expiration Date',
                Input => {
                    Type => 'Date',
                    Required => 1,
                    YearPeriodPast => 20,
                    YearPeriodFuture => 10,
                },
                CountMin => 0,
                CountMax => 1,
                CountDefault => 0,
            },
        ],
    },
    {
        Key => 'Media',
        Name => 'Media',
        Input => {
            Type => 'Text',
            Size => 40,
            MaxLength => 20,
        },
    },
    {
        Key => 'Note',
        Name => 'Note',
        Searchable => 1,
        Input => {
            Type => 'TextArea',
            Required => 1,
        },
        CountMin => 0,
        CountMax => 1,
        CountDefault => 0,
    },
];",
    );

    # get list of installed config item classes
    my $ClassList = $Self->{GeneralCatalogObject}->ItemList(
        Class => 'ITSM::ConfigItem::Class',
    );
    my %ReverseClassList = reverse %{$ClassList};

    CLASSNAME:
    for my $ClassName ( sort { lc $a cmp lc $b } keys %Definition ) {

        # check if class exists
        my $ClassID = $ReverseClassList{$ClassName};

        next CLASSNAME if !$ClassID;

        # check if definition already exists
        my $DefinitionList = $Self->{ConfigItemObject}->DefinitionList(
            ClassID => $ClassID,
        );

        next CLASSNAME if !defined $DefinitionList;
        next CLASSNAME if $DefinitionList && ref $DefinitionList eq 'ARRAY' && @{$DefinitionList};

        # add the new definition
        $Self->{ConfigItemObject}->DefinitionAdd(
            ClassID    => $ClassID,
            Definition => $Definition{$ClassName},
            UserID     => 1,
        );
    }

    return 1;
}

=item _LinkDelete()

delete all existing links to config items

    my $Result = $CodeObject->_LinkDelete();

=cut

sub _LinkDelete {
    my ( $Self, %Param ) = @_;

    # get all config items
    my $ConfigItemIDs = $Self->{ConfigItemObject}->ConfigItemSearch();

    return if !$ConfigItemIDs;
    return if ref $ConfigItemIDs ne 'ARRAY';

    # delete the config item links
    for my $ConfigItemID ( @{$ConfigItemIDs} ) {
        $Self->{LinkObject}->LinkDeleteAll(
            Object => 'ITSMConfigItem',
            Key    => $ConfigItemID,
            UserID => 1,
        );
    }

    return 1;
}

=item _FillupEmptyLastVersionID()

fillup empty entries in the last_version_id column of the configitem table

    my $Result = $CodeObject->_FillupEmptyLastVersionID();

=cut

sub _FillupEmptyLastVersionID {
    my ( $Self, %Param ) = @_;

    # get config items with empty last_version_id
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id FROM configitem WHERE '
            . 'last_version_id = 0 OR last_version_id IS NULL',
    );

    # fetch the result
    my @ConfigItemIDs;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @ConfigItemIDs, $Row[0];
    }

    CONFIGITEMID:
    for my $ConfigItemID (@ConfigItemIDs) {

        # get the last version of this config item
        $Self->{DBObject}->Prepare(
            SQL => 'SELECT id FROM configitem_version '
                . 'WHERE configitem_id = ? ORDER BY id DESC',
            Bind  => [ \$ConfigItemID ],
            Limit => 1,
        );

        # fetch the result
        my $VersionID;
        while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
            $VersionID = $Row[0];
        }

        next CONFIGITEMID if !$VersionID;

        # update inci_state_id
        $Self->{DBObject}->Do(
            SQL => 'UPDATE configitem '
                . 'SET last_version_id = ? '
                . 'WHERE id = ?',
            Bind => [ \$VersionID, \$ConfigItemID ],
        );
    }

    return 1;
}

=item _FillupEmptyVersionIncidentStateID()

fillup empty entries in the inci_state_id column of the configitem_version table

    my $Result = $CodeObject->_FillupEmptyVersionIncidentStateID();

=cut

sub _FillupEmptyVersionIncidentStateID {
    my ( $Self, %Param ) = @_;

    # get operational incident state list
    my $InciStateList = $Self->{GeneralCatalogObject}->ItemList(
        Class       => 'ITSM::Core::IncidentState',
        Preferences => {
            Functionality => 'operational',
        },
    );

    # error handling
    if ( !$InciStateList || ref $InciStateList ne 'HASH' || !%{$InciStateList} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "Can't find any item in general catalog class ITSM::Core::IncidentState!",
        );
        return;
    }

    # sort ids
    my @InciStateKeyList = sort keys %{$InciStateList};

    # update inci_state_id
    return $Self->{DBObject}->Do(
        SQL => 'UPDATE configitem_version '
            . 'SET inci_state_id = ? '
            . 'WHERE inci_state_id = 0 OR inci_state_id IS NULL',
        Bind => [ \$InciStateKeyList[0] ],
    );
}

=item _FillupEmptyIncidentAndDeploymentStateID()

fillup empty entries in the cur_depl_state_id or cur_inci_state_id column of the configitem table

    my $Result = $CodeObject->_FillupEmptyIncidentAndDeploymentStateID();

=cut

sub _FillupEmptyIncidentAndDeploymentStateID {
    my ( $Self, %Param ) = @_;

    # get config items with empty cur_depl_state_id or cur_inci_state_id
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id FROM configitem WHERE '
            . 'cur_depl_state_id = 0 OR cur_depl_state_id IS NULL OR '
            . 'cur_inci_state_id = 0 OR cur_inci_state_id IS NULL',
    );

    # fetch the result
    my @ConfigItemIDs;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @ConfigItemIDs, $Row[0];
    }

    CONFIGITEMID:
    for my $ConfigItemID (@ConfigItemIDs) {

        # get last version
        my $LastVersion = $Self->{ConfigItemObject}->VersionGet(
            ConfigItemID => $ConfigItemID,
        );

        next CONFIGITEMID if !$LastVersion;
        next CONFIGITEMID if ref $LastVersion ne 'HASH';
        next CONFIGITEMID if !$LastVersion->{DeplStateID};
        next CONFIGITEMID if !$LastVersion->{InciStateID};

        # complete config item
        $Self->{DBObject}->Do(
            SQL => 'UPDATE configitem SET '
                . 'cur_depl_state_id = ?, '
                . 'cur_inci_state_id = ? '
                . 'WHERE id = ?',
            Bind => [
                \$LastVersion->{DeplStateID},
                \$LastVersion->{InciStateID},
                \$ConfigItemID,
            ],
        );
    }

    return 1;
}

=item _FillupEmptyCurInciStateTypeFromCIs()

Fillup empty entries in the service preferences for the key 'CurInciStateTypeFromCIs'.
This field stores the current incident type as influenced by linked CIs of a service.

    my $Result = $CodeObject->_FillupEmptyCurInciStateTypeFromCIs();

=cut

sub _FillupEmptyCurInciStateTypeFromCIs {
    my ( $Self, %Param ) = @_;

    # get service list
    my %ServiceList = $Self->{ServiceObject}->ServiceList(
        Valid  => 0,
        UserID => 1,
    );

    # get the incident link type
    my $LinkType = $Self->{ConfigObject}->Get('ITSM::Core::IncidentLinkType');

    SERVICEID:
    for my $ServiceID ( sort keys %ServiceList ) {

        # get service data
        my %Service = $Self->{ServiceObject}->ServiceGet(
            ServiceID => $ServiceID,
            UserID    => 1,
        );

        # only if the CurInciStateTypeFromCIs is not set yet
        next SERVICEID if $Service{CurInciStateTypeFromCIs};

        # find all linked config items
        my %LinkedConfigItemIDs = $Self->{LinkObject}->LinkKeyListWithData(
            Object1 => 'Service',
            Key1    => $ServiceID,
            Object2 => 'ITSMConfigItem',
            State   => 'Valid',
            Type    => $LinkType,
            UserID  => 1,
        );

        # set default incident state type
        my $CurInciStateTypeFromCIs = 'operational';

        # investigate the current incident state of each config item
        CONFIGITEMID:
        for my $ConfigItemID ( sort keys %LinkedConfigItemIDs ) {

            # extract config item data
            my $ConfigItemData = $LinkedConfigItemIDs{$ConfigItemID};

            next CONFIGITEMID if $ConfigItemData->{CurDeplStateType} ne 'productive';
            next CONFIGITEMID if $ConfigItemData->{CurInciStateType} eq 'operational';

            # check if service must be set to 'warning'
            if ( $ConfigItemData->{CurInciStateType} eq 'warning' ) {
                $CurInciStateTypeFromCIs = 'warning';
                next CONFIGITEMID;
            }

            # check if service must be set to 'incident'
            if ( $ConfigItemData->{CurInciStateType} eq 'incident' ) {
                $CurInciStateTypeFromCIs = 'incident';
                last CONFIGITEMID;
            }
        }

        # update the current incident state type from CIs of the service
        $Self->{ServiceObject}->ServicePreferencesSet(
            ServiceID => $ServiceID,
            Key       => 'CurInciStateTypeFromCIs',
            Value     => $CurInciStateTypeFromCIs,
            UserID    => 1,
        );
    }

    return 1;
}

=item _DeleteServicePreferences()

Deletes the service preferences for the key 'CurInciStateTypeFromCIs'.

    my $Result = $CodeObject->_DeleteServicePreferences();

=cut

sub _DeleteServicePreferences {
    my ( $Self, %Param ) = @_;

    # get service list
    my %ServiceList = $Self->{ServiceObject}->ServiceList(
        Valid  => 0,
        UserID => 1,
    );

    SERVICEID:
    for my $ServiceID ( sort keys %ServiceList ) {

        # delete the current incident state type from CIs of the service
        $Self->{ServiceObject}->ServicePreferencesSet(
            ServiceID => $ServiceID,
            Key       => 'CurInciStateTypeFromCIs',
            Value     => '',
            UserID    => 1,
        );
    }

    return 1;
}

1;

=back

=head1 TERMS AND CONDITIONS

This software is part of the OTRS project (L<http://otrs.org/>).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

ITSM::ConfigItem::Class
Computer
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Class
Hardware
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Class
Location
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Class
Network
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Class
Software
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Expired
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Inactive
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Maintenance
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Pilot
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Planned
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Production
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Repair
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Retired
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Review
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::DeploymentState
Test/QA
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::YesNo
Yes
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::YesNo
No
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
Laptop
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
Desktop
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
Phone
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
PDA
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
Server
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Computer::Type
Other
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Monitor
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Printer
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Switch
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Router
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
WLAN Access Point
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Security Device
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Backup Device
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Mouse
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Keybord
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Camera
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Beamer
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Modem
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
PCMCIA Card
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
USB Device
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Docking Station
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Scanner
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Hardware::Type
Other
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Building
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Office
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Floor
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Room
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Rack
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Workplace
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Outlet
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
IT Facility
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Location::Type
Other
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Network::Type
LAN
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Network::Type
WLAN
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Network::Type
Telco
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Network::Type
GSM
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Network::Type
Other
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Client Application
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Middleware
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Server Application
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Client OS
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Server OS
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Admin Tool
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
User Tool
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Embedded
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::Type
Other
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Single Licence
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Per User
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Concurrent Users
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Per Processor
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Per Server
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Per Node
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Volume Licence
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Enterprise Licence
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Developer Licence
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Demo
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Time Restricted
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Freeware
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Open Source
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Software::LicenceType
Unlimited
1
current_timestamp
1
current_timestamp
1
ConfigItemCreate
1
current_timestamp
1
current_timestamp
1
ConfigItemDelete
1
current_timestamp
1
current_timestamp
1
LinkAdd
1
current_timestamp
1
current_timestamp
1
LinkDelete
1
current_timestamp
1
current_timestamp
1
NameUpdate
1
current_timestamp
1
current_timestamp
1
VersionCreate
1
current_timestamp
1
current_timestamp
1
ValueUpdate
1
current_timestamp
1
current_timestamp
1
DefinitionUpdate
1
current_timestamp
1
current_timestamp
1
IncidentStateUpdate
1
current_timestamp
1
current_timestamp
1
DeploymentStateUpdate
1
current_timestamp
1
current_timestamp
1
VersionDelete
1
current_timestamp
1
current_timestamp
1
AttachmentAdd
1
current_timestamp
1
current_timestamp
1
AttachmentDelete
1
current_timestamp
1
current_timestamp
1
ITSM::ConfigItem::Class
Location
1
current_timestamp
1
current_timestamp
1
ConfigItemCreate
1
current_timestamp
1
current_timestamp
1
ConfigItemDelete
1
current_timestamp
1
current_timestamp
1
LinkAdd
1
current_timestamp
1
current_timestamp
1
LinkDelete
1
current_timestamp
1
current_timestamp
1
NameUpdate
1
current_timestamp
1
current_timestamp
1
VersionCreate
1
current_timestamp
1
current_timestamp
1
ValueUpdate
1
current_timestamp
1
current_timestamp
1
DefinitionUpdate
1
current_timestamp
1
current_timestamp
1
IncidentStateUpdate
1
current_timestamp
1
current_timestamp
1
DeploymentStateUpdate
1
current_timestamp
1
current_timestamp
1
VersionDelete
1
current_timestamp
1
current_timestamp
1
AttachmentAdd
1
current_timestamp
1
current_timestamp
1
AttachmentDelete
1
current_timestamp
1
current_timestamp
1