From 34845d5a82621ca5d96adabbc2e35a90c31b0104 Mon Sep 17 00:00:00 2001 From: Rosie Le Faive Date: Fri, 11 Oct 2019 10:23:56 -0700 Subject: [PATCH 1/4] Switch the label and summary of contextReaction map_uri_predicate. --- islandora.iml | 20 +++++++++++++++++++ .../MappingUriPredicateReaction.php | 4 ++-- 2 files changed, 22 insertions(+), 2 deletions(-) create mode 100644 islandora.iml diff --git a/islandora.iml b/islandora.iml new file mode 100644 index 000000000..d1d2d7891 --- /dev/null +++ b/islandora.iml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php b/src/Plugin/ContextReaction/MappingUriPredicateReaction.php index 05f2f8c00..76667194f 100644 --- a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php +++ b/src/Plugin/ContextReaction/MappingUriPredicateReaction.php @@ -17,7 +17,7 @@ * * @ContextReaction( * id = "islandora_map_uri_predicate", - * label = @Translation("Map URI to predicate") + * label = @Translation("JSON-LD self-reference") * ) */ class MappingUriPredicateReaction extends NormalizerAlterReaction { @@ -69,7 +69,7 @@ public static function create(ContainerInterface $container, array $configuratio * {@inheritdoc} */ public function summary() { - return $this->t('Map Drupal URI to configured predicate.'); + return $this->t('When creating the JSON-LD for this Drupal entity, add a relationship to itself using this predicate.'); } /** From 2163b9d8cf6d92d12bd47d9fc10a9f5c5c8006a3 Mon Sep 17 00:00:00 2001 From: Rosie Le Faive Date: Fri, 11 Oct 2019 10:37:35 -0700 Subject: [PATCH 2/4] Switch config form to Self-reference predicate. --- src/Plugin/ContextReaction/MappingUriPredicateReaction.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php b/src/Plugin/ContextReaction/MappingUriPredicateReaction.php index 76667194f..fb2864a87 100644 --- a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php +++ b/src/Plugin/ContextReaction/MappingUriPredicateReaction.php @@ -123,8 +123,8 @@ public function buildConfigurationForm(array $form, FormStateInterface $form_sta $config = $this->getConfiguration(); $form[self::URI_PREDICATE] = [ '#type' => 'textfield', - '#title' => $this->t('Drupal URI predicate'), - '#description' => $this->t("The Drupal object's URI will be added to the resource with this predicate. Must use a defined prefix."), + '#title' => $this->t('Self-reference predicate'), + '#description' => $this->t("When creating the JSON-LD for this Drupal entity, add a relationship from the entity to itself using this predicate. It must use a defined prefix."), '#default_value' => isset($config[self::URI_PREDICATE]) ? $config[self::URI_PREDICATE] : '', '#size' => 35, ]; From c150ef4cf499ef81140a08c54dd7cb5cf013f24e Mon Sep 17 00:00:00 2001 From: Rosie Le Faive Date: Fri, 11 Oct 2019 11:07:16 -0700 Subject: [PATCH 3/4] Rename files to JsonldSelfReference... . --- islandora.iml | 20 -------- ...on.php => JsonldSelfReferenceReaction.php} | 49 ++++++++++--------- ...hp => JsonldSelfReferenceReactionTest.php} | 16 +++--- .../JsonldTypeAlterReactionTest.php | 2 +- 4 files changed, 34 insertions(+), 53 deletions(-) delete mode 100644 islandora.iml rename src/Plugin/ContextReaction/{MappingUriPredicateReaction.php => JsonldSelfReferenceReaction.php} (71%) rename tests/src/Functional/{MappingUriPredicateReactionTest.php => JsonldSelfReferenceReactionTest.php} (91%) diff --git a/islandora.iml b/islandora.iml deleted file mode 100644 index d1d2d7891..000000000 --- a/islandora.iml +++ /dev/null @@ -1,20 +0,0 @@ - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php b/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php similarity index 71% rename from src/Plugin/ContextReaction/MappingUriPredicateReaction.php rename to src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php index fb2864a87..b8008033e 100644 --- a/src/Plugin/ContextReaction/MappingUriPredicateReaction.php +++ b/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php @@ -13,16 +13,17 @@ use Symfony\Component\DependencyInjection\ContainerInterface; /** - * Map URI to predicate context reaction. + * Create a self-reference in JSON-LD RDF context reaction. Formerly called + * "Map URI to predicate" context reaction. Renamed for clarity. * * @ContextReaction( * id = "islandora_map_uri_predicate", * label = @Translation("JSON-LD self-reference") * ) */ -class MappingUriPredicateReaction extends NormalizerAlterReaction { +class JsonldSelfReferenceReaction extends NormalizerAlterReaction { - const URI_PREDICATE = 'drupal_uri_predicate'; + const SELF_REFERENCE_PREDICATE = 'drupal_uri_predicate'; /** * Media source service. @@ -77,11 +78,11 @@ public function summary() { */ public function execute(EntityInterface $entity = NULL, array &$normalized = NULL, array $context = NULL) { $config = $this->getConfiguration(); - $drupal_predicate = $config[self::URI_PREDICATE]; - if (!is_null($drupal_predicate) && !empty($drupal_predicate)) { + $self_ref_predicate = $config[self::SELF_REFERENCE_PREDICATE]; + if (!is_null($self_ref_predicate) && !empty($self_ref_predicate)) { $url = $this->getSubjectUrl($entity); if ($context['needs_jsonldcontext'] === FALSE) { - $drupal_predicate = NormalizerBase::escapePrefix($drupal_predicate, $context['namespaces']); + $self_ref_predicate = NormalizerBase::escapePrefix($self_ref_predicate, $context['namespaces']); } if (isset($normalized['@graph']) && is_array($normalized['@graph'])) { foreach ($normalized['@graph'] as &$graph) { @@ -91,24 +92,24 @@ public function execute(EntityInterface $entity = NULL, array &$normalized = NUL $file = $this->mediaSource->getSourceFile($entity); $graph['@id'] = $this->utils->getDownloadUrl($file); } - if (isset($graph[$drupal_predicate])) { - if (!is_array($graph[$drupal_predicate])) { - if ($graph[$drupal_predicate] == $url) { + if (isset($graph[$self_ref_predicate])) { + if (!is_array($graph[$self_ref_predicate])) { + if ($graph[$self_ref_predicate] == $url) { // Don't add it if it already exists. return; } - $tmp = $graph[$drupal_predicate]; - $graph[$drupal_predicate] = [$tmp]; + $tmp = $graph[$self_ref_predicate]; + $graph[$self_ref_predicate] = [$tmp]; } - elseif (array_search($url, array_column($graph[$drupal_predicate], '@id'))) { + elseif (array_search($url, array_column($graph[$self_ref_predicate], '@id'))) { // Don't add it if it already exists. return; } } else { - $graph[$drupal_predicate] = []; + $graph[$self_ref_predicate] = []; } - $graph[$drupal_predicate][] = ["@id" => $url]; + $graph[$self_ref_predicate][] = ["@id" => $url]; return; } } @@ -121,11 +122,11 @@ public function execute(EntityInterface $entity = NULL, array &$normalized = NUL */ public function buildConfigurationForm(array $form, FormStateInterface $form_state) { $config = $this->getConfiguration(); - $form[self::URI_PREDICATE] = [ + $form[self::SELF_REFERENCE_PREDICATE] = [ '#type' => 'textfield', '#title' => $this->t('Self-reference predicate'), - '#description' => $this->t("When creating the JSON-LD for this Drupal entity, add a relationship from the entity to itself using this predicate. It must use a defined prefix."), - '#default_value' => isset($config[self::URI_PREDICATE]) ? $config[self::URI_PREDICATE] : '', + '#description' => $this->t("When creating the JSON-LD for this Drupal entity, add a relationship from the entity to itself using this predicate. It must use a defined RDF namespace prefix."), + '#default_value' => isset($config[self::SELF_REFERENCE_PREDICATE]) ? $config[self::SELF_REFERENCE_PREDICATE] : '', '#size' => 35, ]; return $form; @@ -135,19 +136,19 @@ public function buildConfigurationForm(array $form, FormStateInterface $form_sta * {@inheritdoc} */ public function validateConfigurationForm(array &$form, FormStateInterface $form_state) { - $drupal_predicate = $form_state->getValue(self::URI_PREDICATE); - if (!is_null($drupal_predicate) and !empty($drupal_predicate)) { - if (preg_match('/^https?:\/\//', $drupal_predicate)) { + $self_ref_predicate = $form_state->getValue(self::SELF_REFERENCE_PREDICATE); + if (!is_null($self_ref_predicate) and !empty($self_ref_predicate)) { + if (preg_match('/^https?:\/\//', $self_ref_predicate)) { // Can't validate all URIs so we have to trust them. return; } - elseif (preg_match('/^([^\s:]+):/', $drupal_predicate, $matches)) { + elseif (preg_match('/^([^\s:]+):/', $self_ref_predicate, $matches)) { $predicate_prefix = $matches[1]; $rdf = rdf_get_namespaces(); $rdf_prefixes = array_keys($rdf); if (!in_array($predicate_prefix, $rdf_prefixes)) { $form_state->setErrorByName( - self::URI_PREDICATE, + self::SELF_REFERENCE_PREDICATE, $this->t('Namespace prefix @prefix is not registered.', ['@prefix' => $predicate_prefix] ) @@ -156,7 +157,7 @@ public function validateConfigurationForm(array &$form, FormStateInterface $form } else { $form_state->setErrorByName( - self::URI_PREDICATE, + self::SELF_REFERENCE_PREDICATE, $this->t('Predicate must use a defined prefix or be a full URI') ); } @@ -168,7 +169,7 @@ public function validateConfigurationForm(array &$form, FormStateInterface $form * {@inheritdoc} */ public function submitConfigurationForm(array &$form, FormStateInterface $form_state) { - $this->setConfiguration([self::URI_PREDICATE => $form_state->getValue(self::URI_PREDICATE)]); + $this->setConfiguration([self::SELF_REFERENCE_PREDICATE => $form_state->getValue(self::SELF_REFERENCE_PREDICATE)]); } } diff --git a/tests/src/Functional/MappingUriPredicateReactionTest.php b/tests/src/Functional/JsonldSelfReferenceReactionTest.php similarity index 91% rename from tests/src/Functional/MappingUriPredicateReactionTest.php rename to tests/src/Functional/JsonldSelfReferenceReactionTest.php index bf7bff6e5..6311cb17d 100644 --- a/tests/src/Functional/MappingUriPredicateReactionTest.php +++ b/tests/src/Functional/JsonldSelfReferenceReactionTest.php @@ -8,7 +8,7 @@ * @package Drupal\Tests\islandora\Functional * @group islandora */ -class MappingUriPredicateReactionTest extends IslandoraFunctionalTestBase { +class JsonldSelfReferenceReactionTest extends IslandoraFunctionalTestBase { /** * {@inheritdoc} @@ -37,7 +37,7 @@ public function setUp() { } /** - * @covers \Drupal\islandora\Plugin\ContextReaction\MappingUriPredicateReaction + * @covers \Drupal\islandora\Plugin\ContextReaction\JsonldSelfReferenceReaction */ public function testMappingReaction() { $account = $this->drupalCreateUser([ @@ -79,21 +79,21 @@ public function testMappingReaction() { $this->drupalGet("admin/structure/context/$context_name"); // Can't use an undefined prefix. $this->getSession()->getPage() - ->fillField("Drupal URI predicate", "bob:smith"); + ->fillField("Self-reference predicate", "bob:smith"); $this->getSession()->getPage()->pressButton("Save and continue"); $this->assertSession() ->pageTextContains("Namespace prefix bob is not registered"); // Can't use a straight string. $this->getSession()->getPage() - ->fillField("Drupal URI predicate", "woohoo"); + ->fillField("Self-reference predicate", "woohoo"); $this->getSession()->getPage()->pressButton("Save and continue"); $this->assertSession() ->pageTextContains("Predicate must use a defined prefix or be a full URI"); // Use an existing prefix. $this->getSession()->getPage() - ->fillField("Drupal URI predicate", "owl:sameAs"); + ->fillField("Self-reference predicate", "owl:sameAs"); $this->getSession()->getPage()->pressButton("Save and continue"); $this->assertSession() ->pageTextContains("The context $context_name has been saved"); @@ -114,7 +114,7 @@ public function testMappingReaction() { $this->drupalGet("admin/structure/context/$context_name"); // Change to a random URL. $this->getSession()->getPage() - ->fillField("Drupal URI predicate", "http://example.org/first/second"); + ->fillField("Self-reference predicate", "http://example.org/first/second"); $this->getSession()->getPage()->pressButton("Save and continue"); $this->assertSession() ->pageTextContains("The context $context_name has been saved"); @@ -135,7 +135,7 @@ public function testMappingReaction() { } /** - * @covers \Drupal\islandora\Plugin\ContextReaction\MappingUriPredicateReaction + * @covers \Drupal\islandora\Plugin\ContextReaction\JsonldSelfReferenceReaction */ public function testMappingReactionForMedia() { $account = $this->drupalCreateUser([ @@ -172,7 +172,7 @@ public function testMappingReactionForMedia() { // Use an existing prefix. $this->getSession()->getPage() - ->fillField("Drupal URI predicate", "iana:describedby"); + ->fillField("Self-reference predicate", "iana:describedby"); $this->getSession()->getPage()->pressButton("Save and continue"); $this->assertSession() ->pageTextContains("The context $context_name has been saved"); diff --git a/tests/src/Functional/JsonldTypeAlterReactionTest.php b/tests/src/Functional/JsonldTypeAlterReactionTest.php index fdf120579..29232ca16 100644 --- a/tests/src/Functional/JsonldTypeAlterReactionTest.php +++ b/tests/src/Functional/JsonldTypeAlterReactionTest.php @@ -8,7 +8,7 @@ * @package Drupal\Tests\islandora\Functional * @group islandora */ -class JsonldTypeAlterReactionTest extends MappingUriPredicateReactionTest { +class JsonldTypeAlterReactionTest extends JsonldSelfReferenceReactionTest { /** * @covers \Drupal\islandora\Plugin\ContextReaction\JsonldTypeAlterReaction From 75a2fe300da3c5e9043900cc568ed513fa1cc5c6 Mon Sep 17 00:00:00 2001 From: Rosie Le Faive Date: Mon, 14 Oct 2019 08:04:18 -0700 Subject: [PATCH 4/4] Coding standards. --- src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php b/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php index b8008033e..ed6aac95e 100644 --- a/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php +++ b/src/Plugin/ContextReaction/JsonldSelfReferenceReaction.php @@ -13,8 +13,9 @@ use Symfony\Component\DependencyInjection\ContainerInterface; /** - * Create a self-reference in JSON-LD RDF context reaction. Formerly called - * "Map URI to predicate" context reaction. Renamed for clarity. + * Create a self-reference in RDF when creating JSON-LD. + * + * Formerly called "Map URI to predicate". Renamed for clarity. * * @ContextReaction( * id = "islandora_map_uri_predicate",