mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00
fix subscriber
This commit is contained in:
@@ -11,6 +11,7 @@
|
|||||||
|
|
||||||
namespace Alchemy\Phrasea\WorkerManager\Provider;
|
namespace Alchemy\Phrasea\WorkerManager\Provider;
|
||||||
|
|
||||||
|
use Alchemy\Phrasea\Core\LazyLocator;
|
||||||
use Alchemy\Phrasea\Model\Manipulator\WebhookEventManipulator;
|
use Alchemy\Phrasea\Model\Manipulator\WebhookEventManipulator;
|
||||||
use Alchemy\Phrasea\Plugin\PluginProviderInterface;
|
use Alchemy\Phrasea\Plugin\PluginProviderInterface;
|
||||||
use Alchemy\Phrasea\Application as PhraseaApplication;
|
use Alchemy\Phrasea\Application as PhraseaApplication;
|
||||||
@@ -61,9 +62,7 @@ class QueueWorkerServiceProvider implements PluginProviderInterface
|
|||||||
$app->extend('dispatcher', function (EventDispatcherInterface $dispatcher, Application $app) {
|
$app->extend('dispatcher', function (EventDispatcherInterface $dispatcher, Application $app) {
|
||||||
|
|
||||||
$dispatcher->addSubscriber(
|
$dispatcher->addSubscriber(
|
||||||
(new RecordSubscriber($app)
|
new RecordSubscriber($app, new LazyLocator($app, 'phraseanet.appbox'))
|
||||||
)->setApplicationBox($app['phraseanet.appbox'])
|
|
||||||
|
|
||||||
);
|
);
|
||||||
$dispatcher->addSubscriber(new ExportSubscriber($app['alchemy_worker.message.publisher']));
|
$dispatcher->addSubscriber(new ExportSubscriber($app['alchemy_worker.message.publisher']));
|
||||||
$dispatcher->addSubscriber(new AssetsIngestSubscriber($app['alchemy_worker.message.publisher']));
|
$dispatcher->addSubscriber(new AssetsIngestSubscriber($app['alchemy_worker.message.publisher']));
|
||||||
|
@@ -3,7 +3,6 @@
|
|||||||
namespace Alchemy\Phrasea\WorkerManager\Subscriber;
|
namespace Alchemy\Phrasea\WorkerManager\Subscriber;
|
||||||
|
|
||||||
use Alchemy\Phrasea\Application;
|
use Alchemy\Phrasea\Application;
|
||||||
use Alchemy\Phrasea\Application\Helper\ApplicationBoxAware;
|
|
||||||
use Alchemy\Phrasea\Core\Event\Record\DeletedEvent;
|
use Alchemy\Phrasea\Core\Event\Record\DeletedEvent;
|
||||||
use Alchemy\Phrasea\Core\Event\Record\DeleteEvent;
|
use Alchemy\Phrasea\Core\Event\Record\DeleteEvent;
|
||||||
use Alchemy\Phrasea\Core\Event\Record\MetadataChangedEvent;
|
use Alchemy\Phrasea\Core\Event\Record\MetadataChangedEvent;
|
||||||
@@ -23,8 +22,6 @@ use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
|||||||
|
|
||||||
class RecordSubscriber implements EventSubscriberInterface
|
class RecordSubscriber implements EventSubscriberInterface
|
||||||
{
|
{
|
||||||
use ApplicationBoxAware;
|
|
||||||
|
|
||||||
/** @var MessagePublisher $messagePublisher */
|
/** @var MessagePublisher $messagePublisher */
|
||||||
private $messagePublisher;
|
private $messagePublisher;
|
||||||
|
|
||||||
@@ -34,33 +31,40 @@ class RecordSubscriber implements EventSubscriberInterface
|
|||||||
/** @var Application */
|
/** @var Application */
|
||||||
private $app;
|
private $app;
|
||||||
|
|
||||||
public function __construct(Application $app)
|
/**
|
||||||
|
* @var callable
|
||||||
|
*/
|
||||||
|
private $appboxLocator;
|
||||||
|
|
||||||
|
public function __construct(Application $app, callable $appboxLocator)
|
||||||
{
|
{
|
||||||
$this->messagePublisher = $app['alchemy_worker.message.publisher'];
|
$this->messagePublisher = $app['alchemy_worker.message.publisher'];
|
||||||
$this->workerResolver = $app['alchemy_worker.type_based_worker_resolver'];
|
$this->workerResolver = $app['alchemy_worker.type_based_worker_resolver'];
|
||||||
$this->app = $app;
|
$this->app = $app;
|
||||||
|
$this->appboxLocator = $appboxLocator;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onSubdefinitionCreate(SubdefinitionCreateEvent $event)
|
public function onSubdefinitionCreate(SubdefinitionCreateEvent $event)
|
||||||
{
|
{
|
||||||
$record = $this->findDataboxById($event->getRecord()->getDataboxId())->get_record($event->getRecord()->getRecordId());
|
$record = $this->getApplicationBox()->get_databox($event->getRecord()->getDataboxId())->get_record($event->getRecord()->getRecordId());
|
||||||
|
|
||||||
$subdefs = $record->getDatabox()->get_subdef_structure()->getSubdefGroup($record->getType());
|
if (!$record->isStory()) {
|
||||||
|
$subdefs = $record->getDatabox()->get_subdef_structure()->getSubdefGroup($record->getType());
|
||||||
|
|
||||||
foreach ($subdefs as $subdef) {
|
foreach ($subdefs as $subdef) {
|
||||||
$payload = [
|
$payload = [
|
||||||
'message_type' => MessagePublisher::SUBDEF_CREATION_TYPE,
|
'message_type' => MessagePublisher::SUBDEF_CREATION_TYPE,
|
||||||
'payload' => [
|
'payload' => [
|
||||||
'recordId' => $event->getRecord()->getRecordId(),
|
'recordId' => $event->getRecord()->getRecordId(),
|
||||||
'databoxId' => $event->getRecord()->getDataboxId(),
|
'databoxId' => $event->getRecord()->getDataboxId(),
|
||||||
'subdefName' => $subdef->get_name(),
|
'subdefName' => $subdef->get_name(),
|
||||||
'status' => $event->isNewRecord() ? MessagePublisher::NEW_RECORD_MESSAGE : ''
|
'status' => $event->isNewRecord() ? MessagePublisher::NEW_RECORD_MESSAGE : ''
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
$this->messagePublisher->publishMessage($payload, MessagePublisher::SUBDEF_QUEUE);
|
$this->messagePublisher->publishMessage($payload, MessagePublisher::SUBDEF_QUEUE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onDelete(DeleteEvent $event)
|
public function onDelete(DeleteEvent $event)
|
||||||
@@ -116,7 +120,7 @@ class RecordSubscriber implements EventSubscriberInterface
|
|||||||
$mediaSubdefRepository = $this->getMediaSubdefRepository($databoxId);
|
$mediaSubdefRepository = $this->getMediaSubdefRepository($databoxId);
|
||||||
$mediaSubdefs = $mediaSubdefRepository->findByRecordIdsAndNames([$recordId]);
|
$mediaSubdefs = $mediaSubdefRepository->findByRecordIdsAndNames([$recordId]);
|
||||||
|
|
||||||
$databox = $this->findDataboxById($databoxId);
|
$databox = $this->getApplicationBox()->get_databox($databoxId);
|
||||||
$record = $databox->get_record($recordId);
|
$record = $databox->get_record($recordId);
|
||||||
$type = $record->getType();
|
$type = $record->getType();
|
||||||
|
|
||||||
@@ -205,7 +209,7 @@ class RecordSubscriber implements EventSubscriberInterface
|
|||||||
$databoxId = $event->getRecord()->getDataboxId();
|
$databoxId = $event->getRecord()->getDataboxId();
|
||||||
$recordId = $event->getRecord()->getRecordId();
|
$recordId = $event->getRecord()->getRecordId();
|
||||||
|
|
||||||
$databox = $this->findDataboxById($databoxId);
|
$databox = $this->getApplicationBox()->get_databox($databoxId);
|
||||||
$record = $databox->get_record($recordId);
|
$record = $databox->get_record($recordId);
|
||||||
$type = $record->getType();
|
$type = $record->getType();
|
||||||
|
|
||||||
@@ -231,11 +235,11 @@ class RecordSubscriber implements EventSubscriberInterface
|
|||||||
public static function getSubscribedEvents()
|
public static function getSubscribedEvents()
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
RecordEvents::CREATED => 'onRecordCreated',
|
RecordEvents::CREATED => 'onRecordCreated',
|
||||||
RecordEvents::SUBDEFINITION_CREATE => 'onSubdefinitionCreate',
|
RecordEvents::SUBDEFINITION_CREATE => 'onSubdefinitionCreate',
|
||||||
RecordEvents::DELETE => 'onDelete',
|
RecordEvents::DELETE => 'onDelete',
|
||||||
WorkerEvents::SUBDEFINITION_CREATION_FAILURE => 'onSubdefinitionCreationFailure',
|
WorkerEvents::SUBDEFINITION_CREATION_FAILURE => 'onSubdefinitionCreationFailure',
|
||||||
RecordEvents::METADATA_CHANGED => 'onMetadataChanged',
|
RecordEvents::METADATA_CHANGED => 'onMetadataChanged',
|
||||||
WorkerEvents::STORY_CREATE_COVER => 'onStoryCreateCover',
|
WorkerEvents::STORY_CREATE_COVER => 'onStoryCreateCover',
|
||||||
WorkerEvents::SUBDEFINITION_WRITE_META => 'onSubdefinitionWritemeta'
|
WorkerEvents::SUBDEFINITION_WRITE_META => 'onSubdefinitionWritemeta'
|
||||||
];
|
];
|
||||||
@@ -265,4 +269,14 @@ class RecordSubscriber implements EventSubscriberInterface
|
|||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return \appbox
|
||||||
|
*/
|
||||||
|
private function getApplicationBox()
|
||||||
|
{
|
||||||
|
$callable = $this->appboxLocator;
|
||||||
|
|
||||||
|
return $callable();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -19,9 +19,6 @@ class SubscriberTest extends \PhraseanetTestCase
|
|||||||
|
|
||||||
$sexportSubscriber = new ExportSubscriber($app['alchemy_worker.message.publisher']->reveal());
|
$sexportSubscriber = new ExportSubscriber($app['alchemy_worker.message.publisher']->reveal());
|
||||||
$this->assertInstanceOf('Symfony\\Component\\EventDispatcher\\EventSubscriberInterface', $sexportSubscriber);
|
$this->assertInstanceOf('Symfony\\Component\\EventDispatcher\\EventSubscriberInterface', $sexportSubscriber);
|
||||||
|
|
||||||
$recordSubscriber = new RecordSubscriber($app);
|
|
||||||
$this->assertInstanceOf('Symfony\\Component\\EventDispatcher\\EventSubscriberInterface', $recordSubscriber);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIfPublisheMessageOnSubscribeEvent()
|
public function testIfPublisheMessageOnSubscribeEvent()
|
||||||
|
@@ -44,8 +44,8 @@ class WorkerServiceTest extends \PHPUnit_Framework_TestCase
|
|||||||
|
|
||||||
$writemetadatasWorker = new WriteMetadatasWorker(
|
$writemetadatasWorker = new WriteMetadatasWorker(
|
||||||
$writer,
|
$writer,
|
||||||
$app['alchemy_service.logger'],
|
$app['alchemy_worker.logger'],
|
||||||
$app['alchemy_service.message.publisher'],
|
$app['alchemy_worker.message.publisher'],
|
||||||
$app['repo.worker-running-job']
|
$app['repo.worker-running-job']
|
||||||
);
|
);
|
||||||
$this->assertInstanceOf('Alchemy\\Phrasea\\WorkerManager\\Worker\\WorkerInterface', $writemetadatasWorker);
|
$this->assertInstanceOf('Alchemy\\Phrasea\\WorkerManager\\Worker\\WorkerInterface', $writemetadatasWorker);
|
||||||
|
Reference in New Issue
Block a user