class CreateStatusEntities in CMS Content Sync 8
Same name and namespace in other branches
- 2.1.x modules/cms_content_sync_migrate_acquia_content_hub/src/CreateStatusEntities.php \Drupal\cms_content_sync_migrate_acquia_content_hub\CreateStatusEntities
- 2.0.x modules/cms_content_sync_migrate_acquia_content_hub/src/CreateStatusEntities.php \Drupal\cms_content_sync_migrate_acquia_content_hub\CreateStatusEntities
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\cms_content_sync_migrate_acquia_content_hub\CreateStatusEntities
Expanded class hierarchy of CreateStatusEntities
2 files declare their use of CreateStatusEntities
- cms_content_sync_migrate_acquia_content_hub.drush.inc in modules/
cms_content_sync_migrate_acquia_content_hub/ cms_content_sync_migrate_acquia_content_hub.drush.inc - Contains Drush commands for Content Sync.
- MigrationBase.php in modules/
cms_content_sync_migrate_acquia_content_hub/ src/ Form/ MigrationBase.php
File
- modules/
cms_content_sync_migrate_acquia_content_hub/ src/ CreateStatusEntities.php, line 14
Namespace
Drupal\cms_content_sync_migrate_acquia_content_hubView source
class CreateStatusEntities extends ControllerBase {
/**
* Collect relevant nodes.
*
* @param $flow_id
* @param $flow_configurations
* @param $pools
* @param $type
* @param bool $execute
*/
public function prepare($flow_id, $flow_configurations, $pool_id, $type, $tags = '') {
$operations = [];
if ($type == 'push') {
foreach ($flow_configurations as $type => $type_config) {
foreach ($type_config as $bundle => $bundle_config) {
if ($bundle_config['push_configuration']['behavior'] != PushIntent::PUSH_AUTOMATICALLY) {
continue;
}
$entity_type = \Drupal::entityTypeManager()
->getDefinition($type);
$ids = \Drupal::entityQuery($type)
->condition($entity_type
->getKey('bundle'), $bundle)
->execute();
foreach ($ids as $id) {
$operations[] = [
__NAMESPACE__ . '\\CreateStatusEntities::execute',
[
$type,
$id,
$flow_id,
$pool_id,
'push',
],
];
}
}
}
return $operations;
}
$tags = MigrationBase::getTermsFromFilter($tags);
if (empty($tags)) {
return $operations;
}
$ids = [];
foreach ($tags as $tag) {
$ids[] = $tag
->id();
}
$query = \Drupal::database()
->select('taxonomy_index', 'ti');
$query
->fields('ti', [
'nid',
]);
$query
->condition('ti.tid', $ids, 'IN');
$result = $query
->execute()
->fetchCol();
foreach ($result as $nid) {
$operations[] = [
__NAMESPACE__ . '\\CreateStatusEntities::execute',
[
'node',
$nid,
$flow_id,
$pool_id,
'pull',
],
];
}
return $operations;
}
/**
* Batch create Status Entities for collected nodes.
*
* @param $nid
* @param $flow_id
* @param $bundle_id
* @param $pools
* @param $field_name
* @param $type
*/
public static function execute($entity_type, $entity_id, $flow_id, $pool_id, $type) {
$entity = \Drupal::entityTypeManager()
->getStorage($entity_type)
->load($entity_id);
// Drupal doesn't reliably update their taxonomy_index table when a node gets deleted.
if (!$entity) {
return;
}
// If a node has a match, create a status entity.
// Ensure that a status entity does not already exist.
$entity_status = EntityStatus::getInfoForEntity($entity_type, $entity
->uuid(), $flow_id, $pool_id);
if (!$entity_status) {
$data = [
'flow' => $flow_id,
'pool' => $pool_id,
'entity_type' => $entity_type,
'entity_uuid' => $entity
->uuid(),
'entity_type_version' => Flow::getEntityTypeVersion($entity_type, $entity
->bundle()),
'flags' => 0,
'source_url' => NULL,
];
if ($entity_type == 'node' && $type == 'pull') {
$data['last_' . $type] = $entity
->getChangedTime();
}
$entity_status = EntityStatus::create($data);
if ($type == 'push') {
$entity_status
->isPushEnabled(TRUE);
$entity_status
->isSourceEntity(TRUE);
}
$entity_status
->save();
}
}
}
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 manager. | |
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:: |
40 |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity manager service. | |
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. Overrides UrlGeneratorTrait:: |
|
ControllerBase:: |
protected | function | Returns the state storage service. | |
CreateStatusEntities:: |
public static | function | Batch create Status Entities for collected nodes. | |
CreateStatusEntities:: |
public | function | Collect relevant nodes. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator 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. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
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. | 1 |
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. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |