You are here

node.inc in Drupal-to-Drupal data migration 7.2

Implementation of DrupalNodeMigration for Drupal 5 sources.

File

d5/node.inc
View source
<?php

/**
 * @file
 * Implementation of DrupalNodeMigration for Drupal 5 sources.
 */

/**
 * Handling specific to a Drupal 5 source for nodes.
 */
class DrupalNode5Migration extends DrupalNodeMigration {

  /**
   * Translation from field names assigned when executing the query to our
   * subfield notation.
   *
   * @var array
   *  key: DB-compatible name (e.g., field_buy_link_title).
   *  value: Subfield notation (e.g., field_buy_link:title).
   */
  protected $fixFieldNames = array();

  /**
   * @param array $arguments
   */
  public function __construct(array $arguments) {
    parent::__construct($arguments);
    $query = $this
      ->query();
    $this->sourceOptions['fix_field_names'] = $this->fixFieldNames;
    $this->source = new MigrateDrupal5SourceSQL($query, $this->sourceFields, NULL, $this->sourceOptions);
    if (field_info_instance('node', 'body', $this->destinationType)) {
      $this
        ->addFieldMapping('body:summary', 'teaser');
      $this
        ->addFieldMapping('body:format', 'format')
        ->callbacks(array(
        $this,
        'mapFormat',
      ));
    }
    else {
      $this
        ->addUnmigratedSources(array(
        'teaser',
        'format',
      ));
    }
    $this
      ->addFieldMapping(NULL, 'moderate');
  }

  /**
   * Query for basic node fields from Drupal 5.
   *
   * @return QueryConditionInterface
   */
  protected function query() {
    $query = Database::getConnection('default', $this->sourceConnection)
      ->select('node', 'n')
      ->fields('n', array(
      'nid',
      'vid',
      'title',
      'uid',
      'status',
      'created',
      'changed',
      'comment',
      'promote',
      'moderate',
      'sticky',
    ))
      ->condition('n.type', $this->sourceType)
      ->orderBy('n.changed');
    $query
      ->innerJoin('node_revisions', 'nr', 'n.vid=nr.vid');
    $query
      ->fields('nr', array(
      'body',
      'teaser',
      'format',
    ));

    // Pick up simple CCK fields
    $cck_table = 'content_type_' . $this->sourceType;
    if (Database::getConnection('default', $this->sourceConnection)
      ->schema()
      ->tableExists($cck_table)) {
      $query
        ->leftJoin($cck_table, 'f', 'n.vid=f.vid');

      // The main column for the field should be rendered with
      // the field name, not the column name (e.g., field_foo rather
      // than field_foo_value).
      $field_info = $this->version
        ->getSourceFieldInfo();
      foreach ($field_info as $field_name => $info) {
        if (isset($info['columns']) && !$info['multiple'] && $info['db_storage']) {
          $i = 0;
          foreach ($info['columns'] as $display_name => $column_name) {
            if ($i++ == 0) {
              $query
                ->addField('f', $column_name, $field_name);
            }
            else {

              // The database API won't allow colons in column aliases, so we
              // will accept the default alias, and fix up the field names later.
              // Remember how to translate the field names.
              $clean_name = str_replace(':', '_', $display_name);
              $this->fixFieldNames[$clean_name] = $display_name;
              $query
                ->addField('f', $column_name);
            }
          }
        }
      }
    }

    // Join node_counter for Statistics support
    if ($this
      ->moduleExists('statistics')) {
      $query
        ->leftJoin('node_counter', 'nc', 'n.nid=nc.nid');
      $query
        ->addField('nc', 'daycount');
      $query
        ->addField('nc', 'timestamp');
      $query
        ->addField('nc', 'totalcount');
    }
    return $query;
  }
  public function prepareRow($row) {
    if (parent::prepareRow($row) === FALSE) {
      return FALSE;
    }

    // Convert the default field names to the nice-looking ones.
    foreach ($this->fixFieldNames as $clean => $display) {
      if (isset($row->{$clean})) {
        $row->{$display} = $row->{$clean};
        unset($row->{$clean});
      }
    }

    // Don't populate summary if the teaser matches the generated summary.
    if (empty($row->teaser) || $row->teaser == text_summary($row->body)) {
      $row->teaser = '';
    }
  }

}

/**
 * We override the default SQL source class just so we can clean up subfield
 * names for the UI.
 */
class MigrateDrupal5SourceSQL extends MigrateSourceSQL {

  /**
   * Translation from field names assigned when executing the query to our
   * subfield notation.
   *
   * @var array
   *  key: DB-compatible name (e.g., field_buy_link_title).
   *  value: Subfield notation (e.g., field_buy_link:title).
   */
  public $fixFieldNames = array();
  public function __construct(SelectQueryInterface $query, array $fields = array(), SelectQueryInterface $count_query = NULL, array $options = array()) {
    $this->fixFieldNames = $options['fix_field_names'];
    parent::__construct($query, $fields, $count_query, $options);
  }
  public function fields() {
    $fields = parent::fields();

    // Remove the default subfield names in favor of the nice-looking ones.
    foreach ($this->fixFieldNames as $clean => $display) {
      if (isset($fields[$clean])) {
        unset($fields[$clean]);
      }
    }
    return $fields;
  }

}

Classes

Namesort descending Description
DrupalNode5Migration Handling specific to a Drupal 5 source for nodes.
MigrateDrupal5SourceSQL We override the default SQL source class just so we can clean up subfield names for the UI.