<?php
/**
* Pimcore
*
* This source file is available under two different licenses:
* - GNU General Public License version 3 (GPLv3)
* - Pimcore Commercial License (PCL)
* Full copyright and license information is available in
* LICENSE.md which is distributed with this source code.
*
* @copyright Copyright (c) Pimcore GmbH (http://www.pimcore.org)
* @license http://www.pimcore.org/license GPLv3 and PCL
*/
namespace Pimcore\Bundle\AdminBundle\EventListener;
use Pimcore\Db;
use Pimcore\Event\DataObjectClassDefinitionEvents;
use Pimcore\Event\Model\DataObject\ClassDefinitionEvent;
use Pimcore\Event\Model\UserRoleEvent;
use Pimcore\Event\UserRoleEvents;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
/**
* @internal
*/
class ImportConfigListener implements EventSubscriberInterface
{
/**
* {@inheritdoc}
*/
public static function getSubscribedEvents(): array
{
return [
DataObjectClassDefinitionEvents::POST_DELETE => 'onClassDelete',
UserRoleEvents::POST_DELETE => 'onUserDelete',
];
}
/**
* @param ClassDefinitionEvent $event
*/
public function onClassDelete($event)
{
$class = $event->getClassDefinition();
$classId = $class->getId();
// collect gridConfigs for that class id
$db = Db::get();
$importConfigIds = $db->fetchFirstColumn('select id from importconfigs where classId = ?', [$classId]);
if ($importConfigIds) {
$db->executeQuery('delete from importconfig_shares where importConfigId in (' . implode($importConfigIds) . ')');
}
$this->cleanupImportConfigs('classId = ' . $db->quote($classId));
}
/**
* @param UserRoleEvent $event
*/
public function onUserDelete($event)
{
$user = $event->getUserRole();
$userId = $user->getId();
$db = Db::get();
$importConfigIds = $db->fetchFirstColumn('select id from importconfigs where ownerId = ?', [$userId]);
if ($importConfigIds) {
$db->executeQuery('delete from importconfig_shares where importConfigId in (' . implode($importConfigIds) . ')');
}
$this->cleanupImportConfigs('ownerId = ' . $userId);
}
protected function cleanupImportConfigs($condition)
{
$db = Db::get();
$db->executeQuery('DELETE FROM importconfigs where ' . $condition);
}
}