From 2ec002520ca84022db1817e05b67524d65bd70d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jose=20Garc=C3=ADa?= Date: Thu, 5 Sep 2024 09:44:40 +0200 Subject: [PATCH] Batch editing - In XPATH replace mode don't try to add a node if doesn't exist --- .../api/records/editing/BatchEditsApi.java | 42 ++++++++----------- 1 file changed, 17 insertions(+), 25 deletions(-) diff --git a/services/src/main/java/org/fao/geonet/api/records/editing/BatchEditsApi.java b/services/src/main/java/org/fao/geonet/api/records/editing/BatchEditsApi.java index 09d038c0fbd..6d95565507e 100644 --- a/services/src/main/java/org/fao/geonet/api/records/editing/BatchEditsApi.java +++ b/services/src/main/java/org/fao/geonet/api/records/editing/BatchEditsApi.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2001-2016 Food and Agriculture Organization of the + * Copyright (C) 2001-2024 Food and Agriculture Organization of the * United Nations (FAO-UN), United Nations World Food Programme (WFP) * and United Nations Environment Programme (UNEP) * @@ -37,7 +37,6 @@ import org.fao.geonet.ApplicationContextHolder; import org.fao.geonet.api.ApiParams; import org.fao.geonet.api.ApiUtils; -import org.fao.geonet.api.exception.NotAllowedException; import org.fao.geonet.api.processing.report.IProcessingReport; import org.fao.geonet.api.processing.report.SimpleMetadataProcessingReport; import org.fao.geonet.domain.AbstractMetadata; @@ -110,24 +109,21 @@ public synchronized void setApplicationContext(ApplicationContext context) { @ResponseStatus(HttpStatus.OK) @ResponseBody public Object previewBatchEdit( - @Parameter(description = ApiParams.API_PARAM_RECORD_UUIDS_OR_SELECTION, - required = false) + @Parameter(description = ApiParams.API_PARAM_RECORD_UUIDS_OR_SELECTION) @RequestParam(required = false) String[] uuids, @Parameter( - description = ApiParams.API_PARAM_BUCKET_NAME, - required = false) + description = ApiParams.API_PARAM_BUCKET_NAME) @RequestParam( required = false ) - String bucket, + String bucket, @Parameter( - description = "Return differences with diff, diffhtml or patch", - required = false + description = "Return differences with diff, diffhtml or patch" ) @RequestParam( required = false ) - DiffType diffType, + DiffType diffType, @RequestBody BatchEditParameter[] edits, HttpServletRequest request) throws Exception { @@ -153,25 +149,22 @@ public Object previewBatchEdit( @ResponseStatus(HttpStatus.CREATED) @ResponseBody public IProcessingReport batchEdit( - @Parameter(description = ApiParams.API_PARAM_RECORD_UUIDS_OR_SELECTION, - required = false) + @Parameter(description = ApiParams.API_PARAM_RECORD_UUIDS_OR_SELECTION) @RequestParam(required = false) String[] uuids, @Parameter( - description = ApiParams.API_PARAM_BUCKET_NAME, - required = false) + description = ApiParams.API_PARAM_BUCKET_NAME) @RequestParam( required = false ) - String bucket, + String bucket, @Parameter( - description = ApiParams.API_PARAM_UPDATE_DATESTAMP, - required = false + description = ApiParams.API_PARAM_UPDATE_DATESTAMP ) @RequestParam( required = false, defaultValue = "false" ) - boolean updateDateStamp, + boolean updateDateStamp, @RequestBody BatchEditParameter[] edits, HttpServletRequest request) throws Exception { @@ -185,7 +178,7 @@ private Pair applyBatchEdits( HttpServletRequest request, boolean previewOnly, DiffType diffType) throws Exception { List listOfUpdates = Arrays.asList(edits); - if (listOfUpdates.size() == 0) { + if (listOfUpdates.isEmpty()) { throw new IllegalArgumentException("At least one edit must be defined."); } @@ -206,7 +199,7 @@ private Pair applyBatchEdits( setOfUuidsToEdit = Sets.newHashSet(Arrays.asList(uuids)); } - if (setOfUuidsToEdit.size() == 0) { + if (setOfUuidsToEdit.isEmpty()) { throw new IllegalArgumentException("At least one record should be defined or selected for updates."); } @@ -214,10 +207,9 @@ private Pair applyBatchEdits( DataManager dataMan = appContext.getBean(DataManager.class); SchemaManager _schemaManager = context.getBean(SchemaManager.class); AccessManager accessMan = context.getBean(AccessManager.class); - final String settingId = Settings.SYSTEM_CSW_TRANSACTION_XPATH_UPDATE_CREATE_NEW_ELEMENTS; - boolean createXpathNodeIfNotExists = - context.getBean(SettingManager.class).getValueAsBool(settingId); - + // This value is used in replace mode to create the node if it doesn't exist. + // We don't want to create a node in replace mode, just replace the element if it exists, otherwise ignore it. + boolean createXpathNodeIfNotExists = false; SimpleMetadataProcessingReport report = new SimpleMetadataProcessingReport(); report.setTotalRecords(setOfUuidsToEdit.size()); @@ -254,7 +246,7 @@ private Pair applyBatchEdits( if (StringUtils.isNotEmpty(batchEditParameter.getCondition())) { applyEdit = false; final Object node = Xml.selectSingle(metadata, batchEditParameter.getCondition(), metadataSchema.getNamespaces()); - if (node != null && node instanceof Boolean && (Boolean)node == true) { + if (node != null && node instanceof Boolean && (Boolean) node == true) { applyEdit = true; } }