From e9faec41fc13c223b77ad415091d6ab295c0e647 Mon Sep 17 00:00:00 2001 From: bach Date: Tue, 20 Apr 2021 13:05:18 +0200 Subject: [PATCH] popsu_migrate: D7NodeStatic ok --- ...grate_plus.migration.d7_allpublicfiles.yml | 2 +- ...grate_plus.migration.d7_node_programme.yml | 2 +- .../migrate_plus.migration.d7_node_projet.yml | 2 +- .../migrate_plus.migration.d7_node_static.yml | 49 +++++ .../migrate_plus.migration.d7_node_theme.yml | 2 +- ....migration.d7_taxonomy_term_type_theme.yml | 2 +- ..._plus.migration.d7_taxonomy_term_ville.yml | 2 +- .../sync/migrate_plus.migration.d7_users.yml | 2 +- .../migrate_plus.migration_group.popsu.yml | 2 +- .../migrate_plus.migration.d7_node_static.yml | 54 +++++ .../Plugin/migrate/source/D7NodeStatic.php | 201 ++++++++++++++++++ 11 files changed, 312 insertions(+), 8 deletions(-) create mode 100644 config/sync/migrate_plus.migration.d7_node_static.yml create mode 100644 web/modules/custom/popsu_migrate/config/install/migrate_plus.migration.d7_node_static.yml create mode 100644 web/modules/custom/popsu_migrate/src/Plugin/migrate/source/D7NodeStatic.php diff --git a/config/sync/migrate_plus.migration.d7_allpublicfiles.yml b/config/sync/migrate_plus.migration.d7_allpublicfiles.yml index 6f3add0b..09761c38 100644 --- a/config/sync/migrate_plus.migration.d7_allpublicfiles.yml +++ b/config/sync/migrate_plus.migration.d7_allpublicfiles.yml @@ -1,4 +1,4 @@ -uuid: 3b18c19c-bd38-4a42-b283-25f371788ec9 +uuid: e1cf47fe-1b42-4c9a-a3f9-80e79bac0005 langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_node_programme.yml b/config/sync/migrate_plus.migration.d7_node_programme.yml index 382169f0..4ea29a44 100644 --- a/config/sync/migrate_plus.migration.d7_node_programme.yml +++ b/config/sync/migrate_plus.migration.d7_node_programme.yml @@ -1,4 +1,4 @@ -uuid: ff1ce5b3-a7b2-40b0-8e9e-2ec01681c77a +uuid: b45c0dd4-f26e-46cc-b7bd-15ad9bcee8b1 langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_node_projet.yml b/config/sync/migrate_plus.migration.d7_node_projet.yml index 3bcd4e2c..240b19b1 100644 --- a/config/sync/migrate_plus.migration.d7_node_projet.yml +++ b/config/sync/migrate_plus.migration.d7_node_projet.yml @@ -1,4 +1,4 @@ -uuid: 2813009c-582e-402d-9e02-f0f05d12a3dd +uuid: df23e80f-3155-40c8-87cf-c345ad055d9d langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_node_static.yml b/config/sync/migrate_plus.migration.d7_node_static.yml new file mode 100644 index 00000000..6f556060 --- /dev/null +++ b/config/sync/migrate_plus.migration.d7_node_static.yml @@ -0,0 +1,49 @@ +uuid: 28dfe1fe-90b9-4311-a46e-3ec3dbbd0053 +langcode: fr +status: true +dependencies: { } +_core: + default_config_hash: giLUW65Fkj4Orn9QcEvs9tTY5s_MZ66ETkDLSoU8btk +id: d7_node_static +class: null +field_plugin_method: null +cck_plugin_method: null +migration_tags: + - 'Drupal 7' + - Content + - Popsu +migration_group: popsu +label: 'Node Static' +source: + plugin: d7_node_static + batch_size: 500 +process: + type: + plugin: default_value + default_value: static + created: created + changed: changed + uid: + plugin: default_value + default_value: 34 + title: title + field_textes: field_textes + field_pieces_jointes: + plugin: sub_process + source: field_popsu_pageneutral_insert + process: + target_id: + plugin: migration_lookup + migration: d7_allpublicfiles + source: fid + no_stub: true + display: display + description: description + field_memo: field_memo +destination: + plugin: 'entity:node' +migration_dependencies: + required: + - d7_allpublicfiles + - d7_users + - d7_taxonomy_term_type_theme diff --git a/config/sync/migrate_plus.migration.d7_node_theme.yml b/config/sync/migrate_plus.migration.d7_node_theme.yml index 8639b0d4..15e85d74 100644 --- a/config/sync/migrate_plus.migration.d7_node_theme.yml +++ b/config/sync/migrate_plus.migration.d7_node_theme.yml @@ -1,4 +1,4 @@ -uuid: 9d6fb691-ce28-425c-af92-302d08a722fc +uuid: 83bd4f30-716c-4ae8-918b-55bb56e0ea2e langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_taxonomy_term_type_theme.yml b/config/sync/migrate_plus.migration.d7_taxonomy_term_type_theme.yml index e10d7151..c94554cc 100644 --- a/config/sync/migrate_plus.migration.d7_taxonomy_term_type_theme.yml +++ b/config/sync/migrate_plus.migration.d7_taxonomy_term_type_theme.yml @@ -1,4 +1,4 @@ -uuid: f7a74141-0abc-49d9-b16e-a5614c84c5f5 +uuid: 6d30ad1d-8450-451f-be72-efdae5dfb3c4 langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_taxonomy_term_ville.yml b/config/sync/migrate_plus.migration.d7_taxonomy_term_ville.yml index a4b1c952..a0a16518 100644 --- a/config/sync/migrate_plus.migration.d7_taxonomy_term_ville.yml +++ b/config/sync/migrate_plus.migration.d7_taxonomy_term_ville.yml @@ -1,4 +1,4 @@ -uuid: e1ae926a-63cc-4c77-b7a4-033ef995bc22 +uuid: 55c6fb53-6dac-4ec7-a0f8-3f9655b0b1e4 langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration.d7_users.yml b/config/sync/migrate_plus.migration.d7_users.yml index d9d8759b..299f8635 100644 --- a/config/sync/migrate_plus.migration.d7_users.yml +++ b/config/sync/migrate_plus.migration.d7_users.yml @@ -1,4 +1,4 @@ -uuid: d5f4eb4e-b259-4f8b-842d-62dad092b522 +uuid: 16730dbd-d94c-4962-ac1b-9acc603b7e8d langcode: fr status: true dependencies: { } diff --git a/config/sync/migrate_plus.migration_group.popsu.yml b/config/sync/migrate_plus.migration_group.popsu.yml index 4e7beadf..ce19a28c 100644 --- a/config/sync/migrate_plus.migration_group.popsu.yml +++ b/config/sync/migrate_plus.migration_group.popsu.yml @@ -1,4 +1,4 @@ -uuid: ff4c5119-217d-405f-a438-c2badb8900c9 +uuid: beb0c7e2-2ff3-4eef-a325-aa30360a6817 langcode: fr status: true dependencies: diff --git a/web/modules/custom/popsu_migrate/config/install/migrate_plus.migration.d7_node_static.yml b/web/modules/custom/popsu_migrate/config/install/migrate_plus.migration.d7_node_static.yml new file mode 100644 index 00000000..3b7e9866 --- /dev/null +++ b/web/modules/custom/popsu_migrate/config/install/migrate_plus.migration.d7_node_static.yml @@ -0,0 +1,54 @@ +id: d7_node_static +label: Node Static +migration_group: popsu +audit: true +migration_tags: + - Drupal 7 + - Content + - Popsu + +source: + plugin: d7_node_static + batch_size: 500 + # high_water_property: + # name: changed + # alias: n + +destination: + plugin: entity:node + +process: + # nid: nid + type: + plugin: default_value + default_value: static + created: created + changed: changed + + uid: + plugin: default_value + default_value: 34 + + title: title + + field_textes: field_textes + + field_pieces_jointes: + plugin: sub_process + source: field_popsu_pageneutral_insert + process: + target_id: + plugin: migration_lookup + migration: d7_allpublicfiles + source: fid + no_stub: true + display: display + description: description + + field_memo: field_memo + +migration_dependencies: + required: + - d7_allpublicfiles + - d7_users + - d7_taxonomy_term_type_theme diff --git a/web/modules/custom/popsu_migrate/src/Plugin/migrate/source/D7NodeStatic.php b/web/modules/custom/popsu_migrate/src/Plugin/migrate/source/D7NodeStatic.php new file mode 100644 index 00000000..1092eea0 --- /dev/null +++ b/web/modules/custom/popsu_migrate/src/Plugin/migrate/source/D7NodeStatic.php @@ -0,0 +1,201 @@ +moduleHandler = $module_handler; + $this->logger = $loggerFactory->get('popsu_migration'); + } + + /** + * {@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'), + $container->get('logger.factory') + ); + } + + /** + * 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', + 'uid', + 'language', + 'status', + 'created', + 'changed', + ]) + ->fields('nr', [ + 'vid', + 'title', + 'log', + 'timestamp', + ]) + ->orderBy('changed'); + + $query->addField('n', 'uid', 'node_uid'); + $query->addField('nr', 'uid', 'revision_uid'); + $query->innerJoin('node', 'n', static::JOIN); + + $query->condition('n.type', ['popsu_page_neutral'], 'IN'); + + return $query; + } + + /** + * {@inheritdoc} + */ + public function prepareRow(Row $row) { + $nid = $row->getSourceProperty('nid'); + $vid = $row->getSourceProperty('vid'); + $type = $row->getSourceProperty('type'); + $title = $row->getSourceProperty('title'); + Drush::output()->writeln('- - - - ' . $title . ' ('.$nid.')' . '- - - - '); + + $memo = ''; + $memo .= "#migration : old nid = ".$nid."\n"; + $memo .= "#migration : old content type = ".$type."\n"; + + // Get Field API field values. + foreach ($this->getFields('node', $type) as $field_name => $field) { + $field_values = $this->getFieldValues('node', $field_name, $nid, $vid, NULL); + $row->setSourceProperty($field_name, $field_values); + // switch ($field_name) { + // // ville + // case 'field_popsu_ville_ville': + // $ville = $field_values; + // break; + // } + } + + # Text paragraphe + $text_fields = array( + 'field_popsu_pageneutral_body' => 'Texte de la page', + 'field_popsu_pageneutral_col2' => 'Texte de la 2ème colone', + ); + $textes_paragraphes = array(); + foreach ($text_fields as $field_name => $title) { + if ($text = $row->getSourceProperty($field_name)){ + // Drush::output()->writeln(dump($text)); + $text[0]['format'] = 'wysiwyg'; + $p = Paragraph::create(['type' => 'textes']); + $p->set('field_texte', $text) + ->set('field_titre', $title) + ->isNew(); + $p->save(); + $textes_paragraphes[] = array( + 'target_id' => $p->id(), + 'target_revision_id' => $p->getRevisionId(), + ); + } + } + if (!empty($textes_paragraphes)) { + // Drush::output()->writeln(dump($textes_paragraphes)); + $row->setSourceProperty('field_textes', $textes_paragraphes); + } + + // record migration errors in field_memo + if(isset($memo)){ + $field_memo = array( + array( + 'value' => $memo + ) + ); + $row->setSourceProperty('field_memo', $field_memo); + } + + 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; + } + +}