# -- # Copyright (C) 2001-2019 OTRS AG, https://otrs.com/ # -- # This software comes with ABSOLUTELY NO WARRANTY. For details, see # the enclosed file COPYING for license information (GPL). If you # did not receive this file, see https://www.gnu.org/licenses/gpl-3.0.txt. # -- package Kernel::System::Calendar::Ticket::DynamicField; use strict; use warnings; use Kernel::System::VariableCheck qw(:all); our @ObjectDependencies = ( 'Kernel::System::Log', 'Kernel::System::DynamicField', 'Kernel::System::DynamicFieldValue', 'Kernel::System::Ticket', ); =head1 NAME Kernel::System::Calendar::Ticket::DynamicField - DynamicField appointment type =head1 DESCRIPTION DynamicField ticket appointment type. =head1 PUBLIC INTERFACE =head2 new() create an object. Do not use it directly, instead use: use Kernel::System::ObjectManager; local $Kernel::OM = Kernel::System::ObjectManager->new(); my $TicketDynamicFieldObject = $Kernel::OM->Get('Kernel::System::Calendar::Ticket::DynamicField'); =cut sub new { my ( $Type, %Param ) = @_; # allocate new hash for object my $Self = {}; bless( $Self, $Type ); return $Self; } =head2 GetTime() returns time value for dynamic field appointment type. my $StartTime = $TicketDynamicFieldObject->GetTime( Type => 'DynamicField_TestDate', TicketID => 1, ); =cut sub GetTime { my ( $Self, %Param ) = @_; # check needed stuff for my $Needed (qw(Type TicketID)) { if ( !$Param{$Needed} ) { $Kernel::OM->Get('Kernel::System::Log')->Log( Priority => 'error', Message => "Need $Needed!", ); return; } } # get ticket data incl. dynamic fields my %Ticket = $Kernel::OM->Get('Kernel::System::Ticket')->TicketGet( TicketID => $Param{TicketID}, DynamicFields => 1, ); return if !$Ticket{ $Param{Type} }; # check if we found a valid time value and return it if ( $Ticket{ $Param{Type} } =~ '\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}' ) { return $Ticket{ $Param{Type} }; } return; } =head2 SetTime() set ticket dynamic field value to supplied time value. my $Success = $TicketDynamicFieldObject->SetTime( Type => 'DynamicField_TestDate', Value => '2016-01-01 00:00:00' TicketID => 1, ); returns 1 if successful. =cut sub SetTime { my ( $Self, %Param ) = @_; # check needed stuff for my $Needed (qw(Type Value TicketID)) { if ( !$Param{$Needed} ) { $Kernel::OM->Get('Kernel::System::Log')->Log( Priority => 'error', Message => "Need $Needed!", ); return; } } # get dynamic field data my $DynamicFieldName = $Param{Type}; $DynamicFieldName =~ s/^DynamicField_//; my $DynamicField = $Kernel::OM->Get('Kernel::System::DynamicField')->DynamicFieldGet( Name => $DynamicFieldName, ); return if !$DynamicField; # set dynamic field value my $Success = $Kernel::OM->Get('Kernel::System::DynamicFieldValue')->ValueSet( FieldID => $DynamicField->{ID}, ObjectID => $Param{TicketID}, Value => [ { ValueDateTime => $Param{Value}, }, ], UserID => 1, ); return $Success; } 1; =head1 TERMS AND CONDITIONS This software is part of the OTRS project (L). This software comes with ABSOLUTELY NO WARRANTY. For details, see the enclosed file COPYING for license information (GPL). If you did not receive this file, see L. =cut