class Node in Drupal 8
Same name in this branch
- 8 core/modules/node/src/Entity/Node.php \Drupal\node\Entity\Node
- 8 core/modules/node/src/Plugin/views/argument_default/Node.php \Drupal\node\Plugin\views\argument_default\Node
- 8 core/modules/node/src/Plugin/views/wizard/Node.php \Drupal\node\Plugin\views\wizard\Node
- 8 core/modules/node/src/Plugin/views/field/Node.php \Drupal\node\Plugin\views\field\Node
- 8 core/modules/node/src/Plugin/migrate/source/d6/Node.php \Drupal\node\Plugin\migrate\source\d6\Node
- 8 core/modules/node/src/Plugin/migrate/source/d7/Node.php \Drupal\node\Plugin\migrate\source\d7\Node
Same name and namespace in other branches
- 9 core/modules/node/src/Plugin/migrate/source/d7/Node.php \Drupal\node\Plugin\migrate\source\d7\Node
Drupal 7 node source from database.
Plugin annotation
@MigrateSource(
  id = "d7_node",
  source_module = "node"
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait- class \Drupal\migrate\Plugin\migrate\source\SourcePluginBase implements RollbackAwareInterface, MigrateSourceInterface- class \Drupal\migrate\Plugin\migrate\source\SqlBase implements ContainerFactoryPluginInterface, RequirementsInterface- class \Drupal\migrate_drupal\Plugin\migrate\source\DrupalSqlBase implements DependentPluginInterface, ContainerFactoryPluginInterface uses DeprecatedServicePropertyTrait, DependencyTrait- class \Drupal\migrate_drupal\Plugin\migrate\source\d7\FieldableEntity- class \Drupal\node\Plugin\migrate\source\d7\Node
 
 
- class \Drupal\migrate_drupal\Plugin\migrate\source\d7\FieldableEntity
 
- class \Drupal\migrate_drupal\Plugin\migrate\source\DrupalSqlBase implements DependentPluginInterface, ContainerFactoryPluginInterface uses DeprecatedServicePropertyTrait, DependencyTrait
 
- class \Drupal\migrate\Plugin\migrate\source\SqlBase implements ContainerFactoryPluginInterface, RequirementsInterface
 
- class \Drupal\migrate\Plugin\migrate\source\SourcePluginBase implements RollbackAwareInterface, MigrateSourceInterface
 
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of Node
15 string references to 'Node'
- CategorizingPluginManagerTraitTest::setUp in core/tests/ Drupal/ Tests/ Core/ Plugin/ CategorizingPluginManagerTraitTest.php 
- CategorizingPluginManagerTraitTest::testProcessDefinitionCategory in core/tests/ Drupal/ Tests/ Core/ Plugin/ CategorizingPluginManagerTraitTest.php 
- @covers ::processDefinitionCategory
- CategoryAutocompleteTest::providerTestAutocompleteSuggestions in core/modules/ block/ tests/ src/ Unit/ CategoryAutocompleteTest.php 
- Data provider for testAutocompleteSuggestions().
- CategoryAutocompleteTest::setUp in core/modules/ block/ tests/ src/ Unit/ CategoryAutocompleteTest.php 
- CommentBundlesTest::setUp in core/modules/ comment/ tests/ src/ Kernel/ CommentBundlesTest.php 
File
- core/modules/ node/ src/ Plugin/ migrate/ source/ d7/ Node.php, line 22 
Namespace
Drupal\node\Plugin\migrate\source\d7View source
class Node extends FieldableEntity {
  /**
   * The module handler.
   *
   * @var \Drupal\Core\Extension\ModuleHandlerInterface
   */
  protected $moduleHandler;
  /**
   * {@inheritdoc}
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration, StateInterface $state, EntityTypeManagerInterface $entity_type_manager, ModuleHandlerInterface $module_handler) {
    parent::__construct($configuration, $plugin_id, $plugin_definition, $migration, $state, $entity_type_manager);
    $this->moduleHandler = $module_handler;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration = NULL) {
    return new static($configuration, $plugin_id, $plugin_definition, $migration, $container
      ->get('state'), $container
      ->get('entity_type.manager'), $container
      ->get('module_handler'));
  }
  /**
   * The join options between the node and the node_revisions table.
   */
  const JOIN = 'n.vid = nr.vid';
  /**
   * {@inheritdoc}
   */
  public function query() {
    // Select node in its last revision.
    $query = $this
      ->select('node_revision', 'nr')
      ->fields('n', [
      'nid',
      'type',
      'language',
      'status',
      'created',
      'changed',
      'comment',
      'promote',
      'sticky',
      'tnid',
      'translate',
    ])
      ->fields('nr', [
      'vid',
      'title',
      'log',
      'timestamp',
    ]);
    $query
      ->addField('n', 'uid', 'node_uid');
    $query
      ->addField('nr', 'uid', 'revision_uid');
    $query
      ->innerJoin('node', 'n', static::JOIN);
    // If the content_translation module is enabled, get the source langcode
    // to fill the content_translation_source field.
    if ($this->moduleHandler
      ->moduleExists('content_translation')) {
      $query
        ->leftJoin('node', 'nt', 'n.tnid = nt.nid');
      $query
        ->addField('nt', 'language', 'source_langcode');
    }
    $this
      ->handleTranslations($query);
    if (isset($this->configuration['node_type'])) {
      $query
        ->condition('n.type', $this->configuration['node_type']);
    }
    return $query;
  }
  /**
   * {@inheritdoc}
   */
  public function prepareRow(Row $row) {
    $nid = $row
      ->getSourceProperty('nid');
    $vid = $row
      ->getSourceProperty('vid');
    $type = $row
      ->getSourceProperty('type');
    // If this entity was translated using Entity Translation, we need to get
    // its source language to get the field values in the right language.
    // The translations will be migrated by the d7_node_entity_translation
    // migration.
    $entity_translatable = $this
      ->isEntityTranslatable('node') && (int) $this
      ->variableGet('language_content_type_' . $type, 0) === 4;
    $source_language = $this
      ->getEntityTranslationSourceLanguage('node', $nid);
    $language = $entity_translatable && $source_language ? $source_language : $row
      ->getSourceProperty('language');
    // If this is using d7_node_complete source plugin and this is a node
    // using entity translation then set the language of this revision to the
    // entity translation language.
    if ($row
      ->getSourceProperty('etr_created')) {
      $language = $row
        ->getSourceProperty('language');
    }
    // Get Field API field values.
    foreach ($this
      ->getFields('node', $type) as $field_name => $field) {
      // Ensure we're using the right language if the entity and the field are
      // translatable.
      $field_language = $entity_translatable && $field['translatable'] ? $language : NULL;
      $row
        ->setSourceProperty($field_name, $this
        ->getFieldValues('node', $field_name, $nid, $vid, $field_language));
    }
    // Make sure we always have a translation set.
    if ($row
      ->getSourceProperty('tnid') == 0) {
      $row
        ->setSourceProperty('tnid', $row
        ->getSourceProperty('nid'));
    }
    // If the node title was replaced by a real field using the Drupal 7 Title
    // module, use the field value instead of the node title.
    if ($this
      ->moduleExists('title')) {
      $title_field = $row
        ->getSourceProperty('title_field');
      if (isset($title_field[0]['value'])) {
        $row
          ->setSourceProperty('title', $title_field[0]['value']);
      }
    }
    return parent::prepareRow($row);
  }
  /**
   * {@inheritdoc}
   */
  public function fields() {
    $fields = [
      'nid' => $this
        ->t('Node ID'),
      'type' => $this
        ->t('Type'),
      'title' => $this
        ->t('Title'),
      'node_uid' => $this
        ->t('Node authored by (uid)'),
      'revision_uid' => $this
        ->t('Revision authored by (uid)'),
      'created' => $this
        ->t('Created timestamp'),
      'changed' => $this
        ->t('Modified timestamp'),
      'status' => $this
        ->t('Published'),
      'promote' => $this
        ->t('Promoted to front page'),
      'sticky' => $this
        ->t('Sticky at top of lists'),
      'revision' => $this
        ->t('Create new revision'),
      'language' => $this
        ->t('Language (fr, en, ...)'),
      'tnid' => $this
        ->t('The translation set id for this node'),
      'timestamp' => $this
        ->t('The timestamp the latest revision of this node was created.'),
    ];
    return $fields;
  }
  /**
   * {@inheritdoc}
   */
  public function getIds() {
    $ids['nid']['type'] = 'integer';
    $ids['nid']['alias'] = 'n';
    return $ids;
  }
  /**
   * Adapt our query for translations.
   *
   * @param \Drupal\Core\Database\Query\SelectInterface $query
   *   The generated query.
   */
  protected function handleTranslations(SelectInterface $query) {
    // Check whether or not we want translations.
    if (empty($this->configuration['translations'])) {
      // No translations: Yield untranslated nodes, or default translations.
      $query
        ->where('n.tnid = 0 OR n.tnid = n.nid');
    }
    else {
      // Translations: Yield only non-default translations.
      $query
        ->where('n.tnid <> 0 AND n.tnid <> n.nid');
    }
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| DependencySerializationTrait:: | protected | property | An array of entity type IDs keyed by the property name of their storages. | |
| DependencySerializationTrait:: | protected | property | An array of service IDs keyed by property name used for serialization. | |
| DependencySerializationTrait:: | public | function | 1 | |
| DependencySerializationTrait:: | public | function | 2 | |
| DependencyTrait:: | protected | property | The object's dependencies. | |
| DependencyTrait:: | protected | function | Adds multiple dependencies. | |
| DependencyTrait:: | protected | function | Adds a dependency. | |
| DeprecatedServicePropertyTrait:: | public | function | Allows to access deprecated/removed properties. | |
| DrupalSqlBase:: | protected | property | 1 | |
| DrupalSqlBase:: | protected | property | The entity type manager. | |
| DrupalSqlBase:: | protected | property | If the source provider is missing. | |
| DrupalSqlBase:: | protected | property | The contents of the system table. | |
| DrupalSqlBase:: | public | function | Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: | 1 | 
| DrupalSqlBase:: | public | function | Checks if requirements for this plugin are OK. Overrides SqlBase:: | 2 | 
| DrupalSqlBase:: | protected | function | Retrieves a module schema_version from the source Drupal database. | |
| DrupalSqlBase:: | public | function | Retrieves all system data information from the source Drupal database. | |
| DrupalSqlBase:: | protected | function | Checks if a given module is enabled in the source Drupal database. | |
| DrupalSqlBase:: | protected | function | Reads a variable from a source Drupal database. | |
| FieldableEntity:: | protected | function | Gets an entity source language from the 'entity_translation' table. | |
| FieldableEntity:: | protected | function | Returns all non-deleted field instances attached to a specific entity type. | |
| FieldableEntity:: | protected | function | Retrieves field values for a single field of a single entity. | |
| FieldableEntity:: | protected | function | Checks if an entity type uses Entity Translation. | |
| MessengerTrait:: | protected | property | The messenger. | 29 | 
| MessengerTrait:: | public | function | Gets the messenger. | 29 | 
| MessengerTrait:: | public | function | Sets the messenger. | |
| Node:: | protected | property | The module handler. Overrides SourcePluginBase:: | |
| Node:: | public static | function | Creates an instance of the plugin. Overrides DrupalSqlBase:: | |
| Node:: | public | function | Returns available fields on the source. Overrides MigrateSourceInterface:: | |
| Node:: | public | function | Defines the source fields uniquely identifying a source row. Overrides MigrateSourceInterface:: | |
| Node:: | protected | function | Adapt our query for translations. | |
| Node:: | constant | The join options between the node and the node_revisions table. | ||
| Node:: | public | function | Adds additional data to the row. Overrides SourcePluginBase:: | 1 | 
| Node:: | public | function | Overrides SqlBase:: | |
| Node:: | public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides DrupalSqlBase:: | |
| PluginBase:: | protected | property | Configuration information passed into the plugin. | 1 | 
| PluginBase:: | protected | property | The plugin implementation definition. | 1 | 
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
| PluginBase:: | public | function | Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: | 3 | 
| PluginBase:: | public | function | Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Determines if the plugin is configurable. | |
| SourcePluginBase:: | protected | property | The backend cache. | |
| SourcePluginBase:: | protected | property | Whether this instance should cache the source count. | 1 | 
| SourcePluginBase:: | protected | property | Key to use for caching counts. | |
| SourcePluginBase:: | protected | property | The current row from the query. | |
| SourcePluginBase:: | protected | property | The primary key of the current row. | |
| SourcePluginBase:: | protected | property | Information on the property used as the high-water mark. | |
| SourcePluginBase:: | protected | property | The key-value storage for the high-water value. | |
| SourcePluginBase:: | protected | property | The migration ID map. | |
| SourcePluginBase:: | protected | property | The iterator to iterate over the source rows. | |
| SourcePluginBase:: | protected | property | Flags whether source plugin will read the map row and add to data row. | |
| SourcePluginBase:: | protected | property | The entity migration object. | |
| SourcePluginBase:: | protected | property | The high water mark at the beginning of the import operation. | |
| SourcePluginBase:: | protected | property | Whether this instance should not attempt to count the source. | 1 | 
| SourcePluginBase:: | protected | property | Flags whether to track changes to incoming data. | 1 | 
| SourcePluginBase:: | protected | function | Check if the incoming data is newer than what we've previously imported. | |
| SourcePluginBase:: | public | function | ||
| SourcePluginBase:: | protected | function | Gets the source count checking if the source is countable or using the iterator_count function. | 1 | 
| SourcePluginBase:: | protected | function | Gets the cache object. | |
| SourcePluginBase:: | public | function | Gets the currentSourceIds data member. | |
| SourcePluginBase:: | protected | function | The current value of the high water mark. | |
| SourcePluginBase:: | protected | function | Get the name of the field used as the high watermark. | |
| SourcePluginBase:: | protected | function | Get information on the property used as the high watermark. | |
| SourcePluginBase:: | protected | function | Get the high water storage object. | 1 | 
| SourcePluginBase:: | protected | function | Returns the iterator that will yield the row arrays to be processed. | |
| SourcePluginBase:: | protected | function | Gets the module handler. | |
| SourcePluginBase:: | public | function | Gets the source module providing the source data. Overrides MigrateSourceInterface:: | |
| SourcePluginBase:: | public | function | Gets the iterator key. | |
| SourcePluginBase:: | public | function | The migration iterates over rows returned by the source plugin. This method determines the next row which will be processed and imported into the system. | |
| SourcePluginBase:: | public | function | Performs post-rollback tasks. Overrides RollbackAwareInterface:: | |
| SourcePluginBase:: | public | function | Performs pre-rollback tasks. Overrides RollbackAwareInterface:: | |
| SourcePluginBase:: | public | function | Rewinds the iterator. | |
| SourcePluginBase:: | protected | function | Checks if the incoming row has changed since our last import. | |
| SourcePluginBase:: | protected | function | Save the new high water mark. | |
| SourcePluginBase:: | public | function | Checks whether the iterator is currently valid. | |
| SqlBase:: | protected | property | The count of the number of batches run. | |
| SqlBase:: | protected | property | Number of records to fetch from the database during each batch. | |
| SqlBase:: | protected | property | The database object. | 1 | 
| SqlBase:: | protected | property | The query string. | |
| SqlBase:: | protected | property | State service for retrieving database info. | |
| SqlBase:: | public | function | Gets the source count. Overrides SourcePluginBase:: | 6 | 
| SqlBase:: | protected | function | Prepares query for the next set of data from the source database. | |
| SqlBase:: | protected | function | Position the iterator to the following row. Overrides SourcePluginBase:: | |
| SqlBase:: | public | function | Gets the database connection object. | 2 | 
| SqlBase:: | protected | function | Initializes the iterator with the source data. Overrides SourcePluginBase:: | 20 | 
| SqlBase:: | protected | function | Checks if we can join against the map table. | 1 | 
| SqlBase:: | protected | function | Adds tags and metadata to the query. | |
| SqlBase:: | protected | function | Wrapper for database select. | |
| SqlBase:: | protected | function | Gets a connection to the referenced database. | |
| SqlBase:: | public | function | Prints the query string when the object is used as a string. Overrides MigrateSourceInterface:: | |
| 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. | 
