<?xml version="1.0" encoding="utf-8" ?>
<otrs_package version="1.1">
    <Name>ImportExportTicket</Name>
    <Version>6.4.1</Version>
    <Vendor>Rother OSS GmbH</Vendor>
    <URL>https://otobo.io/</URL>
    <License>GNU GENERAL PUBLIC LICENSE Version 3, 29 June 2007</License>
    <ChangeLog Date="2026-05-04 11:02:42" Version="6.4.1">- Rename the package to RotherOSS-ImportExportTicketZnuny
- Explicitly mention Znuny in the description.
- Set Version to 0.0.0 as the version is managed by OPMS
- Avoid layout glitch with long German translation
- Added the layout module for DateTime input fields
- Backport the config file
- Change framework version and references to OTOBO in documentation
- Remove customized Kernel/System/ImportExport.pm
- Adapt .sopm file to Znuny 6.4.5
- Add a .gitignore file
- Remove the inadvertently added file .DS_Store
- Translated using Weblate (German)
- Add documentation.
- Add hint to LegacySystemIDSupport to documentation.
- Issue #19: add IsExportComplete()
- Issue #18: avoid infinit loop when exporting without chunking
- Issue #17: Use the default value 0 for the ChunkSize
- Issue #17: fix the name of the backend object in the POD
- Issue #17: fix ObjectDependencies
- Issue #17: tidying, remove redundant module loading
- Add state to the mappinglist.
- Updated copyright year.
- Updated package via pp script.
- Removed documentation.yml file.
- Added Translatable statements to attribute configurations.
- Change framework to 11.0.x again.
- Issue #14: require the framework version 11.0.6
- Issue #14: remove the console commands
- Add new translation and documentation.
- Issue #10: actually pass the large limit to TicketSearch()
- Issue #12: fiddle with the status
- Issue #12: add support for the SkipExistingTickets import filter
- Issue #12: do not import articles if the corresponding ticket was skipped
- Issue #12: some tidying
- Issue #10: workaround for the default limit in TicketSearch()
- Issue #10: tidying and enhances code comments
- Switch date and time related filters around
- Saner ordering of data export filters
- Group the article related options together
- Update only tickets of a specific user
- Tidying: use the variable $LogObject
- Add comment, that search by owner or responsible is not possible
- more rigorous check of the three optional features
- Avoid a warning about an undefined value
- Tidying: replace 'if !' with 'unless'
- Revert &quot;Fix the search parameters for the ticket search&quot;
- Fix the search parameters for the ticket search
- Allow '-' in the prefix
- Pass correct parameter to TIcketIDLookup()
- Avoid warinings about $Ticket{TicketID}
- Tidying, add some code comments
- Sync with changes on OTOBO 11.1.x
- Change some otobo.de to otobo.io
- Set version to 0.0.0, in order to satisfy OPMS
- First stab at backporting from OTOBO 11.1.x
- Re-added lost Validation sub import.
- Added ExternalSource param to correctly handle import values for reference dynamic fields.
- Removed ImportExport as required package because it was included into core with rel-11_0. Updated framework version in documentation.
- Added comment.
- Updated sopm file.
- Did some smaller alignments with ConfigItem ObjectBackend.
- Fix perl.
- Owner required; Skip tickets if articles are on same line; Articles have CreateTime attribute;
- Try to add a list to the doc.
- Add usage to the doc.
- Remove leftover code.
- Multiselect treatment and utf-8 encoding.
- Several fixes.
- Keep TN if given.
- Add creation date import.
- Fix Ticket(Number)IDRelation.
- Fix various stuff.
- Several fixes. Links not working yet, multiselect fields temporarily hardcoded.
- Tidied.
- Fix ticket data assignment for separate articles. Add value maps.
- First stub.
Ported ImportExportTicket back to Znuny 6.4.5. The port is based on the latest version of the package for OTOBO 11.0.x and on the files integrated in OTOBO 11.1.x.</ChangeLog>
    <Description Lang="en">Ticket backend for the ImportExport module in Znuny installations.</Description>
    <Framework Minimum="6.4.5">6.4.x</Framework>
    <BuildCommitID>933ba5d88a5ced5032bd45dac945853af2b0cca2</BuildCommitID>
    <BuildDate>2026-05-04 11:02:45</BuildDate>
    <BuildHost>opms.rother-oss.com</BuildHost>
    <Filelist>
        <File Location="Kernel/Config/Files/XML/ImportExportTicket.xml" Permission="660" Encode="Base64"><?xml version="1.0" encoding="utf-8" ?>
<otrs_config version="2.0" init="Application">
    <Setting Name="ImportExport::ObjectBackendRegistration###Ticket" Required="0" Valid="1">
        <Description Translatable="1">Object backend module registration for the import/export module.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::ModuleRegistration</Navigation>
        <Value>
            <Hash>
                <Item Key="Module">Kernel::System::ImportExport::ObjectBackend::Ticket</Item>
                <Item Key="Name">Ticket</Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::SynchronizeWithForeignDB" Required="0" Valid="0">
        <Description Translatable="1">If activated additional data such as the history and links will be read from a foreign DB containing the exported tickets and added to the imported tickets on this system. This is only available for created, not for updated tickets.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket</Navigation>
        <Value>
            <Hash>
                <Item Key="DatabaseDSN"></Item>
                <Item Key="DatabaseUser"></Item>
                <Item Key="DatabasePw"></Item>
                <Item Key="Type"></Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###001-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key">Queue</Item>
                <Item Key="Map">
                    <Hash>
                        <Item Key="OtherSystemMisc">Misc</Item>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###002-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key">Article_DynamicField_NoMulti</Item>
                <Item Key="Map">
                    <Hash>
                        <Item Key="OtherSystem5">7</Item>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###003-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###004-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###005-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###006-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###007-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###008-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###009-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###010-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###011-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###012-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###013-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###014-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###015-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###016-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###017-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###018-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###019-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###020-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###021-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###022-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###023-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###024-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
    <Setting Name="ImportExport::Ticket::ImportValueMap###025-Custom" Required="0" Valid="0">
        <Description Translatable="1">Value map. Define a key and a value map from import file to OTOBO.</Description>
        <Navigation>Core::ImportExport::ObjectBackend::Ticket::ImportValueMaps</Navigation>
        <Value>
            <Hash>
                <Item Key="Key"></Item>
                <Item Key="Map">
                    <Hash>
                    </Hash>
                </Item>
            </Hash>
        </Value>
    </Setting>
</otrs_config>
</File>
        <File Location="Kernel/System/ImportExport/ObjectBackend/Ticket.pm" Permission="660" Encode="Base64"># --
# OTOBO is a web-based ticketing system for service organisations.
# --
# Copyright (C) 2001-2020 OTRS AG, https://otrs.com/
# Copyright (C) 2019-2025 Rother OSS GmbH, https://otobo.io/
# --
# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) 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 General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# --

package Kernel::System::ImportExport::ObjectBackend::Ticket;

use v5.24;
use strict;
use warnings;
use namespace::autoclean;
use utf8;

# core modules
use Encode;
use MIME::Base64 qw(encode_base64 decode_base64);

# CPAN modules

# OTOBO modules
use Kernel::Language              qw(Translatable);
use Kernel::System::VariableCheck qw(IsArrayRefWithData);

our @ObjectDependencies = (
    'Kernel::Config',
    'Kernel::System::DB',
    'Kernel::System::DynamicField',
    'Kernel::System::DynamicField::Backend',
    'Kernel::System::ImportExport',
    'Kernel::System::LinkObject',
    'Kernel::System::Lock',
    'Kernel::System::Log',
    'Kernel::System::Priority',
    'Kernel::System::Queue',
    'Kernel::System::SLA',
    'Kernel::System::Service',
    'Kernel::System::State',
    'Kernel::System::Ticket',
    'Kernel::System::Ticket::Article',
    'Kernel::System::Type',
    'Kernel::System::User',
);

=head1 NAME

Kernel::System::ImportExport::ObjectBackend::Ticket - import/export backend for tickets

=head1 DESCRIPTION

All functions to import and export tickets.

=head1 PUBLIC INTERFACE

=head2 new()

create an object

    use Kernel::System::ObjectManager;

    local $Kernel::OM = Kernel::System::ObjectManager->new();
    my $BackendObject = $Kernel::OM->Get('Kernel::System::ImportExport::ObjectBackend::Ticket');

=cut

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

    # Changing the config
    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    # Fiddling with SysConfig in the constructor is a bit hackish.
    # It should be fine as the ImportExport object is only used in console commands
    # and in a single frontend module. The changed config object in the frontend module
    # is fine as the config object is recreated for each request.
    $ConfigObject->Set(
        Key   => 'SendmailModule',
        Value => 'Kernel::System::Email::DoNotSendEmail',
    );
    $ConfigObject->Set(
        Key   => 'CheckEmailAddresses',
        Value => 0,
    );

    # turn off some event handlers
    $ConfigObject->Set(
        Key   => 'Ticket::EventModulePost###950-TicketAppointments',
        Value => undef,
    );
    $ConfigObject->Set(
        Key   => 'Ticket::EventModulePost###8000-GenericInterface',
        Value => undef,
    );

    # allocate new hash for object
    return bless {
        TicketIDRelation       => {},
        TicketNumberIDRelation => {},
        AllFoundTicketIDs      => undef,    # will be initialized in first call to ExportDataGet()
        LastHandledIndex       => -1,       # used for chunking
        ChunkingFinished       =>  1,       # indicate that chunking is finished, which is kind of true when no chunking is requested
    }, $Type;
}

