You are here

class CreateStatusEntities in CMS Content Sync 2.1.x

Same name and namespace in other branches
  1. 8 modules/cms_content_sync_migrate_acquia_content_hub/src/CreateStatusEntities.php \Drupal\cms_content_sync_migrate_acquia_content_hub\CreateStatusEntities
  2. 2.0.x modules/cms_content_sync_migrate_acquia_content_hub/src/CreateStatusEntities.php \Drupal\cms_content_sync_migrate_acquia_content_hub\CreateStatusEntities

Hierarchy

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_hub
View 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

Namesort descending Modifiers Type Description Overrides
ControllerBase::$configFactory protected property The configuration factory.
ControllerBase::$currentUser protected property The current user service. 1
ControllerBase::$entityFormBuilder protected property The entity form builder.
ControllerBase::$entityTypeManager protected property The entity type manager.
ControllerBase::$formBuilder protected property The form builder. 2
ControllerBase::$keyValue protected property The key-value storage. 1
ControllerBase::$languageManager protected property The language manager. 1
ControllerBase::$moduleHandler protected property The module handler. 2
ControllerBase::$stateService protected property The state service.
ControllerBase::cache protected function Returns the requested cache bin.
ControllerBase::config protected function Retrieves a configuration object.
ControllerBase::container private function Returns the service container.
ControllerBase::create public static function Instantiates a new instance of this class. Overrides ContainerInjectionInterface::create 46
ControllerBase::currentUser protected function Returns the current user. 1
ControllerBase::entityFormBuilder protected function Retrieves the entity form builder.
ControllerBase::entityTypeManager protected function Retrieves the entity type manager.
ControllerBase::formBuilder protected function Returns the form builder service. 2
ControllerBase::keyValue protected function Returns a key/value storage collection. 1
ControllerBase::languageManager protected function Returns the language manager service. 1
ControllerBase::moduleHandler protected function Returns the module handler. 2
ControllerBase::redirect protected function Returns a redirect response object for the specified route.
ControllerBase::state protected function Returns the state storage service.
CreateStatusEntities::execute public static function Batch create Status Entities for collected nodes.
CreateStatusEntities::prepare public function Collect relevant nodes.
LoggerChannelTrait::$loggerFactory protected property The logger channel factory service.
LoggerChannelTrait::getLogger protected function Gets the logger for a specific channel.
LoggerChannelTrait::setLoggerFactory public function Injects the logger channel factory.
MessengerTrait::$messenger protected property The messenger. 27
MessengerTrait::messenger public function Gets the messenger. 27
MessengerTrait::setMessenger public function Sets the messenger.
RedirectDestinationTrait::$redirectDestination protected property The redirect destination service. 1
RedirectDestinationTrait::getDestinationArray protected function Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url.
RedirectDestinationTrait::getRedirectDestination protected function Returns the redirect destination service.
RedirectDestinationTrait::setRedirectDestination public function Sets the redirect destination service.
StringTranslationTrait::$stringTranslation protected property The string translation service. 4
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.