mirror of
https://github.com/jbcr/ezmigrationbundle.git
synced 2026-03-24 08:52:08 +01:00
238 lines
7.7 KiB
PHP
238 lines
7.7 KiB
PHP
<?php
|
|
|
|
namespace Kaliop\eZMigrationBundle\Core\Executor;
|
|
|
|
use eZ\Publish\API\Repository\Values\Content\Section;
|
|
use Kaliop\eZMigrationBundle\API\Collection\SectionCollection;
|
|
use Kaliop\eZMigrationBundle\API\MigrationGeneratorInterface;
|
|
use Kaliop\eZMigrationBundle\API\EnumerableMatcherInterface;
|
|
use Kaliop\eZMigrationBundle\Core\Matcher\SectionMatcher;
|
|
|
|
/**
|
|
* Handles section migrations.
|
|
*/
|
|
class SectionManager extends RepositoryExecutor implements MigrationGeneratorInterface, EnumerableMatcherInterface
|
|
{
|
|
protected $supportedStepTypes = array('section');
|
|
protected $supportedActions = array('create', 'load', 'update', 'delete');
|
|
|
|
/** @var SectionMatcher $sectionMatcher */
|
|
protected $sectionMatcher;
|
|
|
|
/**
|
|
* @param SectionMatcher $sectionMatcher
|
|
*/
|
|
public function __construct(SectionMatcher $sectionMatcher)
|
|
{
|
|
$this->sectionMatcher = $sectionMatcher;
|
|
}
|
|
|
|
/**
|
|
* Handles the section create migration action
|
|
*/
|
|
protected function create($step)
|
|
{
|
|
foreach (array('name', 'identifier') as $key) {
|
|
if (!isset($step->dsl[$key])) {
|
|
throw new \Exception("The '$key' key is missing in a section creation definition");
|
|
}
|
|
}
|
|
|
|
$sectionService = $this->repository->getSectionService();
|
|
|
|
$sectionCreateStruct = $sectionService->newSectionCreateStruct();
|
|
|
|
$sectionIdentifier = $this->referenceResolver->resolveReference($step->dsl['identifier']);
|
|
$sectionCreateStruct->identifier = $sectionIdentifier;
|
|
$sectionCreateStruct->name = $this->referenceResolver->resolveReference($step->dsl['name']);
|
|
|
|
$section = $sectionService->createSection($sectionCreateStruct);
|
|
|
|
$this->setReferences($section, $step);
|
|
|
|
return $section;
|
|
}
|
|
|
|
protected function load($step)
|
|
{
|
|
$sectionCollection = $this->matchSections('load', $step);
|
|
|
|
$this->setReferences($sectionCollection, $step);
|
|
|
|
return $sectionCollection;
|
|
}
|
|
|
|
/**
|
|
* Handles the section update migration action
|
|
*/
|
|
protected function update($step)
|
|
{
|
|
$sectionCollection = $this->matchSections('update', $step);
|
|
|
|
if (count($sectionCollection) > 1 && array_key_exists('references', $step->dsl)) {
|
|
throw new \Exception("Can not execute Section update because multiple sections match, and a references section is specified in the dsl. References can be set when only 1 section matches");
|
|
}
|
|
|
|
$sectionService = $this->repository->getSectionService();
|
|
foreach ($sectionCollection as $key => $section) {
|
|
$sectionUpdateStruct = $sectionService->newSectionUpdateStruct();
|
|
|
|
if (isset($step->dsl['identifier'])) {
|
|
$sectionUpdateStruct->identifier = $this->referenceResolver->resolveReference($step->dsl['identifier']);
|
|
}
|
|
if (isset($step->dsl['name'])) {
|
|
$sectionUpdateStruct->name = $this->referenceResolver->resolveReference($step->dsl['name']);
|
|
}
|
|
|
|
$section = $sectionService->updateSection($section, $sectionUpdateStruct);
|
|
|
|
$sectionCollection[$key] = $section;
|
|
}
|
|
|
|
$this->setReferences($sectionCollection, $step);
|
|
|
|
return $sectionCollection;
|
|
}
|
|
|
|
/**
|
|
* Handles the section delete migration action
|
|
*/
|
|
protected function delete($step)
|
|
{
|
|
$sectionCollection = $this->matchSections('delete', $step);
|
|
|
|
$this->setReferences($sectionCollection, $step);
|
|
|
|
$sectionService = $this->repository->getSectionService();
|
|
|
|
foreach ($sectionCollection as $section) {
|
|
$sectionService->deleteSection($section);
|
|
}
|
|
|
|
return $sectionCollection;
|
|
}
|
|
|
|
/**
|
|
* @param string $action
|
|
* @return SectionCollection
|
|
* @throws \Exception
|
|
*/
|
|
protected function matchSections($action, $step)
|
|
{
|
|
if (!isset($step->dsl['match'])) {
|
|
throw new \Exception("A match condition is required to $action a section");
|
|
}
|
|
|
|
// convert the references passed in the match
|
|
$match = $this->resolveReferencesRecursively($step->dsl['match']);
|
|
|
|
return $this->sectionMatcher->match($match);
|
|
}
|
|
|
|
/**
|
|
* @param Section $section
|
|
* @param array $references the definitions of the references to set
|
|
* @throws \InvalidArgumentException When trying to assign a reference to an unsupported attribute
|
|
* @return array key: the reference names, values: the reference values
|
|
*/
|
|
protected function getReferencesValues($section, array $references, $step)
|
|
{
|
|
$refs = array();
|
|
|
|
foreach ($references as $reference) {
|
|
switch ($reference['attribute']) {
|
|
case 'section_id':
|
|
case 'id':
|
|
$value = $section->id;
|
|
break;
|
|
case 'section_identifier':
|
|
case 'identifier':
|
|
$value = $section->identifier;
|
|
break;
|
|
case 'section_name':
|
|
case 'name':
|
|
$value = $section->name;
|
|
break;
|
|
default:
|
|
throw new \InvalidArgumentException('Section Manager does not support setting references for attribute ' . $reference['attribute']);
|
|
}
|
|
|
|
$refs[$reference['identifier']] = $value;
|
|
}
|
|
|
|
return $refs;
|
|
}
|
|
|
|
/**
|
|
* @param array $matchCondition
|
|
* @param string $mode
|
|
* @param array $context
|
|
* @throws \Exception
|
|
* @return array
|
|
*/
|
|
public function generateMigration(array $matchCondition, $mode, array $context = array())
|
|
{
|
|
$currentUser = $this->authenticateUserByContext($context);
|
|
$sectionCollection = $this->sectionMatcher->match($matchCondition);
|
|
$data = array();
|
|
|
|
/** @var \eZ\Publish\API\Repository\Values\Content\Section $section */
|
|
foreach ($sectionCollection as $section) {
|
|
|
|
$sectionData = array(
|
|
'type' => reset($this->supportedStepTypes),
|
|
'mode' => $mode,
|
|
);
|
|
|
|
switch ($mode) {
|
|
case 'create':
|
|
$sectionData = array_merge(
|
|
$sectionData,
|
|
array(
|
|
'identifier' => $section->identifier,
|
|
'name' => $section->name,
|
|
)
|
|
);
|
|
break;
|
|
case 'update':
|
|
$sectionData = array_merge(
|
|
$sectionData,
|
|
array(
|
|
'match' => array(
|
|
SectionMatcher::MATCH_SECTION_ID => $section->id
|
|
),
|
|
'identifier' => $section->identifier,
|
|
'name' => $section->name,
|
|
)
|
|
);
|
|
break;
|
|
case 'delete':
|
|
$sectionData = array_merge(
|
|
$sectionData,
|
|
array(
|
|
'match' => array(
|
|
SectionMatcher::MATCH_SECTION_ID => $section->id
|
|
)
|
|
)
|
|
);
|
|
break;
|
|
default:
|
|
throw new \Exception("Executor 'section' doesn't support mode '$mode'");
|
|
}
|
|
|
|
$data[] = $sectionData;
|
|
}
|
|
|
|
$this->authenticateUserByReference($currentUser);
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @return string[]
|
|
*/
|
|
public function listAllowedConditions()
|
|
{
|
|
return $this->sectionMatcher->listAllowedConditions();
|
|
}
|
|
}
|