From ff1806f17752ae754f4874c22f178b49c06217a5 Mon Sep 17 00:00:00 2001 From: Diego Pino Navarro Date: Mon, 13 Jul 2020 18:20:48 -0400 Subject: [PATCH 1/3] Update JsonApiDrushCommands.php Super quick prelrease fix here. No big mess/issue here. it's basically me coding/testing/etc. But pretty sure some day someone will be happy about this! - Some quite complex JSON's ended being valid JSONs but invalida CURL data payloads (i learn more everyday). This fixes this --- src/Commands/JsonApiDrushCommands.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Commands/JsonApiDrushCommands.php b/src/Commands/JsonApiDrushCommands.php index dd1dc59..14b72bf 100644 --- a/src/Commands/JsonApiDrushCommands.php +++ b/src/Commands/JsonApiDrushCommands.php @@ -539,7 +539,7 @@ public function ingest( } } - $curl_body = json_encode($data_body); + $curl_body = json_encode($data_body, JSON_HEX_TAG | JSON_HEX_APOS | JSON_HEX_QUOT | JSON_HEX_AMP | JSON_UNESCAPED_UNICODE); $args_node = [ 'curl', From 6ee7cce185a9313737790f96b21e864d4bbc0871 Mon Sep 17 00:00:00 2001 From: Diego Pino Navarro Date: Mon, 13 Jul 2020 21:21:14 -0400 Subject: [PATCH 2/3] Minor fixes and double checking JSON is correct --- src/Commands/JsonApiDrushCommands.php | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/src/Commands/JsonApiDrushCommands.php b/src/Commands/JsonApiDrushCommands.php index 14b72bf..0227173 100644 --- a/src/Commands/JsonApiDrushCommands.php +++ b/src/Commands/JsonApiDrushCommands.php @@ -247,13 +247,22 @@ class JsonApiDrushCommands extends DrushCommands { } JSON; - /** * Wraps a JSON API node post call back with added files. * * @param string $jsonfilepath * A file containing either a full JSON API data payload or just SBF JSON * data. + * @param array $options + * 'files' => A folder or file that will be attached to the ADO + * 'user' => Drupal user that will do the action via JSON API + * 'password' => password for 'user' + * 'bundle' => 'digital_object', + * 'fieldname' => 'field_descriptive_metadata', + * 'uuid' => If provided and ADO exists ingest will not happen, + * 'moderation_state' => draft/published. Anything that is valid. + * + * @throws \Exception if ingest is not possible * * @command archipelago:jsonapi-ingest * @aliases ap-jsonapi-ingest @@ -370,6 +379,15 @@ public function ingest( // Check if JSON is a full JSON API data payload or just our SBF. // If just SBF, we need to have the machine name of the field to push data $data = json_decode($json_data, TRUE); + $json_error = json_last_error(); + if ($json_error != JSON_ERROR_NONE) { + // Well this is how life ends. + throw new \Exception( + dt( + 'The provided JSON could not be parsed or is not a valid JSON. Suspending the ingest' + ) + ); + } if (isset($data['data']['type']) && $data['data']['type'] == 'node--' . $bundle) { try { // @see https://github.com/swaggest/php-json-schema @@ -455,10 +473,10 @@ public function ingest( if (isset($response['data']['attributes']['drupal_internal__fid'])) { $this->output()->writeln( dt( - 'File @file sucessfully uploaded with file ID @fileid ', + 'File @file sucessfully uploaded with Internal Drupal file ID @fileid ', [ '@file' => $file->filename, - '@fileod' => $response['data']['attributes']['drupal_internal__fid'], + '@fileid' => $response['data']['attributes']['drupal_internal__fid'], ] ) ); From 05d861e3bbe6d5b7897d0bee866919303220c6a2 Mon Sep 17 00:00:00 2001 From: Diego Pino Navarro Date: Mon, 13 Jul 2020 21:26:19 -0400 Subject: [PATCH 3/3] Also throw error if JSON not present or empty --- src/Commands/JsonApiDrushCommands.php | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/Commands/JsonApiDrushCommands.php b/src/Commands/JsonApiDrushCommands.php index 0227173..38e1499 100644 --- a/src/Commands/JsonApiDrushCommands.php +++ b/src/Commands/JsonApiDrushCommands.php @@ -433,7 +433,13 @@ public function ingest( } } - + else { + throw new \Exception( + dt( + 'JSON payload seems to be missing or invalid JSON. Suspending the ingest' + ) + ); + } if ($field_name) { foreach ($files as $file) {