diff --git a/gui-backend/src/main/java/eu/melodic/upperware/guibackend/controller/deployment/DeploymentController.java b/gui-backend/src/main/java/eu/melodic/upperware/guibackend/controller/deployment/DeploymentController.java index 7887e9b23dd38ea9476ac0e1f1fb1b96dab0caa6..9a6a97cc242af02bcc734b91fdc31251174f235e 100644 --- a/gui-backend/src/main/java/eu/melodic/upperware/guibackend/controller/deployment/DeploymentController.java +++ b/gui-backend/src/main/java/eu/melodic/upperware/guibackend/controller/deployment/DeploymentController.java @@ -73,6 +73,7 @@ public class DeploymentController { @ResponseStatus(HttpStatus.CREATED) public List saveSecureVariables(@RequestBody List secureVariablesRequest) { log.info("POST request for save secure variables"); + secureStoreService.validateSecureVariables(secureVariablesRequest); return secureStoreService.saveSecureVariables(secureVariablesRequest); } } diff --git a/gui-backend/src/main/java/eu/melodic/upperware/guibackend/service/secure/store/SecureStoreService.java b/gui-backend/src/main/java/eu/melodic/upperware/guibackend/service/secure/store/SecureStoreService.java index 292b63de75df611877fb2f7a42d65e491da31732..f37c34f6bba7460e23be6b7029c9b5a960b8b79f 100644 --- a/gui-backend/src/main/java/eu/melodic/upperware/guibackend/service/secure/store/SecureStoreService.java +++ b/gui-backend/src/main/java/eu/melodic/upperware/guibackend/service/secure/store/SecureStoreService.java @@ -3,6 +3,7 @@ package eu.melodic.upperware.guibackend.service.secure.store; import eu.melodic.upperware.guibackend.communication.cloudiator.CloudiatorApi; import eu.melodic.upperware.guibackend.controller.deployment.common.SecureVariable; import eu.melodic.upperware.guibackend.exception.SecureVariableNotFoundException; +import eu.melodic.upperware.guibackend.exception.ValidationException; import eu.melodic.upperware.guibackend.model.byon.LoginCredential; import eu.melodic.upperware.guibackend.model.provider.CloudDefinition; import lombok.AllArgsConstructor; @@ -44,6 +45,18 @@ public class SecureStoreService { return secureVariablesKeys; } + // This method checks correctness of secure variable names, + // chars: '/' and '\' are not allowed as key of variable for Cloudiator secure store. + public void validateSecureVariables(List secureVariablesRequest) { + String invalidVariables = secureVariablesRequest.stream() + .filter(secureVariable -> secureVariable.getName().contains("/") || secureVariable.getName().contains("\\")) + .map(SecureVariable::getName) + .collect(Collectors.joining(", ")); + if (!invalidVariables.isEmpty()) { + throw new ValidationException(String.format("Variables: [ %s ] contain not allowed chars: '\\' or '/'", invalidVariables)); + } + } + public List saveSecureVariables(List secureVariablesRequest) { return secureVariablesRequest .stream() @@ -86,7 +99,9 @@ public class SecureStoreService { } public Pair createKeyLabelForSecret(CloudDefinition cloudDefinition) { - String keyForSecret = cloudDefinition.getApi().getProviderName() + "-" + cloudDefinition.getCredential().getUser() + SECURE_VARIABLE_SECURE_SUFIX; + String keyForSecret = cloudDefinition.getApi().getProviderName() + "-" + + cloudDefinition.getId() + + SECURE_VARIABLE_SECURE_SUFIX; return Pair.of(keyForSecret, SECURE_VARIABLE_PREFIX + keyForSecret + SECURE_VARIABLE_SUFFIX); }