Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
100.00% |
1 / 1 |
|
100.00% |
3 / 3 |
CRAP | |
100.00% |
17 / 17 |
| TermNode | |
100.00% |
1 / 1 |
|
100.00% |
4 / 4 |
4 | |
100.00% |
17 / 17 |
| query | |
100.00% |
1 / 1 |
1 | |
100.00% |
7 / 7 |
|||
| fields | |
100.00% |
1 / 1 |
1 | |
100.00% |
0 / 0 |
|||
| prepareRow | |
100.00% |
1 / 1 |
1 | |
100.00% |
7 / 7 |
|||
| getIds | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
| <?php | |
| /** | |
| * @file | |
| * Contains \Drupal\taxonomy\Plugin\migrate\source\d6\TermNode. | |
| */ | |
| namespace Drupal\taxonomy\Plugin\migrate\source\d6; | |
| use Drupal\migrate\Row; | |
| use Drupal\migrate_drupal\Plugin\migrate\source\DrupalSqlBase; | |
| /** | |
| * Source returning tids from the term_node table for the current revision. | |
| * | |
| * @MigrateSource( | |
| * id = "d6_term_node", | |
| * source_provider = "taxonomy" | |
| * ) | |
| */ | |
| class TermNode extends DrupalSqlBase { | |
| /** | |
| * The join options between the node and the term node table. | |
| */ | |
| const JOIN = 'tn.vid = n.vid'; | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function query() { | |
| $query = $this->select('term_node', 'tn') | |
| ->distinct() | |
| ->fields('tn', array('nid', 'vid')) | |
| ->fields('n', array('type')); | |
| // Because this is an inner join it enforces the current revision. | |
| $query->innerJoin('term_data', 'td', 'td.tid = tn.tid AND td.vid = :vid', array(':vid' => $this->configuration['vid'])); | |
| $query->innerJoin('node', 'n', static::JOIN); | |
| return $query; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function fields() { | |
| return array( | |
| 'nid' => $this->t('The node revision ID.'), | |
| 'vid' => $this->t('The node revision ID.'), | |
| 'tid' => $this->t('The term ID.'), | |
| ); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function prepareRow(Row $row) { | |
| // Select the terms belonging to the revision selected. | |
| $query = $this->select('term_node', 'tn') | |
| ->fields('tn', array('tid')) | |
| ->condition('n.nid', $row->getSourceProperty('nid')); | |
| $query->join('node', 'n', static::JOIN); | |
| $query->innerJoin('term_data', 'td', 'td.tid = tn.tid AND td.vid = :vid', array(':vid' => $this->configuration['vid'])); | |
| $row->setSourceProperty('tid', $query->execute()->fetchCol()); | |
| return parent::prepareRow($row); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function getIds() { | |
| $ids['vid']['type'] = 'integer'; | |
| $ids['vid']['alias'] = 'tn'; | |
| return $ids; | |
| } | |
| } |