diff --git a/CHANGELOG.md b/CHANGELOG.md index f420e18..4e27a0a 100755 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,15 @@ # Stanford Migrate +8.x-1.19 +-------------------------------------------------------------------------------- +_Release Date: 2021-11-18_ + +- Removed migrate_tools patch that has been fixed +- D8CORE-4677 Migrate process plugin to get the OAuth token for use CAP (#42) +- If the last name is empty, but a first name is parsed, move the first name to the last name. (#41) + + 8.x-1.18 -------------------------------------------------------------------------------- _Release Date: 2021-10-20_ diff --git a/composer.json b/composer.json index d62ae5a..1c3c58c 100755 --- a/composer.json +++ b/composer.json @@ -26,9 +26,6 @@ "drupal/migrate_plus": { "https://www.drupal.org/project/migrate_plus/issues/2837684": "https://www.drupal.org/files/issues/2837684-8-migrate-plus-xml-return-as-xml.patch", "https://www.drupal.org/project/migrate_plus/issues/3050058": "https://www.drupal.org/files/issues/2019-05-17/migrate_plus-no_selector-3050058-3.patch" - }, - "drupal/migrate_tools": { - "https://www.drupal.org/project/migrate_tools/issues/2894708": "https://www.drupal.org/files/issues/2019-02-28/disabled-migrations-list-2894708-17.patch" } } }, diff --git a/src/Plugin/migrate/process/ImageDimensionSkip.php b/src/Plugin/migrate/process/ImageDimensionSkip.php index eb76413..6a8ec1b 100644 --- a/src/Plugin/migrate/process/ImageDimensionSkip.php +++ b/src/Plugin/migrate/process/ImageDimensionSkip.php @@ -99,7 +99,7 @@ protected function isImageBigger($value) { return FALSE; } try { - [$width, $height] = getimagesize($value); + [$width, $height] = @getimagesize($value); } catch (\Exception $e) { return FALSE; diff --git a/src/Plugin/migrate/process/NameField.php b/src/Plugin/migrate/process/NameField.php index 0610bbb..2ba9cbb 100644 --- a/src/Plugin/migrate/process/NameField.php +++ b/src/Plugin/migrate/process/NameField.php @@ -29,12 +29,16 @@ class NameField extends ProcessPluginBase { */ public function transform($value, MigrateExecutableInterface $migrate_executable, Row $row, $destination_property) { $name = FullNameParser::parse($value); - return [ + $name = [ 'title' => $name['salutation'], 'given' => !empty($name['fname']) ? $name['fname'] : $name['initials'], 'family' => trim($name['lname'] . ' ' . $name['suffix']), ]; - + if (empty($name['family']) && $name['given']) { + $name['family'] = $name['given']; + $name['given'] = ''; + } + return $name; } } diff --git a/src/Plugin/migrate/process/OauthAccessToken.php b/src/Plugin/migrate/process/OauthAccessToken.php new file mode 100644 index 0000000..1c8d4ed --- /dev/null +++ b/src/Plugin/migrate/process/OauthAccessToken.php @@ -0,0 +1,84 @@ +get('plugin.manager.migrate_plus.authentication') + ); + } + + /** + * {@inheritDoc} + */ + public function __construct(array $configuration, $plugin_id, $plugin_definition, AuthenticationPluginManager $auth_manager) { + parent::__construct($configuration, $plugin_id, $plugin_definition); + $this->authPluginManager = $auth_manager; + } + + /** + * {@inheritDoc} + */ + public function transform($value, MigrateExecutableInterface $migrate_executable, Row $row, $destination_property) { + $this->configuration += $row->getSource(); + $options = $this->getAuthenticationPlugin()->getAuthenticationOptions(); + preg_match('/ .*$/', $options['headers']['Authorization'], $bearer_match); + return trim(reset($bearer_match)); + } + + /** + * Returns the initialized authentication plugin. + * + * @return \Drupal\migrate_plus\AuthenticationPluginInterface + * The authentication plugin. + */ + public function getAuthenticationPlugin() { + if (!isset($this->authenticationPlugin)) { + $this->authenticationPlugin = $this->authPluginManager->createInstance($this->configuration['authentication']['plugin'], $this->configuration['authentication']); + } + return $this->authenticationPlugin; + } + +} diff --git a/stanford_migrate.info.yml b/stanford_migrate.info.yml index a59855e..3d064ac 100755 --- a/stanford_migrate.info.yml +++ b/stanford_migrate.info.yml @@ -3,7 +3,7 @@ description: 'Adds more functionality to migrate and migrate plus modules' type: module core_version_requirement: ^8.8 || ^9 package: 'Stanford' -version: 8.x-1.18 +version: 8.x-1.19 dependencies: - drupal:migrate - migrate_plus:migrate_plus diff --git a/tests/src/Unit/Plugin/migrate/process/NameFieldTest.php b/tests/src/Unit/Plugin/migrate/process/NameFieldTest.php index f8a46b4..340616f 100644 --- a/tests/src/Unit/Plugin/migrate/process/NameFieldTest.php +++ b/tests/src/Unit/Plugin/migrate/process/NameFieldTest.php @@ -51,6 +51,14 @@ public function testTranform() { 'family' => 'Doe', ]; $this->assertEquals($expected, $name_info); + + $name_info = $plugin->transform('Drupal', $migrate_executable, $row, 'field_stuff'); + $expected = [ + 'title' => '', + 'given' => '', + 'family' => 'Drupal', + ]; + $this->assertEquals($expected, $name_info); } } diff --git a/tests/src/Unit/Plugin/migrate/process/OauthAccessTokenTest.php b/tests/src/Unit/Plugin/migrate/process/OauthAccessTokenTest.php new file mode 100644 index 0000000..fa0764f --- /dev/null +++ b/tests/src/Unit/Plugin/migrate/process/OauthAccessTokenTest.php @@ -0,0 +1,53 @@ + ['Authorization' => 'Bearer foo-bar-baz']]; + $auth_plugin = $this->createMock(AuthenticationPluginInterface::class); + $auth_plugin->method('getAuthenticationOptions')->willReturn($auth_headers); + + $auth_manager = $this->createMock(AuthenticationPluginManager::class); + $auth_manager->method('createInstance')->willReturn($auth_plugin); + $container = new ContainerBuilder(); + $container->set('plugin.manager.migrate_plus.authentication', $auth_manager); + $this->processPlugin = OauthAccessToken::create($container, [], '', []); + } + + /** + * The process plugin returns the correct string. + */ + public function testTransform() { + $migration = $this->createMock(MigrateExecutableInterface::class); + $row = new Row(); + $row->setSourceProperty('authentication', ['plugin' => 'oauth2']); + $this->assertEquals('foo-bar-baz', $this->processPlugin->transform('', $migration, $row, '')); + } + +}