# -- # 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::GenericInterface::Operation::ConfigItem::ConfigItemDelete; use strict; use warnings; use MIME::Base64; use Kernel::System::VariableCheck qw(:all); use parent qw( Kernel::GenericInterface::Operation::Common Kernel::GenericInterface::Operation::ConfigItem::Common ); our $ObjectManagerDisabled = 1; =head1 NAME Kernel::GenericInterface::Operation::ConfigItem::ConfigItemDelete - GenericInterface Configuration Item Delete Operation backend =head1 PUBLIC INTERFACE =head2 new() usually, you want to create an instance of this by using Kernel::GenericInterface::Operation->new(); =cut sub new { my ( $Type, %Param ) = @_; my $Self = {}; bless( $Self, $Type ); # check needed objects for my $Needed (qw(DebuggerObject WebserviceID)) { if ( !$Param{$Needed} ) { return { Success => 0, ErrorMessage => "Got no $Needed!", }; } $Self->{$Needed} = $Param{$Needed}; } $Self->{OperationName} = 'ConfigItemDelete'; $Self->{Config} = $Kernel::OM->Get('Kernel::Config')->Get('GenericInterface::Operation::ConfigItemDelete'); return $Self; } =head2 Run() perform ConfigItemDelete Operation. This function is able to return one or more ConfigItem entries in one call. my $Result = $OperationObject->Run( Data => { UserLogin => 'some agent login', # UserLogin or CustomerUserLogin or SessionID is # required CustomerUserLogin => 'some customer login', SessionID => 123, Password => 'some password', # if UserLogin or customerUserLogin is sent then # Password is required ConfigItemID => '32,33', # required, could be coma separated IDs or an Array }, ); $Result = { Success => 1, # 0 or 1 ErrorMessage => '', # in case of error Data => { # result data payload after Operation ConfigItemID => [123, 456], # Configuration Item IDs number in OTRS::ITSM (Service desk system) Error => { # should not return errors ErrorCode => 'ConfigItemDelete.ErrorCode' ErrorMessage => 'Error Description' }, }, }; =cut sub Run { my ( $Self, %Param ) = @_; my $Result = $Self->Init( WebserviceID => $Self->{WebserviceID}, ); if ( !$Result->{Success} ) { $Self->ReturnError( ErrorCode => 'Webservice.InvalidConfiguration', ErrorMessage => $Result->{ErrorMessage}, ); } my ( $UserID, $UserType ) = $Self->Auth( %Param ); if ( !$UserID ) { return $Self->ReturnError( ErrorCode => '$Self->{OperationName}.AuthFail', ErrorMessage => "$Self->{OperationName}: Authorization failing!", ); } # check needed stuff for my $Needed (qw(ConfigItemID)) { if ( !$Param{Data}->{$Needed} ) { return $Self->ReturnError( ErrorCode => "$Self->{OperationName}.MissingParameter", ErrorMessage => "$Self->{OperationName}: $Needed parameter is missing!", ); } } my $ErrorMessage = ''; # all needed variables my @ConfigItemIDs; if ( IsStringWithData( $Param{Data}->{ConfigItemID} ) ) { @ConfigItemIDs = split /\s*,\s*/, $Param{Data}->{ConfigItemID}; } elsif ( IsArrayRefWithData( $Param{Data}->{ConfigItemID} ) ) { @ConfigItemIDs = @{ $Param{Data}->{ConfigItemID} }; } else { return $Self->ReturnError( ErrorCode => "$Self->{OperationName}.WrongStructure", ErrorMessage => "$Self->{OperationName}: Structure for ConfigItemID is not correct!", ); } my $ConfigItemObject = $Kernel::OM->Get('Kernel::System::ITSMConfigItem'); my @DeletedConfigItemIDs; # start ConfigItem loop CONFIGITEM: for my $ConfigItemID (@ConfigItemIDs) { # check create permissions my $Permission = $ConfigItemObject->Permission( Scope => 'Item', ItemID => $ConfigItemID, UserID => $UserID, Type => $Self->{Config}->{Permission}, ); if ( !$Permission ) { return $Self->ReturnError( ErrorCode => "$Self->{OperationName}.AccessDenied", ErrorMessage => "$Self->{OperationName}: Can not delete configuration item!", ); } # delete the configitem my $DeleteSuccess = $ConfigItemObject->ConfigItemDelete( ConfigItemID => $ConfigItemID, UserID => $UserID, ); if ( !$DeleteSuccess ) { $ErrorMessage = 'Could not delete ConfigItem ID ' . $ConfigItemID . ' in Kernel::GenericInterface::Operation::ConfigItem::ConfigItemDelete::Run()'; return $Self->ReturnError( ErrorCode => '$Self->{OperationName}.DeleteError', ErrorMessage => "$Self->{OperationName}: $ErrorMessage", ); } push @DeletedConfigItemIDs, $ConfigItemID; } # finish ConfigItem loop if ( !IsArrayRefWithData( \@DeletedConfigItemIDs ) ) { return { Success => 0, ErrorMessage => 'Could not delete ConfigItems!', }; } return { Success => 1, Data => { ConfigItemID => \@DeletedConfigItemIDs, }, }; } 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