class ManualPull in CMS Content Sync 2.0.x
Same name and namespace in other branches
- 8 src/Controller/ManualPull.php \Drupal\cms_content_sync\Controller\ManualPull
- 2.1.x src/Controller/ManualPull.php \Drupal\cms_content_sync\Controller\ManualPull
Provides a listing of Flow.
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, RedirectDestinationTrait, StringTranslationTrait
- class \Drupal\cms_content_sync\Controller\ManualPull
Expanded class hierarchy of ManualPull
File
- src/
Controller/ ManualPull.php, line 16
Namespace
Drupal\cms_content_sync\ControllerView source
class ManualPull extends ControllerBase {
/**
* Ensure that the pull tab is just show if a flow exists which contains
* and entity type that has its pull set to "manual".
*/
public function access() {
$flows = Flow::getAll();
$manually_pulled_entity_types = [];
foreach ($flows as $flow) {
if (!empty($flow
->getEntityTypesToPull(PullIntent::PULL_MANUALLY))) {
$manually_pulled_entity_types[$flow
->id()] = $flow
->getEntityTypesToPull(PullIntent::PULL_MANUALLY);
}
}
return AccessResult::allowedIf(!empty($manually_pulled_entity_types))
->addCacheableDependency($flows);
}
/**
* Render the content synchronization Angular frontend.
*
* @throws \Drupal\Component\Plugin\Exception\InvalidPluginDefinitionException
* @throws \Drupal\Component\Plugin\Exception\PluginNotFoundException
* @throws \EdgeBox\SyncCore\Exception\SyncCoreException
*
* @return array
*/
public function content() {
$settings = ContentSyncSettings::getInstance();
if (Migration::alwaysUseV2() || 'yes' === \Drupal::request()->query
->get('v2')) {
$embed = Embed::create(\Drupal::getContainer());
return $embed
->pullDashboard();
}
$config = [
'siteUrl' => $settings
->getSiteBaseUrl(),
'pools' => [],
'flows' => [],
'entity_types' => [],
];
$pools = Pool::getAll();
$cloud = _cms_content_sync_is_cloud_version() && $settings
->isDirectSyncCoreAccessEnabled();
$sync_core_settings = null;
$connection_id = null;
foreach (Flow::getAll() as $id => $flow) {
$config['flows'][$flow->id] = [
'id' => $flow->id,
'name' => $flow->name,
];
foreach ($flow
->getEntityTypeConfig() as $definition) {
if (!$flow
->canPullEntity($definition['entity_type_name'], $definition['bundle_name'], PullIntent::PULL_MANUALLY)) {
continue;
}
foreach ($flow
->getEntityTypeConfig($definition['entity_type_name'], $definition['bundle_name'])['import_pools'] as $id => $option) {
if (Pool::POOL_USAGE_ALLOW != $option) {
continue;
}
$pool = $pools[$id];
$config['pools'][$pool->id] = [
'id' => $pool->id,
'label' => $pool->label,
'site_id' => DrupalApplication::get()
->getSiteMachineName(),
];
if (!$sync_core_settings) {
$sync_core_settings = $pool
->getClient()
->getSyndicationService()
->configurePullDashboard();
}
}
$index = $definition['entity_type_name'] . '.' . $definition['bundle_name'];
if (!isset($config['entity_types'][$index])) {
// Get the entity type and bundle name.
$entity_type_storage = \Drupal::entityTypeManager()
->getStorage($definition['entity_type_name']);
$entity_type = $entity_type_storage
->getEntityType();
$entity_type_label = $entity_type
->getLabel()
->render();
$bundle_info = \Drupal::service('entity_type.bundle.info')
->getBundleInfo($definition['entity_type_name']);
$bundle_label = $bundle_info[$definition['bundle_name']]['label'];
$config['entity_types'][$index] = [
'entity_type_name' => $definition['entity_type_name'],
'entity_type_label' => $entity_type_label,
'bundle_name' => $definition['bundle_name'],
'bundle_label' => $bundle_label,
'version' => $definition['version'],
'pools' => [],
'preview' => $definition['preview'] ?? Flow::PREVIEW_DISABLED,
];
}
else {
if (Flow::PREVIEW_DISABLED == $config['entity_types'][$index]['preview'] || Flow::PREVIEW_TABLE != $definition['preview']) {
$config['entity_types'][$index]['preview'] = $definition['preview'] ?? Flow::PREVIEW_DISABLED;
}
}
foreach ($definition['import_pools'] as $id => $action) {
if (!isset($config['entity_types'][$index]['pools'][$id]) || Pool::POOL_USAGE_FORCE == $action || Pool::POOL_USAGE_FORBID == $config['entity_types'][$index]['pools'][$id]) {
$config['entity_types'][$index]['pools'][$id] = $action;
}
}
}
}
// Provide additional conditions for "subscribe only to" filters.
if ($cloud) {
$entity_type_ids = [];
/**
* @var \Drupal\Core\Entity\EntityFieldManager $entityFieldManager
*/
$entityFieldManager = \Drupal::service('entity_field.manager');
foreach (Flow::getAll() as $flow) {
foreach ($flow
->getEntityTypeConfig() as $definition) {
if (!$flow
->canPullEntity($definition['entity_type_name'], $definition['bundle_name'], PullIntent::PULL_MANUALLY)) {
continue;
}
foreach ($definition['import_pools'] as $pool_id => $behavior) {
if (Pool::POOL_USAGE_ALLOW != $behavior) {
continue;
}
if (isset($entity_type_ids[$pool_id][$definition['entity_type_name']][$definition['bundle_name']])) {
continue;
}
if (EntityHandlerPluginManager::isEntityTypeFieldable($definition['entity_type_name'])) {
/**
* @var \Drupal\Core\Field\FieldDefinitionInterface[] $fields
*/
$fields = $entityFieldManager
->getFieldDefinitions($definition['entity_type_name'], $definition['bundle_name']);
foreach ($fields as $key => $field) {
$field_config = $flow
->getFieldHandlerConfig($definition['entity_type_name'], $definition['bundle_name'], $key);
if (empty($field_config)) {
continue;
}
if (empty($field_config['handler_settings']['subscribe_only_to'])) {
continue;
}
$allowed = [];
foreach ($field_config['handler_settings']['subscribe_only_to'] as $ref) {
$allowed[] = $ref['uuid'];
}
$sync_core_settings
->ifTaggedWith($pool_id, $definition['entity_type_name'], $definition['bundle_name'], $key, $allowed);
}
}
$entity_type_ids[$pool_id][$definition['entity_type_name']][$definition['bundle_name']] = true;
}
}
}
}
$config = array_merge($config, $sync_core_settings
->getConfig());
if (empty($config['entity_types'])) {
\Drupal::messenger()
->addMessage(t('There are no entity types to be pulled manually.'));
}
return [
'#theme' => 'cms_content_sync_content_dashboard',
'#configuration' => $config,
'#attached' => [
'library' => [
'cms_content_sync/pull',
],
],
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ControllerBase:: |
protected | property | The configuration factory. | |
ControllerBase:: |
protected | property | The current user service. | 1 |
ControllerBase:: |
protected | property | The entity form builder. | |
ControllerBase:: |
protected | property | The entity type manager. | |
ControllerBase:: |
protected | property | The form builder. | 2 |
ControllerBase:: |
protected | property | The key-value storage. | 1 |
ControllerBase:: |
protected | property | The language manager. | 1 |
ControllerBase:: |
protected | property | The module handler. | 2 |
ControllerBase:: |
protected | property | The state service. | |
ControllerBase:: |
protected | function | Returns the requested cache bin. | |
ControllerBase:: |
protected | function | Retrieves a configuration object. | |
ControllerBase:: |
private | function | Returns the service container. | |
ControllerBase:: |
public static | function |
Instantiates a new instance of this class. Overrides ContainerInjectionInterface:: |
46 |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity type manager. | |
ControllerBase:: |
protected | function | Returns the form builder service. | 2 |
ControllerBase:: |
protected | function | Returns a key/value storage collection. | 1 |
ControllerBase:: |
protected | function | Returns the language manager service. | 1 |
ControllerBase:: |
protected | function | Returns the module handler. | 2 |
ControllerBase:: |
protected | function | Returns a redirect response object for the specified route. | |
ControllerBase:: |
protected | function | Returns the state storage service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
ManualPull:: |
public | function | Ensure that the pull tab is just show if a flow exists which contains and entity type that has its pull set to "manual". | |
ManualPull:: |
public | function | Render the content synchronization Angular frontend. | |
MessengerTrait:: |
protected | property | The messenger. | 27 |
MessengerTrait:: |
public | function | Gets the messenger. | 27 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 4 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |