From 8d31caadd3e50933f2fa3fd031ca7c53c5a0b124 Mon Sep 17 00:00:00 2001 From: GeoNetwork opensource <59019313+geonetworkbuild@users.noreply.github.com> Date: Tue, 24 Dec 2024 12:11:12 +0100 Subject: [PATCH] Return xml inside JSON status (#8580) Co-authored-by: WANGF --- .../api/records/MetadataWorkflowApi.java | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/services/src/main/java/org/fao/geonet/api/records/MetadataWorkflowApi.java b/services/src/main/java/org/fao/geonet/api/records/MetadataWorkflowApi.java index 054a72b0d86..da45b9b1fd8 100644 --- a/services/src/main/java/org/fao/geonet/api/records/MetadataWorkflowApi.java +++ b/services/src/main/java/org/fao/geonet/api/records/MetadataWorkflowApi.java @@ -66,6 +66,8 @@ import org.jdom.Element; import org.jdom.input.JDOMParseException; import org.jdom.output.XMLOutputter; +import org.json.JSONException; +import org.json.JSONObject; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.springframework.data.domain.PageRequest; @@ -1259,9 +1261,29 @@ private String getValidatedStateText(MetadataStatus metadataStatus, State state, checkCanViewStatus(stateText, httpSession); } + if (isValidJSON(stateText)) { + JSONObject json = new JSONObject(stateText); + String xmlRecord = json.getString("xmlRecord"); + return xmlRecord; + } + return stateText; } + /** + * Check if the input string is valid JSON format string + * @param json input string + * @return boolean if string is JSON format + */ + private boolean isValidJSON(String json) { + try { + new JSONObject(json); + } catch (JSONException e) { + return false; + } + return true; + } + /** * Checks if the metadata workflow is enabled. *