diff options
author | Gurjeet Bedi <gurjeetb@amdocs.com> | 2018-01-08 18:43:56 -0500 |
---|---|---|
committer | Gurjeet Bedi <gurjeetb@amdocs.com> | 2018-01-09 10:18:42 -0500 |
commit | 10ad7fc35b93f0d74052c76fef724f8494acb7ba (patch) | |
tree | 8443504c64b448a80d471bd8050f1cabdfb06592 /src/main | |
parent | eabf0a08faa6581c88c2e4ca5be56d4630891046 (diff) |
Validate the FromAppID when populating SOT props
Rejecting request when FromAppID is not set
Issue-ID: AAI-482
Change-Id: I34862ed17146dc8bf3ecaa13afd9a76a20c9476c
Signed-off-by: Gurjeet Bedi <gurjeetb@amdocs.com>
Diffstat (limited to 'src/main')
-rw-r--r-- | src/main/java/org/onap/crud/service/CrudRestService.java | 47 | ||||
-rw-r--r-- | src/main/java/org/onap/crud/util/CrudServiceUtil.java | 11 |
2 files changed, 36 insertions, 22 deletions
diff --git a/src/main/java/org/onap/crud/service/CrudRestService.java b/src/main/java/org/onap/crud/service/CrudRestService.java index fcf19c0..4b05b88 100644 --- a/src/main/java/org/onap/crud/service/CrudRestService.java +++ b/src/main/java/org/onap/crud/service/CrudRestService.java @@ -95,7 +95,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { String result = graphDataService.getVertex(version, id, type); @@ -125,7 +125,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { Map<String, String> filter = new HashMap<String, String>(); for (Map.Entry<String, List<String>> e : uriInfo.getQueryParameters().entrySet()) { @@ -160,7 +160,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { @@ -192,7 +192,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.GET, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { Map<String, String> filter = new HashMap<String, String>(); for (Map.Entry<String, List<String>> e : uriInfo.getQueryParameters().entrySet()) { @@ -229,7 +229,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.PUT, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.PUT, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { EdgePayload payload = EdgePayload.fromJson(content); @@ -276,7 +276,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.PATCH, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.PATCH, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { EdgePayload payload = EdgePayload.fromJson(content); @@ -315,7 +315,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.PUT, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.PUT, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { VertexPayload payload = VertexPayload.fromJson(content); @@ -325,6 +325,7 @@ public class CrudRestService { if (payload.getId() != null && !payload.getId().equals(id)) { throw new CrudException("ID Mismatch", Status.BAD_REQUEST); } + String result; payload.setProperties(CrudServiceUtil.mergeHeaderInFoToPayload(payload.getProperties(), headers, false)); @@ -363,7 +364,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.PATCH, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.PATCH, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { VertexPayload payload = VertexPayload.fromJson(content); if (payload.getProperties() == null || payload.getProperties().isJsonNull()) { @@ -403,7 +404,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { VertexPayload payload = VertexPayload.fromJson(content); @@ -548,7 +549,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { BulkPayload payload = BulkPayload.fromJson(content); @@ -586,7 +587,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { VertexPayload payload = VertexPayload.fromJson(content); @@ -631,7 +632,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { EdgePayload payload = EdgePayload.fromJson(content); @@ -672,7 +673,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.POST, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { EdgePayload payload = EdgePayload.fromJson(content); @@ -715,7 +716,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.DELETE, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.DELETE, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { String result = graphDataService.deleteVertex(version, id, type); @@ -745,7 +746,7 @@ public class CrudRestService { logger.debug("Incoming request..." + content); Response response = null; - if (validateRequest(req, uri, content, Action.DELETE, CrudServiceConstants.CRD_AUTH_POLICY_NAME)) { + if (validateRequest(req, uri, content, Action.DELETE, CrudServiceConstants.CRD_AUTH_POLICY_NAME, headers)) { try { String result = graphDataService.deleteEdge(version, id, type); @@ -764,8 +765,9 @@ public class CrudRestService { } protected boolean validateRequest(HttpServletRequest req, String uri, String content, Action action, - String authPolicyFunctionName) { - try { + String authPolicyFunctionName, HttpHeaders headers) { + boolean isValid = false; + try { String cipherSuite = (String) req.getAttribute("javax.servlet.request.cipher_suite"); String authUser = null; if (cipherSuite != null) { @@ -774,7 +776,16 @@ public class CrudRestService { X500Principal subjectDn = clientCert.getSubjectX500Principal(); authUser = subjectDn.toString(); } - return this.auth.validateRequest(authUser.toLowerCase(), action.toString() + ":" + authPolicyFunctionName); + isValid = this.auth.validateRequest(authUser.toLowerCase(), action.toString() + ":" + authPolicyFunctionName); + + String sourceOfTruth = null; + if(headers.getRequestHeaders().containsKey("X-FromAppId")) + sourceOfTruth = headers.getRequestHeaders().getFirst("X-FromAppId"); + + if(sourceOfTruth == null || sourceOfTruth.trim() == "") + throw new CrudException("Invalid request, Missing X-FromAppId header", Status.BAD_REQUEST); + + return isValid; } catch (Exception e) { logResult(action, uri, e); return false; diff --git a/src/main/java/org/onap/crud/util/CrudServiceUtil.java b/src/main/java/org/onap/crud/util/CrudServiceUtil.java index 45f2414..345a1cf 100644 --- a/src/main/java/org/onap/crud/util/CrudServiceUtil.java +++ b/src/main/java/org/onap/crud/util/CrudServiceUtil.java @@ -84,10 +84,14 @@ public class CrudServiceUtil { RelationshipSchemaLoader.loadModels(); } + /** + * This method will merge header property from app id in request payload if not already populated + * @param propertiesFromRequest + * @param headers + * @param isAdd + * @return + */ public static JsonElement mergeHeaderInFoToPayload(JsonElement propertiesFromRequest, HttpHeaders headers, boolean isAdd) { - if(!headers.getRequestHeaders().containsKey("X-FromAppId")) - return propertiesFromRequest; - String sourceOfTruth = headers.getRequestHeaders().getFirst("X-FromAppId"); Set<Map.Entry<String, JsonElement>> properties = new HashSet<Map.Entry<String, JsonElement>>(); properties.addAll(propertiesFromRequest.getAsJsonObject().entrySet()); @@ -124,5 +128,4 @@ public class CrudServiceUtil { return gson.fromJson(sb.toString(), JsonElement.class); } - } |