=head2 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} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need UserID!',
        );

        return;
    }

    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');
    my @Attributes;    # will be returned

    # queue
    {
        my %QueueList = $Kernel::OM->Get('Kernel::System::Queue')->QueueList;
        push @Attributes,
            {
                Key   => 'QueueID',
                Name  => Translatable('Default Queue'),
                Input => {
                    Type        => 'Selection',
                    Data        => \%QueueList,
                    Required    => 1,
                    Translation => 0,
                    Class       => 'Modernize',
                },
            };
    }

    if ( $ConfigObject->Get('Ticket::Type') ) {
        my %TypeList = $Kernel::OM->Get('Kernel::System::Type')->TypeList(
            Valid => 1,
        );

        push @Attributes, {
            Key   => 'TypeID',
            Name  => Translatable('Default Type'),
            Input => {
                Type        => 'Selection',
                Data        => \%TypeList || {},
                Required    => 1,
                Translation => 1,
                Class       => 'Modernize',
            },
        };
    }

    if ( $ConfigObject->Get('Ticket::Service') ) {
        my %ServiceList = $Kernel::OM->Get('Kernel::System::Service')->ServiceList(
            UserID => 1,
        );

        push @Attributes, {
            Key   => 'ServiceID',
            Name  => Translatable('Default Service'),
            Input => {
                Type         => 'Selection',
                Data         => \%ServiceList || {},
                Required     => 0,
                Translation  => 0,
                PossibleNone => 1,
                Class        => 'Modernize',
            },
        };

        my %SLAList = $Kernel::OM->Get('Kernel::System::SLA')->SLAList(
            UserID => 1,
        );

        push @Attributes, {
            Key   => 'SLAID',
            Name  => Translatable('Default SLA'),
            Input => {
                Type         => 'Selection',
                Data         => \%SLAList || {},
                Required     => 0,
                Translation  => 0,
                PossibleNone => 1,
                Class        => 'Modernize',
            },
        };
    }

    # State
    {
        my %StateList = $Kernel::OM->Get('Kernel::System::State')->StateList(
            UserID => 1,
        );

        push @Attributes,
            {
                Key   => 'StateID',
                Name  => Translatable('Default state'),
                Input => {
                    Type        => 'Selection',
                    Data        => \%StateList,
                    Required    => 1,
                    Translation => 1,
                    Class       => 'Modernize',
                },
            };
    }

    # Priority
    {
        my %PriorityList = $Kernel::OM->Get('Kernel::System::Priority')->PriorityList(
            Valid => 1,
        );

        push @Attributes,
            {
                Key   => 'PriorityID',
                Name  => Translatable('Default priority'),
                Input => {
                    Type        => 'Selection',
                    Data        => \%PriorityList,
                    Required    => 1,
                    Translation => 1,
                    Class       => 'Modernize',
                },
            };
    }

    # Owner and Responsible
    {
        my %UserList = $Kernel::OM->Get('Kernel::System::User')->UserList;

        push @Attributes,
            {
                Key   => 'OwnerID',
                Name  => Translatable('Default owner'),
                Input => {
                    Type        => 'Selection',
                    Data        => \%UserList,
                    Required    => 1,
                    Translation => 0,
                    Class       => 'Modernize',
                },
            };

        if ( $ConfigObject->Get('Ticket::Responsible') ) {
            push @Attributes,
                {
                    Key   => 'ResponsibleID',
                    Name  => Translatable('Default responsible'),
                    Input => {
                        Type         => 'Selection',
                        Data         => \%UserList,
                        Required     => 0,
                        PossibleNone => 1,
                        Translation  => 0,
                        Class        => 'Modernize',
                    },
                };
        }
    }

    {
        my %LockList = $Kernel::OM->Get('Kernel::System::Lock')->LockList(
            UserID => 1,
        );

        push @Attributes,
            {
                Key   => 'LockID',
                Name  => Translatable('Default lock'),
                Input => {
                    Type        => 'Selection',
                    Data        => \%LockList,
                    Required    => 1,
                    Translation => 1,
                    Class       => 'Modernize',
                },
            };
    }

    push @Attributes,
        {
            Key   => 'CustomerID',
            Name  => Translatable('Default CustomerID'),
            Input => {
                Type      => 'Text',
                Required  => 0,
                Size      => 50,
                MaxLength => 250,
            },
        },
        {
            Key   => 'CustomerUserID',
            Name  => Translatable('Default CustomerUserID'),
            Input => {
                Type      => 'Text',
                Required  => 0,
                Size      => 50,
                MaxLength => 250,
            },
        },
        {
            Key   => 'ArchiveFlag',
            Name  => Translatable('Default ArchiveFlag'),
            Input => {
                Type         => 'Selection',
                Data         => { map { $_ => $_ } qw( y n ) },
                Required     => 1,
                Translation  => 0,
                Class        => 'Modernize',
                ValueDefault => 'n',
            },
        },
        {
            Key   => 'Subject',
            Name  => Translatable('Default subject'),
            Input => {
                Type         => 'Text',
                Required     => 0,
                Size         => 50,
                MaxLength    => 250,
                ValueDefault => $ConfigObject->Get('TicketImport::DefaultSubject'),
            },
        },
        {
            Key   => 'Body',
            Name  => Translatable('Default body'),
            Input => {
                Type         => 'Text',
                Required     => 0,
                Size         => 50,
                MaxLength    => 250,
                ValueDefault => $ConfigObject->Get('TicketImport::DefaultBody'),
            },
        },
        {
            Key   => 'SenderType',
            Name  => Translatable('Default sender type'),
            Input => {
                Type => 'Selection',
                Data => {
                    agent    => 'agent',
                    customer => 'customer',
                },
                Required => 1,
                Class    => 'Modernize',
            },
        },
        {
            Key   => 'IsVisibleToCustomer',
            Name  => Translatable('Default is visible to customer'),
            Input => {
                Type => 'Checkbox',
            },
        },
        {
            Key   => 'EmptyFieldsLeaveTheOldValues',
            Name  => Translatable('Empty fields mean that the current values are kept'),
            Input => {
                Type => 'Checkbox',
            },
        },
        {
            Key   => 'SkipExistingTickets',
            Name  => Translatable('Do not update existing tickets'),
            Input => {
                Type => 'Checkbox',
            },
        },
        {
            Key   => 'AllowedOwnerInTarget',
            Name  => Translatable('Only update tickets of this user in the target system'),
            Input => {
                Type      => 'Text',
                Required  => 0,
                Size      => 50,
                MaxLength => 191,      # length of users.login field in the database
            },
        };

    # article related options
    push @Attributes,
        {
            Key   => 'IncludeArticles',
            Name  => Translatable('Import/Export articles'),
            Input => {
                Type => 'Checkbox',
            },
        },
        {
            Key   => 'ArticleBackend',
            Name  => Translatable('Default Backend'),
            Input => {
                Type         => 'Selection',
                Data         => { map { $_ => $_ } qw( Email Phone Internal ) },
                Required     => 1,
                Translation  => 0,
                Class        => 'Modernize',
                ValueDefault => 'n',
            },
        },
        {
            Key   => 'ArticleSeparateLines',
            Name  => Translatable('Store articles on separate lines indicated by a blank first entry'),
            Input => {
                Type => 'Checkbox',
            },
        },
        {
            Key   => 'IncludeAttachments',
            Name  => Translatable('Import/Export attachments (as the last entries per line)'),
            Input => {
                Type => 'Checkbox',
            },
        };

    return \@Attributes;
}

=head2 MappingObjectAttributesGet()

gets the mapping attributes of an object as reference to an array of hash references.

    my $Attributes = $ObjectBackend->MappingObjectAttributesGet(
        TemplateID => 123,
        UserID     => 1,
    );

Returns:

    # TODO
    my $Attributes = [
        {
            Input => {
                Data => [
                    [...]
                ],
            },
        },
    ];

=cut

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

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );

            return;
        }
    }

    my $ImportExportObject = $Kernel::OM->Get('Kernel::System::ImportExport');

    # get object data
    my $ObjectData = $ImportExportObject->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    return [] unless $ObjectData;
    return [] unless ref $ObjectData eq 'HASH';

    # the possible mappings depend on the activated feature set
    my $ConfigObject        = $Kernel::OM->Get('Kernel::Config');
    my @TypeElements        = $ConfigObject->Get('Ticket::Type')        ? qw( Type TypeID )                 : ();
    my @ServiceElements     = $ConfigObject->Get('Ticket::Service')     ? qw( Service ServiceID SLA SLAID ) : ();
    my @ResponsibleElements = $ConfigObject->Get('Ticket::Responsible') ? qw( Responsible ResponsibleID )   : ();
    my @ElementList =
        map { { Key => $_, Value => $_ } }
        (
            qw( TicketID TicketNumber Title ),
            @TypeElements,
            qw( Queue QueueID ),
            @ServiceElements,
            qw( State StateID Priority PriorityID CustomerID CustomerUserID Owner OwnerID Lock LockID ),
            @ResponsibleElements,
            qw( ArchiveFlag Created )
        );

    my $DynamicFieldObject = $Kernel::OM->Get('Kernel::System::DynamicField');

    # columns for dynamic fields
    {
        my $DynFieldList = $DynamicFieldObject->DynamicFieldList(
            ObjectType => 'Ticket',
            ResultType => 'HASH',
        );
        push @ElementList,
            map { { Key => "DynamicField_$_", Value => "DynamicField_$_" } }
            sort
            values $DynFieldList->%*;
    }

    if ( $ObjectData->{IncludeArticles} ) {
        if ( $ObjectData->{ArticleSeparateLines} ) {
            push @ElementList, {
                Key   => 'Article_TicketID',
                Value => 'Article_TicketID',
            };
        }

        # columns for articles
        push @ElementList, map { { Key => "Article_$_", Value => "Article_$_" } }
            qw( ArticleID ArticleBackend From To Cc Bcc Subject Body SenderType IsVisibleForCustomer
            MessageID ReplyTo InReplyTo References Charset MimeType PlainEmail CreateTime );

        # columns for article dynamic fields
        my $DynFieldList = $DynamicFieldObject->DynamicFieldList(
            ObjectType => 'Article',
            ResultType => 'HASH',
        );
        push @ElementList,
            map { { Key => "Article_DynamicField_$_", Value => "Article_DynamicField_$_" } }
            sort
            values $DynFieldList->%*;
    }

    return [
        {
            Key   => 'Key',
            Name  => Translatable('Key'),
            Input => {
                Type         => 'Selection',
                Data         => \@ElementList,
                Required     => 1,
                Translation  => 0,
                PossibleNone => 1,
                Class        => 'Modernize',
            },
        },
        {
            Key   => 'Identifier',
            Name  => Translatable('Identifier'),
            Input => {
                Type => 'Checkbox',
            },
        },
    ];
}

