Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
75.00% |
3 / 4 |
CRAP | |
46.67% |
14 / 30 |
| Comment | |
0.00% |
0 / 1 |
|
75.00% |
3 / 4 |
8.79 | |
46.67% |
14 / 30 |
| query | |
100.00% |
1 / 1 |
1 | |
100.00% |
5 / 5 |
|||
| prepareRow | |
100.00% |
1 / 1 |
2 | |
100.00% |
7 / 7 |
|||
| fields | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 16 |
|||
| getIds | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
| <?php | |
| /** | |
| * @file | |
| * Contains \Drupal\comment\Plugin\migrate\source\d7\Comment. | |
| */ | |
| namespace Drupal\comment\Plugin\migrate\source\d7; | |
| use Drupal\migrate\Row; | |
| use Drupal\migrate_drupal\Plugin\migrate\source\d7\FieldableEntity; | |
| /** | |
| * Drupal 7 comment source from database. | |
| * | |
| * @MigrateSource( | |
| * id = "d7_comment", | |
| * source_provider = "comment" | |
| * ) | |
| */ | |
| class Comment extends FieldableEntity { | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function query() { | |
| $query = $this->select('comment', 'c')->fields('c'); | |
| $query->innerJoin('node', 'n', 'c.nid = n.nid'); | |
| $query->addField('n', 'type', 'node_type'); | |
| $query->orderBy('c.created'); | |
| return $query; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function prepareRow(Row $row) { | |
| $cid = $row->getSourceProperty('cid'); | |
| $node_type = $row->getSourceProperty('node_type'); | |
| $comment_type = 'comment_node_' . $node_type; | |
| $row->setSourceProperty('comment_type', 'comment_node_' . $node_type); | |
| foreach (array_keys($this->getFields('comment', $comment_type)) as $field) { | |
| $row->setSourceProperty($field, $this->getFieldValues('comment', $field, $cid)); | |
| } | |
| return parent::prepareRow($row); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function fields() { | |
| return array( | |
| 'cid' => $this->t('Comment ID.'), | |
| 'pid' => $this->t('Parent comment ID. If set to 0, this comment is not a reply to an existing comment.'), | |
| 'nid' => $this->t('The {node}.nid to which this comment is a reply.'), | |
| 'uid' => $this->t('The {users}.uid who authored the comment. If set to 0, this comment was created by an anonymous user.'), | |
| 'subject' => $this->t('The comment title.'), | |
| 'comment' => $this->t('The comment body.'), | |
| 'hostname' => $this->t("The author's host name."), | |
| 'created' => $this->t('The time that the comment was created, as a Unix timestamp.'), | |
| 'changed' => $this->t('The time that the comment was edited by its author, as a Unix timestamp.'), | |
| 'status' => $this->t('The published status of a comment. (0 = Published, 1 = Not Published)'), | |
| 'format' => $this->t('The {filter_formats}.format of the comment body.'), | |
| 'thread' => $this->t("The vancode representation of the comment's place in a thread."), | |
| 'name' => $this->t("The comment author's name. Uses {users}.name if the user is logged in, otherwise uses the value typed into the comment form."), | |
| 'mail' => $this->t("The comment author's email address from the comment form, if user is anonymous, and the 'Anonymous users may/must leave their contact information' setting is turned on."), | |
| 'homepage' => $this->t("The comment author's home page address from the comment form, if user is anonymous, and the 'Anonymous users may/must leave their contact information' setting is turned on."), | |
| 'type' => $this->t("The {node}.type to which this comment is a reply."), | |
| ); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function getIds() { | |
| $ids['cid']['type'] = 'integer'; | |
| return $ids; | |
| } | |
| } |