=head2 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 ) = @_;

    #  note that there is no search by owner or responsible

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );

            return;
        }
    }

    # TODO: why is the ObjectData needed here?
    # get object data
    my $ImportExportObject = $Kernel::OM->Get('Kernel::System::ImportExport');
    my $ObjectData         = $ImportExportObject->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    return [] unless $ObjectData;
    return [] unless ref $ObjectData eq 'HASH';

    my %QueueList = $Kernel::OM->Get('Kernel::System::Queue')->QueueList();

    my %StateList = $Kernel::OM->Get('Kernel::System::State')->StateList(
        UserID => 1,
    );

    my %PriorityList = $Kernel::OM->Get('Kernel::System::Priority')->PriorityList(
        Valid => 1,
    );

    my @Attributes = (
        {
            Key   => 'QueueIDs',
            Name  => 'Queue',
            Input => {
                Type         => 'Selection',
                Data         => \%QueueList,
                Required     => 0,
                Translation  => 0,
                PossibleNone => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        },
    );

    my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

    if ( $ConfigObject->Get('Ticket::Type') ) {
        my %TypeList = $Kernel::OM->Get('Kernel::System::Type')->TypeList(
            Valid => 1,
        );

        push @Attributes, {
            Key   => 'TypeIDs',
            Name  => 'Type',
            Input => {
                Type         => 'Selection',
                Data         => \%TypeList || {},
                Required     => 0,
                Translation  => 1,
                PossibleNone => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        };
    }

    if ( $ConfigObject->Get('Ticket::Service') ) {
        my %ServiceList = $Kernel::OM->Get('Kernel::System::Service')->ServiceList(
            UserID => 1,
        );

        push @Attributes, {
            Key   => 'ServiceIDs',
            Name  => 'Service',
            Input => {
                Type         => 'Selection',
                Data         => \%ServiceList || {},
                Required     => 0,
                Translation  => 0,
                PossibleNone => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        };

        my %SLAList = $Kernel::OM->Get('Kernel::System::SLA')->SLAList(
            UserID => 1,
        );

        push @Attributes, {
            Key   => 'SLAIDs',
            Name  => 'SLA',
            Input => {
                Type         => 'Selection',
                Data         => \%SLAList || {},
                Required     => 0,
                Translation  => 0,
                PossibleNone => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        };
    }

    push @Attributes,
        {
            Key   => 'StateIDs',
            Name  => 'State',
            Input => {
                Type         => 'Selection',
                Data         => \%StateList,
                Required     => 0,
                PossibleNone => 1,
                Translation  => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        },
        {
            Key   => 'PriorityIDs',
            Name  => 'Priority',
            Input => {
                Type         => 'Selection',
                Data         => \%PriorityList,
                Required     => 0,
                PossibleNone => 1,
                Translation  => 1,
                Size         => 5,
                Multiple     => 1,
                Class        => 'Modernize',
            },
        },
        {
            Key   => 'CustomerID',
            Name  => 'CustomerID',
            Input => {
                Type      => 'Text',
                Size      => 50,
                MaxLength => 250,
            },
        };

    # Filter by create or change time, specify in minutes
    {
        my @KeyAndNames = (
            [ TicketCreateTimeNewerMinutes => 'Ticket Create Time (newer) [min]' ],
            [ TicketCreateTimeOlderMinutes => 'Ticket Create Time (older) [min]' ],
            [ TicketChangeTimeNewerMinutes => 'Ticket Change Time (newer) [min]' ],
            [ TicketChangeTimeOlderMinutes => 'Ticket Change Time (older) [min]' ],
        );
        for my $ArrRef (@KeyAndNames) {
            my ( $Key, $Name ) = $ArrRef->@*;
            push @Attributes,
                {
                    Key   => $Key,
                    Name  => $Name,
                    Input => {
                        Type      => 'Text',
                        Size      => 50,
                        MaxLength => 50,
                    },
                },
                ;
        }
    }

    # Filter by create or change time, specify by date and time
    {
        my @KeyAndNames = (
            [ TicketCreateTimeNewerDate     => 'Ticket Create Time (after)' ],
            [ TicketCreateTimeOlderDate     => 'Ticket Create Time (before)' ],
            [ TicketLastChangeTimeNewerDate => 'Ticket Last Change Time (after)' ],
            [ TicketLastChangeTimeOlderDate => 'Ticket Last Change Time (before)' ],
        );
        for my $ArrRef (@KeyAndNames) {
            my ( $Key, $Name ) = $ArrRef->@*;
            push @Attributes,
                {
                    Key   => $Key,
                    Name  => $Name,
                    Input => {
                        Type     => 'DateTime',
                        Optional => 1,
                    },
                },
                ;
        }
    }

    return \@Attributes;
}

=head2 ExportDataGet()

get export data as a reference to an array for array references, that is a C<2D-table>

    my $Rows = $ObjectBackend->ExportDataGet(
        TemplateID => 123,
        UserID     => 1,
    );

When the parameter C<ChunkSize> is passed then chunked export mode is assumed.
On the first invocation the complete search result list is retrieved
and stored in the instance. Then the detailed data for first chunk is returned.
Each subsequent invocation only gets the detailed data for the next chunk.

=cut

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

    # check needed stuff
    for my $Argument (qw(TemplateID UserID)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );

            return;
        }
    }

    my $ImportExportObject = $Kernel::OM->Get('Kernel::System::ImportExport');

    # get object data
    my $ObjectData = $ImportExportObject->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check object data
    if ( !$ObjectData || ref $ObjectData ne 'HASH' ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "No object data found for the template id $Param{TemplateID}",
        );

        return;
    }

    # get the mapping list
    my $MappingList = $ImportExportObject->MappingList(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check the mapping list
    if ( !$MappingList || ref $MappingList ne 'ARRAY' || !@{$MappingList} ) {

        $Kernel::OM->Get('Kernel::System::Log')->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 = $ImportExportObject->MappingObjectDataGet(
            MappingID => $MappingID,
            UserID    => $Param{UserID},
        );

        # check mapping object data
        if ( !$MappingObjectData || ref $MappingObjectData ne 'HASH' ) {

            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "No valid mapping list found for the template id $Param{TemplateID}",
            );

            return;
        }

        push @MappingObjectList, $MappingObjectData;
    }

    # List of IDs for tickets that are to be exported.
    # In chunked mode this is only chunk. In non-chunked mode these are all relevant IDs.
    my @TicketIDs;
    {
        # Search all Ticket_IDs.
        # When in chunked mode then get the complete list in the first invocation and store it as instance data.
        # For simplicities sake assume that the template ID does not change in subsequent calls.
        my %TicketSearchParam = (
            TemplateID => $Param{TemplateID},
            UserID     => $Param{UserID},
        );
        if ( ( $Param{ChunkSize} // 0 ) >= 1 ) {

            # chunked mode,
            $Self->{ChunkingFinished} = 0;

            # search only on the first invocation
            $Self->{AllFoundTicketIDs} //= [ $Self->_TicketSearch(%TicketSearchParam) ];

            # do the chunking
            my $NewLastHandledIndex = $Self->{LastHandledIndex} + $Param{ChunkSize};
            my $EndIndex            = $#{ $Self->{AllFoundTicketIDs} };
            if ( $NewLastHandledIndex >= $EndIndex ) {
                $Self->{ChunkingFinished} = 1;
                $NewLastHandledIndex = $EndIndex;
            }
            @TicketIDs = @{ $Self->{AllFoundTicketIDs} }[ $Self->{LastHandledIndex} + 1 .. $NewLastHandledIndex ];
            $Self->{LastHandledIndex} = $NewLastHandledIndex;
        }
        else {
            @TicketIDs = $Self->_TicketSearch(%TicketSearchParam);
        }
    }

    my $ArticleObject = $Kernel::OM->Get('Kernel::System::Ticket::Article');

    my @ExportData;
    my %TicketData;

    my @TicketMapping;
    my @ArticleMapping;
    my $TicketMappingLast;
    my $ArticleMappingLast = 0;    # in case of separate lines an empty entry will precede (thus not -1)
    my $StorePlainEmail    = 0;

    for my $i ( 0 .. $#MappingObjectList ) {

        # handle empty key
        if ( !$MappingObjectList[$i]{Key} ) {
            $TicketMapping[$i]{Key} = '';
            if ( !$ObjectData->{ArticleSeparateLines} ) {
                $TicketMappingLast = $i;
            }
        }

        # article keys
        elsif ( $MappingObjectList[$i]{Key} =~ /^Article_(.+)$/ ) {
            if ( $ObjectData->{ArticleSeparateLines} ) {
                push @ArticleMapping, $MappingObjectList[$i];
                $ArticleMapping[ ++$ArticleMappingLast ]{Key} = $1;
                $TicketMapping[$i]{Key} = '';
            }
            else {
                $ArticleMapping[$i]      = $MappingObjectList[$i];
                $ArticleMapping[$i]{Key} = $1;
                $ArticleMappingLast      = $i;
            }

            if ( $1 eq 'PlainEmail' ) {
                $StorePlainEmail = 1;
            }
        }

        # ticket keys
        else {
            $TicketMapping[$i] = $MappingObjectList[$i];
            $TicketMappingLast = $i;
        }
    }

    # export tickets ...
    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
    for my $TicketID (@TicketIDs) {

        %TicketData = $TicketObject->TicketGet(
            TicketID      => $TicketID,
            UserID        => 1,
            DynamicFields => 1,
        );

        # add data to the export data array
        my @TicketItem;
        for my $i ( 0 .. $TicketMappingLast ) {

            # extract key
            my $Key = $TicketMapping[$i]{Key};

            $TicketItem[$i] = $Key && defined $TicketData{$Key}
                ? IsArrayRefWithData( $TicketData{$Key} )
                    ? join( '###', ( map { encode_base64( Encode::encode( 'UTF-8', $_ ) ) } $TicketData{$Key}->@* ) )
                    : $TicketData{$Key}
                : '';
        }

        if ( !$ObjectData->{IncludeArticles} || $ObjectData->{ArticleSeparateLines} ) {
            push @ExportData, \@TicketItem;
        }

        if ( $ObjectData->{IncludeArticles} ) {

            # Get article data.
            my @Articles = $ArticleObject->ArticleList(
                TicketID => $TicketID,
            );

            my $ArticleCount = 0;
            for my $Article (@Articles) {

                my $ArticleBackendObject = $ArticleObject->BackendForArticle( %{$Article} );

                my %ArticleFull = $ArticleBackendObject->ArticleGet(
                    TicketID      => $TicketID,
                    ArticleID     => $Article->{ArticleID},
                    DynamicFields => 1,
                    UserID        => 1,
                );

                $ArticleFull{ArticleBackend} = $ArticleBackendObject->ChannelNameGet();

                if ( $StorePlainEmail && $ArticleBackendObject->can('ArticlePlain') ) {
                    $ArticleFull{PlainEmail} = $ArticleBackendObject->ArticlePlain(
                        ArticleID => $Article->{ArticleID},
                        UserID    => 1,
                    );
                }

                my @ArticleItem = $ObjectData->{ArticleSeparateLines} ? ('') : @TicketItem;
                ARTICLEMAP:
                for my $i ( 0 .. $ArticleMappingLast ) {

                    # empty fields are done in the ticket part
                    next ARTICLEMAP unless $ArticleMapping[$i];

                    # extract key
                    my $Key = $ArticleMapping[$i]{Key};

                    $ArticleItem[$i] = defined $ArticleFull{$Key}
                        ? IsArrayRefWithData( $ArticleFull{$Key} )
                            ? join( '###', ( map { encode_base64( Encode::encode( 'UTF-8', $_ ) ) } $ArticleFull{$Key}->@* ) )
                            : $ArticleFull{$Key}
                        : '';
                }

                if ( $ObjectData->{IncludeAttachments} && $ArticleBackendObject->can('ArticleAttachmentIndex') ) {
                    my %Index = $ArticleBackendObject->ArticleAttachmentIndex(
                        ArticleID => $Article->{ArticleID},
                    );

                    for my $Key ( sort keys %Index ) {
                        my %Attachment = $ArticleBackendObject->ArticleAttachment(
                            TicketID  => $TicketID,
                            ArticleID => $Article->{ArticleID},
                            FileID    => $Key,
                        );

                        for my $Key (qw( Filename ContentType Disposition )) {
                            $Attachment{$Key} = Encode::encode( 'UTF-8', $Attachment{$Key} );
                        }

                        my $AttachmentString;
                        for my $Key (qw( Filename ContentID ContentType Disposition Content ContentAlternative )) {
                            $Attachment{$Key} //= '';
                            $AttachmentString .= $AttachmentString ? '###' : '';
                            $AttachmentString .= $Key . '###' . encode_base64( $Attachment{$Key} );
                        }

                        push @ArticleItem, $AttachmentString;
                    }
                }

                push @ExportData, \@ArticleItem;
            }
        }
    }

    return \@ExportData;
}

=head2 IsExportComplete()

Indicate whether the last C<ExportDataGet()> has returned the last chunk of data.
A true value is also returned when chunking had not been activated.

    my $ChunkingFinished = $ObjectBackend->IsExportComplete;

=cut

sub IsExportComplete {
    my ($Self) = @_;

    return $Self->{ChunkingFinished};
}

=head2 ImportDataSave()

imports a single entity of the import data. An entity is either a ticket or an article.

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 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 ( $TicketID, $RetCode ) = $ObjectBackend->ImportDataSave(
        TemplateID    => 123,
        ImportDataRow => $ArrayRef,
        Counter       => 367,
        UserID        => 1,
    );

An empty C<TicketID> indicates failure. Otherwise it indicates the
location of the imported data.
C<RetCode> is one of:

=over 4

=item "Ticket not changed" : the import did not change the ticket data

=item "Ticket not changed, Article created" : the import did not change the ticket data. But an article was created.

=item "Ticket created" : a ticket was created

=item "Ticket created, Article created" : a ticket with an article was created

=item "Ticket updated" : a ticket was updated

=item "Ticket skipped" : a ticket was skipped because of an import filter. was shut.

There are two input filters: AllowedOwnerInTarget and SkipExistingTickets.

=item "Ticket updated, Article created" : a ticket was updated and an article was created

=item "Article created" : an article was created

=item "Article skipped" : an article was skipped

Either because the corresponding ticket was skipped or because the article
already had been imported.

=back

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} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );

            return;
        }
    }

    # check import data row
    if ( ref $Param{ImportDataRow} ne 'ARRAY' ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Can't import entity $Param{Counter}: ImportDataRow must be an array reference",
        );

        return;
    }

    my $ImportExportObject = $Kernel::OM->Get('Kernel::System::ImportExport');

    # get object data, that is the config of this template
    my $ObjectData = $ImportExportObject->ObjectDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    # check object data
    if ( !$ObjectData || ref $ObjectData ne 'HASH' ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  =>
                "Can't import entity $Param{Counter}: "
                . "No object data found for the template id '$Param{TemplateID}'",
        );

        return;
    }

    # get and check the mapping list
    # TODO: why is this called for every row of the import file ?
    my $MappingList = $ImportExportObject->MappingList(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );
    if ( !$MappingList || ref $MappingList ne 'ARRAY' || !@{$MappingList} ) {

        $Kernel::OM->Get('Kernel::System::Log')->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
    # TODO: why is this called for every row of the import file ?
    my @MappingObjectList;
    for my $MappingID ( $MappingList->@* ) {

        # get mapping object data
        my $MappingObjectData = $ImportExportObject->MappingObjectDataGet(
            MappingID => $MappingID,
            UserID    => $Param{UserID},
        );

        # check mapping object data
        if ( !$MappingObjectData || ref $MappingObjectData ne 'HASH' ) {

            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  =>
                    "Can't import entity $Param{Counter}: "
                    . "No mapping object data found for the mapping id '$MappingID'",
            );

            return;
        }

        push @MappingObjectList, $MappingObjectData;
    }

    # prepare import data
    my %Ticket;
    my %Article;
    my %Identifier;

    my $ConfigObject  = $Kernel::OM->Get('Kernel::Config');
    my $MappingConfig = $ConfigObject->Get('ImportExport::Ticket::ImportValueMap') // {};
    my %ValueMap =
        map { $_->{Key} => $_->{Map} }
        values $MappingConfig->%*;

    # Determine whether we have an article on a separate line.
    # The value of the first column is the marker. When it is empty,
    # pr has the value C<0>, the we have an article on a separate line.
    my $ArticleIsOnSeparateLine =
        $ObjectData->{IncludeArticles}
        &&
        $ObjectData->{ArticleSeparateLines}
        &&
        !$Param{ImportDataRow}[0]
        &&
        1;

    if ( $ArticleIsOnSeparateLine && $Self->{LastTicketWasSkipped} ) {

        # Skip this article because the last ticket was ignored.
        # Returning -1 as this does not count as a failure,
        # but we still want to indicate that something special is going on.
        return ( -1, 'Article skipped' );
    }
    elsif ($ArticleIsOnSeparateLine) {

        # Handling an article an a separate line. The last ticket was not ignored.

        my $i = 1;
        MAPPINGOBJECTDATA:
        for my $MappingObjectData (@MappingObjectList) {

            if ( $MappingObjectData->{Key} =~ /^Article_(.+)$/ ) {
                my $Value = $Param{ImportDataRow}[ $i++ ];
                $Article{$1} = defined $Value && $ValueMap{ $MappingObjectData->{Key} } && defined $ValueMap{ $MappingObjectData->{Key} }{$Value}
                    ? $ValueMap{ $MappingObjectData->{Key} }{$Value} : $Value;
            }
            else {
                next MAPPINGOBJECTDATA;
            }

            next MAPPINGOBJECTDATA unless $MappingObjectData->{Identifier};

            if ( $MappingObjectData->{Key} ne 'Article_ArticleID' ) {
                $Kernel::OM->Get('Kernel::System::Log')->Log(
                    Priority => 'error',
                    Message  =>
                        "Can't import entity $Param{Counter}: "
                        . "Articles can only be identified via 'Article_ArticleID' not by '$MappingObjectData->{Key}'.",
                );

                return;
            }
            elsif ( !$Param{ImportDataRow}[ $i - 1 ] ) {
                $Kernel::OM->Get('Kernel::System::Log')->Log(
                    Priority => 'error',
                    Message  =>
                        "Can't import entity $Param{Counter}: "
                        . "'Article_ArticleID' can not be empty or 0 when used as identifier.",
                );

                return;
            }

            $Identifier{Article}{ArticleID} = 1;
        }

        if ( $ObjectData->{IncludeAttachments} && $i <= $#{ $Param{ImportDataRow} } ) {

            # the last and unmapped entries are attachments
            $Article{Attachments} = [ @{ $Param{ImportDataRow} }[ $i .. $#{ $Param{ImportDataRow} } ] ];
        }
    }
    else {

        # Handling a line with ticket information.
        # The data for an article might be included in that line.
        MAPPINGOBJECTDATA:
        for my $i ( 0 .. $#MappingObjectList ) {

            my $MappingObjectData = $MappingObjectList[$i];

            my $Value = $Param{ImportDataRow}[$i];
            $Value = defined $Value && $ValueMap{ $MappingObjectData->{Key} } && defined $ValueMap{ $MappingObjectData->{Key} }{$Value}
                ? $ValueMap{ $MappingObjectData->{Key} }{$Value} : $Value;

            if ( $MappingObjectData->{Key} =~ m/^Article_(.+)$/ ) {
                next MAPPINGOBJECTDATA if $ObjectData->{ArticleSeparateLines};
                next MAPPINGOBJECTDATA unless $ObjectData->{IncludeArticles};

                $Article{$1} = $Value;
            }
            else {
                $Ticket{ $MappingObjectData->{Key} } = $Value;
            }

            # identifiers are usually TicketID or TicketNumber
            next MAPPINGOBJECTDATA unless $MappingObjectData->{Identifier};

            if ( !$Value ) {
                $Kernel::OM->Get('Kernel::System::Log')->Log(
                    Priority => 'error',
                    Message  =>
                        "Can't import entity $Param{Counter}: "
                        . "'$MappingObjectData->{Key}' can not be empty or 0 when used as identifier.",
                );

                return;
            }

            if ( $MappingObjectData->{Key} eq 'Article_ArticleID' ) {
                $Identifier{Article}{ArticleID} = 1;
            }
            elsif ( $MappingObjectData->{Key} =~ /^Article_/ ) {
                $Kernel::OM->Get('Kernel::System::Log')->Log(
                    Priority => 'error',
                    Message  =>
                        "Can't import entity $Param{Counter}: "
                        . "Currently only Article_ArticleID is a valid identifier for articles (not '$MappingObjectData->{Key}').",
                );

                return;
            }
            else {
                $Identifier{Ticket}{ $MappingObjectData->{Key} } = 1;
            }
        }

        if ( %Article && $ObjectData->{IncludeAttachments} && $#MappingObjectList < $#{ $Param{ImportDataRow} } ) {

            # the last and unmapped entries are attachments
            $Article{Attachments} = [ @{ $Param{ImportDataRow} }[ $#MappingObjectList + 1 .. $#{ $Param{ImportDataRow} } ] ];
        }
    }

    my $Status = 'Ticket not changed';
    $Self->{Error} = '';
    if (
        %Ticket
        &&
        ( !$Ticket{TicketID} || !exists $Self->{TicketIDRelation}{ $Ticket{TicketID} } )
        )
    {
        $Status = $Self->_ImportTicket(
            Ticket     => \%Ticket,
            Identifier => $Identifier{Ticket},
            ObjectData => $ObjectData,
        );

        if ( !$Status ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Can't import entity $Param{Counter}: TicketImport: $Self->{Error}",
            );

            return;
        }
    }

    # An article exists because an article was declared in the same line as the ticket,
    # or because an article was declared in a separate line.
    if ( %Article && $ObjectData->{IncludeArticles} ) {
        my $ArticleStatus = $Self->_ImportArticle(
            Article    => \%Article,
            Identifier => $Identifier{Article},
            ObjectData => $ObjectData,
        );

        if ( !$ArticleStatus ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Can't import entity $Param{Counter}: ArticleImport: $Self->{Error}",
            );

            return;
        }

        # Only the article status is relevant when the article is on a seperate line.
        # Otherwise both ticket status and article status are relevant.
        if ($ArticleIsOnSeparateLine) {
            $Status = $ArticleStatus;
        }
        else {
            $Status = join ', ', $Status, $ArticleStatus;
        }
    }

    # Skipped tickets and articles are not reported as failures
    return ( -1, $Status ) if $Status =~ m/skipped/;

    # Return the last ticket ID even if that value is used only
    # as a failure indicator in ImportExport.
    return ( $Self->{LastTicketID}, $Status );
}

=head1 Internal Subroutines

=head2 _TicketSearch

just a wrapper around C<Kernel::System::Ticket::TicketSearch()>

=cut

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

    my $ImportExportObject = $Kernel::OM->Get('Kernel::System::ImportExport');
    my $TicketObject       = $Kernel::OM->Get('Kernel::System::Ticket');

    # get search data
    my $SearchData = $ImportExportObject->SearchDataGet(
        TemplateID => $Param{TemplateID},
        UserID     => $Param{UserID},
    );

    my %IsSelection = map { $_ => 1 } qw( TypeIDs QueueIDs ServiceIDs SLAIDs StateIDs PriorityIDs CustomerID );

    my %SearchDataPrepared;
    KEY:
    for my $Key ( keys %{$SearchData} ) {
        next KEY unless defined $SearchData->{$Key};

        $SearchDataPrepared{$Key} = $IsSelection{$Key} ? [ split /#####/, $SearchData->{$Key} ] : $SearchData->{$Key};
    }

    # Create an array in order to make sure that sort is not called in scalar context.
    #
    # TicketSearch() has a default limit of 10_000. This is fine in a webapp but not for a complete export.
    # As a workaround set the limit to a large number like one billion.
    my @SortedTicketIDs = sort { $a <=> $b } $TicketObject->TicketSearch(
        %SearchDataPrepared,
        Limit  => 1_000_000_000,
        Result => 'ARRAY',
        UserID => 1,
    );

    return @SortedTicketIDs;
}

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

    # We are dealing with a new ticket. We assume that this ticket
    # won't be skipped until we check the import filters.
    undef $Self->{LastTicketWasSkipped};

    my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
    my $LogObject    = $Kernel::OM->Get('Kernel::System::Log');

    my %Ticket = $Param{Ticket}->%*;    # data from the import file
    my %DBTicket;                       # Ticket as retrieved from the database
    my $Status = 'Ticket not changed';

    if ( $Param{Identifier} ) {
        my $DBTicketID;

        # TicketID takes precedence over TicketNumber
        if ( $Param{Identifier}{TicketID} ) {

            # check previously imported tickets of this run
            if ( $Self->{TicketIDRelation}{ $Ticket{TicketID} } ) {

                # we silently skip this ticket, if it already has been imported
                # this situation will always occur when articles are not imported separately
                # for the sake of consistency, we treat other situations the same, although they are less clear
                #
                # Articles which follow on separate lines would still be imported in this case.
                my $Prio = !$Param{ObjectData}{ArticleSeparateLines}
                    && $Self->{LastTicketID} == $Self->{TicketIDRelation}{ $Ticket{TicketID} } ? 'debug' : 'info';
                $LogObject->Log(
                    Priority => $Prio,
                    Message  => "Skipping ticket creation for entity $Param{Counter} (TicketID $Ticket{TicketID}) as it was handled before."
                );
                $Self->{LastTicketID} = $Self->{TicketIDRelation}{ $Ticket{TicketID} };

                return $Status;
            }

            # existing but undefined entry means previous error - we skip and do nothing
            elsif ( exists $Self->{TicketIDRelation}{ $Ticket{TicketID} } ) {
                return $Self->_ImportError(
                    %Param,
                    Message => "TicketID $Ticket{TicketID} was incorrectly imported before canceling new try.",
                );
            }

            # exclude tickets which were created in this run and by chance got the current TicketID
            elsif ( !{ reverse $Self->{TicketIDRelation}->%* }->{ $Ticket{TicketID} } ) {
                $DBTicketID = $Ticket{TicketID};
            }
        }
        elsif ( $Param{Identifier}{TicketNumber} ) {

            # check previously imported tickets of this run
            if ( $Self->{TicketNumberIDRelation}{ $Ticket{TicketNumber} } ) {

                # we silently skip this ticket, if it already has been imported
                # this situation will always occur when articles are not imported separately
                # for the sake of consistency, we treat other situations the same, although they are less clear
                #
                # Articles which follow on separate lines would still be imported in this case.
                my $Prio = !$Param{ObjectData}{ArticleSeparateLines}
                    && $Self->{LastTicketID} == $Self->{TicketNumberIDRelation}{ $Ticket{TicketNumber} } ? 'debug' : 'info';
                $LogObject->Log(
                    Priority => $Prio,
                    Message  => "Skipping ticket creation for entity $Param{Counter} (TicketNumber $Ticket{TicketNumber}) as it was handled before."
                );
                $Self->{LastTicketID} = $Self->{TicketNumberIDRelation}{ $Ticket{TicketNumber} };

                return $Self->{LastTicketID};
            }

            # existing but undefined entry means previous error - we skip and do nothing
            elsif ( exists $Self->{TicketNumberIDRelation}{ $Ticket{TicketNumber} } ) {
                return $Self->_ImportError(
                    %Param,
                    Message => "TicketNumber $Ticket{TicketNumber} was incorrectly imported before canceling new try.",
                );
            }

            # exclude tickets which were created in this run and by chance got the current TicketNumber
            # TODO: how is CreatedNumbers provided with content ?
            elsif ( !$Self->{CreatedNumbers}{ $Ticket{TicketNumber} } ) {
                $DBTicketID = $TicketObject->TicketIDLookup(
                    TicketNumber => $Ticket{TicketNumber},
                );
            }
        }
        else {
            return $Self->_ImportError(
                %Param,
                Message =>
                    'For ticket correlation checks either TicketID or TicketNumber has to be included as identifier. (Using no identifier to just create new tickets is also possible.)',
            );
        }

        if ($DBTicketID) {
            %DBTicket = $TicketObject->TicketGet(
                TicketID      => $DBTicketID,
                DynamicFields => 0,
                UserID        => 1,
                Silent        => 1,
            );
        }
    }

    # verify whether we really got the right ticket, all identifiers must match
    if (%DBTicket) {
        ATTR:
        for my $Attr ( keys $Param{Identifier}->%* ) {
            if ( $DBTicket{$Attr} ne $Ticket{$Attr} ) {
                %DBTicket = ();

                last ATTR;
            }
        }
    }

    # just update the ticket if it is already present
    if (%DBTicket) {

        # There are cases when a ticket update should not take place. Currently two
        # of these cases are supported. In both of these cases no articles
        # are imported until a new ticket is encountered.
        {
            # Update only tickets that are not owned by a specific agent. Usually this special agent
            # is the default agent of a previous import. The use case is when additional users
            # are are activated after an initial import of the tickets.
            if (
                $Param{ObjectData}->{AllowedOwnerInTarget}
                &&
                $DBTicket{Owner} ne $Param{ObjectData}->{AllowedOwnerInTarget}
                )
            {
                undef $Self->{LastTicketID};
                $Self->{LastTicketWasSkipped} = 1;

                return 'Ticket skipped';
            }

            # Don't mess with existing tickets.
            if ( $Param{ObjectData}->{SkipExistingTickets} ) {
                undef $Self->{LastTicketID};
                $Self->{LastTicketWasSkipped} = 1;

                return 'Ticket skipped';
            }
        }

        $Status = 'Ticket not changed';
        my $TicketUpdatedStatus = 'Ticket updated';

        # decide whether the old values should be kept
        my $SkipEmpty = $Param{ObjectData}{EmptyFieldsLeaveTheOldValues};

        # customer
        $Ticket{CustomerID}     ||= $SkipEmpty ? $DBTicket{CustomerID}     : $Param{ObjectData}{CustomerID};
        $Ticket{CustomerUserID} ||= $SkipEmpty ? $DBTicket{CustomerUserID} : $Param{ObjectData}{CustomerUserID};
        $DBTicket{CustomerID}     //= '';
        $DBTicket{CustomerUserID} //= '';

        if ( ( !$Ticket{CustomerID} && $DBTicket{CustomerID} ) || ( !$Ticket{CustomerUserID} && $DBTicket{CustomerUserID} ) ) {
            $LogObject->Log(
                Priority => 'notice',
                Message  => "Unexpected state encountered for existing TicketID $Ticket{TicketID} (Entity $Param{Counter}): "
                    . "Ticket customer can not be emptied - not a real chronological update; ignoring this, and keeping Customer(User)ID.",
            );
        }

        {
            my $Update = $Ticket{CustomerID} && $Ticket{CustomerID} ne $DBTicket{CustomerID} ? 1 :
                $Ticket{CustomerUserID} && $Ticket{CustomerUserID} ne $DBTicket{CustomerUserID} ? 1 : 0;

            if ($Update) {
                $Status = $TicketUpdatedStatus;
                my $Success = $TicketObject->TicketCustomerSet(
                    No       => $Ticket{CustomerID},
                    User     => $Ticket{CustomerUserID},
                    TicketID => $DBTicket{TicketID},
                    UserID   => 1,
                );

                return $Self->_ImportError(
                    %Param,
                    Message => "Could not update Customer(User) for TicketID $DBTicket{TicketID}",
                ) unless $Success;
            }
        }

        # title
        $Ticket{Title} ||=
            ( defined $Ticket{Title} && $Ticket{Title} eq '0' ) ? '0' :
            $SkipEmpty                                          ? $DBTicket{Title} :
            $Param{ObjectData}{Subject}                         ? $Param{ObjectData}{Subject} : '';

        if ( $Ticket{Title} ne $DBTicket{Title} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketTitleUpdate(
                Title    => $Ticket{Title},
                TicketID => $DBTicket{TicketID},
                UserID   => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update Title for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # queue
        if ( !$Ticket{QueueID} && $Ticket{Queue} ) {
            $Ticket{QueueID} = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup(
                Queue => $Ticket{Queue},
            );
        }
        $Ticket{QueueID} ||= $SkipEmpty ? $DBTicket{QueueID} : $Param{ObjectData}{QueueID};

        if ( $Ticket{QueueID} ne $DBTicket{QueueID} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketQueueSet(
                QueueID  => $Ticket{QueueID},
                TicketID => $DBTicket{TicketID},
                UserID   => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update Queue for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # need for checking the activated features: Ticket::Type, Ticket::Responsible, Ticket::Service
        my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

        # type
        if ( $ConfigObject->Get('Ticket::Type') ) {
            if ( !$Ticket{TypeID} && $Ticket{Type} ) {
                $Ticket{TypeID} = $Kernel::OM->Get('Kernel::System::Type')->TypeLookup(
                    Type => $Ticket{Type},
                );
            }
            $Ticket{TypeID} ||= $SkipEmpty ? $DBTicket{TypeID} : $Param{ObjectData}{TypeID};

            if ( $Ticket{TypeID} ne $DBTicket{TypeID} ) {
                $Status = $TicketUpdatedStatus;
                my $Success = $TicketObject->TicketTypeSet(
                    TypeID   => $Ticket{TypeID},
                    TicketID => $DBTicket{TicketID},
                    UserID   => 1,
                );

                return $Self->_ImportError(
                    %Param,
                    Message => "Could not update Type for TicketID $DBTicket{TicketID}",
                ) unless $Success;
            }
        }

        if ( $ConfigObject->Get('Ticket::Service') ) {

            # service
            if ( !$Ticket{ServiceID} && $Ticket{Service} ) {
                $Ticket{ServiceID} = $Kernel::OM->Get('Kernel::System::Service')->ServiceLookup(
                    Name => $Ticket{Service},
                );
            }
            $Ticket{ServiceID} ||= $SkipEmpty ? $DBTicket{ServiceID} : $Param{ObjectData}{ServiceID};
            $DBTicket{ServiceID} //= '';

            if ( !$Ticket{ServiceID} && $DBTicket{ServiceID} ) {
                $LogObject->Log(
                    Priority => 'notice',
                    Message  => "Unexpected state encountered for existing TicketID $Ticket{TicketID} (Entity $Param{Counter}): "
                        . "Services can not be emptied - not a real chronological update; ignoring this, and keeping the Service.",
                );
            }

            if ( $Ticket{ServiceID} && $Ticket{ServiceID} ne $DBTicket{ServiceID} ) {
                $Status = $TicketUpdatedStatus;
                my $Success = $TicketObject->TicketServiceSet(
                    ServiceID => $Ticket{ServiceID},
                    TicketID  => $DBTicket{TicketID},
                    UserID    => 1,
                );

                return $Self->_ImportError(
                    %Param,
                    Message => "Could not update Service for TicketID $DBTicket{TicketID}",
                ) unless $Success;
            }

            # SLA
            if ( !$Ticket{SLAID} && $Ticket{SLA} ) {
                $Ticket{SLAID} = $Kernel::OM->Get('Kernel::System::SLA')->SLALookup(
                    SLA => $Ticket{SLA},
                );
            }
            $Ticket{SLAID} ||= $SkipEmpty ? $DBTicket{SLAID} : $Param{ObjectData}{SLAID};
            $DBTicket{SLAID} //= '';

            if ( !$Ticket{SLAID} && $DBTicket{SLAID} ) {
                $LogObject->Log(
                    Priority => 'notice',
                    Message  => "Unexpected state encountered for existing TicketID $Ticket{TicketID} (Entity $Param{Counter}): "
                        . "SLAs can not be emptied - not a real chronological update; ignoring this, and keeping the SLA.",
                );
            }

            if ( $Ticket{SLAID} && $Ticket{SLAID} ne $DBTicket{SLAID} ) {
                $Status = $TicketUpdatedStatus;
                my $Success = $TicketObject->TicketSLASet(
                    SLAID    => $Ticket{SLAID},
                    TicketID => $DBTicket{TicketID},
                    UserID   => 1,
                );

                return $Self->_ImportError(
                    %Param,
                    Message => "Could not update SLA for TicketID $DBTicket{TicketID}",
                ) unless $Success;
            }
        }

        # owner
        if ( !$Ticket{OwnerID} && $Ticket{Owner} ) {
            $Ticket{OwnerID} = $Kernel::OM->Get('Kernel::System::User')->UserLookup(
                UserLogin => $Ticket{Owner},
            );
        }
        $Ticket{OwnerID} ||= $SkipEmpty ? $DBTicket{OwnerID} : $Param{ObjectData}{OwnerID};

        if ( !$Ticket{OwnerID} && $DBTicket{OwnerID} ) {
            $LogObject->Log(
                Priority => 'notice',
                Message  => "Unexpected state encountered for existing TicketID $Ticket{TicketID} (Entity $Param{Counter}): "
                    . "Owners can not be emptied - not a real chronological update; ignoring this, and keeping the Owner.",
            );
        }

        if ( $Ticket{OwnerID} && $Ticket{OwnerID} ne $DBTicket{OwnerID} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketOwnerSet(
                NewUserID => $Ticket{OwnerID},
                TicketID  => $DBTicket{TicketID},
                UserID    => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update Owner for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # lock
        if ( !$Ticket{LockID} && $Ticket{Lock} ) {
            $Ticket{LockID} = $Kernel::OM->Get('Kernel::System::Lock')->LockLookup(
                Lock => $Ticket{Lock},
            );
        }
        $Ticket{LockID} ||= $SkipEmpty ? $DBTicket{LockID} : $Param{ObjectData}{LockID};

        # check whether an owner exists here - if not trying to lock will fail
        if ( $Ticket{OwnerID} && $Ticket{LockID} ne $DBTicket{LockID} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketLockSet(
                LockID   => $Ticket{LockID},
                TicketID => $DBTicket{TicketID},
                UserID   => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update Lock for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # responsible
        if ( $ConfigObject->Get('Ticket::Responsible') ) {
            if ( !$Ticket{ResponsibleID} && $Ticket{Responsible} ) {
                $Ticket{ResponsibleID} = $Kernel::OM->Get('Kernel::System::User')->UserLookup(
                    UserLogin => $Ticket{Responsible},
                );
            }
            $Ticket{ResponsibleID} ||= $SkipEmpty ? $DBTicket{ResponsibleID} : $Param{ObjectData}{ResponsibleID};

            if ( !$Ticket{ResponsibleID} && $DBTicket{ResponsibleID} ) {
                $LogObject->Log(
                    Priority => 'notice',
                    Message  => "Unexpected state encountered for existing TicketID $Ticket{TicketID} (Entity $Param{Counter}): "
                        . "Responsibles can not be emptied - not a real chronological update; ignoring this, and keeping the Responsible.",
                );
            }

            if ( $Ticket{ResponsibleID} && $Ticket{ResponsibleID} ne $DBTicket{ResponsibleID} ) {
                $Status = $TicketUpdatedStatus;
                my $Success = $TicketObject->TicketResponsibleSet(
                    NewUserID => $Ticket{ResponsibleID},
                    TicketID  => $DBTicket{TicketID},
                    UserID    => 1,
                );

                return $Self->_ImportError(
                    %Param,
                    Message => "Could not update Responsible for TicketID $DBTicket{TicketID}",
                ) unless $Success;
            }
        }

        # priority
        if ( !$Ticket{PriorityID} && $Ticket{Priority} ) {
            $Ticket{PriorityID} = $Kernel::OM->Get('Kernel::System::Priority')->PriorityLookup(
                Priority => $Ticket{Priority},
            );
        }
        $Ticket{PriorityID} ||= $SkipEmpty ? $DBTicket{PriorityID} : $Param{ObjectData}{PriorityID};

        if ( $Ticket{PriorityID} ne $DBTicket{PriorityID} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketPrioritySet(
                PriorityID => $Ticket{PriorityID},
                TicketID   => $DBTicket{TicketID},
                UserID     => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update Priority for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # state
        if ( !$Ticket{StateID} && $Ticket{State} ) {
            $Ticket{StateID} = $Kernel::OM->Get('Kernel::System::State')->StateLookup(
                State => $Ticket{State},
            );
        }
        $Ticket{StateID} ||= $SkipEmpty ? $DBTicket{StateID} : $Param{ObjectData}{StateID};

        if ( $Ticket{StateID} ne $DBTicket{StateID} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketStateSet(
                StateID  => $Ticket{StateID},
                TicketID => $DBTicket{TicketID},
                UserID   => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update State for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }

        # archive flag
        $Ticket{ArchiveFlag} ||= $SkipEmpty ? $DBTicket{ArchiveFlag} : $Param{ObjectData}{ArchiveFlag};

        if ( $Ticket{ArchiveFlag} ne $DBTicket{ArchiveFlag} ) {
            $Status = $TicketUpdatedStatus;
            my $Success = $TicketObject->TicketArchiveFlagSet(
                ArchiveFlag => $Ticket{ArchiveFlag},
                TicketID    => $DBTicket{TicketID},
                UserID      => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not update ArchiveFlag for TicketID $DBTicket{TicketID}",
            ) unless $Success;
        }
    }

    # A new ticket will be created. Collect the input for TicketCreate in %DBTicket.
    else {
        $Status = 'Ticket created';

        # customer
        $DBTicket{CustomerID}   = $Ticket{CustomerID}     || $Param{ObjectData}{CustomerID};
        $DBTicket{CustomerUser} = $Ticket{CustomerUserID} || $Param{ObjectData}{CustomerUserID};

        # title
        $DBTicket{Title} = ( $Ticket{Title} || ( defined $Ticket{Title} && $Ticket{Title} eq '0' ) )
            ?
            $Ticket{Title}
            :
            $Param{ObjectData}{Subject};

        # queue
        if ( !$Ticket{QueueID} && $Ticket{Queue} ) {
            $Ticket{QueueID} = $Kernel::OM->Get('Kernel::System::Queue')->QueueLookup(
                Queue => $Ticket{Queue},
            );
        }
        $DBTicket{QueueID} = $Ticket{QueueID} || $Param{ObjectData}{QueueID};

        # need for checking the activated features: Ticket::Type, Ticket::Responsible, Ticket::Service
        my $ConfigObject = $Kernel::OM->Get('Kernel::Config');

        # type
        if ( $ConfigObject->Get('Ticket::Type') ) {
            if ( !$Ticket{TypeID} && $Ticket{Type} ) {
                $Ticket{TypeID} = $Kernel::OM->Get('Kernel::System::Type')->TypeLookup(
                    Type => $Ticket{Type},
                );
            }
            $DBTicket{TypeID} = $Ticket{TypeID} || $Param{ObjectData}{TypeID};
        }

        if ( $ConfigObject->Get('Ticket::Service') ) {

            # service
            if ( !$Ticket{ServiceID} && $Ticket{Service} ) {
                $Ticket{ServiceID} = $Kernel::OM->Get('Kernel::System::Service')->ServiceLookup(
                    Name => $Ticket{Service},
                );
            }
            $DBTicket{ServiceID} = $Ticket{ServiceID} || $Param{ObjectData}{ServiceID};

            # sla
            if ( !$Ticket{SLAID} && $Ticket{SLA} ) {
                $Ticket{SLAID} = $Kernel::OM->Get('Kernel::System::SLA')->SLALookup(
                    SLA => $Ticket{SLA},
                );
            }
            $DBTicket{SLAID} = $Ticket{SLAID} || $Param{ObjectData}{SLAID};
        }

        # owner
        if ( !$Ticket{OwnerID} && $Ticket{Owner} ) {
            $Ticket{OwnerID} = $Kernel::OM->Get('Kernel::System::User')->UserLookup(
                UserLogin => $Ticket{Owner},
            );
        }
        $DBTicket{OwnerID} = $Ticket{OwnerID} || $Param{ObjectData}{OwnerID};

        # lock
        if ( !$Ticket{LockID} && $Ticket{Lock} ) {
            $Ticket{LockID} = $Kernel::OM->Get('Kernel::System::Lock')->LockLookup(
                Lock => $Ticket{Lock},
            );
        }
        $DBTicket{LockID} = $Ticket{LockID} || $Param{ObjectData}{LockID};

        # responsible
        if ( $ConfigObject->Get('Ticket::Responsible') ) {
            if ( !$Ticket{ResponsibleID} && $Ticket{Responsible} ) {
                $Ticket{ResponsibleID} = $Kernel::OM->Get('Kernel::System::User')->UserLookup(
                    UserLogin => $Ticket{Responsible},
                );
            }
            $DBTicket{ResponsibleID} = $Ticket{ResponsibleID} || $Param{ObjectData}{ResponsibleID};
        }

        # priority
        if ( !$Ticket{PriorityID} && $Ticket{Priority} ) {
            $Ticket{PriorityID} = $Kernel::OM->Get('Kernel::System::Priority')->PriorityLookup(
                Priority => $Ticket{Priority},
            );
        }
        $DBTicket{PriorityID} = $Ticket{PriorityID} || $Param{ObjectData}{PriorityID};

        # state
        if ( !$Ticket{StateID} && $Ticket{State} ) {
            $Ticket{StateID} = $Kernel::OM->Get('Kernel::System::State')->StateLookup(
                State => $Ticket{State},
            );
        }
        $DBTicket{StateID} = $Ticket{StateID} || $Param{ObjectData}{StateID};

        # archive flag
        $DBTicket{ArchiveFlag} = $Ticket{ArchiveFlag} || $Param{ObjectData}{ArchiveFlag};

        # Handle pending transaction events of the previously created ticket
        # before creating a new ticket.
        $TicketObject->EventHandlerTransaction;

        # Create a new ticket. The transaction events generated here will be handled
        # before the next ticket creation or during global destruction.
        $DBTicket{TicketID} = $TicketObject->TicketCreate(
            %DBTicket,
            TN     => $Ticket{TicketNumber} // '',
            UserID => 1,
        );

        return $Self->_ImportError(
            %Param,
            Message => 'Could not create new ticket',
        ) unless $DBTicket{TicketID};

        $DBTicket{TicketNumber} = $TicketObject->TicketNumberLookup(
            TicketID => $DBTicket{TicketID},
        );

        if ( $Ticket{Created} ) {
            $Self->{DBObject} //= $Kernel::OM->Get('Kernel::System::DB');

            return unless $Self->{DBObject}->Do(
                SQL  => "UPDATE ticket SET create_time = ? WHERE id = ?",
                Bind => [ \$Ticket{Created}, \$DBTicket{TicketID} ],
            );
        }

        # Fetch additional data from the source installation if configured.
        my $SyncDBConfig = $ConfigObject->Get('ImportExport::Ticket::SynchronizeWithForeignDB');
        if ($SyncDBConfig) {
            my $Success = $Self->_SynchronizeExtendedDBEntries(
                ForeignDB       => $SyncDBConfig,
                ForeignTicketID => $Ticket{TicketID},
                TicketID        => $DBTicket{TicketID},
            );

            return $Self->_ImportError(
                %Param,
                Message => "Could not synchronize extended DB entries for ticket $DBTicket{TicketID}",
            ) unless $Success;
        }
    }

    my $DynamicFieldObject        = $Kernel::OM->Get('Kernel::System::DynamicField');
    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');
    my %StandardMultiSelect       = map { $_ => 1 } qw( Multiselect Database WebService );

    # dynamic fields
    DYNAMICFIELD:
    for my $Attr ( keys %Ticket ) {

        # only handle dynamic fields
        next DYNAMICFIELD unless $Attr =~ m/^DynamicField_(.+)$/;

        my $DynamicFieldConfig = $DynamicFieldObject->DynamicFieldGet(
            Name => $1,
        );

        # get the current value
        my $DBValue = $DynamicFieldBackendObject->ValueGet(
            DynamicFieldConfig => $DynamicFieldConfig,
            ObjectID           => $DBTicket{TicketID},
            UserID             => 1,
        );

        # multi select fields need special treatment
        if ( $StandardMultiSelect{ $DynamicFieldConfig->{FieldType} } || ref $DBValue eq 'ARRAY' ) {
            $Ticket{$Attr} = $Ticket{$Attr} ? [ map { decode( 'UTF-8', decode_base64($_) ) } split( /###/, $Ticket{$Attr} ) ] : [];
        }

        next DYNAMICFIELD unless $DynamicFieldBackendObject->ValueIsDifferent(
            DynamicFieldConfig => $DynamicFieldConfig,
            Value1             => $Ticket{$Attr},
            Value2             => $DBValue,
        );

        if ( $Status eq 'Ticket not changed' ) {
            $Status = 'Ticket updated';
        }

        my $Success = $DynamicFieldBackendObject->FieldValueValidate(
            DynamicFieldConfig => $DynamicFieldConfig,
            Value              => $Ticket{$Attr},
            UserID             => 1,
        );

        if ($Success) {

            # set the value
            $Success = $DynamicFieldBackendObject->ValueSet(
                DynamicFieldConfig => $DynamicFieldConfig,
                ObjectID           => $DBTicket{TicketID},
                Value              => $Ticket{$Attr},
                ExternalSource     => 1,
                UserID             => 1,
            );
        }

        return $Self->_ImportError(
            %Param,
            Message => "Could not update $Attr to '$Ticket{$Attr}' for TicketID $DBTicket{TicketID}",
        ) unless $Success;
    }

    if ( $Param{Identifier}{TicketID} || $Param{ObjectData}{IncludeArticles} ) {

        # TODO: why the check on IncludeArticles
        if ( $Ticket{TicketID} ) {
            $Self->{TicketIDRelation}{ $Ticket{TicketID} } = $DBTicket{TicketID};
        }
    }
    if ( $Param{Identifier}{TicketNumber} ) {
        $Self->{TicketNumberIDRelation}{ $Ticket{TicketNumber} } = $DBTicket{TicketID};
    }

    # remember the ticket ID so that articles can be attached to it
    $Self->{LastTicketID} = $DBTicket{TicketID};

    return $Status;
}

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

    my %Article = $Param{Article}->%*;

    my $TicketID =
        $Article{TicketID} && $Self->{TicketIDRelation}{ $Article{TicketID} } ? $Self->{TicketIDRelation}{ $Article{TicketID} } :
        $Self->{LastTicketID}                                                 ? $Self->{LastTicketID} : '';

    return $Self->_ImportError(
        %Param,
        Message => "Could not find new TicketID for Article",
    ) unless $TicketID;

    my $ArticleObject = $Kernel::OM->Get('Kernel::System::Ticket::Article');

    # avoid duplicate articles if ArticleID is given
    if ( $Param{Identifier} && $Param{Identifier}{ArticleID} && $Article{ArticleID} ) {
        my @DBArticles = $ArticleObject->ArticleList(
            TicketID  => $TicketID,
            ArticleID => $Article{ArticleID},
        );

        return 'Article skipped' if @DBArticles;
    }

    my %ValidImportChannel = map { $_ => 1 } qw( Email Internal Phone );
    my $ChannelName        = $Article{ArticleBackend} || $Param{ObjectData}{ArticleBackend};

    return $Self->_ImportError(
        %Param,
        Message => "'$ChannelName' is (currently) not a supported ArticleBackend",
    ) unless $ValidImportChannel{$ChannelName};

    my $ConfigObject         = $Kernel::OM->Get('Kernel::Config');
    my $ArticleBackendObject = $ArticleObject->BackendForChannel( ChannelName => $ChannelName );

    if ( $ChannelName eq 'Email' && !$Article{MessageID} ) {
        my $Time   = $Kernel::OM->Create('Kernel::System::DateTime')->ToEpoch();
        my $Random = rand 999999;
        my $FQDN   = $ConfigObject->Get('FQDN');
        $Article{MessageID} = "<$Time.$Random\@$FQDN>";
    }

    my $HistoryComment = '%%Imported Article';
    if ( $Article{TicketID} || $Article{ArticleID} ) {
        $HistoryComment .= ' - Legacy';
        $HistoryComment .= $Article{TicketID}  ? " TID: $Article{TicketID};"  : '';
        $HistoryComment .= $Article{ArticleID} ? " AID: $Article{ArticleID};" : '';
    }

    # Handle pending transaction events of the previously created article
    # before creating a new article.
    $ArticleBackendObject->EventHandlerTransaction;
    $ArticleObject->EventHandlerTransaction;

    my $ArticleID = $ArticleBackendObject->ArticleCreate(
        NoAgentNotify        => 1,
        TicketID             => $TicketID,
        SenderType           => $Article{SenderType} || $Param{ObjectData}{SenderType},
        IsVisibleForCustomer => defined $Article{IsVisibleForCustomer}
            && $Article{IsVisibleForCustomer} ne '' ? $Article{IsVisibleForCustomer} : $Param{ObjectData}{IsVisibleForCustomer} // 0,
        From           => $Article{From},
        To             => $Article{To},
        Cc             => $Article{Cc},
        Bcc            => $Article{Bcc},
        ReplyTo        => $Article{ReplyTo},
        InReplyTo      => $Article{InReplyTo},
        References     => $Article{References},
        Subject        => $Article{Subject}  || $Param{ObjectData}{Subject},
        Body           => $Article{Body}     || $Param{ObjectData}{Body},
        Charset        => $Article{Charset}  || 'utf-8',
        MimeType       => $Article{MimeType} || 'text/plain',
        HistoryType    => 'Misc',
        HistoryComment => $HistoryComment,
        MessageID      => $Article{MessageID},
        UserID         => 1,
    );

    return $Self->_ImportError(
        %Param,
        Message => "Could not create the article",
    ) unless $ArticleID;

    if ( $Article{CreateTime} ) {
        $Self->{DBObject} //= $Kernel::OM->Get('Kernel::System::DB');

        return unless $Self->{DBObject}->Do(
            SQL  => "UPDATE article SET create_time = ? WHERE id = ?",
            Bind => [ \$Article{CreateTime}, \$ArticleID ],
        );
    }

    my $SyncDBConfig = $ConfigObject->Get('ImportExport::Ticket::SynchronizeWithForeignDB');
    if ($SyncDBConfig) {
        my $Success = $Self->_SynchronizeExtendedDBEntries(
            ForeignDB        => $SyncDBConfig,
            ForeignArticleID => $Article{ArticleID},
            ArticleID        => $ArticleID,
            TicketID         => $TicketID,
        );

        return $Self->_ImportError(
            %Param,
            Message => "Could not synchronize extended DB entries for ticket $ArticleID",
        ) unless $Success;
    }

    # attachments
    if ( $Param{ObjectData}{IncludeAttachments} && $Article{Attachments} ) {
        for my $AttachmentString ( $Article{Attachments}->@* ) {
            my %Attachment = split( /###/, $AttachmentString, -1 );

            for my $Key ( keys %Attachment ) {
                $Attachment{$Key} = $Attachment{$Key} eq '' ? '' : decode_base64( $Attachment{$Key} );
            }

            KEY:
            for my $Key (qw( Filename ContentType Disposition )) {
                next KEY unless $Attachment{$Key};

                $Attachment{$Key} = Encode::decode( 'UTF-8', $Attachment{$Key} );
            }

            my $Success = $ArticleBackendObject->ArticleWriteAttachment(
                %Attachment,
                ArticleID => $ArticleID,
                UserID    => 1,
            );

            return $Self->_ImportError(
                %Param,
                Message => "Error with importing an attachment for article $ArticleID",
            ) unless $Success;
        }
    }

    # plain email
    if ( $Article{PlainEmail} ) {
        my $Success = $ArticleBackendObject->ArticleWritePlain(
            ArticleID => $ArticleID,
            Email     => $Article{PlainEmail},
            UserID    => 1,
        );

        return $Self->_ImportError(
            %Param,
            Message => "Error with importing the plain email for article $ArticleID",
        ) unless $Success;
    }

    my $DynamicFieldObject        = $Kernel::OM->Get('Kernel::System::DynamicField');
    my $DynamicFieldBackendObject = $Kernel::OM->Get('Kernel::System::DynamicField::Backend');
    my %StandardMultiSelect       = map { $_ => 1 } qw( Multiselect Database WebService );

    # dynamic fields
    DYNAMICFIELD:
    for my $Attr ( keys %Article ) {
        my $DynamicFieldConfig;
        if ( $Attr =~ /^DynamicField_(.+)$/ ) {
            $DynamicFieldConfig = $DynamicFieldObject->DynamicFieldGet(
                Name => $1,
            );
        }
        else {
            next DYNAMICFIELD;
        }

        # get the current value
        my $DBValue = $DynamicFieldBackendObject->ValueGet(
            DynamicFieldConfig => $DynamicFieldConfig,
            ObjectID           => $ArticleID,
            UserID             => 1,
        );

        # multi select fields need special treatment
        if ( $StandardMultiSelect{ $DynamicFieldConfig->{FieldType} } || ref $DBValue eq 'ARRAY' ) {
            $Article{$Attr} = $Article{$Attr} ? [ map { decode( 'UTF-8', decode_base64($_) ) } split( /###/, $Article{$Attr} ) ] : [];
        }

        next DYNAMICFIELD unless $DynamicFieldBackendObject->ValueIsDifferent(
            DynamicFieldConfig => $DynamicFieldConfig,
            Value1             => $Article{$Attr},
            Value2             => $DBValue,
        );

        my $Success = $DynamicFieldBackendObject->FieldValueValidate(
            DynamicFieldConfig => $DynamicFieldConfig,
            Value              => $Article{$Attr},
            UserID             => 1,
        );

        if ($Success) {

            # set the value
            $Success = $DynamicFieldBackendObject->ValueSet(
                DynamicFieldConfig => $DynamicFieldConfig,
                ObjectID           => $ArticleID,
                Value              => $Article{$Attr},
                ExternalSource     => 1,
                UserID             => 1,
            );
        }

        return $Self->_ImportError(
            %Param,
            Message => "Could not update $Attr for ArticleID $ArticleID",
        ) unless $Success;
    }

    return 'Article created';
}

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

    $Self->{Error} = $Param{Message} || '';

    if ( exists $Param{Ticket} ) {
        $Self->{LastTicketID} = undef;

        if ( $Param{Identifier} && $Param{Identifier}{TicketID} && $Param{Ticket}{TicketID} ) {
            $Self->{TicketIDRelation}{ $Param{Ticket}{TicketID} } = undef;
        }
        elsif ( $Param{Identifier} && $Param{Identifier}{TicketNumber} && $Param{Ticket}{TicketNumber} ) {
            $Self->{TicketNumberIDRelation}{ $Param{Ticket}{TicketNumber} } = undef;
        }
    }

    elsif ( exists $Param{Article} ) {
        my $ImportedTID = $Param{Article}{TicketID} ? $Self->{TicketIDRelation}{ $Param{Article}{TicketID} } : $Self->{LastTicketID};
        my $ExtraInfo   = $Param{Article}{TicketID} ? " Originial TicketID: $Param{Article}{TicketID};"      : '';
        $ExtraInfo     .= $ImportedTID               ? " Imported TicketID: $ImportedTID;"                 : '';
        $ExtraInfo     .= $Param{Article}{ArticleID} ? " Originial ArticleID: $Param{Article}{ArticleID};" : '';
        $Self->{Error} .= $ExtraInfo;
    }

    return;
}

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

    if ( !$Param{ForeignDB}{DatabaseDSN} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need a DatabaseDSN in the ForeignDB settings',
        );

        return;
    }

    if ( !$Param{TicketID} || !( ( $Param{ArticleID} && $Param{ForeignArticleID} || $Param{ForeignTicketID} ) ) ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need TicketID and either ArticleID and ForeignArticleID or ForeignTicketID!',
        );

        return;
    }

    if ( !$Self->{FDBObject} || !$Self->{DBObject} ) {
        $Self->{DBObject}  = $Kernel::OM->Get('Kernel::System::DB');
        $Self->{FDBObject} = Kernel::System::DB->new(
            $Param{ForeignDB}->%*,
        );
    }

    if ( $Param{ArticleID} ) {

        # article_flag
        return unless $Self->{FDBObject}->Prepare(
            SQL  => 'SELECT create_by FROM article_flag WHERE article_id = ? AND article_key = ? AND article_value = ?',
            Bind => [ \$Param{ForeignArticleID}, \'Seen', \1 ],
        );

        while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
            return unless $Self->{DBObject}->Do(
                SQL => 'INSERT INTO article_flag (article_id, article_key, article_value, create_time, create_by)' .
                    'VALUES (?, ?, ?, current_timestamp, ?)',
                Bind => [ \$Param{ArticleID}, \'Seen', \1, \$Row[0] ],
            );
        }

        # article_history
        return unless $Self->{FDBObject}->Prepare(
            SQL => 'SELECT name, history_type_id, type_id, queue_id, owner_id, priority_id, state_id, create_time, create_by, change_time, change_by ' .
                'FROM ticket_history WHERE article_id = ?',
            Bind => [ \$Param{ForeignArticleID} ],
        );

        while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
            return unless $Self->{DBObject}->Do(
                SQL =>
                    'INSERT INTO ticket_history (ticket_id, article_id, name, history_type_id, type_id, queue_id, owner_id, priority_id, state_id, create_time, create_by, change_time, change_by)'
                    .
                    'VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)',
                Bind => [ \$Param{TicketID}, \$Param{ArticleID}, ( map { \$_ } @Row ) ],
            );
        }

        return 1;
    }

    # ticket_flag
    return unless $Self->{FDBObject}->Prepare(
        SQL  => 'SELECT create_by FROM ticket_flag WHERE ticket_id = ? AND ticket_key = ? AND ticket_value = ?',
        Bind => [ \$Param{ForeignTicketID}, \'Seen', \1 ],
    );

    while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
        return unless $Self->{DBObject}->Do(
            SQL => 'INSERT INTO ticket_flag (ticket_id, ticket_key, ticket_value, create_time, create_by)' .
                'VALUES (?, ?, ?, current_timestamp, ?)',
            Bind => [ \$Param{TicketID}, \'Seen', \1, \$Row[0] ],
        );
    }

    # ticket_history
    return unless $Self->{DBObject}->Do(
        SQL  => 'DELETE FROM ticket_history WHERE ticket_id = ? AND (article_id IS NULL OR article_id = 0)',
        Bind => [ \$Param{TicketID} ],
    );

    $Kernel::OM->Get('Kernel::System::Ticket')->HistoryAdd(
        Name         => "\%\%Imported Ticket - Legacy TicketID: $Param{ForeignTicketID}",
        HistoryType  => 'Misc',
        TicketID     => $Param{TicketID},
        CreateUserID => 1,
    );

    return unless $Self->{FDBObject}->Prepare(
        SQL => 'SELECT name, history_type_id, type_id, queue_id, owner_id, priority_id, state_id, create_time, create_by, change_time, change_by ' .
            'FROM ticket_history WHERE ticket_id = ? AND (article_id IS NULL OR article_id = 0)',
        Bind => [ \$Param{ForeignTicketID} ],
    );

    while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
        return unless $Self->{DBObject}->Do(
            SQL =>
                'INSERT INTO ticket_history (ticket_id, name, history_type_id, type_id, queue_id, owner_id, priority_id, state_id, create_time, create_by, change_time, change_by)'
                .
                'VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)',
            Bind => [ \$Param{TicketID}, ( map { \$_ } @Row ) ],
        );
    }

    # link_relation
    my $LinkObject = $Kernel::OM->Get('Kernel::System::LinkObject');
    my $ForeignTicketObjectID;

    my %ForeignLinkObjects;
    my %LObjectIDs;

    return unless $Self->{FDBObject}->Prepare(
        SQL  => "SELECT id,name FROM link_object ",
        Bind => [],
    );
    while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
        $ForeignLinkObjects{ $Row[0] } = $Row[1];
        $LObjectIDs{ $Row[1] }         = $LinkObject->ObjectLookup(
            Name => $Row[1],
        );

        if ( $Row[1] eq 'Ticket' ) {
            $ForeignTicketObjectID = $Row[0];
        }
    }

    my %ForeignLinkTypes;
    my %LTypeIDs;

    return unless $Self->{FDBObject}->Prepare(
        SQL  => "SELECT id,name FROM link_type ",
        Bind => [],
    );
    while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {
        $ForeignLinkTypes{ $Row[0] } = $Row[1];
        $LTypeIDs{ $Row[1] }         = $LinkObject->TypeLookup(
            Name   => $Row[1],
            UserID => 1,
        );
    }

    my %Direction = (
        source => 'target',
        target => 'source',
    );

    for my $Key ( keys %Direction ) {

        return unless $Self->{FDBObject}->Prepare(
            SQL => "SELECT $Key" . "_object_id, $Key" . "_key, type_id, state_id FROM link_relation " .
                "WHERE $Direction{$Key}_object_id = ? AND $Direction{$Key}_key = ?",
            Bind => [ \$ForeignTicketObjectID, \$Param{ForeignTicketID} ],
        );

        LINK:
        while ( my @Row = $Self->{FDBObject}->FetchrowArray() ) {

            $Row[0] = $LObjectIDs{ $ForeignLinkObjects{ $Row[0] } };
            $Row[2] = $LTypeIDs{ $ForeignLinkTypes{ $Row[2] } };

            # deal with other imported tickets
            if ( $Row[0] == $LObjectIDs{Ticket} ) {
                next LINK if $Row[1] > $Param{ForeignTicketID};

                $Row[1] = exists $Self->{TicketIDRelation}{ $Row[1] } ? $Self->{TicketIDRelation}{ $Row[1] } : $Row[1];
            }

            return unless $Self->{DBObject}->Do(
                SQL =>
                    "INSERT INTO link_relation ($Direction{$Key}_object_id, $Direction{$Key}_key, $Key\_object_id, $Key\_key, type_id, state_id, create_time, create_by) " .
                    "VALUES (?, ?, ?, ?, ?, ?, current_timestamp, ?)",
                Bind => [ \$LObjectIDs{Ticket}, \$Param{TicketID}, ( map { \$_ } @Row ), \1 ],
            );
        }
    }

    # ticket_watcher
    # TODO

    # form_draft
    # TODO

    # calender_appointment_ticket
    # TODO

    return 1;
}

1;
</File>
        <File Location="Kernel/Output/HTML/ImportExport/LayoutDateTime.pm" Permission="660" Encode="Base64">IyAtLQojIE9UT0JPIGlzIGEgd2ViLWJhc2VkIHRpY2tldGluZyBzeXN0ZW0gZm9yIHNlcnZpY2Ugb3JnYW5pc2F0aW9ucy4KIyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDIwIE9UUlMgQUcsIGh0dHBzOi8vb3Rycy5jb20vCiMgQ29weXJpZ2h0IChDKSAyMDE5LTIwMjYgUm90aGVyIE9TUyBHbWJILCBodHRwczovL290b2JvLmlvLwojIC0tCiMgVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU6IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkgaXQgdW5kZXIKIyB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieSB0aGUgRnJlZSBTb2Z0d2FyZQojIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiMgVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsIGJ1dCBXSVRIT1VUCiMgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YgTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MKIyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuIFNlZSB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KIyBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZQojIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtLiBJZiBub3QsIHNlZSA8aHR0cHM6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8+LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6T3V0cHV0OjpIVE1MOjpJbXBvcnRFeHBvcnQ6OkxheW91dERhdGVUaW1lOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKb3VyIEBPYmplY3REZXBlbmRlbmNpZXMgPSAoCiAgICAnS2VybmVsOjpTeXN0ZW06OkxvZycsCiAgICAnS2VybmVsOjpPdXRwdXQ6OkhUTUw6OkxheW91dCcsCiAgICAnS2VybmVsOjpTeXN0ZW06OldlYjo6UmVxdWVzdCcsCik7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpPdXRwdXQ6OkhUTUw6OkltcG9ydEV4cG9ydDo6TGF5b3V0RGF0ZVRpbWUgLSBsYXlvdXQgYmFja2VuZCBtb2R1bGUKCj1oZWFkMSBERVNDUklQVElPTgoKQWxsIGxheW91dCBmdW5jdGlvbnMgZm9yIERhdGVUaW1lIGVsZW1lbnRzIGluIEltcG9ydC9FeHBvcnQuCgo9Y3V0Cgo9aGVhZDIgbmV3KCkKCkNyZWF0ZSBhbiBvYmplY3QKCiAgICBteSAkQmFja2VuZE9iamVjdCA9IEtlcm5lbDo6T3V0cHV0OjpIVE1MOjpJbXBvcnRFeHBvcnQ6OkxheW91dERhdGVUaW1lLT5uZXcoCiAgICAgICAgJVBhcmFtLAogICAgKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIHJldHVybiBibGVzcyB7fSwgJFR5cGU7Cn0KCj1oZWFkMiBGb3JtSW5wdXRDcmVhdGUoKQoKQ3JlYXRlIGEgaW5wdXQgc3RyaW5nCgogICAgbXkgJFZhbHVlID0gJEJhY2tlbmRPYmplY3QtPkZvcm1JbnB1dENyZWF0ZSgKICAgICAgICBJdGVtICAgPT4gJEl0ZW1SZWYsCiAgICAgICAgUHJlZml4ID0+ICdQcmVmaXg6OicsICAjIChvcHRpb25hbCkKICAgICAgICBWYWx1ZSAgPT4gJ1ZhbHVlJywgICAgICMgKG9wdGlvbmFsKQogICAgICAgIENsYXNzICA9PiAnTW9kZXJuaXplJyAgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEZvcm1JbnB1dENyZWF0ZSB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBpZiAoICEkUGFyYW17SXRlbX0gKSB7CiAgICAgICAgJEtlcm5lbDo6T00tPkdldCgnS2VybmVsOjpTeXN0ZW06OkxvZycpLT5Mb2coCiAgICAgICAgICAgIFByaW9yaXR5ID0+ICdlcnJvcicsCiAgICAgICAgICAgIE1lc3NhZ2UgID0+ICdOZWVkIEl0ZW0hJywKICAgICAgICApOwogICAgICAgIHJldHVybjsKICAgIH0KCiAgICBteSAkUHJlZml4ID0gJFBhcmFte1ByZWZpeH0gfHwgJFBhcmFte0l0ZW19e0lucHV0fXtQcmVmaXh9IHx8ICcnOwogICAgJFByZWZpeCAuPSAkUGFyYW17SXRlbX17S2V5fTsKCiAgICAjIHNldCBkZWZhdWx0IHZhbHVlCiAgICAkUGFyYW17VmFsdWV9IHx8PSAkUGFyYW17SXRlbX0tPntJbnB1dH0tPntWYWx1ZURlZmF1bHR9OwoKICAgIGlmICggJFBhcmFte1ZhbHVlfSApIHsKICAgICAgICBteSAoICRZZWFyLCAkTW9udGgsICREYXksICRIb3VyLCAkTWludXRlLCAkU2Vjb25kICkgPSAkUGFyYW17VmFsdWV9ID1+CiAgICAgICAgICAgIG17IFxBICggXGR7NH0gKSAtICggXGR7Mn0gKSAtICggXGR7Mn0gKSBccyAoIFxkezJ9ICkgOiAoIFxkezJ9ICkgOiAoIFxkezJ9ICkgXHogfXhtczsKCiAgICAgICAgIyBJZiBhIHZhbHVlIGlzIHNlbnQgdGhpcyB2YWx1ZSBtdXN0IGJlIGFjdGl2ZSwgdGhlbiB0aGUgVXNlZCBwYXJ0IG5lZWRzIHRvIGJlIHNldCB0byAxCiAgICAgICAgIyAgIG90aGVyd2lzZSB1c2VyIGNhbiBlYXNpbHkgZm9yZ2V0IHRvIG1hcmsgdGhlIGNoZWNrYm94IGFuZCB0aGlzIGNvdWxkIGxlYWQgaW50byBkYXRhCiAgICAgICAgIyAgIGxvc3QgKEJ1ZyM4MjU4KS4KICAgICAgICAkUGFyYW17ICRQcmVmaXggLiAnVXNlZCcgfSAgID0gMTsKICAgICAgICAkUGFyYW17ICRQcmVmaXggLiAnWWVhcicgfSAgID0gJFllYXI7CiAgICAgICAgJFBhcmFteyAkUHJlZml4IC4gJ01vbnRoJyB9ICA9ICRNb250aDsKICAgICAgICAkUGFyYW17ICRQcmVmaXggLiAnRGF5JyB9ICAgID0gJERheTsKICAgICAgICAkUGFyYW17ICRQcmVmaXggLiAnSG91cicgfSAgID0gJEhvdXI7CiAgICAgICAgJFBhcmFteyAkUHJlZml4IC4gJ01pbnV0ZScgfSA9ICRNaW51dGU7CiAgICB9CgogICAgJFBhcmFteyAkUHJlZml4IC4gJ1ZhbHVlJyB9ICAgID0gJFBhcmFte0l0ZW19e0lucHV0fXtSZXF1aXJlZH07CiAgICAkUGFyYW17ICRQcmVmaXggLiAnT3B0aW9uYWwnIH0gPSAkUGFyYW17SXRlbX17SW5wdXR9e09wdGlvbmFsfTsKICAgICRQYXJhbXsgJFByZWZpeCAuICdDbGFzcycgfSAgICA9ICRQYXJhbXtJdGVtfXtJbnB1dH17Q2xhc3N9OwoKICAgICMgZ2VuZXJhdGUgb3B0aW9uIHN0cmluZwogICAgbXkgJFN0cmluZyA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6T3V0cHV0OjpIVE1MOjpMYXlvdXQnKS0+QnVpbGREYXRlU2VsZWN0aW9uKAogICAgICAgICVQYXJhbSwKICAgICAgICBQcmVmaXggPT4gJFByZWZpeCwKICAgICAgICBGb3JtYXQgPT4gJ0RhdGVJbnB1dEZvcm1hdExvbmcnLAogICAgKTsKCiAgICByZXR1cm4gJFN0cmluZzsKfQoKPWhlYWQyIEZvcm1EYXRhR2V0KCkKCkdldCBmb3JtIGRhdGEKCiAgICBteSAkRm9ybURhdGEgPSAkQmFja2VuZE9iamVjdC0+Rm9ybURhdGFHZXQoCiAgICAgICAgSXRlbSAgID0+ICRJdGVtUmVmLAogICAgICAgIFByZWZpeCA9PiAnUHJlZml4OjonLCAgIyAob3B0aW9uYWwpCiAgICApOwoKPWN1dAoKc3ViIEZvcm1EYXRhR2V0IHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBjaGVjayBuZWVkZWQgc3R1ZmYKICAgIGlmICggISRQYXJhbXtJdGVtfSApIHsKICAgICAgICAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6TG9nJyktPkxvZygKICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgTWVzc2FnZSAgPT4gJ05lZWQgSXRlbSEnLAogICAgICAgICk7CiAgICAgICAgcmV0dXJuOwogICAgfQoKICAgIG15ICRQYXJhbU9iamVjdCA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpXZWI6OlJlcXVlc3QnKTsKCiAgICBteSAkUHJlZml4ID0gJFBhcmFte1ByZWZpeH0gfHwgJFBhcmFte0l0ZW19e0lucHV0fXtQcmVmaXh9IHx8ICcnOwogICAgJFByZWZpeCAuPSAkUGFyYW17SXRlbX17S2V5fTsKCiAgICBteSAlVmFsdWVzOwogICAgZm9yIG15ICRUeXBlIChxdyhVc2VkIFllYXIgTW9udGggRGF5IEhvdXIgTWludXRlKSkgewogICAgICAgICRWYWx1ZXN7ICRQcmVmaXggLiAkVHlwZSB9ID0gJFBhcmFtT2JqZWN0LT5HZXRQYXJhbSgKICAgICAgICAgICAgUGFyYW0gPT4gJFByZWZpeCAuICRUeXBlLAogICAgICAgICkgfHwgMDsKICAgIH0KCiAgICBteSAkRm9ybURhdGE7CiAgICBpZiAoICRWYWx1ZXN7ICRQcmVmaXggLiAnVXNlZCcgfSApIHsKCiAgICAgICAgIyBhZGQgYSBsZWFkaW5nIHplcm8gZm9yIGRhdGUgcGFydHMgdGhhdCBjb3VsZCBiZSBsZXNzIHRoYW4gdGVuIHRvIGdlbmVyYXRlIGEgY29ycmVjdAogICAgICAgICMgdGltZSBzdGFtcAogICAgICAgIGZvciBteSAkVHlwZSAocXcoTW9udGggRGF5IEhvdXIgTWludXRlIFNlY29uZCkpIHsKICAgICAgICAgICAgJFZhbHVlc3sgJFByZWZpeCAuICRUeXBlIH0gPSBzcHJpbnRmICIlMDJkIiwgJFZhbHVlc3sgJFByZWZpeCAuICRUeXBlIH07CiAgICAgICAgfQoKICAgICAgICBteSAkWWVhciAgID0gJFZhbHVlc3sgJFByZWZpeCAuICdZZWFyJyB9ICAgfHwgJzAwMDAnOwogICAgICAgIG15ICRNb250aCAgPSAkVmFsdWVzeyAkUHJlZml4IC4gJ01vbnRoJyB9ICB8fCAnMDAnOwogICAgICAgIG15ICREYXkgICAgPSAkVmFsdWVzeyAkUHJlZml4IC4gJ0RheScgfSAgICB8fCAnMDAnOwogICAgICAgIG15ICRIb3VyICAgPSAkVmFsdWVzeyAkUHJlZml4IC4gJ0hvdXInIH0gICB8fCAnMDAnOwogICAgICAgIG15ICRNaW51dGUgPSAkVmFsdWVzeyAkUHJlZml4IC4gJ01pbnV0ZScgfSB8fCAnMDAnOwogICAgICAgIG15ICRTZWNvbmQgPSAkVmFsdWVzeyAkUHJlZml4IC4gJ1NlY29uZCcgfSB8fCAnMDAnOwoKICAgICAgICAkRm9ybURhdGEgPQogICAgICAgICAgICAkWWVhciAuICctJyAuICRNb250aCAuICctJyAuICREYXkgLiAnICcgLiAkSG91ciAuICc6JyAuICRNaW51dGUgLiAnOicgLiAkU2Vjb25kOwogICAgfQoKICAgIHJldHVybiAkRm9ybURhdGEgaWYgJEZvcm1EYXRhOwogICAgcmV0dXJuICRGb3JtRGF0YSBpZiAhJFBhcmFte0l0ZW19e0lucHV0fXtSZXF1aXJlZH07CgogICAgIyBzZXQgaW52YWxpZCBwYXJhbQogICAgJFBhcmFte0l0ZW19LT57Rm9ybX0tPntJbnZhbGlkfSA9IDE7CgogICAgcmV0dXJuICRGb3JtRGF0YTsKfQoKMTsK</File>
        <File Location="doc/en/RotherOSS-ImportExportTicketZnuny.pdf" Permission="644" Encode="Base64">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</File>
    </Filelist>
</otrs_package>