diff --git a/Jenkinsfile b/Jenkinsfile index 877c4671..b6a1cc93 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -43,7 +43,7 @@ pipeline { thresholds: [ skipped(failureThreshold: '0'), failed(failureThreshold: '40') ], tools: [ JUnit(pattern: 'target/surefire-reports/*.xml') ] ) - jacoco classPattern: 'target/classes', execPattern: 'target/jacoco.exec', sourcePattern: 'src/main/java', exclusionPattern:'iudx/data/marketplace/apiserver/ApiServerVerticle.class, **/*VertxEBProxy.class, **/*Constants.class, **/*VertxProxyHandler.class, **/*Verticle.class, **/JwtDataConverter.class, iudx/data/marketplace/apiserver/ProviderApis.class, iudx/data/marketplace/apiserver/ConsumerApis.class,iudx/data/marketplace/deploy/*.class, **/*Service.class, **/PolicyServiceImpl.class' + jacoco classPattern: 'target/classes', execPattern: 'target/jacoco.exec', sourcePattern: 'src/main/java', exclusionPattern:'iudx/data/marketplace/apiserver/ApiServerVerticle.class, **/*VertxEBProxy.class, **/*Constants.class, **/*VertxProxyHandler.class, **/*Verticle.class, **/JwtDataConverter.class, iudx/data/marketplace/apiserver/ProviderApis.class, iudx/data/marketplace/apiserver/ConsumerApis.class,iudx/data/marketplace/deploy/*.class, **/*Service.class, **/PolicyServiceImpl.class, **/package-info.class' recordIssues( enabledForFailure: true, diff --git a/docker-compose.test.yml b/docker-compose.test.yml index ca3c66eb..91170c2d 100644 --- a/docker-compose.test.yml +++ b/docker-compose.test.yml @@ -12,6 +12,8 @@ services: - /home/ubuntu/configs/dmp-apd-server-config.json:/usr/share/app/configs/dmp-apd-server.json - /home/ubuntu/configs/dmp-apd-server-keystore.jks:/usr/share/app/configs/keystore.jks - dmp-apd-server-volume:/usr/share/app/storage/temp-dir + - ./iudx-pmd-ruleset.xml:/usr/share/app/iudx-pmd-ruleset.xml + - ./google_checks.xml:/usr/share/app/google_checks.xml depends_on: - zookeeper ports: @@ -34,4 +36,4 @@ services: - dmp-apd-server-net volumes: - dmp-apd-server-volume: + dmp-apd-server-volume: \ No newline at end of file diff --git a/docker/depl.dockerfile b/docker/depl.dockerfile index 5a42970e..97ee613d 100644 --- a/docker/depl.dockerfile +++ b/docker/depl.dockerfile @@ -20,6 +20,8 @@ ENV JAR="iudx.data.marketplace-cluster-${VERSION}-fat.jar" WORKDIR /usr/share/app # Copying openapi docs COPY docs docs +COPY iudx-pmd-ruleset.xml iudx-pmd-ruleset.xml +COPY google_checks.xml google_checks.xml # Copying dev fatjar from builder stage to final image COPY --from=builder /usr/share/app/target/${JAR} ./fatjar.jar EXPOSE 8080 8443 diff --git a/docker/dev.dockerfile b/docker/dev.dockerfile index 6397049c..f2db65ca 100644 --- a/docker/dev.dockerfile +++ b/docker/dev.dockerfile @@ -20,6 +20,8 @@ ENV JAR="iudx.data.marketplace-dev-${VERSION}-fat.jar" WORKDIR /usr/share/app # Copying openapi docs COPY docs docs +COPY iudx-pmd-ruleset.xml iudx-pmd-ruleset.xml +COPY google_checks.xml google_checks.xml # Copying dev fatjar from builder stage to final image COPY --from=builder /usr/share/app/target/${JAR} ./fatjar.jar EXPOSE 8080 8443 diff --git a/pom.xml b/pom.xml index 8efff516..fc7f03a2 100644 --- a/pom.xml +++ b/pom.xml @@ -272,6 +272,43 @@ flyway-maven-plugin 8.5.13 + + org.apache.maven.plugins + maven-pmd-plugin + ${maven-pmd-plugin.version} + + ${openjdk.version} + + ./iudx-pmd-ruleset.xml + + true + + + target/generated-sources + + + + + org.apache.maven.plugins + maven-checkstyle-plugin + ${maven-checkstyle-plugin-google.version} + + + com.puppycrawl.tools + checkstyle + ${checkstyle.version} + + + + + true + UTF-8 + ./google_checks.xml + + ${project.build.sourceDirectory} + + + org.jacoco jacoco-maven-plugin @@ -327,6 +364,8 @@ **/*Service.class + + **/package-info.class iudx/data/marketplace/policies/PolicyServiceImpl.class @@ -490,22 +529,6 @@ - - org.apache.maven.plugins - maven-pmd-plugin - ${maven-pmd-plugin.version} - - ${openjdk.version} - - ./iudx-pmd-ruleset.xml - - true - - - target/generated-sources - - - org.apache.maven.plugins maven-checkstyle-plugin @@ -538,22 +561,6 @@ - - org.apache.maven.plugins - maven-pmd-plugin - ${maven-pmd-plugin.version} - - ${openjdk.version} - - ./iudx-pmd-ruleset.xml - - true - - - target/generated-sources - - - diff --git a/src/main/java/iudx/data/marketplace/apiserver/ApiServerVerticle.java b/src/main/java/iudx/data/marketplace/apiserver/ApiServerVerticle.java index fca5b1f1..2b93443a 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/ApiServerVerticle.java +++ b/src/main/java/iudx/data/marketplace/apiserver/ApiServerVerticle.java @@ -9,7 +9,6 @@ import io.vertx.core.http.*; import io.vertx.core.json.DecodeException; import io.vertx.core.json.JsonObject; -import io.vertx.core.net.JksOptions; import io.vertx.ext.web.Route; import io.vertx.ext.web.Router; import io.vertx.ext.web.RoutingContext; @@ -21,9 +20,8 @@ import iudx.data.marketplace.apiserver.handlers.AuthHandler; import iudx.data.marketplace.apiserver.handlers.ExceptionHandler; import iudx.data.marketplace.apiserver.handlers.ValidationHandler; -import iudx.data.marketplace.apiserver.provider.linkedAccount.LinkedAccountService; +import iudx.data.marketplace.apiserver.provider.linkedaccount.LinkedAccountService; import iudx.data.marketplace.apiserver.util.RequestType; -import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.authenticator.AuthClient; import iudx.data.marketplace.authenticator.AuthenticationService; import iudx.data.marketplace.common.*; @@ -64,7 +62,6 @@ public class ApiServerVerticle extends AbstractVerticle { private WebClientOptions webClientOptions; private AuthenticationService authenticationService; private LinkedAccountService linkedAccountService; - private AuditingService auditingService; private WebhookService webhookService; /** @@ -98,7 +95,6 @@ public void start() throws Exception { webClientOptions.setTrustAll(false).setVerifyHost(true).setSsl(true); webClient = WebClient.create(vertx, webClientOptions); - Api api = Api.getInstance(config().getString("dxApiBasePath")); /* Initialize service proxy */ policyService = PolicyService.createProxy(vertx, POLICY_SERVICE_ADDRESS); @@ -166,7 +162,7 @@ public void start() throws Exception { serverOptions.setCompressionSupported(true).setCompressionLevel(5); server = vertx.createHttpServer(serverOptions); server.requestHandler(router).listen(port); - + Api api = Api.getInstance(config().getString("dxApiBasePath")); router .route(PROVIDER_PATH + "/*") @@ -180,12 +176,11 @@ public void start() throws Exception { .init()); ExceptionHandler exceptionHandler = new ExceptionHandler(); - ValidationHandler checkPolicyValidationHandler = new ValidationHandler(vertx, RequestType.CHECK_POLICY); - ValidationHandler verifyValidationHandler = new ValidationHandler(vertx, RequestType.VERIFY); - ValidationHandler postLinkedAccountHandler = - new ValidationHandler(vertx, RequestType.POST_ACCOUNT); - ValidationHandler putLinkedAccountHandler = - new ValidationHandler(vertx, RequestType.PUT_ACCOUNT); + ValidationHandler checkPolicyValidationHandler = + new ValidationHandler(RequestType.CHECK_POLICY); + ValidationHandler verifyValidationHandler = new ValidationHandler(RequestType.VERIFY); + ValidationHandler postLinkedAccountHandler = new ValidationHandler(RequestType.POST_ACCOUNT); + ValidationHandler putLinkedAccountHandler = new ValidationHandler(RequestType.PUT_ACCOUNT); router .get(api.getPoliciesUrl()) @@ -193,11 +188,10 @@ public void start() throws Exception { .handler(this::getPoliciesHandler) .failureHandler(exceptionHandler); - - router - .post(api.getProductUserMapsPath()) - .handler(this::mapUserToProduct) - .failureHandler(exceptionHandler); + // router + // .post(api.getProductUserMapsPath()) + // .handler(this::mapUserToProduct) + // .failureHandler(exceptionHandler); router .post(api.getVerifyUrl()) @@ -207,7 +201,7 @@ public void start() throws Exception { .failureHandler(exceptionHandler); ValidationHandler verifyPaymentValidationHandler = - new ValidationHandler(vertx, RequestType.VERIFY_PAYMENT); + new ValidationHandler(RequestType.VERIFY_PAYMENT); router .post(api.getVerifyPaymentApi()) .handler(verifyPaymentValidationHandler) @@ -235,17 +229,17 @@ public void start() throws Exception { .handler(this::handleFetchLinkedAccount) .failureHandler(exceptionHandler); - router - .get(api.getCheckPolicyPath()) - .handler(checkPolicyValidationHandler) - .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) - .handler(this::checkPolicyHandler) - .failureHandler(exceptionHandler); + router + .get(api.getCheckPolicyPath()) + .handler(checkPolicyValidationHandler) + .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) + .handler(this::checkPolicyHandler) + .failureHandler(exceptionHandler); /*Webhook routes */ ValidationHandler orderPaidRequestValidationHandler = - new ValidationHandler(vertx, RequestType.ORDER_PAID_WEBHOOK); + new ValidationHandler(RequestType.ORDER_PAID_WEBHOOK); router .post("/order-paid-webhooks") .handler(this::handleWebhookSignatureValidation) @@ -254,7 +248,7 @@ public void start() throws Exception { .failureHandler(exceptionHandler); ValidationHandler paymentAuthorizedRequestValidationHandler = - new ValidationHandler(vertx, RequestType.PAYMENT_AUTHORIZED_WEBHOOK); + new ValidationHandler(RequestType.PAYMENT_AUTHORIZED_WEBHOOK); router .post("/payment-authorized") .handler(this::handleWebhookSignatureValidation) @@ -262,7 +256,7 @@ public void start() throws Exception { .handler(this::paymentAuthorizedRequestHandler); ValidationHandler paymentFailedRequestValidationHandler = - new ValidationHandler(vertx, RequestType.PAYMENT_FAILED_WEBHOOK); + new ValidationHandler(RequestType.PAYMENT_FAILED_WEBHOOK); router .post("/payments-failed") .handler(this::handleWebhookSignatureValidation) @@ -308,35 +302,33 @@ private void setServerOptions(HttpServerOptions serverOptions) { port = config().getInteger("httpPort") == null ? 8080 : config().getInteger("httpPort"); } - private void checkPolicyHandler(RoutingContext routingContext) { - HttpServerResponse response = routingContext.response(); - - User user = routingContext.get("user"); - String productVariantId = routingContext.request().getParam("productVariantId"); - policyService - .checkPolicy(productVariantId, user) - .onComplete( - handler -> { - if (handler.succeeded()) { - int statusCode = handler.result().getInteger(STATUS_CODE); - String result = handler.result().getJsonObject(RESULTS).encode(); - handleSuccessResponse(response, statusCode, result); - } else { - handleFailureResponse(routingContext, handler.cause().getMessage()); - } - }); - } + HttpServerResponse response = routingContext.response(); + + User user = routingContext.get("user"); + String productVariantId = routingContext.request().getParam("productVariantId"); + policyService + .checkPolicy(productVariantId, user) + .onComplete( + handler -> { + if (handler.succeeded()) { + int statusCode = handler.result().getInteger(STATUS_CODE); + String result = handler.result().getJsonObject(RESULTS).encode(); + handleSuccessResponse(response, statusCode, result); + } else { + handleFailureResponse(routingContext, handler.cause().getMessage()); + } + }); + } private void handleWebhookSignatureValidation(RoutingContext routingContext) { JsonObject requestBody = routingContext.body().asJsonObject(); HttpServerRequest request = routingContext.request(); - HttpServerResponse response = routingContext.response(); - String xRazorpaySignature = request.headers().get(HEADER_X_RAZORPAY_SIGNATURE); + String xrazorpaySignature = request.headers().get(HEADER_X_RAZORPAY_SIGNATURE); razorPayService - .webhookSignatureValidator(requestBody, xRazorpaySignature) + .webhookSignatureValidator(requestBody, xrazorpaySignature) .onSuccess( requestValidated -> { LOGGER.debug("Request Validated"); @@ -352,7 +344,6 @@ private void handleWebhookSignatureValidation(RoutingContext routingContext) { private void paymentFailedRequestHandler(RoutingContext routingContext) { JsonObject requestBody = routingContext.body().asJsonObject(); - HttpServerRequest request = routingContext.request(); HttpServerResponse response = routingContext.response(); LOGGER.debug(requestBody); @@ -377,7 +368,6 @@ private void paymentFailedRequestHandler(RoutingContext routingContext) { private void paymentAuthorizedRequestHandler(RoutingContext routingContext) { JsonObject requestBody = routingContext.body().asJsonObject(); - HttpServerRequest request = routingContext.request(); HttpServerResponse response = routingContext.response(); LOGGER.debug(requestBody); @@ -388,7 +378,6 @@ private void paymentAuthorizedRequestHandler(RoutingContext routingContext) { private void orderPaidRequestHandler(RoutingContext routingContext) { JsonObject requestBody = routingContext.body().asJsonObject(); - HttpServerRequest request = routingContext.request(); HttpServerResponse response = routingContext.response(); String orderId = @@ -423,11 +412,10 @@ private void handleVerifyPayment(RoutingContext routingContext) { }) .onFailure( verifyFailed -> { - handleResponse(response, BAD_REQUEST.getValue(), verifyFailed.getMessage()); + handleResponse(response, BAD_REQUEST.getValue(), verifyFailed.getMessage()); }); } - private void printDeployedEndpoints(Router router) { for (Route route : router.getRoutes()) { if (route.getPath() != null) { @@ -436,7 +424,6 @@ private void printDeployedEndpoints(Router router) { } } - private void getPoliciesHandler(RoutingContext routingContext) { HttpServerResponse response = routingContext.response(); @@ -454,7 +441,7 @@ private void getPoliciesHandler(RoutingContext routingContext) { }); } - private void mapUserToProduct(RoutingContext routingContext) {} + // private void mapUserToProduct(RoutingContext routingContext) {} private void handlePostLinkedAccount(RoutingContext routingContext) { JsonObject requestBody = routingContext.body().asJsonObject(); @@ -545,9 +532,7 @@ private void handleVerify(RoutingContext routingContext) { private void handleSuccessResponse(HttpServerResponse response, int statusCode, String result) { response.putHeader(CONTENT_TYPE, APPLICATION_JSON).setStatusCode(statusCode).end(result); } - private void handleResponse(HttpServerResponse response, int statusCode, String result) { - response.putHeader(CONTENT_TYPE, APPLICATION_JSON).setStatusCode(statusCode).end(result); - } + /** * Handles Failed HTTP Response @@ -594,6 +579,10 @@ private void handleFailureResponse(RoutingContext routingContext, String failure } } + private void handleResponse(HttpServerResponse response, int statusCode, String result) { + response.putHeader(CONTENT_TYPE, APPLICATION_JSON).setStatusCode(statusCode).end(result); + } + private void handleResponse( HttpServerResponse response, HttpStatusCode statusCode, ResponseUrn urn) { handleResponse(response, statusCode, urn, statusCode.getDescription()); diff --git a/src/main/java/iudx/data/marketplace/apiserver/ConsumerApis.java b/src/main/java/iudx/data/marketplace/apiserver/ConsumerApis.java index 13561ad6..37fda18a 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/ConsumerApis.java +++ b/src/main/java/iudx/data/marketplace/apiserver/ConsumerApis.java @@ -42,7 +42,13 @@ public class ConsumerApis { private AuthClient authClient; private AuthenticationService authenticationService; - ConsumerApis(Vertx vertx, Router router, Api apis, PostgresService postgresService, AuthClient authClient, AuthenticationService authenticationService) { + ConsumerApis( + Vertx vertx, + Router router, + Api apis, + PostgresService postgresService, + AuthClient authClient, + AuthenticationService authenticationService) { this.vertx = vertx; this.router = router; this.api = apis; @@ -53,14 +59,9 @@ public class ConsumerApis { Router init() { - ValidationHandler resourceValidationHandler = new ValidationHandler(vertx, RequestType.RESOURCE); - ValidationHandler providerValidationHandler = - new ValidationHandler(vertx, RequestType.PROVIDER); - ValidationHandler orderValidationHandler = new ValidationHandler(vertx, RequestType.ORDER); - ValidationHandler purchaseValidationHandler = - new ValidationHandler(vertx, RequestType.PURCHASE); + ValidationHandler resourceValidationHandler = new ValidationHandler(RequestType.RESOURCE); + ValidationHandler providerValidationHandler = new ValidationHandler(RequestType.PROVIDER); ExceptionHandler exceptionHandler = new ExceptionHandler(); - ValidationHandler productVariantHandler = new ValidationHandler(vertx, RequestType.PRODUCT); consumerService = ConsumerService.createProxy(vertx, CONSUMER_SERVICE_ADDRESS); @@ -85,6 +86,8 @@ Router init() { .handler(this::listProducts) .failureHandler(exceptionHandler); + ValidationHandler purchaseValidationHandler = new ValidationHandler(RequestType.PURCHASE); + router .get(api.getConsumerListPurchases()) .handler(purchaseValidationHandler) @@ -92,13 +95,17 @@ Router init() { .handler(this::listPurchases) .failureHandler(exceptionHandler); - router - .get(api.getConsumerProductVariantPath()) + ValidationHandler productVariantHandler = new ValidationHandler(RequestType.PRODUCT); + + router + .get(api.getConsumerProductVariantPath()) .handler(productVariantHandler) .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::listProductVariants) .failureHandler(exceptionHandler); + ValidationHandler orderValidationHandler = new ValidationHandler(RequestType.ORDER); + router .post(CONSUMER_PATH + ORDERS_PATH + "/:productVariantId") .handler(orderValidationHandler) @@ -115,18 +122,22 @@ private void createOrder(RoutingContext routingContext) { LOGGER.debug(variantId); - JsonObject requestBody = new JsonObject() - .put(AUTH_INFO, routingContext.data().get(AUTH_INFO)) - .put(PRODUCT_VARIANT_ID, variantId); + JsonObject requestBody = + new JsonObject() + .put(AUTH_INFO, routingContext.data().get(AUTH_INFO)) + .put(PRODUCT_VARIANT_ID, variantId); User user = routingContext.get("user"); - consumerService.createOrder(requestBody, user, handler -> { - if(handler.succeeded()) { - handleSuccessResponse(routingContext, 201, handler.result()); - } else { - handleFailureResponse(routingContext, handler.cause()); - } - }); + consumerService.createOrder( + requestBody, + user, + handler -> { + if (handler.succeeded()) { + handleSuccessResponse(routingContext, 201, handler.result()); + } else { + handleFailureResponse(routingContext, handler.cause()); + } + }); } private void listProviders(RoutingContext routingContext) { @@ -141,10 +152,10 @@ private void listProviders(RoutingContext routingContext) { User consumer = routingContext.get("user"); consumerService.listProviders( - consumer, + consumer, requestBody, handler -> { - if (handler.succeeded()) { + if (handler.succeeded()) { if (handler.result().getJsonArray(RESULTS).isEmpty()) { handleSuccessResponse(routingContext, 204, handler.result()); } else { @@ -168,7 +179,7 @@ private void listResources(RoutingContext routingContext) { requestBody.put(AUTH_INFO, authInfo); consumerService.listResources( - consumer, + consumer, requestBody, handler -> { if (handler.succeeded()) { @@ -188,8 +199,7 @@ private void listProductVariants(RoutingContext routingContext) { User consumer = routingContext.get("user"); MultiMap requestParams = routingContext.request().params(); String productId = requestParams.get("productId"); - JsonObject requestJson = - new JsonObject().put("productId", productId); + JsonObject requestJson = new JsonObject().put("productId", productId); consumerService.listProductVariants( consumer, @@ -216,7 +226,7 @@ private void listProducts(RoutingContext routingContext) { User consumer = routingContext.get("user"); consumerService.listProducts( - consumer, + consumer, requestBody, handler -> { if (handler.succeeded()) { @@ -238,26 +248,22 @@ private void listPurchases(RoutingContext routingContext) { String productId = requestParams.get("productId"); String paymentStatus = requestParams.get("paymentStatus"); JsonObject requestJson = - new JsonObject().put("resourceId", resourceId).put("productId", productId).put("paymentStatus", paymentStatus); + new JsonObject() + .put("resourceId", resourceId) + .put("productId", productId) + .put("paymentStatus", paymentStatus); - consumerService.listPurchase(consumer,requestJson, handler -> { - if(handler.succeeded()) - { - handleSuccessResponse(routingContext, HttpStatusCode.SUCCESS.getValue(), handler.result()); - } - else - { - handleFailureResponse(routingContext, handler.cause().getMessage()); - } - }); - } - - private void handleFailureResponse(RoutingContext routingContext, Throwable cause) { - routingContext - .response() - .putHeader(CONTENT_TYPE, APPLICATION_JSON) - .setStatusCode(400) - .end(cause.getMessage()); + consumerService.listPurchase( + consumer, + requestJson, + handler -> { + if (handler.succeeded()) { + handleSuccessResponse( + routingContext, HttpStatusCode.SUCCESS.getValue(), handler.result()); + } else { + handleFailureResponse(routingContext, handler.cause().getMessage()); + } + }); } private void handleSuccessResponse( @@ -272,7 +278,7 @@ private void handleSuccessResponse( .setStatusCode(statusCode) .end(result.toString()); break; - case 204: + default: //204 routingContext .response() .putHeader(CONTENT_TYPE, APPLICATION_JSON) @@ -282,6 +288,14 @@ private void handleSuccessResponse( } } + private void handleFailureResponse(RoutingContext routingContext, Throwable cause) { + routingContext + .response() + .putHeader(CONTENT_TYPE, APPLICATION_JSON) + .setStatusCode(400) + .end(cause.getMessage()); + } + /** * Handles Failed HTTP Response * @@ -309,16 +323,16 @@ private void handleFailureResponse(RoutingContext routingContext, String failure urn = ResponseUrn.fromCode(String.valueOf(type)); } if (jsonObject.getString(DETAIL) != null) { - String detail = jsonObject.getString(DETAIL); + String detail = jsonObject.getString(DETAIL); response - .putHeader(CONTENT_TYPE, APPLICATION_JSON) - .setStatusCode(type) - .end(generateResponse(status, urn, detail).toString()); + .putHeader(CONTENT_TYPE, APPLICATION_JSON) + .setStatusCode(type) + .end(generateResponse(status, urn, detail).toString()); } else { response - .putHeader(CONTENT_TYPE, APPLICATION_JSON) - .setStatusCode(type) - .end(generateResponse(status, urn).toString()); + .putHeader(CONTENT_TYPE, APPLICATION_JSON) + .setStatusCode(type) + .end(generateResponse(status, urn).toString()); } } catch (DecodeException exception) { @@ -328,19 +342,18 @@ private void handleFailureResponse(RoutingContext routingContext, String failure } private void handleResponse( - HttpServerResponse response, HttpStatusCode statusCode, ResponseUrn urn) { + HttpServerResponse response, HttpStatusCode statusCode, ResponseUrn urn) { handleResponse(response, statusCode, urn, statusCode.getDescription()); } private void handleResponse( - HttpServerResponse response, - HttpStatusCode statusCode, - ResponseUrn urn, - String failureMessage) { + HttpServerResponse response, + HttpStatusCode statusCode, + ResponseUrn urn, + String failureMessage) { response - .putHeader(CONTENT_TYPE, APPLICATION_JSON) - .setStatusCode(statusCode.getValue()) - .end(generateResponse(statusCode, urn, failureMessage).toString()); + .putHeader(CONTENT_TYPE, APPLICATION_JSON) + .setStatusCode(statusCode.getValue()) + .end(generateResponse(statusCode, urn, failureMessage).toString()); } - } diff --git a/src/main/java/iudx/data/marketplace/apiserver/ProviderApis.java b/src/main/java/iudx/data/marketplace/apiserver/ProviderApis.java index bc8e75ce..b66fe3e6 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/ProviderApis.java +++ b/src/main/java/iudx/data/marketplace/apiserver/ProviderApis.java @@ -30,7 +30,6 @@ import iudx.data.marketplace.product.ProductService; import iudx.data.marketplace.product.variant.ProductVariantService; import java.util.Map; - import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -64,17 +63,7 @@ public class ProviderApis { Router init() { - ValidationHandler productValidationHandler = new ValidationHandler(vertx, RequestType.PRODUCT); - ValidationHandler variantValidationHandler = - new ValidationHandler(vertx, RequestType.PRODUCT_VARIANT); - ValidationHandler deleteVariantValidationHandler = - new ValidationHandler(vertx, RequestType.DELETE_PRODUCT_VARIANT); - ValidationHandler listVariantValidationHandler = - new ValidationHandler(vertx, RequestType.LIST_PRODUCT_VARIANT); - ValidationHandler resourceValidationHandler = - new ValidationHandler(vertx, RequestType.RESOURCE); - ValidationHandler purchaseValidationHandler = - new ValidationHandler(vertx, RequestType.PURCHASE); + ValidationHandler productValidationHandler = new ValidationHandler(RequestType.PRODUCT); ExceptionHandler exceptionHandler = new ExceptionHandler(); productService = ProductService.createProxy(vertx, PRODUCT_SERVICE_ADDRESS); @@ -94,6 +83,7 @@ Router init() { .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::handleDeleteProduct) .failureHandler(exceptionHandler); + ValidationHandler resourceValidationHandler = new ValidationHandler(RequestType.RESOURCE); router .get(api.getProviderListProductsPath()) @@ -101,6 +91,7 @@ Router init() { .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::listProducts) .failureHandler(exceptionHandler); + ValidationHandler purchaseValidationHandler = new ValidationHandler(RequestType.PURCHASE); router .get(api.getProviderListPurchasesPath()) @@ -108,6 +99,7 @@ Router init() { .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::listPurchases) .failureHandler(exceptionHandler); + ValidationHandler variantValidationHandler = new ValidationHandler(RequestType.PRODUCT_VARIANT); router .post(api.getProviderProductVariantPath()) @@ -122,13 +114,16 @@ Router init() { .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::handleUpdateProductVariant) .failureHandler(exceptionHandler); - + ValidationHandler listVariantValidationHandler = + new ValidationHandler(RequestType.LIST_PRODUCT_VARIANT); router .get(api.getProviderProductVariantPath()) .handler(listVariantValidationHandler) .handler(AuthHandler.create(authenticationService, api, postgresService, authClient)) .handler(this::handleGetProductVariants) .failureHandler(exceptionHandler); + ValidationHandler deleteVariantValidationHandler = + new ValidationHandler(RequestType.DELETE_PRODUCT_VARIANT); router .delete(api.getProviderProductVariantPath()) @@ -162,11 +157,10 @@ private void handleCreateProduct(RoutingContext routingContext) { } else if (errorMessage.contains(ResponseUrn.INTERNAL_SERVER_ERR_URN.getMessage())) { routingContext.fail( new DxRuntimeException(500, ResponseUrn.INTERNAL_SERVER_ERR_URN, errorMessage)); - } else if( errorMessage.contains(ResponseUrn.FORBIDDEN_URN.getUrn())) - { - handleFailureResponse(routingContext, errorMessage, HttpStatusCode.FORBIDDEN.getValue()); - } - else { + } else if (errorMessage.contains(ResponseUrn.FORBIDDEN_URN.getUrn())) { + handleFailureResponse( + routingContext, errorMessage, HttpStatusCode.FORBIDDEN.getValue()); + } else { handleFailureResponse(routingContext, handler.cause()); } } @@ -233,18 +227,21 @@ private void listPurchases(RoutingContext routingContext) { String productId = requestParams.get("productId"); String paymentStatus = requestParams.get("paymentStatus"); JsonObject requestJson = - new JsonObject().put("resourceId", resourceId).put("productId", productId).put("paymentStatus", paymentStatus); - variantService - .listPurchase(provider, requestJson, handler -> { - if(handler.succeeded()) - { - handleSuccessResponse(routingContext, HttpStatusCode.SUCCESS.getValue(), handler.result()); - } - else - { - handleFailure(routingContext, handler.cause().getMessage()); - } - }); + new JsonObject() + .put("resourceId", resourceId) + .put("productId", productId) + .put("paymentStatus", paymentStatus); + variantService.listPurchase( + provider, + requestJson, + handler -> { + if (handler.succeeded()) { + handleSuccessResponse( + routingContext, HttpStatusCode.SUCCESS.getValue(), handler.result()); + } else { + handleFailure(routingContext, handler.cause().getMessage()); + } + }); } private void handleCreateProductVariant(RoutingContext routingContext) { @@ -268,7 +265,7 @@ private void handleCreateProductVariant(RoutingContext routingContext) { ResponseUrn.RESOURCE_ALREADY_EXISTS_URN, ResponseUrn.RESOURCE_ALREADY_EXISTS_URN.getMessage())); - } else if (errMessage.contains(ResponseUrn.FORBIDDEN_URN.getUrn())){ + } else if (errMessage.contains(ResponseUrn.FORBIDDEN_URN.getUrn())) { handleFailureResponse( routingContext, errMessage, HttpStatusCode.FORBIDDEN.getValue()); } else { @@ -335,8 +332,7 @@ private void handleDeleteProductVariant(RoutingContext routingContext) { if (handler.succeeded()) { handleSuccessResponse(routingContext, 200, handler.result()); } else { - handleFailure( - routingContext, handler.cause().getMessage()); + handleFailure(routingContext, handler.cause().getMessage()); } }); } @@ -349,12 +345,13 @@ private void handleFailureResponse(RoutingContext routingContext, Throwable caus .end(cause.getMessage()); } - private void handleFailureResponse(RoutingContext routingContext, String failureMessage, int statusCode) { + private void handleFailureResponse( + RoutingContext routingContext, String failureMessage, int statusCode) { routingContext - .response() - .putHeader(CONTENT_TYPE, APPLICATION_JSON) - .setStatusCode(statusCode) - .end(failureMessage); + .response() + .putHeader(CONTENT_TYPE, APPLICATION_JSON) + .setStatusCode(statusCode) + .end(failureMessage); } private void handleFailure(RoutingContext routingContext, String failureMessage) { @@ -431,6 +428,8 @@ private void handleSuccessResponse( .setStatusCode(statusCode) .end(); break; + default: + break; } } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/exceptions/DxRuntimeException.java b/src/main/java/iudx/data/marketplace/apiserver/exceptions/DxRuntimeException.java index 20b57633..f418db47 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/exceptions/DxRuntimeException.java +++ b/src/main/java/iudx/data/marketplace/apiserver/exceptions/DxRuntimeException.java @@ -1,4 +1,3 @@ - package iudx.data.marketplace.apiserver.exceptions; import iudx.data.marketplace.common.ResponseUrn; diff --git a/src/main/java/iudx/data/marketplace/apiserver/handlers/AuthHandler.java b/src/main/java/iudx/data/marketplace/apiserver/handlers/AuthHandler.java index 002307b9..697c47e6 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/handlers/AuthHandler.java +++ b/src/main/java/iudx/data/marketplace/apiserver/handlers/AuthHandler.java @@ -91,8 +91,7 @@ public void handle(RoutingContext context) { } else { processAuthFailure(context, "Invalid token"); } - } else // for all the other endpoints - { + } else { // for all the other endpoints checkAuth(requestJson, authInfo) .onSuccess( userObject -> { @@ -129,7 +128,7 @@ Future checkAuth(JsonObject request, JsonObject authInfo) { return promise.future(); } - Future getUserInfo(JsonObject tokenIntrospectResult) { + Future getUserInfo(JsonObject tokenIntrospectResult) { LOGGER.info("Getting user info.."); Promise promise = Promise.promise(); UserContainer userContainer = new UserContainer(); @@ -242,13 +241,13 @@ private String getNormalisedPath(String url) { return api.getConsumerListProducts(); } else if (url.contains(api.getConsumerOrderApi())) { return api.getConsumerOrderApi(); - } else if(url.matches(api.getLinkedAccountService())){ + } else if (url.matches(api.getLinkedAccountService())) { return api.getLinkedAccountService(); - } else if(url.matches(api.getConsumerListResourcePath())) { + } else if (url.matches(api.getConsumerListResourcePath())) { return api.getConsumerListResourcePath(); - } else if(url.matches(api.getConsumerProductVariantPath())) { + } else if (url.matches(api.getConsumerProductVariantPath())) { return api.getConsumerProductVariantPath(); - } else if(url.matches(api.getVerifyPaymentApi())) { + } else if (url.matches(api.getVerifyPaymentApi())) { return api.getVerifyPaymentApi(); } else if (url.matches(api.getCheckPolicyPath())) { return api.getCheckPolicyPath(); diff --git a/src/main/java/iudx/data/marketplace/apiserver/handlers/ExceptionHandler.java b/src/main/java/iudx/data/marketplace/apiserver/handlers/ExceptionHandler.java index b820bcc7..2ed0e211 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/handlers/ExceptionHandler.java +++ b/src/main/java/iudx/data/marketplace/apiserver/handlers/ExceptionHandler.java @@ -1,5 +1,7 @@ package iudx.data.marketplace.apiserver.handlers; +import static iudx.data.marketplace.apiserver.util.Constants.*; + import io.vertx.core.Handler; import io.vertx.core.json.DecodeException; import io.vertx.core.json.JsonObject; @@ -12,8 +14,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.apiserver.util.Constants.*; - public class ExceptionHandler implements Handler { private static final Logger LOGGER = LogManager.getLogger(ExceptionHandler.class); @@ -59,20 +59,19 @@ public void handle(RoutingContext routingContext) { LOGGER.error(" -------------- "); LOGGER.error(failure.fillInStackTrace()); - String INTERNAL_ERROR_RESP = - new RespBuilder() - .withType(ResponseUrn.INTERNAL_SERVER_ERR_URN.getUrn()) - .withTitle(ResponseUrn.INTERNAL_SERVER_ERR_URN.getMessage()) - .getResponse(); + String internalErrorResp = + new RespBuilder() + .withType(ResponseUrn.INTERNAL_SERVER_ERR_URN.getUrn()) + .withTitle(ResponseUrn.INTERNAL_SERVER_ERR_URN.getMessage()) + .getResponse(); routingContext .response() .setStatusCode(500) .putHeader(HEADER_CONTENT_TYPE, APPLICATION_JSON) - .end(INTERNAL_ERROR_RESP); + .end(internalErrorResp); routingContext.next(); - } routingContext.next(); } @@ -87,7 +86,7 @@ private JsonObject validationFailureReponse(String message) { /** * Handles the JsonDecode Exception. * - * @param routingContext + * @param routingContext associated with the request to add the appropriate response */ public void handleDecodeException(RoutingContext routingContext) { @@ -112,14 +111,12 @@ public void handleDecodeException(RoutingContext routingContext) { routingContext.next(); return; } - - } /** * Handles the exception from casting a object to different object. * - * @param routingContext + * @param routingContext associated with the request to add the appropriate response */ public void handleClassCastException(RoutingContext routingContext) { diff --git a/src/main/java/iudx/data/marketplace/apiserver/handlers/ValidationHandler.java b/src/main/java/iudx/data/marketplace/apiserver/handlers/ValidationHandler.java index 04c1a63e..4498d886 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/handlers/ValidationHandler.java +++ b/src/main/java/iudx/data/marketplace/apiserver/handlers/ValidationHandler.java @@ -1,31 +1,26 @@ package iudx.data.marketplace.apiserver.handlers; - import io.vertx.core.Handler; import io.vertx.core.MultiMap; -import io.vertx.core.Vertx; import io.vertx.core.json.JsonObject; import io.vertx.ext.web.RoutingContext; import iudx.data.marketplace.apiserver.util.RequestType; import iudx.data.marketplace.apiserver.validation.ValidationHandlerFactory; import iudx.data.marketplace.apiserver.validation.types.Validator; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Optional; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class ValidationHandler implements Handler { private static final Logger LOGGER = LogManager.getLogger(ValidationHandler.class); private RequestType requestType; - private Vertx vertx; - public ValidationHandler(Vertx vertx, RequestType requestType) { - this.vertx = vertx; + public ValidationHandler(RequestType requestType) { this.requestType = requestType; } @@ -37,8 +32,7 @@ public void handle(RoutingContext context) { Map pathParams = context.pathParams(); parameters.addAll(pathParams); - List validations = - validationFactory.build(requestType, parameters, body); + List validations = validationFactory.build(requestType, parameters, body); for (Validator validator : Optional.ofNullable(validations).orElse(Collections.emptyList())) { LOGGER.debug("validator : " + validator.getClass().getName()); validator.isValid(); diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountService.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountService.java deleted file mode 100644 index a47a7701..00000000 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountService.java +++ /dev/null @@ -1,51 +0,0 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; - - -import io.vertx.codegen.annotations.GenIgnore; -import io.vertx.codegen.annotations.ProxyGen; -import io.vertx.codegen.annotations.VertxGen; -import io.vertx.core.Future; -import io.vertx.core.Vertx; -import io.vertx.core.json.JsonObject; -import iudx.data.marketplace.policies.User; - -@VertxGen -@ProxyGen -public interface LinkedAccountService { - - - /* factory method */ - @GenIgnore - static LinkedAccountService createProxy(Vertx vertx, String address) - { - return new LinkedAccountServiceVertxEBProxy(vertx, address); - } - - /* service operation */ - - /** - * Used to create a new linked account through for Razorpay - * @param request Provider's business related information to create a linked account - * @param user Provider details as User object - * @return Future of JsonObject when it is successful, Future containing failure message during failure - */ - Future createLinkedAccount(JsonObject request, User user); - - /** - * Used to fetch a linked account created through DMP for Razorpay - * @param user Provider details as User object - * @return Future of JsonObject containing linked account details sent by Razorpay - * when it is successful, Future containing failure message during failure - */ - Future fetchLinkedAccount(User user); - - /** - * Used to update a linked account created through DMP for Razorpay - * @param request Provider's business related information to create a linked account - * all the details expect business_type, email can be updated - * @param user Provider details as User object - * @return Future of JsonObject when it is successful, Future containing failure message during failure - */ - Future updateLinkedAccount(JsonObject request, User user); - -} diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/package-info.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/package-info.java deleted file mode 100644 index 42fabd73..00000000 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/package-info.java +++ /dev/null @@ -1,8 +0,0 @@ - -@ModuleGen( - groupPackage = "iudx.data.marketplace.apiserver.provider", - name = "iudx-data-marketplace-apiserver-provider", - useFutures = true) -package iudx.data.marketplace.apiserver.provider.linkedAccount; - -import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/util/Constants.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/util/Constants.java deleted file mode 100644 index d204418c..00000000 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/util/Constants.java +++ /dev/null @@ -1,31 +0,0 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount.util; - -public class Constants { - public static final String INSERT_MERCHANT_INFO_QUERY = - "INSERT INTO merchant_table(" - + " reference_id, phone_number, email, legal_business_name, customer_facing_business_name, account_id," - + " provider_id, status, rzp_account_product_id) " - + " VALUES ('$1', '$2', '$3', '$4', '$5','$6', '$7', '$8', '$9');"; - -public static final String FETCH_MERCHANT_INFO_QUERY = - "SELECT account_id, rzp_account_product_id, status FROM merchant_table WHERE provider_id = '$1'"; - -public static String UPDATE_LINKED_ACCOUNT_STATUS_QUERY = - "UPDATE merchant_table SET status = 'ACTIVATED' WHERE provider_id = '$1' RETURNING reference_id"; - - public static final String ACCOUNT_TYPE = "route"; - public static final String FAILURE_MESSAGE = "User registration incomplete : "; - public static final String GET_ACCOUNT_ID_QUERY = - "SELECT DISTINCT M.account_id, M.rzp_account_product_id,\n" - + "M.modified_at AS \"updatedAt\" , M.created_at AS \"createdAt\" \n" - + "FROM merchant_table M\n" - + "WHERE M.provider_id = '$1'\n"; - public static final String GET_MERCHANT_INFO_QUERY = "SELECT account_id, reference_id FROM merchant_table WHERE provider_id = '$1'" + - " AND email = '$2'"; - - public static final String UPDATE_MERCHANT_INFO_QUERY = "UPDATE merchant_table SET " + - " phone_number = '$1', legal_business_name = '$2', customer_facing_business_name = '$3' " + - " WHERE provider_id = '$4' AND email = '$5' RETURNING account_id; "; - - -} diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/CreateLinkedAccount.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/CreateLinkedAccount.java similarity index 79% rename from src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/CreateLinkedAccount.java rename to src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/CreateLinkedAccount.java index 9b6b999f..f9af55e0 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/CreateLinkedAccount.java +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/CreateLinkedAccount.java @@ -1,5 +1,7 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; +package iudx.data.marketplace.apiserver.provider.linkedaccount; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.*; +import static iudx.data.marketplace.apiserver.util.Constants.*; import com.google.common.hash.Hashing; import io.vertx.core.Future; @@ -14,16 +16,12 @@ import iudx.data.marketplace.policies.User; import iudx.data.marketplace.postgres.PostgresService; import iudx.data.marketplace.razorpay.RazorPayService; -import org.apache.commons.lang.StringUtils; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.nio.charset.StandardCharsets; import java.security.SecureRandom; import java.util.Arrays; - -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.*; -import static iudx.data.marketplace.apiserver.util.Constants.*; +import org.apache.commons.lang.StringUtils; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class CreateLinkedAccount { private static final Logger LOGGER = LogManager.getLogger(CreateLinkedAccount.class); @@ -46,7 +44,7 @@ public CreateLinkedAccount( PostgresService postgresService, Api api, AuditingService auditingService, - RazorPayService razorPayService ) { + RazorPayService razorPayService) { this.postgresService = postgresService; this.api = api; this.auditingService = auditingService; @@ -55,16 +53,16 @@ public CreateLinkedAccount( /** * Initiates provider registration flow + * * @param request Information used to create linked account present in payload * @param provider User object * @return Successful or failure response of type Future JsonObject */ - public Future initiateCreatingLinkedAccount(JsonObject request, User provider) { String referenceId = createReferenceId(); String emailId = provider.getEmailId(); JsonObject merchantDetails = getLinkedAccountDetails(request, referenceId, emailId); - String providerId = provider.getUserId(); + String providerId = provider.getUserId(); setProviderId(providerId); var razorpayFlowFuture = createLinkedAccount(merchantDetails); @@ -74,7 +72,7 @@ public Future initiateCreatingLinkedAccount(JsonObject request, User isRazorpayFlowSuccessful -> { if (isRazorpayFlowSuccessful) { /* insert in DB */ - return insertInfoInDB(INSERT_MERCHANT_INFO_QUERY, referenceId); + return insertInfoInDb(INSERT_MERCHANT_INFO_QUERY, referenceId); } else { return Future.failedFuture(razorpayFlowFuture.cause().getMessage()); } @@ -82,46 +80,48 @@ public Future initiateCreatingLinkedAccount(JsonObject request, User /* send the information for auditing */ /* audit info = Ids generated by Razorpay + Necessary information (Non-sensitive PII) */ - Future auditingFuture = userResponse.compose(insertInDBSuccessful -> - addAuditLogs(referenceId,provider)); + // Future auditingFuture = + userResponse.compose(insertInDBSuccessful -> addAuditLogs(referenceId, provider)); return userResponse; } /** - * Initiates creating linked account and accepting terms and conditions - * Fetches and sets accountId, accountProductId after creating linked account and after accepting TnC respectively + * Initiates creating linked account and accepting terms and conditions Fetches and sets + * accountId, accountProductId after creating linked account and after accepting TnC respectively * * @param merchantDetails of type JsonObject to required to create linked account through Razorpay - * @return true if the flow is successful, respective failure response if any - * of type Future + * @return true if the flow is successful, respective failure response if any of type Future */ private Future createLinkedAccount(JsonObject merchantDetails) { - Future linkedAccountCreationFuture = razorPayService.createLinkedAccount(merchantDetails.toString()); - Future productConfigurationFuture = linkedAccountCreationFuture.compose(linkedAccountJson -> { - String accountId = linkedAccountJson.getString("accountId"); - setAccountId(accountId); - return razorPayService.requestProductConfiguration(linkedAccountJson); - }); + Future linkedAccountCreationFuture = + razorPayService.createLinkedAccount(merchantDetails.toString()); + Future productConfigurationFuture = + linkedAccountCreationFuture.compose( + linkedAccountJson -> { + String accountId = linkedAccountJson.getString("accountId"); + setAccountId(accountId); + return razorPayService.requestProductConfiguration(linkedAccountJson); + }); Future requestProductConfigurationFuture = - productConfigurationFuture.compose(productConfigJson -> { - String accountProductId = productConfigJson.getString("razorpayAccountProductId"); - setAccountProductId(accountProductId); - return Future.succeededFuture(true); - }); + productConfigurationFuture.compose( + productConfigJson -> { + String accountProductId = productConfigJson.getString("razorpayAccountProductId"); + setAccountProductId(accountProductId); + return Future.succeededFuture(true); + }); return requestProductConfigurationFuture; } - /** - * Creates a request body to create linked account through Razorpay based on the request - * payload
- * Options fields in the request payload are : - *
customerFacingBusinessName - *
legalInfo JSON - *
GST - *
PAN + * Creates a request body to create linked account through Razorpay based on the request payload + *
+ * Options fields in the request payload are :
+ * customerFacingBusinessName
+ * legalInfo JSON
+ * GST
+ * PAN * * @param request Request payload of type JsonObject * @param referenceId random Id generated to act as internal reference @@ -130,7 +130,6 @@ private Future createLinkedAccount(JsonObject merchantDetails) { */ public JsonObject getLinkedAccountDetails( JsonObject request, String referenceId, String emailId) { - String businessType = request.getString("businessType"); String category = request.getJsonObject("profile").getString("category"); String subcategory = request.getJsonObject("profile").getString("subcategory"); JsonObject registered = @@ -141,7 +140,6 @@ public JsonObject getLinkedAccountDetails( String state = registered.getString("state"); String postalCode = registered.getString("postalCode"); String country = registered.getString("country"); - String contactName = request.getString("contactName"); JsonObject registeredJson = new JsonObject() @@ -153,11 +151,7 @@ public JsonObject getLinkedAccountDetails( .put("country", country); JsonObject addressJson = new JsonObject().put("registered", registeredJson); - JsonObject profileJson = - new JsonObject() - .put("category", category) - .put("subcategory", subcategory) - .put("addresses", addressJson); + JsonObject legalInfoJson = new JsonObject(); /* checks if optional field legal info is null */ @@ -173,32 +167,27 @@ public JsonObject getLinkedAccountDetails( } String phoneNumber = request.getString("phone"); String legalBusinessName = request.getString("legalBusinessName"); - String customerFacingBusinessName = request.getString("customerFacingBusinessName"); + String businessType = request.getString("businessType"); + JsonObject profileJson = new JsonObject().put("category", category) + .put("subcategory", subcategory).put("addresses", addressJson); + JsonObject details = new JsonObject().put("email", emailId).put("phone", phoneNumber) + .put("legal_business_name", legalBusinessName).put("type", ACCOUNT_TYPE).put("reference_id", referenceId) + .put("business_type", businessType).put("profile", profileJson).put("legal_info", legalInfoJson); setLegalBusinessName(legalBusinessName); setEmailId(emailId); setPhoneNumber(phoneNumber); setBusinessType(businessType); - - JsonObject details = - new JsonObject() - .put("email", emailId) - .put("phone", phoneNumber) - .put("legal_business_name", legalBusinessName) - .put("type", ACCOUNT_TYPE) - .put("reference_id", referenceId) - .put("business_type", businessType) - .put("profile", profileJson) - .put("legal_info", legalInfoJson); - setCustomerFacingBusinessName(legalBusinessName); /* customer facing business name is not a necessary field in the request body - * while inserting in the DB, if customer facing business name is null, it is - * replaced with the legal business name */ + * while inserting in the DB, if customer facing business name is null, it is + * replaced with the legal business name */ + String customerFacingBusinessName = request.getString("customerFacingBusinessName"); if (StringUtils.isNotBlank(customerFacingBusinessName)) { setCustomerFacingBusinessName(customerFacingBusinessName); details.put("customer_facing_business_name", customerFacingBusinessName); } + String contactName = request.getString("contactName"); if (StringUtils.isNotBlank(contactName)) { details.put("contact_name", contactName); } @@ -206,13 +195,14 @@ public JsonObject getLinkedAccountDetails( } /** - * Inserts a record in DB with required merchant details like referenceId, phoneNumber, - * provider email id, business name, Razorpay generated account id, account status + * Inserts a record in DB with required merchant details like referenceId, phoneNumber, provider + * email id, business name, Razorpay generated account id, account status + * * @param query Insert query of type string * @param referenceId Acts as primary key to store record * @return Success or failure response of type Future Json object */ - Future insertInfoInDB(String query, String referenceId) { + Future insertInfoInDb(String query, String referenceId) { Promise promise = Promise.promise(); String finalQuery = query @@ -254,9 +244,10 @@ Future insertInfoInDB(String query, String referenceId) { } /** - * Creates a referenceId of length = 20 based on present time as seed. This referenceId could be sent to Razorpay - * while creating linked account and it can also act as an internal reference to store relevant - * merchant information in the DB + * Creates a referenceId of length = 20 based on present time as seed. This referenceId could be + * sent to Razorpay while creating linked account and it can also act as an internal reference to + * store relevant merchant information in the DB + * * @return referenceId as string which to act as primary key to store record in DB */ private String createReferenceId() { @@ -270,13 +261,12 @@ private String createReferenceId() { .substring(0, 20); return referenceId; } - public String getBusinessType() - { + + public String getBusinessType() { return this.businessType; } - public void setBusinessType(String businessType) - { + public void setBusinessType(String businessType) { this.businessType = businessType; } @@ -335,15 +325,15 @@ public String getStatus() { public void setStatus(String status) { this.status = status; } - public void setAccountProductId(String rzpAccountProductId){ - this.accountProductId = rzpAccountProductId; - } - public String getAccountProductId() - { + public String getAccountProductId() { return this.accountProductId; } + public void setAccountProductId(String rzpAccountProductId) { + this.accountProductId = rzpAccountProductId; + } + public Future addAuditLogs(String referenceId, User provider) { JsonObject auditInfo = new JsonObject() diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/FetchLinkedAccount.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/FetchLinkedAccount.java similarity index 95% rename from src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/FetchLinkedAccount.java rename to src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/FetchLinkedAccount.java index c2848b86..3797da7b 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/FetchLinkedAccount.java +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/FetchLinkedAccount.java @@ -1,4 +1,7 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; +package iudx.data.marketplace.apiserver.provider.linkedaccount; + +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.*; +import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; import io.vertx.core.Future; import io.vertx.core.Promise; @@ -14,9 +17,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.*; -import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; - public class FetchLinkedAccount { private static final Logger LOGGER = LogManager.getLogger(FetchLinkedAccount.class); PostgresService postgresService; @@ -27,9 +27,7 @@ public class FetchLinkedAccount { String createdAt; public FetchLinkedAccount( - PostgresService postgresService, - Api api, - RazorPayService razorPayService) { + PostgresService postgresService, Api api, RazorPayService razorPayService) { this.postgresService = postgresService; this.api = api; this.razorPayService = razorPayService; @@ -55,11 +53,9 @@ public Future initiateFetchingLinkedAccount(User provider) { public Future generateSuccessResponse(JsonObject rzpResponseJson) { String emailId = rzpResponseJson.getString("email"); - String accountId = rzpResponseJson.getString("id"); String type = rzpResponseJson.getString("type"); String status = rzpResponseJson.getString("status"); String referenceId = rzpResponseJson.getString("reference_id"); - String businessType = rzpResponseJson.getString("business_type"); String category = rzpResponseJson.getJsonObject("profile").getString("category"); String subcategory = rzpResponseJson.getJsonObject("profile").getString("subcategory"); JsonObject registered = @@ -104,12 +100,8 @@ public Future generateSuccessResponse(JsonObject rzpResponseJson) { } } String phoneNumber = rzpResponseJson.getString("phone"); - String legalBusinessName = rzpResponseJson.getString("legal_business_name"); - String customerFacingBusinessName = rzpResponseJson.getString("customer_facing_business_name"); - - JsonObject details = - new JsonObject() - .put("accountId", accountId) + String accountId = rzpResponseJson.getString("id"); + JsonObject details = new JsonObject().put("accountId", accountId) .put("type", type) .put("status", status) .put("email", emailId) @@ -119,9 +111,16 @@ public Future generateSuccessResponse(JsonObject rzpResponseJson) { if (StringUtils.isNotBlank(contactName)) { details.put("contactName", contactName); } + + String businessType = rzpResponseJson.getString("business_type"); + String legalBusinessName = rzpResponseJson.getString("legal_business_name"); + details.put("referenceId", referenceId); details.put("businessType", businessType); details.put("legalBusinessName", legalBusinessName); + + String customerFacingBusinessName = rzpResponseJson.getString("customer_facing_business_name"); + if (StringUtils.isNotBlank(customerFacingBusinessName)) { details.put("customerFacingBusinessName", customerFacingBusinessName); } @@ -150,13 +149,13 @@ Future getAccountId(String query, User provider) { if (handler.succeeded()) { if (!handler.result().getJsonArray(RESULTS).isEmpty()) { JsonObject result = handler.result().getJsonArray(RESULTS).getJsonObject(0); - String accountId = result.getString("account_id"); String accountProductId = result.getString("rzp_account_product_id"); String updatedAt = result.getString("updatedAt"); String createdAt = result.getString("createdAt"); setRazorpayAccountProductId(accountProductId); setUpdatedAt(updatedAt); setCreatedAt(createdAt); + String accountId = result.getString("account_id"); promise.complete(new JsonObject().put("accountId", accountId)); } else { promise.fail( @@ -187,6 +186,7 @@ public String getRazorpayAccountProductId() { public void setRazorpayAccountProductId(String razorpayAccountProductId) { this.razorpayAccountProductId = razorpayAccountProductId; } + public String getUpdatedAt() { return updatedAt; } @@ -194,14 +194,12 @@ public String getUpdatedAt() { public void setUpdatedAt(String updatedAt) { this.updatedAt = updatedAt; } - public String getCreatedAt() - { + + public String getCreatedAt() { return createdAt; } - public void setCreatedAt(String createdAt) - { + public void setCreatedAt(String createdAt) { this.createdAt = createdAt; } - } diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountService.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountService.java new file mode 100644 index 00000000..97e6cdf7 --- /dev/null +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountService.java @@ -0,0 +1,52 @@ +package iudx.data.marketplace.apiserver.provider.linkedaccount; + +import io.vertx.codegen.annotations.GenIgnore; +import io.vertx.codegen.annotations.ProxyGen; +import io.vertx.codegen.annotations.VertxGen; +import io.vertx.core.Future; +import io.vertx.core.Vertx; +import io.vertx.core.json.JsonObject; +import iudx.data.marketplace.policies.User; + +@VertxGen +@ProxyGen +public interface LinkedAccountService { + + /* factory method */ + @GenIgnore + static LinkedAccountService createProxy(Vertx vertx, String address) { + return new LinkedAccountServiceVertxEBProxy(vertx, address); + } + + /* service operation */ + + /** + * Used to create a new linked account through for Razorpay + * + * @param request Provider's business related information to create a linked account + * @param user Provider details as User object + * @return Future of JsonObject when it is successful, Future containing failure message during + * failure + */ + Future createLinkedAccount(JsonObject request, User user); + + /** + * Used to fetch a linked account created through DMP for Razorpay + * + * @param user Provider details as User object + * @return Future of JsonObject containing linked account details sent by Razorpay when it is + * successful, Future containing failure message during failure + */ + Future fetchLinkedAccount(User user); + + /** + * Used to update a linked account created through DMP for Razorpay + * + * @param request Provider's business related information to create a linked account all the + * details expect business_type, email can be updated + * @param user Provider details as User object + * @return Future of JsonObject when it is successful, Future containing failure message during + * failure + */ + Future updateLinkedAccount(JsonObject request, User user); +} diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountServiceImpl.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountServiceImpl.java similarity index 63% rename from src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountServiceImpl.java rename to src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountServiceImpl.java index 44cbff54..63572590 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountServiceImpl.java @@ -1,14 +1,12 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; +package iudx.data.marketplace.apiserver.provider.linkedaccount; import io.vertx.core.Future; import io.vertx.core.Promise; import io.vertx.core.json.JsonObject; import iudx.data.marketplace.policies.User; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; public class LinkedAccountServiceImpl implements LinkedAccountService { - private static final Logger LOG = LoggerFactory.getLogger(LinkedAccountServiceImpl.class); + // private static final Logger LOG = LoggerFactory.getLogger(LinkedAccountServiceImpl.class); private final CreateLinkedAccount createLinkedAccount; private final FetchLinkedAccount fetchLinkedAccount; @@ -45,15 +43,15 @@ public Future fetchLinkedAccount(User user) { Promise promise = Promise.promise(); this.fetchLinkedAccount - .initiateFetchingLinkedAccount(user) - .onComplete( - handler -> { - if (handler.succeeded()) { - promise.complete(handler.result()); - } else { - promise.fail(handler.cause().getMessage()); - } - }); + .initiateFetchingLinkedAccount(user) + .onComplete( + handler -> { + if (handler.succeeded()) { + promise.complete(handler.result()); + } else { + promise.fail(handler.cause().getMessage()); + } + }); return promise.future(); } @@ -62,15 +60,15 @@ public Future updateLinkedAccount(JsonObject request, User user) { Promise promise = Promise.promise(); this.updateLinkedAccount - .initiateUpdatingLinkedAccount(request, user) - .onComplete( - handler -> { - if (handler.succeeded()) { - promise.complete(handler.result()); - } else { - promise.fail(handler.cause().getMessage()); - } - }); + .initiateUpdatingLinkedAccount(request, user) + .onComplete( + handler -> { + if (handler.succeeded()) { + promise.complete(handler.result()); + } else { + promise.fail(handler.cause().getMessage()); + } + }); return promise.future(); } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountVerticle.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountVerticle.java similarity index 75% rename from src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountVerticle.java rename to src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountVerticle.java index 761ca681..fbc78bc3 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/LinkedAccountVerticle.java +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/LinkedAccountVerticle.java @@ -1,24 +1,17 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; +package iudx.data.marketplace.apiserver.provider.linkedaccount; import static iudx.data.marketplace.common.Constants.*; -import com.razorpay.RazorpayClient; import io.vertx.core.AbstractVerticle; import io.vertx.core.Promise; -import io.vertx.ext.web.client.WebClient; -import io.vertx.ext.web.client.WebClientOptions; import io.vertx.serviceproxy.ServiceBinder; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.postgres.PostgresService; import iudx.data.marketplace.razorpay.RazorPayService; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - -import java.security.SecureRandom; public class LinkedAccountVerticle extends AbstractVerticle { - private static final Logger LOGGER = LogManager.getLogger(LinkedAccountVerticle.class); + // private static final Logger LOGGER = LogManager.getLogger(LinkedAccountVerticle.class); private PostgresService postgresService; private LinkedAccountServiceImpl linkedAccountService; @@ -39,10 +32,11 @@ public void start(Promise startPromise) throws Exception { razorPayService = RazorPayService.createProxy(vertx, RAZORPAY_SERVICE_ADDRESS); createLinkedAccount = - new CreateLinkedAccount(postgresService, api, auditingService,razorPayService); + new CreateLinkedAccount(postgresService, api, auditingService, razorPayService); fetchLinkedAccount = new FetchLinkedAccount(postgresService, api, razorPayService); - updateLinkedAccount = new UpdateLinkedAccount(postgresService, api, auditingService, razorPayService); + updateLinkedAccount = + new UpdateLinkedAccount(postgresService, api, auditingService, razorPayService); linkedAccountService = new LinkedAccountServiceImpl(createLinkedAccount, fetchLinkedAccount, updateLinkedAccount); diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/UpdateLinkedAccount.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/UpdateLinkedAccount.java similarity index 64% rename from src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/UpdateLinkedAccount.java rename to src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/UpdateLinkedAccount.java index 8e225075..148962a3 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedAccount/UpdateLinkedAccount.java +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/UpdateLinkedAccount.java @@ -1,4 +1,7 @@ -package iudx.data.marketplace.apiserver.provider.linkedAccount; +package iudx.data.marketplace.apiserver.provider.linkedaccount; + +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.*; +import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; import io.vertx.core.Future; import io.vertx.core.Promise; @@ -16,9 +19,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.*; -import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; - public class UpdateLinkedAccount { private static Logger LOGGER = LogManager.getLogger(UpdateLinkedAccount.class); PostgresService postgresService; @@ -34,12 +34,16 @@ public class UpdateLinkedAccount { String providerId; public UpdateLinkedAccount( - PostgresService postgresService, Api api, AuditingService auditingService, RazorPayService razorPayService) { + PostgresService postgresService, + Api api, + AuditingService auditingService, + RazorPayService razorPayService) { this.postgresService = postgresService; this.api = api; this.auditingService = auditingService; this.razorPayService = razorPayService; } + public Future initiateUpdatingLinkedAccount(JsonObject request, User provider) { String accountRequest = getAccountRequest(request); @@ -48,61 +52,37 @@ public Future initiateUpdatingLinkedAccount(JsonObject request, User String emailId = provider.getEmailId(); setEmailId(emailId); - Future accountInfoFuture = getAccountId(GET_MERCHANT_INFO_QUERY, providerId, emailId); - Future updateAccountInfoInRzpFuture = accountInfoFuture.compose(accountInfoJson -> { - String accountId = accountInfoJson.getString("accountId"); - /* set account id */ - setRzpAccountId(accountId); - return razorPayService.updateLinkedAccount(accountRequest,accountId); - }); - Future userResponseFuture = updateAccountInfoInRzpFuture.compose(isEditInRazorpaySuccessful -> { - if(isEditInRazorpaySuccessful) - { - return updateMerchantInfo(UPDATE_MERCHANT_INFO_QUERY, providerId, emailId); - } - return Future.failedFuture(updateAccountInfoInRzpFuture.cause().getMessage()); - }); + Future accountInfoFuture = + getAccountId(GET_MERCHANT_INFO_QUERY, providerId, emailId); + Future updateAccountInfoInRzpFuture = + accountInfoFuture.compose( + accountInfoJson -> { + String accountId = accountInfoJson.getString("accountId"); + /* set account id */ + setRzpAccountId(accountId); + return razorPayService.updateLinkedAccount(accountRequest, accountId); + }); + Future userResponseFuture = + updateAccountInfoInRzpFuture.compose( + isEditInRazorpaySuccessful -> { + if (isEditInRazorpaySuccessful) { + return updateMerchantInfo(UPDATE_MERCHANT_INFO_QUERY, providerId, emailId); + } + return Future.failedFuture(updateAccountInfoInRzpFuture.cause().getMessage()); + }); /* send the information for auditing */ /* accountId, referenceId, Non-sensitive PII */ - userResponseFuture.compose(insertInDbSuccessful -> { - Future auditFuture = addAuditLogs(provider); - return auditFuture; - }); + userResponseFuture.compose( + insertInDbSuccessful -> { + Future auditFuture = addAuditLogs(provider); + return auditFuture; + }); return userResponseFuture; } - public String getAccountRequest(JsonObject requestBody) - { - String category = requestBody.getJsonObject("profile").getString("category"); - String subcategory = requestBody.getJsonObject("profile").getString("subcategory"); - JsonObject registered = - requestBody.getJsonObject("profile").getJsonObject("addresses").getJsonObject("registered"); - String street1 = registered.getString("street1"); - String street2 = registered.getString("street2"); - String city = registered.getString("city"); - String state = registered.getString("state"); - String postalCode = registered.getString("postalCode"); - String country = registered.getString("country"); - String contactName = requestBody.getString("contactName"); - - JsonObject registeredJson = - new JsonObject() - .put("street1", street1) - .put("street2", street2) - .put("city", city) - .put("state", state) - .put("postal_code", postalCode) - .put("country", country); - - JsonObject addressJson = new JsonObject().put("registered", registeredJson); - JsonObject profileJson = - new JsonObject() - .put("category", category) - .put("subcategory", subcategory) - .put("addresses", addressJson); - + public String getAccountRequest(JsonObject requestBody) { JsonObject legalInfoJson = new JsonObject(); /* checks if optional field legal info is null */ if (requestBody.getJsonObject("legalInfo") != null) { @@ -117,17 +97,36 @@ public String getAccountRequest(JsonObject requestBody) } String phoneNumber = requestBody.getString("phone"); String legalBusinessName = requestBody.getString("legalBusinessName"); - String customerFacingBusinessName = requestBody.getString("customerFacingBusinessName"); setLegalBusinessName(legalBusinessName); setPhoneNumber(phoneNumber); + String category = requestBody.getJsonObject("profile").getString("category"); + String subcategory = requestBody.getJsonObject("profile").getString("subcategory"); + JsonObject registered = + requestBody.getJsonObject("profile").getJsonObject("addresses").getJsonObject("registered"); + String street1 = registered.getString("street1"); + String street2 = registered.getString("street2"); + String city = registered.getString("city"); + String state = registered.getString("state"); + String postalCode = registered.getString("postalCode"); + String country = registered.getString("country"); + JsonObject registeredJson = new JsonObject().put("street1", street1).put("street2", street2).put("city", city) + .put("state", state).put("postal_code", postalCode).put("country", country); + JsonObject addressJson = new JsonObject().put("registered", registeredJson); + + JsonObject profileJson = + new JsonObject() + .put("category", category) + .put("subcategory", subcategory) + .put("addresses", addressJson); JsonObject details = - new JsonObject() - .put("phone", phoneNumber) - .put("legal_business_name", legalBusinessName) - .put("profile", profileJson) - .put("legal_info", legalInfoJson); + new JsonObject() + .put("phone", phoneNumber) + .put("legal_business_name", legalBusinessName) + .put("profile", profileJson) + .put("legal_info", legalInfoJson); + String customerFacingBusinessName = requestBody.getString("customerFacingBusinessName"); setCustomerFacingBusinessName(legalBusinessName); /* customer facing business name is not a necessary field in the request body @@ -137,50 +136,52 @@ public String getAccountRequest(JsonObject requestBody) setCustomerFacingBusinessName(customerFacingBusinessName); details.put("customer_facing_business_name", customerFacingBusinessName); } + String contactName = requestBody.getString("contactName"); + if (StringUtils.isNotBlank(contactName)) { details.put("contact_name", contactName); } return details.encode(); } - public Future getAccountId(String query, String providerId, String emailId) - { + public Future getAccountId(String query, String providerId, String emailId) { Promise promise = Promise.promise(); String finalQuery = query.replace("$1", providerId).replace("$2", emailId); - postgresService.executeQuery(finalQuery, handler -> { - if(handler.succeeded()) - { - boolean isResultEmpty = handler.result().getJsonArray(RESULTS).isEmpty(); - if(!isResultEmpty) - { - JsonObject result = handler.result().getJsonArray(RESULTS).getJsonObject(0); - String accountId = result.getString("account_id"); - - /* set referenceId */ - setReferenceId(result.getString("reference_id")); - - promise.complete(new JsonObject().put("accountId", accountId).put("referenceId", referenceId)); - } - else - { - LOGGER.fatal("Linked account is not created or there was a problem while inserting the record in postgres"); - promise.fail( + postgresService.executeQuery( + finalQuery, + handler -> { + if (handler.succeeded()) { + boolean isResultEmpty = handler.result().getJsonArray(RESULTS).isEmpty(); + if (!isResultEmpty) { + JsonObject result = handler.result().getJsonArray(RESULTS).getJsonObject(0); + String accountId = result.getString("account_id"); + + /* set referenceId */ + setReferenceId(result.getString("reference_id")); + + promise.complete( + new JsonObject().put("accountId", accountId).put("referenceId", referenceId)); + } else { + LOGGER.fatal( + "Linked account is not created or there was a problem while inserting the record in postgres"); + promise.fail( new RespBuilder() - .withType(HttpStatusCode.NOT_FOUND.getValue()) - .withTitle(ResponseUrn.RESOURCE_NOT_FOUND_URN.getUrn()) - .withDetail("Linked account cannot be updated as, it is not found") - .getResponse()); - } - } - else { - LOGGER.error("Failed to fetch account id from postgres : {}", handler.cause().getMessage()); - promise.fail(new RespBuilder() - .withType(HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) - .withTitle(ResponseUrn.INTERNAL_SERVER_ERR_URN.getUrn()) - .withDetail("Linked account could not be updated : Internal Server error") - .getResponse()); - } - }); + .withType(HttpStatusCode.NOT_FOUND.getValue()) + .withTitle(ResponseUrn.RESOURCE_NOT_FOUND_URN.getUrn()) + .withDetail("Linked account cannot be updated as, it is not found") + .getResponse()); + } + } else { + LOGGER.error( + "Failed to fetch account id from postgres : {}", handler.cause().getMessage()); + promise.fail( + new RespBuilder() + .withType(HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) + .withTitle(ResponseUrn.INTERNAL_SERVER_ERR_URN.getUrn()) + .withDetail("Linked account could not be updated : Internal Server error") + .getResponse()); + } + }); return promise.future(); } @@ -276,47 +277,41 @@ public void setCustomerFacingBusinessName(String customerFacingBusinessName) { this.customerFacingBusinessName = customerFacingBusinessName; } - public String getEmailId() - { + public String getEmailId() { return this.emailId; } - public void setEmailId(String emailId) - { + public void setEmailId(String emailId) { this.emailId = emailId; } - public String getRzpAccountId() - { + public String getRzpAccountId() { return this.rzpAccountId; } - public void setRzpAccountId(String rzpAccountId) - { + public void setRzpAccountId(String rzpAccountId) { this.rzpAccountId = rzpAccountId; } - public String getProviderId() - { + public String getProviderId() { return this.providerId; } - public void setProviderId(String providerId) - { + public void setProviderId(String providerId) { this.providerId = providerId; } public Future addAuditLogs(User provider) { JsonObject auditInfo = - new JsonObject() - .put("referenceId", getReferenceId()) - .put("email", getEmailId()) - .put("phoneNumber", getPhoneNumber()) - .put("legalBusinessName", getLegalBusinessName()) - .put("customerFacingBusinessName", getCustomerFacingBusinessName()) - .put("accountId", getRzpAccountId()) - .put("providerId", getProviderId()); + new JsonObject() + .put("referenceId", getReferenceId()) + .put("email", getEmailId()) + .put("phoneNumber", getPhoneNumber()) + .put("legalBusinessName", getLegalBusinessName()) + .put("customerFacingBusinessName", getCustomerFacingBusinessName()) + .put("accountId", getRzpAccountId()) + .put("providerId", getProviderId()); return auditingService.handleAuditLogs( - provider, auditInfo, api.getLinkedAccountService(), HttpMethod.PUT.toString()); + provider, auditInfo, api.getLinkedAccountService(), HttpMethod.PUT.toString()); } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/package-info.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/package-info.java new file mode 100644 index 00000000..71e3ac44 --- /dev/null +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/package-info.java @@ -0,0 +1,7 @@ +@ModuleGen( + groupPackage = "iudx.data.marketplace.apiserver.provider", + name = "iudx-data-marketplace-apiserver-provider", + useFutures = true) +package iudx.data.marketplace.apiserver.provider.linkedaccount; + +import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/util/Constants.java b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/util/Constants.java new file mode 100644 index 00000000..c4985598 --- /dev/null +++ b/src/main/java/iudx/data/marketplace/apiserver/provider/linkedaccount/util/Constants.java @@ -0,0 +1,31 @@ +package iudx.data.marketplace.apiserver.provider.linkedaccount.util; + +public class Constants { + public static final String INSERT_MERCHANT_INFO_QUERY = + "INSERT INTO merchant_table(" + + " reference_id, phone_number, email, legal_business_name, customer_facing_business_name, account_id," + + " provider_id, status, rzp_account_product_id) " + + " VALUES ('$1', '$2', '$3', '$4', '$5','$6', '$7', '$8', '$9');"; + + public static final String FETCH_MERCHANT_INFO_QUERY = + "SELECT account_id, rzp_account_product_id, status FROM merchant_table WHERE provider_id = '$1'"; + + public static String UPDATE_LINKED_ACCOUNT_STATUS_QUERY = + "UPDATE merchant_table SET status = 'ACTIVATED' WHERE provider_id = '$1' RETURNING reference_id"; + + public static final String ACCOUNT_TYPE = "route"; + public static final String FAILURE_MESSAGE = "User registration incomplete : "; + public static final String GET_ACCOUNT_ID_QUERY = + "SELECT DISTINCT M.account_id, M.rzp_account_product_id,\n" + + "M.modified_at AS \"updatedAt\" , M.created_at AS \"createdAt\" \n" + + "FROM merchant_table M\n" + + "WHERE M.provider_id = '$1'\n"; + public static final String GET_MERCHANT_INFO_QUERY = + "SELECT account_id, reference_id FROM merchant_table WHERE provider_id = '$1'" + + " AND email = '$2'"; + + public static final String UPDATE_MERCHANT_INFO_QUERY = + "UPDATE merchant_table SET " + + " phone_number = '$1', legal_business_name = '$2', customer_facing_business_name = '$3' " + + " WHERE provider_id = '$4' AND email = '$5' RETURNING account_id; "; +} diff --git a/src/main/java/iudx/data/marketplace/apiserver/response/ResponseUtil.java b/src/main/java/iudx/data/marketplace/apiserver/response/ResponseUtil.java index d8480c0e..16eb2cd3 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/response/ResponseUtil.java +++ b/src/main/java/iudx/data/marketplace/apiserver/response/ResponseUtil.java @@ -5,19 +5,19 @@ import iudx.data.marketplace.common.ResponseUrn; public class ResponseUtil { - public static JsonObject generateResponse(HttpStatusCode statusCode, ResponseUrn urn) { - return generateResponse(statusCode, urn, statusCode.getDescription()); - } + public static JsonObject generateResponse(HttpStatusCode statusCode, ResponseUrn urn) { + return generateResponse(statusCode, urn, statusCode.getDescription()); + } - public static JsonObject generateResponse( - HttpStatusCode statusCode, ResponseUrn urn, String message) { - String type = urn.getUrn(); + public static JsonObject generateResponse( + HttpStatusCode statusCode, ResponseUrn urn, String message) { + String type = urn.getUrn(); - return new RestResponse.Builder() - .withMessage(message) - .withType(type) - .withTitle(statusCode.getDescription()) - .build() - .toJson(); - } + return new RestResponse.Builder() + .withMessage(message) + .withType(type) + .withTitle(statusCode.getDescription()) + .build() + .toJson(); + } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/response/RestResponse.java b/src/main/java/iudx/data/marketplace/apiserver/response/RestResponse.java index 9b5c623c..ba35b36b 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/response/RestResponse.java +++ b/src/main/java/iudx/data/marketplace/apiserver/response/RestResponse.java @@ -3,78 +3,78 @@ import io.vertx.core.json.JsonObject; public class RestResponse { - private final String type; - private final String title; - private final String detail; - private int status; + private final String type; + private final String title; + private final String detail; + private int status; - private RestResponse(String type, String title, String detail) { - super(); - this.type = type; - this.title = title; - this.detail = detail; - } + private RestResponse(String type, String title, String detail) { + super(); + this.type = type; + this.title = title; + this.detail = detail; + } - private RestResponse(String type, String title, String detail, int status) { - super(); - this.type = type; - this.title = title; - this.detail = detail; - this.status = status; - } + private RestResponse(String type, String title, String detail, int status) { + super(); + this.type = type; + this.title = title; + this.detail = detail; + this.status = status; + } - public JsonObject toJson() { - if (status != 0) { - return new JsonObject() - .put("statusCode", status) - .put("type", this.type) - .put("title", this.title) - .put("detail", this.detail); - } - return new JsonObject() - .put("type", this.type) - .put("title", this.title) - .put("detail", this.detail); + public JsonObject toJson() { + if (status != 0) { + return new JsonObject() + .put("statusCode", status) + .put("type", this.type) + .put("title", this.title) + .put("detail", this.detail); } + return new JsonObject() + .put("type", this.type) + .put("title", this.title) + .put("detail", this.detail); + } - public static class Builder { - private String type; - private String title; - private String detail; - private int status; + public static class Builder { + private String type; + private String title; + private String detail; + private int status; - public Builder() {} + public Builder() {} - public Builder withType(String type) { - this.type = type; - return this; - } + public Builder withType(String type) { + this.type = type; + return this; + } - public Builder withTitle(String title) { - this.title = title; - return this; - } + public Builder withTitle(String title) { + this.title = title; + return this; + } - public Builder withMessage(String message) { - this.detail = message; - return this; - } + public Builder withMessage(String message) { + this.detail = message; + return this; + } - public Builder withStatusCode(int statusCode) { - this.status = statusCode; - return this; - } + public Builder withStatusCode(int statusCode) { + this.status = statusCode; + return this; + } - public RestResponse build() { - return new RestResponse(this.type, this.title, this.detail, this.status); - } + public RestResponse build() { + return new RestResponse(this.type, this.title, this.detail, this.status); + } - public RestResponse build(int statusCode, String type, String title, String detail) { - this.type = type; - this.title = title; - this.detail = detail; - this.status = statusCode; - return new RestResponse(this.type, this.title, this.detail, this.status); - } + public RestResponse build(int statusCode, String type, String title, String detail) { + this.type = type; + this.title = title; + this.detail = detail; + this.status = statusCode; + return new RestResponse(this.type, this.title, this.detail, this.status); } + } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/util/Constants.java b/src/main/java/iudx/data/marketplace/apiserver/util/Constants.java index 4a97fe5b..05db868d 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/apiserver/util/Constants.java @@ -93,7 +93,8 @@ public class Constants { public static final String STRING_URN = "urn"; public static final String DOMAIN = "datakaveri.org"; public static final int VALIDATION_PRODUCT_ID_MAXLEN = 150; - public static final Pattern VALIDATION_PRODUCT_ID_REGEX = Pattern.compile("^[a-zA-Z0-9-]{3,150}$"); + public static final Pattern VALIDATION_PRODUCT_ID_REGEX = + Pattern.compile("^[a-zA-Z0-9-]{3,150}$"); public static final int VALIDATION_VARIANT_NAME_MAX_LEN = 100; public static final Pattern VALIDATION_VARIANT_NAME_REGEX = Pattern.compile("^[a-zA-Z0-9-]{3,100}$"); @@ -103,8 +104,7 @@ public class Constants { public static final Pattern POLICY_ID_PATTERN = Pattern.compile( "[a-fA-F0-9]{8}-[a-fA-F0-9]{4}-4[a-fA-F0-9]{3}-[89abAB][a-fA-F0-9]{3}-[a-fA-F0-9]{12}"); - public static final Pattern ORDER_ID_PATTERN = - Pattern.compile("order_[a-zA-Z0-9]+"); + public static final Pattern ORDER_ID_PATTERN = Pattern.compile("order_[a-zA-Z0-9]+"); // response keys public static final String TYPE = "type"; public static final String TITLE = "title"; diff --git a/src/main/java/iudx/data/marketplace/apiserver/util/RequestType.java b/src/main/java/iudx/data/marketplace/apiserver/util/RequestType.java index a4ab09de..e2b9d2ce 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/util/RequestType.java +++ b/src/main/java/iudx/data/marketplace/apiserver/util/RequestType.java @@ -25,11 +25,11 @@ public enum RequestType { private String filename; - public String getFilename() { - return this.filename; + RequestType(String filename) { + this.filename = filename; } - private RequestType(String filename) { - this.filename = filename; + public String getFilename() { + return this.filename; } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/util/Role.java b/src/main/java/iudx/data/marketplace/apiserver/util/Role.java index 845ee998..e7ffd201 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/util/Role.java +++ b/src/main/java/iudx/data/marketplace/apiserver/util/Role.java @@ -1,29 +1,29 @@ package iudx.data.marketplace.apiserver.util; -import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; +import static iudx.data.marketplace.common.ResponseUrn.ROLE_NOT_FOUND; +import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; import java.util.stream.Stream; -import static iudx.data.marketplace.common.ResponseUrn.ROLE_NOT_FOUND; - public enum Role { - PROVIDER("provider"), - CONSUMER_DELEGATE("consumerDelegate"), - PROVIDER_DELEGATE("providerDelegate"), - CONSUMER("consumer"); - private final String role; + PROVIDER("provider"), + CONSUMER_DELEGATE("consumerDelegate"), + PROVIDER_DELEGATE("providerDelegate"), + CONSUMER("consumer"); + private final String role; + + Role(String value) { + role = value; + } - Role(String value) { - role = value; - } - public String getRole() { - return role; - } + public static Role fromString(String roleValue) { + return Stream.of(values()) + .filter(element -> element.getRole().equalsIgnoreCase(roleValue)) + .findAny() + .orElseThrow(() -> new DxRuntimeException(404, ROLE_NOT_FOUND)); + } - public static Role fromString(String roleValue) { - return Stream.of(values()) - .filter(element -> element.getRole().equalsIgnoreCase(roleValue)) - .findAny() - .orElseThrow(() -> new DxRuntimeException(404, ROLE_NOT_FOUND)); - } + public String getRole() { + return role; + } } diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/ValidationHandlerFactory.java b/src/main/java/iudx/data/marketplace/apiserver/validation/ValidationHandlerFactory.java index 0ab343de..c8ba7980 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/ValidationHandlerFactory.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/ValidationHandlerFactory.java @@ -1,22 +1,21 @@ package iudx.data.marketplace.apiserver.validation; +import static iudx.data.marketplace.apiserver.util.Constants.*; + import io.vertx.core.MultiMap; import io.vertx.core.json.JsonObject; import iudx.data.marketplace.apiserver.util.RequestType; import iudx.data.marketplace.apiserver.validation.types.*; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.util.ArrayList; import java.util.List; - -import static iudx.data.marketplace.apiserver.util.Constants.*; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class ValidationHandlerFactory { private static final Logger LOGGER = LogManager.getLogger(ValidationHandlerFactory.class); public List build( - final RequestType requestType, final MultiMap parameters, final JsonObject body) { + final RequestType requestType, final MultiMap parameters, final JsonObject body) { LOGGER.debug("getValidation4Context() started for : " + requestType); LOGGER.debug("type : " + requestType); List validator = null; @@ -29,22 +28,22 @@ public List build( validator = getProductVariantValidators(parameters, body, requestType); break; case DELETE_PRODUCT_VARIANT: - validator = getDeleteProductVariantValidators(parameters, requestType); + validator = getDeleteProductVariantValidators(parameters); break; case LIST_PRODUCT_VARIANT: validator = listProductVariantValidators(parameters); break; case RESOURCE: - validator = getResourceIDValidators(parameters); + validator = getResourceIdValidators(parameters); break; case PROVIDER: - validator = getProviderIDValidators(parameters); + validator = getProviderIdValidators(parameters); break; case POLICY: validator = getPolicyValidators(body); break; case VERIFY: - validator = getVerifyPolicyValidator(parameters, body); + validator = getVerifyPolicyValidator(body); break; case ORDER: validator = getOrderValidator(parameters); @@ -70,6 +69,8 @@ public List build( case CHECK_POLICY: validator = getCheckPolicyValidator(parameters); break; + default: + break; } return validator; } @@ -79,6 +80,7 @@ private List getCheckPolicyValidator(MultiMap parameters) { validators.add(new UuidTypeValidator(parameters.get(PRODUCT_VARIANT_ID), true)); return validators; } + private List getPaymentWebhookValidator(JsonObject body) { List validators = new ArrayList<>(); validators.add(new JsonSchemaTypeValidator(body, RequestType.ORDER_PAID_WEBHOOK)); @@ -91,10 +93,11 @@ private List getConsumerProductVariantValidator(MultiMap parameters) validators.add(new ProductIdTypeValidator(parameters.get("productId"), true)); return validators; } + private List getPurchaseValidator(MultiMap parameters) { List validators = new ArrayList<>(); - validators.add(new UuidTypeValidator(parameters.get("resourceId"),false)); + validators.add(new UuidTypeValidator(parameters.get("resourceId"), false)); validators.add(new ProductIdTypeValidator(parameters.get("productId"), false)); validators.add(new OrderIdTypeValidator(parameters.get("orderId"), false)); return validators; @@ -112,19 +115,19 @@ private List getPostLinkedAccountValidator(JsonObject body, RequestTy return validators; } - private List getPutLinkedAccountValidator(JsonObject body, RequestType requestType) - { + private List getPutLinkedAccountValidator(JsonObject body, RequestType requestType) { List validators = new ArrayList<>(); validators.add(new JsonSchemaTypeValidator(body, requestType)); return validators; } + private List getOrderValidator(MultiMap parameters) { List validators = new ArrayList<>(); validators.add(new UuidTypeValidator(parameters.get(PRODUCT_VARIANT_ID), true)); return validators; } - private List getVerifyPolicyValidator(MultiMap parameters, JsonObject body) { + private List getVerifyPolicyValidator(JsonObject body) { List validators = new ArrayList<>(); validators.add(new JsonSchemaTypeValidator(body, RequestType.VERIFY)); return validators; @@ -136,7 +139,7 @@ private List getPolicyValidators(final JsonObject body) { return validators; } - private List getResourceIDValidators(final MultiMap parameters) { + private List getResourceIdValidators(final MultiMap parameters) { List validators = new ArrayList<>(); validators.add(new UuidTypeValidator(parameters.get("resourceId"), false)); @@ -144,7 +147,7 @@ private List getResourceIDValidators(final MultiMap parameters) { return validators; } - private List getProviderIDValidators(final MultiMap parameters) { + private List getProviderIdValidators(final MultiMap parameters) { List validators = new ArrayList<>(); validators.add(new UuidTypeValidator(parameters.get(PROVIDER_ID), false)); @@ -152,7 +155,7 @@ private List getProviderIDValidators(final MultiMap parameters) { } private List getProductValidators( - final MultiMap parameters, final JsonObject body, final RequestType requestType) { + final MultiMap parameters, final JsonObject body, final RequestType requestType) { List validators = new ArrayList<>(); if (body == null || body.isEmpty()) { @@ -165,7 +168,7 @@ private List getProductValidators( } private List getProductVariantValidators( - final MultiMap parameters, final JsonObject body, final RequestType requestType) { + final MultiMap parameters, final JsonObject body, final RequestType requestType) { List validators = new ArrayList<>(); if (body == null || body.isEmpty()) { @@ -177,17 +180,15 @@ private List getProductVariantValidators( return validators; } - private List getDeleteProductVariantValidators(final MultiMap parameters, final RequestType requestType) - { + private List getDeleteProductVariantValidators(final MultiMap parameters) { List validators = new ArrayList<>(); validators.add(new UuidTypeValidator(parameters.get(PRODUCT_VARIANT_ID), true)); return validators; } - private List listProductVariantValidators(final MultiMap parameters) - { + private List listProductVariantValidators(final MultiMap parameters) { List validators = new ArrayList<>(); validators.add(new ProductIdTypeValidator(parameters.get(PRODUCT_ID), true)); return validators; } -} \ No newline at end of file +} diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/types/JsonSchemaTypeValidator.java b/src/main/java/iudx/data/marketplace/apiserver/validation/types/JsonSchemaTypeValidator.java index b02c5dd0..8df55903 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/types/JsonSchemaTypeValidator.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/types/JsonSchemaTypeValidator.java @@ -1,9 +1,11 @@ package iudx.data.marketplace.apiserver.validation.types; +import static iudx.data.marketplace.common.ResponseUrn.INVALID_PAYLOAD_FORMAT_URN; +import static iudx.data.marketplace.common.ResponseUrn.SCHEMA_READ_ERROR_URN; + import com.fasterxml.jackson.databind.JsonNode; import com.github.fge.jackson.JsonLoader; import com.github.fge.jsonschema.core.exceptions.ProcessingException; -import com.github.fge.jsonschema.core.report.ProcessingMessage; import com.github.fge.jsonschema.core.report.ProcessingReport; import com.github.fge.jsonschema.main.JsonSchema; import com.github.fge.jsonschema.main.JsonSchemaFactory; @@ -11,23 +13,16 @@ import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; import iudx.data.marketplace.apiserver.util.RequestType; import iudx.data.marketplace.common.HttpStatusCode; +import java.io.IOException; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import java.io.IOException; -import java.io.PrintWriter; -import java.io.StringWriter; - -import static iudx.data.marketplace.common.ResponseUrn.INVALID_PAYLOAD_FORMAT_URN; -import static iudx.data.marketplace.common.ResponseUrn.SCHEMA_READ_ERROR_URN; - public class JsonSchemaTypeValidator implements Validator { private static final Logger LOGGER = LogManager.getLogger(JsonSchemaTypeValidator.class); - + private static String pkg = Validator.class.getPackageName(); + private static final String PACKAGE_NAME = "/" + pkg.replace(".", "/"); private final JsonObject body; private final RequestType requestType; - private static String pkg = Validator.class.getPackageName(); - private static final String PACKAGE_NAME = "/" + pkg.replace(".","/"); public JsonSchemaTypeValidator(JsonObject body, RequestType requestType) { this.body = body; @@ -35,33 +30,44 @@ public JsonSchemaTypeValidator(JsonObject body, RequestType requestType) { isValid(); } + public static JsonNode loadResource(final String name) throws IOException { + return JsonLoader.fromResource(name); + } + + public static JsonNode loadString(final String obj) throws IOException { + return JsonLoader.fromString(obj); + } + @Override public boolean isValid() { boolean isValid; try { isValid = validateJson(body, requestType); } catch (IOException | ProcessingException e) { - throw new DxRuntimeException(failureCode(), SCHEMA_READ_ERROR_URN, failureMessage(body.encode())); + throw new DxRuntimeException( + failureCode(), SCHEMA_READ_ERROR_URN, failureMessage(body.encode())); } - if(!isValid) { - throw new DxRuntimeException(failureCode(), INVALID_PAYLOAD_FORMAT_URN, INVALID_PAYLOAD_FORMAT_URN.getMessage()); + if (!isValid) { + throw new DxRuntimeException( + failureCode(), INVALID_PAYLOAD_FORMAT_URN, INVALID_PAYLOAD_FORMAT_URN.getMessage()); } else { return true; } } - private boolean validateJson(JsonObject body, RequestType requestType) throws IOException, ProcessingException, DxRuntimeException { + private boolean validateJson(JsonObject body, RequestType requestType) + throws IOException, ProcessingException, DxRuntimeException { LOGGER.debug(body); boolean isValid; String schemaPath = PACKAGE_NAME + "/".concat(requestType.getFilename()).concat("_schema.json"); LOGGER.debug(schemaPath); final JsonSchema schema; - try { - final JsonNode sc = loadResource(schemaPath); - } catch (Exception e) { - LOGGER.error("Validation Error {}", e.getMessage()); - } + // try { + // final JsonNode sc = loadResource(schemaPath); + // } catch (Exception e) { + // LOGGER.error("Validation Error {}", e.getMessage()); + // } final JsonNode schemaNode = loadResource(schemaPath); LOGGER.debug(schemaNode.asText()); final JsonSchemaFactory factory = JsonSchemaFactory.byDefault(); @@ -70,12 +76,14 @@ private boolean validateJson(JsonObject body, RequestType requestType) throws IO try { JsonNode jsonobj = loadString(body.toString()); ProcessingReport report = schema.validate(jsonobj); - report.forEach( x -> { - if(x.getLogLevel().toString().equalsIgnoreCase("error")) { - LOGGER.error(x.getMessage()); - throw new DxRuntimeException(failureCode(), INVALID_PAYLOAD_FORMAT_URN, x.getMessage()); - } - }); + report.forEach( + x -> { + if (x.getLogLevel().toString().equalsIgnoreCase("error")) { + LOGGER.error(x.getMessage()); + throw new DxRuntimeException( + failureCode(), INVALID_PAYLOAD_FORMAT_URN, x.getMessage()); + } + }); isValid = report.isSuccess(); } catch (IOException | ProcessingException e) { isValid = false; @@ -83,13 +91,6 @@ private boolean validateJson(JsonObject body, RequestType requestType) throws IO return isValid; } - public static JsonNode loadResource(final String name) throws IOException { - return JsonLoader.fromResource(name); - } - - public static JsonNode loadString(final String obj) throws IOException { - return JsonLoader.fromString(obj); - } @Override public int failureCode() { return HttpStatusCode.BAD_REQUEST.getValue(); diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/types/OrderIdTypeValidator.java b/src/main/java/iudx/data/marketplace/apiserver/validation/types/OrderIdTypeValidator.java index fa641eed..7ea5e9a1 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/types/OrderIdTypeValidator.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/types/OrderIdTypeValidator.java @@ -5,7 +5,6 @@ import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; import iudx.data.marketplace.common.HttpStatusCode; -import org.apache.commons.lang.StringUtils; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -21,7 +20,7 @@ public OrderIdTypeValidator(final String value, final boolean required) { this.required = required; } - public boolean isValidID(final String value) { + public boolean isValidId(final String value) { return ORDER_ID_PATTERN.matcher(value).matches(); } @@ -44,7 +43,7 @@ public boolean isValid() { LOGGER.error("Validation error : Value exceed min character limit."); throw new DxRuntimeException(failureCode(), INVALID_ID_VALUE_URN, failureMessage(value)); } - if (!isValidID(value)) { + if (!isValidId(value)) { LOGGER.error("Validation error : Invalid Order ID"); throw new DxRuntimeException(failureCode(), INVALID_ID_VALUE_URN, failureMessage(value)); } diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/types/ProductIdTypeValidator.java b/src/main/java/iudx/data/marketplace/apiserver/validation/types/ProductIdTypeValidator.java index f17cbce5..6266243c 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/types/ProductIdTypeValidator.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/types/ProductIdTypeValidator.java @@ -21,7 +21,7 @@ public ProductIdTypeValidator(final String value, final boolean required) { this.required = required; } - public boolean isValidID(final String value) { + public boolean isValidId(final String value) { String[] variable = value.split(":"); try { boolean isValidUrn = StringUtils.isNotBlank(variable[0]) && variable[0].equals(STRING_URN); @@ -57,7 +57,7 @@ public boolean isValid() { LOGGER.error("Validation error : Value exceed max character limit."); throw new DxRuntimeException(failureCode(), INVALID_ID_VALUE_URN, failureMessage(value)); } - if (!isValidID(value)) { + if (!isValidId(value)) { LOGGER.error("Validation error : Invalid Name"); throw new DxRuntimeException(failureCode(), INVALID_ID_VALUE_URN, failureMessage(value)); } diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/types/UuidTypeValidator.java b/src/main/java/iudx/data/marketplace/apiserver/validation/types/UuidTypeValidator.java index 9002a391..c4bc493e 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/types/UuidTypeValidator.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/types/UuidTypeValidator.java @@ -20,7 +20,7 @@ public UuidTypeValidator(final String value, final boolean required) { this.required = required; } - public boolean isValidID(final String value) { + public boolean isValidId(final String value) { return VALIDATION_IUDX_ID_REGEX.matcher(value).matches(); } @@ -43,7 +43,7 @@ public boolean isValid() { LOGGER.error("Validation error : Value mismatch character limit."); throw new DxRuntimeException(failureCode(), INVALID_ID_URN, failureMessage(value)); } - if (!isValidID(value)) { + if (!isValidId(value)) { LOGGER.error("Validation error : Invalid ID"); throw new DxRuntimeException(failureCode(), INVALID_ID_URN, failureMessage(value)); } diff --git a/src/main/java/iudx/data/marketplace/apiserver/validation/types/VariantNameTypeValidator.java b/src/main/java/iudx/data/marketplace/apiserver/validation/types/VariantNameTypeValidator.java index c3d52a45..ed6ef3cd 100644 --- a/src/main/java/iudx/data/marketplace/apiserver/validation/types/VariantNameTypeValidator.java +++ b/src/main/java/iudx/data/marketplace/apiserver/validation/types/VariantNameTypeValidator.java @@ -1,15 +1,15 @@ package iudx.data.marketplace.apiserver.validation.types; +import static iudx.data.marketplace.apiserver.util.Constants.VALIDATION_VARIANT_NAME_MAX_LEN; +import static iudx.data.marketplace.apiserver.util.Constants.VALIDATION_VARIANT_NAME_REGEX; +import static iudx.data.marketplace.common.ResponseUrn.INVALID_NAME_URN; + import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; import iudx.data.marketplace.common.HttpStatusCode; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.apiserver.util.Constants.VALIDATION_VARIANT_NAME_MAX_LEN; -import static iudx.data.marketplace.apiserver.util.Constants.VALIDATION_VARIANT_NAME_REGEX; -import static iudx.data.marketplace.common.ResponseUrn.INVALID_NAME_URN; - -public class VariantNameTypeValidator implements Validator{ +public class VariantNameTypeValidator implements Validator { private static final Logger LOGGER = LogManager.getLogger(VariantNameTypeValidator.class); diff --git a/src/main/java/iudx/data/marketplace/auditing/AuditingService.java b/src/main/java/iudx/data/marketplace/auditing/AuditingService.java index 52a2b86b..cf06a0f5 100644 --- a/src/main/java/iudx/data/marketplace/auditing/AuditingService.java +++ b/src/main/java/iudx/data/marketplace/auditing/AuditingService.java @@ -16,15 +16,16 @@ static AuditingService createProxy(Vertx vertx, String address) { return new AuditingServiceVertxEBProxy(vertx, address); } - /*** - * This methods creates is used to create audit logs to be stored in respective databases + /** This methods creates is used to create audit logs to be stored in respective databases * by sending the messages through the data broker + * * @param user The user Object that is created during user authentication * @param information would contain the request body, response and essential additional information * @param api Endpoint that is called by the user * @param httpMethod Http Method of the endpoint * @return Future of type void */ - Future handleAuditLogs (User user, JsonObject information, String api, String httpMethod); + Future handleAuditLogs(User user, JsonObject information, String api, String httpMethod); + Future insertAuditLogIntoRmq(JsonObject request); } diff --git a/src/main/java/iudx/data/marketplace/auditing/AuditingServiceImpl.java b/src/main/java/iudx/data/marketplace/auditing/AuditingServiceImpl.java index 6255af03..0947ae39 100644 --- a/src/main/java/iudx/data/marketplace/auditing/AuditingServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/auditing/AuditingServiceImpl.java @@ -1,21 +1,20 @@ package iudx.data.marketplace.auditing; +import static iudx.data.marketplace.auditing.util.Constants.*; +import static iudx.data.marketplace.auditing.util.Constants.ISO_TIME; +import static iudx.data.marketplace.product.util.Constants.TABLES; + import io.vertx.core.Future; import io.vertx.core.Promise; import io.vertx.core.json.JsonObject; import iudx.data.marketplace.auditing.databroker.DataBrokerService; import iudx.data.marketplace.policies.User; import iudx.data.marketplace.product.util.QueryBuilder; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.time.ZoneId; import java.time.ZonedDateTime; import java.time.temporal.ChronoUnit; - -import static iudx.data.marketplace.auditing.util.Constants.*; -import static iudx.data.marketplace.auditing.util.Constants.ISO_TIME; -import static iudx.data.marketplace.product.util.Constants.TABLES; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class AuditingServiceImpl implements AuditingService { private static final Logger LOGGER = LogManager.getLogger(AuditingServiceImpl.class); @@ -28,7 +27,8 @@ public AuditingServiceImpl(DataBrokerService dataBrokerService, JsonObject confi } @Override - public Future handleAuditLogs(User user, JsonObject information, String api, String httpMethod) { + public Future handleAuditLogs( + User user, JsonObject information, String api, String httpMethod) { LOGGER.debug("handleAuditLogs started"); String userId = user.getUserId(); ZonedDateTime zst = ZonedDateTime.now(ZoneId.of("Asia/Kolkata")); @@ -45,18 +45,17 @@ public Future handleAuditLogs(User user, JsonObject information, String ap Promise promise = Promise.promise(); LOGGER.debug("AuditLog: " + auditLog); - this - .insertAuditLogIntoRmq(auditLog) - .onComplete( - handler -> { - if (handler.succeeded()) { - LOGGER.info("Audit data published into RMQ."); - promise.complete(); - } else { - LOGGER.error("failed: " + handler.cause().getMessage()); - promise.complete(); - } - }); + this.insertAuditLogIntoRmq(auditLog) + .onComplete( + handler -> { + if (handler.succeeded()) { + LOGGER.info("Audit data published into RMQ."); + promise.complete(); + } else { + LOGGER.error("failed: " + handler.cause().getMessage()); + promise.complete(); + } + }); return promise.future(); } diff --git a/src/main/java/iudx/data/marketplace/auditing/AuditingVerticle.java b/src/main/java/iudx/data/marketplace/auditing/AuditingVerticle.java index e7cc3851..09af7476 100644 --- a/src/main/java/iudx/data/marketplace/auditing/AuditingVerticle.java +++ b/src/main/java/iudx/data/marketplace/auditing/AuditingVerticle.java @@ -1,5 +1,7 @@ package iudx.data.marketplace.auditing; +import static iudx.data.marketplace.common.Constants.AUDITING_SERVICE_ADDRESS; + import io.vertx.core.AbstractVerticle; import io.vertx.core.eventbus.MessageConsumer; import io.vertx.core.json.JsonObject; @@ -11,88 +13,85 @@ import iudx.data.marketplace.auditing.databroker.DataBrokerService; import iudx.data.marketplace.auditing.databroker.DataBrokerServiceImpl; -import static iudx.data.marketplace.common.Constants.AUDITING_SERVICE_ADDRESS; - public class AuditingVerticle extends AbstractVerticle { - private RabbitMQOptions config; - private RabbitMQClient client; - private String dataBrokerIp; - private int dataBrokerPort; - private int dataBrokerManagementPort; - private String dataBrokerVhost; - private String dataBrokerUserName; - private String dataBrokerPassword; - private int connectionTimeout; - private int requestedHeartbeat; - private int handshakeTimeout; - private int requestedChannelMax; - private int networkRecoveryInterval; - private ServiceBinder binder; - private MessageConsumer consumer; - private WebClientOptions webConfig; - private DataBrokerService dataBrokerService; - private AuditingService metering; - - @Override - public void start() throws Exception { + private RabbitMQOptions config; + private RabbitMQClient client; + private String dataBrokerIp; + private int dataBrokerPort; + private int dataBrokerManagementPort; + private String dataBrokerVhost; + private String dataBrokerUserName; + private String dataBrokerPassword; + private int connectionTimeout; + private int requestedHeartbeat; + private int handshakeTimeout; + private int requestedChannelMax; + private int networkRecoveryInterval; + private ServiceBinder binder; + private MessageConsumer consumer; + private WebClientOptions webConfig; + private DataBrokerService dataBrokerService; + private AuditingService metering; - /* Read the configuration and set the rabbitMQ server properties. */ - dataBrokerIp = config().getString("dataBrokerIP"); - dataBrokerPort = config().getInteger("dataBrokerPort"); - dataBrokerManagementPort = config().getInteger("dataBrokerManagementPort"); - dataBrokerVhost = config().getString("dataBrokerVhost"); - dataBrokerUserName = config().getString("dataBrokerUserName"); - dataBrokerPassword = config().getString("dataBrokerPassword"); - connectionTimeout = config().getInteger("connectionTimeout"); - requestedHeartbeat = config().getInteger("requestedHeartbeat"); - handshakeTimeout = config().getInteger("handshakeTimeout"); - requestedChannelMax = config().getInteger("requestedChannelMax"); - networkRecoveryInterval = config().getInteger("networkRecoveryInterval"); + @Override + public void start() throws Exception { - /* Configure the RabbitMQ Data Broker client with input from config files. */ + /* Read the configuration and set the rabbitMQ server properties. */ + dataBrokerIp = config().getString("dataBrokerIP"); + dataBrokerPort = config().getInteger("dataBrokerPort"); + dataBrokerManagementPort = config().getInteger("dataBrokerManagementPort"); + dataBrokerVhost = config().getString("dataBrokerVhost"); + dataBrokerUserName = config().getString("dataBrokerUserName"); + dataBrokerPassword = config().getString("dataBrokerPassword"); + connectionTimeout = config().getInteger("connectionTimeout"); + requestedHeartbeat = config().getInteger("requestedHeartbeat"); + handshakeTimeout = config().getInteger("handshakeTimeout"); + requestedChannelMax = config().getInteger("requestedChannelMax"); + networkRecoveryInterval = config().getInteger("networkRecoveryInterval"); - config = - new RabbitMQOptions() - .setUser(dataBrokerUserName) - .setPassword(dataBrokerPassword) - .setHost(dataBrokerIp) - .setPort(dataBrokerPort) - .setVirtualHost(dataBrokerVhost) - .setConnectionTimeout(connectionTimeout) - .setRequestedHeartbeat(requestedHeartbeat) - .setHandshakeTimeout(handshakeTimeout) - .setRequestedChannelMax(requestedChannelMax) - .setNetworkRecoveryInterval(networkRecoveryInterval) - .setAutomaticRecoveryEnabled(true); + /* Configure the RabbitMQ Data Broker client with input from config files. */ - webConfig = - new WebClientOptions() - .setKeepAlive(true) - .setConnectTimeout(86400000) - .setDefaultHost(dataBrokerIp) - .setDefaultPort(dataBrokerManagementPort) - .setKeepAliveTimeout(86400000); - /* Create a Vertx Web Client with the configuration and vertx cluster instance. */ + config = + new RabbitMQOptions() + .setUser(dataBrokerUserName) + .setPassword(dataBrokerPassword) + .setHost(dataBrokerIp) + .setPort(dataBrokerPort) + .setVirtualHost(dataBrokerVhost) + .setConnectionTimeout(connectionTimeout) + .setRequestedHeartbeat(requestedHeartbeat) + .setHandshakeTimeout(handshakeTimeout) + .setRequestedChannelMax(requestedChannelMax) + .setNetworkRecoveryInterval(networkRecoveryInterval) + .setAutomaticRecoveryEnabled(true); - WebClient.create(vertx, webConfig); + webConfig = + new WebClientOptions() + .setKeepAlive(true) + .setConnectTimeout(86400000) + .setDefaultHost(dataBrokerIp) + .setDefaultPort(dataBrokerManagementPort) + .setKeepAliveTimeout(86400000); + /* Create a Vertx Web Client with the configuration and vertx cluster instance. */ - /* - * Create a RabbitMQ Client with the configuration and vertx cluster instance. - */ + WebClient.create(vertx, webConfig); - client = RabbitMQClient.create(vertx, config); - dataBrokerService = new DataBrokerServiceImpl(client); - metering = new AuditingServiceImpl(dataBrokerService, config()); - binder = new ServiceBinder(vertx); - /* Publish the Data Broker service with the Event Bus against an address. */ - consumer = - binder.setAddress(AUDITING_SERVICE_ADDRESS).register(AuditingService.class, metering); - } + /* + * Create a RabbitMQ Client with the configuration and vertx cluster instance. + */ - @Override - public void stop() { - binder.unregister(consumer); - } + client = RabbitMQClient.create(vertx, config); + dataBrokerService = new DataBrokerServiceImpl(client); + metering = new AuditingServiceImpl(dataBrokerService, config()); + binder = new ServiceBinder(vertx); + /* Publish the Data Broker service with the Event Bus against an address. */ + consumer = + binder.setAddress(AUDITING_SERVICE_ADDRESS).register(AuditingService.class, metering); + } + @Override + public void stop() { + binder.unregister(consumer); + } } diff --git a/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerService.java b/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerService.java index 64adf8e4..a8f7ac0a 100644 --- a/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerService.java +++ b/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerService.java @@ -1,10 +1,9 @@ package iudx.data.marketplace.auditing.databroker; - import io.vertx.core.Future; import io.vertx.core.json.JsonObject; public interface DataBrokerService { - Future publishMessage(String toExchange, String routingKey, JsonObject body); + Future publishMessage(String toExchange, String routingKey, JsonObject body); } diff --git a/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerServiceImpl.java b/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerServiceImpl.java index 1f2d8db0..f725b391 100644 --- a/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/auditing/databroker/DataBrokerServiceImpl.java @@ -8,43 +8,45 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -public class DataBrokerServiceImpl implements DataBrokerService{ - private static final Logger LOGGER = LogManager.getLogger(DataBrokerServiceImpl.class); - private RabbitMQClient rabbitWebclient; - public DataBrokerServiceImpl(RabbitMQClient rabbitWebclient) { - this.rabbitWebclient = rabbitWebclient; - } - /** - * @param toExchange Exchange name - * @param routingKey routingKey - * @param messageBody JsonObject - * @return void future - */ - @Override - public Future publishMessage(String toExchange, String routingKey, JsonObject messageBody) { - Promise promise = Promise.promise(); +public class DataBrokerServiceImpl implements DataBrokerService { + private static final Logger LOGGER = LogManager.getLogger(DataBrokerServiceImpl.class); + private RabbitMQClient rabbitWebclient; + + public DataBrokerServiceImpl(RabbitMQClient rabbitWebclient) { + this.rabbitWebclient = rabbitWebclient; + } - Future rabbitMqClientStartFuture; - Buffer buffer = Buffer.buffer(messageBody.toString()); - if (!rabbitWebclient.isConnected()) { - rabbitMqClientStartFuture = rabbitWebclient.start(); - } else { - rabbitMqClientStartFuture = Future.succeededFuture(); - } - rabbitMqClientStartFuture - .compose( - rabbitStartupFuture -> rabbitWebclient.basicPublish(toExchange, routingKey, buffer)) - .onSuccess( - successHandler -> { - LOGGER.debug("Data Published into RMQ"); - promise.complete(); - }) - .onFailure( - failureHandler -> { - LOGGER.error(failureHandler.getMessage()); - promise.fail(failureHandler.getMessage()); - }); + /** + * @param toExchange Exchange name + * @param routingKey routingKey + * @param messageBody JsonObject + * @return void future + */ + @Override + public Future publishMessage(String toExchange, String routingKey, JsonObject messageBody) { + Promise promise = Promise.promise(); - return promise.future(); + Future rabbitMqClientStartFuture; + Buffer buffer = Buffer.buffer(messageBody.toString()); + if (!rabbitWebclient.isConnected()) { + rabbitMqClientStartFuture = rabbitWebclient.start(); + } else { + rabbitMqClientStartFuture = Future.succeededFuture(); } + rabbitMqClientStartFuture + .compose( + rabbitStartupFuture -> rabbitWebclient.basicPublish(toExchange, routingKey, buffer)) + .onSuccess( + successHandler -> { + LOGGER.debug("Data Published into RMQ"); + promise.complete(); + }) + .onFailure( + failureHandler -> { + LOGGER.error(failureHandler.getMessage()); + promise.fail(failureHandler.getMessage()); + }); + + return promise.future(); + } } diff --git a/src/main/java/iudx/data/marketplace/auditing/package-info.java b/src/main/java/iudx/data/marketplace/auditing/package-info.java index c17ec06e..8d0521dd 100644 --- a/src/main/java/iudx/data/marketplace/auditing/package-info.java +++ b/src/main/java/iudx/data/marketplace/auditing/package-info.java @@ -1,4 +1,7 @@ -@ModuleGen(groupPackage = "iudx.data.marketplace.auditing", name = "iudx-data-marketplace-auditing", - useFutures = true) +@ModuleGen( + groupPackage = "iudx.data.marketplace.auditing", + name = "iudx-data-marketplace-auditing", + useFutures = true) package iudx.data.marketplace.auditing; + import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/auditing/util/Constants.java b/src/main/java/iudx/data/marketplace/auditing/util/Constants.java index 4dcd262c..efef7534 100644 --- a/src/main/java/iudx/data/marketplace/auditing/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/auditing/util/Constants.java @@ -2,17 +2,16 @@ public class Constants { - public static final String PRIMARY_KEY = "primaryKey"; - public static final String ORIGIN = "origin"; - public static final String ORIGIN_SERVER = "dmp-apd-server"; - public static final String EXCHANGE_NAME = "auditing"; - public static final String ROUTING_KEY = "#"; - public static final String EPOCH_TIME = "epochTime"; - public static final String ISO_TIME = "isoTime"; - public static final String API = "api"; - public static final String INFORMATION = "info"; - public static final String RESPONSE_SIZE = "response_size"; - public static final String HTTP_METHOD = "httpMethod"; - public static final String USERID = "userid"; - + public static final String PRIMARY_KEY = "primaryKey"; + public static final String ORIGIN = "origin"; + public static final String ORIGIN_SERVER = "dmp-apd-server"; + public static final String EXCHANGE_NAME = "auditing"; + public static final String ROUTING_KEY = "#"; + public static final String EPOCH_TIME = "epochTime"; + public static final String ISO_TIME = "isoTime"; + public static final String API = "api"; + public static final String INFORMATION = "info"; + public static final String RESPONSE_SIZE = "response_size"; + public static final String HTTP_METHOD = "httpMethod"; + public static final String USERID = "userid"; } diff --git a/src/main/java/iudx/data/marketplace/authenticator/AuthClient.java b/src/main/java/iudx/data/marketplace/authenticator/AuthClient.java index 6b03a3b8..8bbdce64 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/AuthClient.java +++ b/src/main/java/iudx/data/marketplace/authenticator/AuthClient.java @@ -1,5 +1,8 @@ package iudx.data.marketplace.authenticator; +import static iudx.data.marketplace.apiserver.util.Constants.*; +import static iudx.data.marketplace.common.HttpStatusCode.INTERNAL_SERVER_ERROR; + import io.vertx.core.Future; import io.vertx.core.Promise; import io.vertx.core.buffer.Buffer; @@ -10,9 +13,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.apiserver.util.Constants.*; -import static iudx.data.marketplace.common.HttpStatusCode.INTERNAL_SERVER_ERROR; - public class AuthClient { private static final Logger LOGGER = LogManager.getLogger(AuthClient.class); diff --git a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationService.java b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationService.java index 93eb05ad..90473077 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationService.java +++ b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationService.java @@ -26,6 +26,18 @@ @ProxyGen public interface AuthenticationService { + /** + * The createProxy helps the code generation blocks to generate proxy code. + * + * @param vertx which is the vertx instance + * @param address which is the proxy address + * @return AuthenticationServiceVertxEBProxy which is a service proxy + */ + @GenIgnore + static AuthenticationService createProxy(Vertx vertx, String address) { + return new AuthenticationServiceVertxEBProxy(vertx, address); + } + /** * The tokenIntrospect method implements the authentication and authorization module using IUDX * APIs. @@ -39,27 +51,14 @@ public interface AuthenticationService { AuthenticationService tokenIntrospect( JsonObject request, JsonObject authenticationInfo, Handler> handler); - /** - * The createProxy helps the code generation blocks to generate proxy code. - * - * @param vertx which is the vertx instance - * @param address which is the proxy address - * @return AuthenticationServiceVertxEBProxy which is a service proxy - */ - @GenIgnore - static AuthenticationService createProxy(Vertx vertx, String address) { - return new AuthenticationServiceVertxEBProxy(vertx, address); - } - /** * Token introspection for verify endpoint that uses a bearer token generated by DX Auth Server + * * @param authInfo contains Api Endpoint, Header token and Api Method * @param handler AsyncResult JsonObject handler * @return AuthenticationService class object */ - @Fluent AuthenticationService tokenIntrospect4Verify( - JsonObject authInfo, Handler> handler - ); -} \ No newline at end of file + JsonObject authInfo, Handler> handler); +} diff --git a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationServiceImpl.java b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationServiceImpl.java index ebede825..23682875 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationServiceImpl.java @@ -1,26 +1,23 @@ package iudx.data.marketplace.authenticator; -import iudx.data.marketplace.authenticator.authorization.*; -import iudx.data.marketplace.authenticator.model.JwtData; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import iudx.data.marketplace.common.Api; +import static iudx.data.marketplace.apiserver.util.Constants.*; +import static iudx.data.marketplace.apiserver.util.Constants.API_ENDPOINT; +import static iudx.data.marketplace.authenticator.authorization.IudxRole.DELEGATE; +import static iudx.data.marketplace.authenticator.util.Constants.*; +import static iudx.data.marketplace.common.Constants.APD_URL; import io.vertx.core.AsyncResult; import io.vertx.core.Future; import io.vertx.core.Handler; import io.vertx.core.Promise; -import io.vertx.core.Vertx; import io.vertx.core.json.JsonObject; import io.vertx.ext.auth.authentication.TokenCredentials; import io.vertx.ext.auth.jwt.JWTAuth; - -import static iudx.data.marketplace.apiserver.util.Constants.*; -import static iudx.data.marketplace.apiserver.util.Constants.API_ENDPOINT; -import static iudx.data.marketplace.apiserver.util.Constants.METHOD; -import static iudx.data.marketplace.authenticator.authorization.IudxRole.DELEGATE; -import static iudx.data.marketplace.authenticator.util.Constants.*; -import static iudx.data.marketplace.common.Constants.APD_URL; +import iudx.data.marketplace.authenticator.authorization.*; +import iudx.data.marketplace.authenticator.model.JwtData; +import iudx.data.marketplace.common.Api; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class AuthenticationServiceImpl implements AuthenticationService { @@ -30,7 +27,9 @@ public class AuthenticationServiceImpl implements AuthenticationService { final String apdUrl; final String issuer; final Api apis; - public AuthenticationServiceImpl(Vertx vertx, final JWTAuth jwtAuth, final JsonObject config, final Api apis) { + + public AuthenticationServiceImpl( + final JWTAuth jwtAuth, final JsonObject config, final Api apis) { this.jwtAuth = jwtAuth; this.issuer = config.getString("issuer"); this.apdUrl = config.getString(APD_URL); @@ -38,26 +37,28 @@ public AuthenticationServiceImpl(Vertx vertx, final JWTAuth jwtAuth, final JsonO } @Override - public AuthenticationService tokenIntrospect(JsonObject request, JsonObject authenticationInfo, Handler> handler) { + public AuthenticationService tokenIntrospect( + JsonObject request, JsonObject authenticationInfo, Handler> handler) { String token = authenticationInfo.getString(TOKEN); ResultContainer resultContainer = new ResultContainer(); Future jwtDecodeFuture = decodeJwt(token); jwtDecodeFuture - .compose( - decodeHandler -> { - resultContainer.jwtData = decodeHandler; - return validateJwtAccess(resultContainer.jwtData); - }) - .compose(isValidJwtAccess -> validateAccess(resultContainer.jwtData, authenticationInfo)) - .onSuccess(successHandler -> handler.handle(Future.succeededFuture(successHandler))) - .onFailure( - failureHandler -> { - LOGGER.error("error : " + failureHandler.getCause()); - handler.handle(Future.failedFuture(failureHandler.getMessage())); - }); + .compose( + decodeHandler -> { + resultContainer.jwtData = decodeHandler; + return validateJwtAccess(resultContainer.jwtData); + }) + .compose(isValidJwtAccess -> validateAccess(resultContainer.jwtData, authenticationInfo)) + .onSuccess(successHandler -> handler.handle(Future.succeededFuture(successHandler))) + .onFailure( + failureHandler -> { + LOGGER.error("error : " + failureHandler.getCause()); + handler.handle(Future.failedFuture(failureHandler.getMessage())); + }); return this; } + Future validateAccess(JwtData jwtData, JsonObject authInfo) { LOGGER.info("Authorization check started"); Promise promise = Promise.promise(); @@ -104,68 +105,63 @@ public Future validateJwtAccess(JwtData jwtData) { return promise.future(); } - - @Override public AuthenticationService tokenIntrospect4Verify( - JsonObject authInfo, Handler> handler) { + JsonObject authInfo, Handler> handler) { String token = authInfo.getString(TOKEN); Future jwtDecodeFuture = decodeJwt(token); jwtDecodeFuture - .onSuccess( - jwtData -> { - if (jwtData.getSub() == null) { - LOGGER.error("No sub value in JWT"); - handler.handle(Future.failedFuture("No sub value in JWT")); - } else if (!(jwtData.getIss() != null && issuer.equalsIgnoreCase(jwtData.getIss()))) { - LOGGER.error("Incorrect issuer value in JWT"); - handler.handle(Future.failedFuture("Incorrect issuer value in JWT")); - } else if (jwtData.getAud().isEmpty()) { - LOGGER.error("No audience value in JWT"); - handler.handle(Future.failedFuture("No audience value in JWT")); - } else if (!jwtData.getAud().equalsIgnoreCase(apdUrl)) { - LOGGER.error("Incorrect audience value in JWT"); - handler.handle(Future.failedFuture("Incorrect subject value in JWT")); - } else { - LOGGER.info("Auth token verified"); - handler.handle(Future.succeededFuture()); - } - }) - .onFailure( - failureHandler -> { - LOGGER.error("Failed to decode the token : {}", failureHandler.getMessage()); - handler.handle(Future.failedFuture(failureHandler.getMessage())); - }); + .onSuccess( + jwtData -> { + if (jwtData.getSub() == null) { + LOGGER.error("No sub value in JWT"); + handler.handle(Future.failedFuture("No sub value in JWT")); + } else if (!(jwtData.getIss() != null && issuer.equalsIgnoreCase(jwtData.getIss()))) { + LOGGER.error("Incorrect issuer value in JWT"); + handler.handle(Future.failedFuture("Incorrect issuer value in JWT")); + } else if (jwtData.getAud().isEmpty()) { + LOGGER.error("No audience value in JWT"); + handler.handle(Future.failedFuture("No audience value in JWT")); + } else if (!jwtData.getAud().equalsIgnoreCase(apdUrl)) { + LOGGER.error("Incorrect audience value in JWT"); + handler.handle(Future.failedFuture("Incorrect subject value in JWT")); + } else { + LOGGER.info("Auth token verified"); + handler.handle(Future.succeededFuture()); + } + }) + .onFailure( + failureHandler -> { + LOGGER.error("Failed to decode the token : {}", failureHandler.getMessage()); + handler.handle(Future.failedFuture(failureHandler.getMessage())); + }); return this; } - // class to contain intermediate data for token introspection - final class ResultContainer { - JwtData jwtData; - } - Future decodeJwt(String jwtToken) { Promise promise = Promise.promise(); TokenCredentials credentials = new TokenCredentials(jwtToken); jwtAuth - .authenticate(credentials) - .onSuccess( - user -> { - JwtData jwtData = new JwtData(user.principal()); - jwtData.setExp(user.get("exp")); - jwtData.setIat(user.get("iat")); - promise.complete(jwtData); - }) - .onFailure( - err -> { - LOGGER.error("failed to decode/validate jwt token : " + err.getMessage()); - promise.fail("failed to decode/validate jwt token : " + err.getMessage()); - }); + .authenticate(credentials) + .onSuccess( + user -> { + JwtData jwtData = new JwtData(user.principal()); + jwtData.setExp(user.get("exp")); + jwtData.setIat(user.get("iat")); + promise.complete(jwtData); + }) + .onFailure( + err -> { + LOGGER.error("failed to decode/validate jwt token : " + err.getMessage()); + promise.fail("failed to decode/validate jwt token : " + err.getMessage()); + }); return promise.future(); } - - + // class to contain intermediate data for token introspection + final class ResultContainer { + JwtData jwtData; + } } diff --git a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationVerticle.java b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationVerticle.java index a61c3dfc..8f4b8fab 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/AuthenticationVerticle.java +++ b/src/main/java/iudx/data/marketplace/authenticator/AuthenticationVerticle.java @@ -1,5 +1,8 @@ package iudx.data.marketplace.authenticator; +import static iudx.data.marketplace.common.Constants.AUTH_SERVICE_ADDRESS; +import static iudx.data.marketplace.common.Constants.JWT_LEEWAY_TIME; + import io.vertx.core.AbstractVerticle; import io.vertx.core.Future; import io.vertx.core.Promise; @@ -12,24 +15,19 @@ import io.vertx.ext.web.client.WebClient; import io.vertx.ext.web.client.WebClientOptions; import io.vertx.serviceproxy.ServiceBinder; -import iudx.data.marketplace.common.CatalogueService; - import iudx.data.marketplace.common.Api; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.AUTH_SERVICE_ADDRESS; -import static iudx.data.marketplace.common.Constants.JWT_LEEWAY_TIME; - public class AuthenticationVerticle extends AbstractVerticle { private static final Logger LOGGER = LogManager.getLogger(AuthenticationVerticle.class); private AuthenticationService authenticationService; - private CatalogueService catalogueService; private ServiceBinder binder; private MessageConsumer consumer; private WebClient webClient; private Api api; + static WebClient createWebClient(Vertx vertx, JsonObject config) { return createWebClient(vertx, config, false); } @@ -76,9 +74,9 @@ public void start() throws Exception { } JWTAuth jwtAuth = JWTAuth.create(vertx, jwtAuthOptions); - catalogueService = new CatalogueService(vertx, config()); + /*CatalogueService catalogueService = new CatalogueService(vertx, config());*/ api = Api.getInstance(config().getString("dxApiBasePath")); - authenticationService = new AuthenticationServiceImpl(vertx, jwtAuth, config(), api); + authenticationService = new AuthenticationServiceImpl(jwtAuth, config(), api); /* Publish the Authentication service with the Event Bus against an address. */ consumer = @@ -115,4 +113,5 @@ private Future getJwtPublicKey(Vertx vertx, JsonObject config) { } }); return promise.future(); - }} + } +} diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationContextFactory.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationContextFactory.java index bbd3425e..8bd917ee 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationContextFactory.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationContextFactory.java @@ -3,7 +3,7 @@ import iudx.data.marketplace.common.Api; public class AuthorizationContextFactory { - public static AuthorizationStatergy create(IudxRole role, Api api){ + public static AuthorizationStatergy create(IudxRole role, Api api) { if (role == null) { throw new IllegalArgumentException(role + " role is not defined in IUDX"); } @@ -17,7 +17,5 @@ public static AuthorizationStatergy create(IudxRole role, Api api){ default: throw new IllegalArgumentException(role + " role is not defined in IUDX"); } - } - } diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationRequest.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationRequest.java index 8145d578..61c5466f 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationRequest.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/AuthorizationRequest.java @@ -1,12 +1,9 @@ package iudx.data.marketplace.authenticator.authorization; -import iudx.data.marketplace.common.Api; - import java.util.Objects; public class AuthorizationRequest { - private final Method method; private final String api; @@ -25,8 +22,12 @@ public Method getMethod() { @Override public boolean equals(Object o) { - if (this == o) return true; - if (!(o instanceof AuthorizationRequest)) return false; + if (this == o) { + return true; + } + if (!(o instanceof AuthorizationRequest)) { + return false; + } AuthorizationRequest that = (AuthorizationRequest) o; return method == that.method && Objects.equals(api, that.api); } diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/ConsumerAuthStatergy.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/ConsumerAuthStatergy.java index 88232365..333b0e84 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/ConsumerAuthStatergy.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/ConsumerAuthStatergy.java @@ -1,28 +1,27 @@ package iudx.data.marketplace.authenticator.authorization; -import io.vertx.core.json.JsonArray; +import static iudx.data.marketplace.authenticator.authorization.Method.GET; +import static iudx.data.marketplace.authenticator.authorization.Method.POST; + import iudx.data.marketplace.authenticator.model.JwtData; import iudx.data.marketplace.common.Api; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; - - -import static iudx.data.marketplace.authenticator.authorization.Method.GET; -import static iudx.data.marketplace.authenticator.authorization.Method.POST; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class ConsumerAuthStatergy implements AuthorizationStatergy { private static final Logger LOGGER = LogManager.getLogger(ConsumerAuthStatergy.class); private static volatile ConsumerAuthStatergy instance; Map> consumerAuthorizationRules = new HashMap<>(); + private ConsumerAuthStatergy(Api apis) { buildPermissions(apis); } + public static ConsumerAuthStatergy getInstance(Api apis) { if (instance == null) { synchronized (ConsumerAuthStatergy.class) { @@ -33,6 +32,7 @@ public static ConsumerAuthStatergy getInstance(Api apis) { } return instance; } + private void buildPermissions(Api apis) { // api access list List apiAccessList = new ArrayList<>(); @@ -50,6 +50,7 @@ private void buildPermissions(Api apis) { apiAccessList.add(new AuthorizationRequest(GET, apis.getPoliciesUrl())); consumerAuthorizationRules.put("api", apiAccessList); } + @Override public boolean isAuthorized(AuthorizationRequest authorizationRequest, JwtData jwtData) { String endpoint = authorizationRequest.getApi(); diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/IudxRole.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/IudxRole.java index 734f973e..eca9b2e9 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/IudxRole.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/IudxRole.java @@ -1,11 +1,12 @@ package iudx.data.marketplace.authenticator.authorization; import iudx.data.marketplace.authenticator.model.JwtData; - import java.util.stream.Stream; public enum IudxRole { - CONSUMER("consumer"), PROVIDER("provider"), DELEGATE("delegate"); + CONSUMER("consumer"), + PROVIDER("provider"), + DELEGATE("delegate"); private final String role; @@ -13,17 +14,15 @@ public enum IudxRole { this.role = role; } - public String getRole() { - return this.role; - } - public static IudxRole fromRole(final JwtData jwtData) { - String role = jwtData.getRole().equalsIgnoreCase(DELEGATE.getRole()) ? jwtData.getDrl() : jwtData.getRole(); - return Stream.of(values()) - .filter(v -> v.role.equalsIgnoreCase(role)) - .findAny() - .orElse(null); + String role = + jwtData.getRole().equalsIgnoreCase(DELEGATE.getRole()) + ? jwtData.getDrl() + : jwtData.getRole(); + return Stream.of(values()).filter(v -> v.role.equalsIgnoreCase(role)).findAny().orElse(null); } - + public String getRole() { + return this.role; + } } diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/JwtAuthorization.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/JwtAuthorization.java index 5753f174..063c70c0 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/JwtAuthorization.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/JwtAuthorization.java @@ -6,7 +6,7 @@ public class JwtAuthorization { - private static final Logger LOGGER = LogManager.getLogger(JwtAuthorization.class); + // private static final Logger LOGGER = LogManager.getLogger(JwtAuthorization.class); private final AuthorizationStatergy authStrategy; diff --git a/src/main/java/iudx/data/marketplace/authenticator/authorization/ProviderAuthStatergy.java b/src/main/java/iudx/data/marketplace/authenticator/authorization/ProviderAuthStatergy.java index ffa7a9b1..a3560c7a 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/authorization/ProviderAuthStatergy.java +++ b/src/main/java/iudx/data/marketplace/authenticator/authorization/ProviderAuthStatergy.java @@ -1,43 +1,36 @@ package iudx.data.marketplace.authenticator.authorization; -import io.vertx.core.json.JsonArray; +import static iudx.data.marketplace.authenticator.authorization.Method.*; + import iudx.data.marketplace.authenticator.model.JwtData; import iudx.data.marketplace.common.Api; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; - - -import static iudx.data.marketplace.authenticator.authorization.Method.*; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class ProviderAuthStatergy implements AuthorizationStatergy { private static final Logger LOGGER = LogManager.getLogger(ProviderAuthStatergy.class); private static volatile ProviderAuthStatergy instance; Map> providerAuthorizationRequest = new HashMap<>(); - private ProviderAuthStatergy(Api api) - { + private ProviderAuthStatergy(Api api) { buildPermissions(api); } - public static ProviderAuthStatergy getInstance(Api api) - { - if(instance == null) - { - synchronized (ProviderAuthStatergy.class) - { - if(instance == null) - { + public static ProviderAuthStatergy getInstance(Api api) { + if (instance == null) { + synchronized (ProviderAuthStatergy.class) { + if (instance == null) { instance = new ProviderAuthStatergy(api); } } } return instance; } + private void buildPermissions(Api api) { List apiAccessList = new ArrayList<>(); apiAccessList.add(new AuthorizationRequest(POST, api.getProviderProductPath())); @@ -49,7 +42,7 @@ private void buildPermissions(Api api) { apiAccessList.add(new AuthorizationRequest(GET, api.getProviderProductVariantPath())); apiAccessList.add(new AuthorizationRequest(DELETE, api.getProviderProductVariantPath())); -// Linked Account APIs + // Linked Account APIs apiAccessList.add(new AuthorizationRequest(POST, api.getLinkedAccountService())); apiAccessList.add(new AuthorizationRequest(PUT, api.getLinkedAccountService())); apiAccessList.add(new AuthorizationRequest(GET, api.getLinkedAccountService())); diff --git a/src/main/java/iudx/data/marketplace/authenticator/model/JwtData.java b/src/main/java/iudx/data/marketplace/authenticator/model/JwtData.java index dc7b6730..8ea1ecd9 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/model/JwtData.java +++ b/src/main/java/iudx/data/marketplace/authenticator/model/JwtData.java @@ -124,27 +124,27 @@ public void setIat(Integer iat) { @Override public String toString() { return "JwtData [access_token=" - + accessToken - + ", sub=" - + sub - + ", iss=" - + iss - + ", aud=" - + aud - + ", exp=" - + exp - + ", iat=" - + iat - + ", iid=" - + iid - + ", role=" - + role - + ", cons=" - + cons - + ", drl=" - + drl - + ", did=" - + did - + "]"; + + accessToken + + ", sub=" + + sub + + ", iss=" + + iss + + ", aud=" + + aud + + ", exp=" + + exp + + ", iat=" + + iat + + ", iid=" + + iid + + ", role=" + + role + + ", cons=" + + cons + + ", drl=" + + drl + + ", did=" + + did + + "]"; } } diff --git a/src/main/java/iudx/data/marketplace/authenticator/util/Constants.java b/src/main/java/iudx/data/marketplace/authenticator/util/Constants.java index d380146f..d4fcf8f9 100644 --- a/src/main/java/iudx/data/marketplace/authenticator/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/authenticator/util/Constants.java @@ -6,5 +6,5 @@ public class Constants { public static final String GET_USER = "select * from user_table where _id=$1::UUID;"; public static final String INSERT_USER_TABLE = - "insert into user_table(_id,email_id,first_name,last_name) values ($1,$2,$3,$4) returning _id;"; + "insert into user_table(_id,email_id,first_name,last_name) values ($1,$2,$3,$4) returning _id;"; } diff --git a/src/main/java/iudx/data/marketplace/common/Api.java b/src/main/java/iudx/data/marketplace/common/Api.java index bfced995..506701a4 100644 --- a/src/main/java/iudx/data/marketplace/common/Api.java +++ b/src/main/java/iudx/data/marketplace/common/Api.java @@ -57,7 +57,7 @@ private void buildPaths() { verifyPaymentApi = new StringBuilder(VERIFY_PAYMENTS_PATH); consumerProductVariantPath = new StringBuilder(CONSUMER_PATH + PRODUCT_VARIANT_PATH); consumerListResourcePath = new StringBuilder(CONSUMER_PATH + LIST_RESOURCES_PATH); - checkPolicyPath = new StringBuilder( dxApiBasePath).append(CHECK_POLICY_PATH + POLICIES_API); + checkPolicyPath = new StringBuilder(dxApiBasePath).append(CHECK_POLICY_PATH + POLICIES_API); } public String getPoliciesUrl() { @@ -107,6 +107,7 @@ public String getConsumerListProducts() { public String getLinkedAccountService() { return linkedAccountService.toString(); } + public String getConsumerOrderApi() { return consumerOrdersApi.toString(); } @@ -114,16 +115,16 @@ public String getConsumerOrderApi() { public String getVerifyPaymentApi() { return verifyPaymentApi.toString(); } - public String getConsumerProductVariantPath() - { + + public String getConsumerProductVariantPath() { return consumerProductVariantPath.toString(); } - public String getConsumerListResourcePath() - { + public String getConsumerListResourcePath() { return consumerListResourcePath.toString(); } - public String getCheckPolicyPath(){ + + public String getCheckPolicyPath() { return checkPolicyPath.toString(); } } diff --git a/src/main/java/iudx/data/marketplace/common/CatalogueService.java b/src/main/java/iudx/data/marketplace/common/CatalogueService.java index 9e48dbd2..d5296369 100644 --- a/src/main/java/iudx/data/marketplace/common/CatalogueService.java +++ b/src/main/java/iudx/data/marketplace/common/CatalogueService.java @@ -10,8 +10,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import java.util.concurrent.TimeUnit; - /** * The Catalogue Service * @@ -28,11 +26,10 @@ public class CatalogueService { static WebClient catWebClient; private static String catHost; private static int catPort; - private static String catItemPath, catRelPath; - private Vertx vertx; + private static String catItemPath; + private static String catRelPath; public CatalogueService(Vertx vertx, JsonObject config) { - this.vertx = vertx; catHost = config.getString(CAT_SERVER_HOST); catPort = config.getInteger(CAT_SERVER_PORT); catItemPath = config.getString(CAT_ITEM_PATH); @@ -50,15 +47,15 @@ public CatalogueService(Vertx vertx, JsonObject config) { * using a webClient * * @see io.vertx.ext.web.client.WebClient - * @param itemID which is String + * @param itemId which is String * @return Future which is of type JsonObject */ - public Future getItemDetails(String itemID) { + public Future getItemDetails(String itemId) { Promise promise = Promise.promise(); JsonObject itemDetails = new JsonObject(); catWebClient .get(catPort, catHost, catItemPath) - .addQueryParam("id", itemID) + .addQueryParam("id", itemId) .send( catItemHandler -> { if (catItemHandler.succeeded()) { @@ -69,13 +66,13 @@ public Future getItemDetails(String itemID) { if (result.getJsonArray("type").contains(TYPE_PROVIDER)) { itemDetails .put("type", TYPE_PROVIDER) - .put(PROVIDER_ID, itemID) + .put(PROVIDER_ID, itemId) .put("ownerUserId", result.getString("ownerUserId", "")) .put(PROVIDER_NAME, result.getString("description", "")); } else if (result.getJsonArray("type").contains(TYPE_RI)) { itemDetails .put("type", TYPE_RI) - .put(RESOURCE_ID, itemID) + .put(RESOURCE_ID, itemId) .put(RESOURCE_NAME, result.getString("label", "")) .put(RESOURCE_SERVER, result.getValue(RESOURCE_SERVER)) .put(PROVIDER, result.getValue(PROVIDER)) @@ -84,11 +81,11 @@ public Future getItemDetails(String itemID) { } promise.complete(itemDetails); } else { - promise.fail("Item with id { " + itemID + " } not found "); + promise.fail("Item with id { " + itemId + " } not found "); } } else { - LOGGER.debug("Cat web client call to {} failed for id: {} ", catItemPath, itemID); - promise.fail("Cat web client call to " + catItemPath + " failed for id: " + itemID); + LOGGER.debug("Cat web client call to {} failed for id: {} ", catItemPath, itemId); + promise.fail("Cat web client call to " + catItemPath + " failed for id: " + itemId); } }); @@ -99,26 +96,27 @@ public Future getItemDetails(String itemID) { * The getResourceCount method calls the IUDX catalogue relationship endpoint using a webClient * * @see io.vertx.ext.web.client.WebClient - * @param resourceID which is a String + * @param resourceId which is a String * @return Future which is of type JsonObject */ - public Future getResourceCount(String resourceID) { + public Future getResourceCount(String resourceId) { Promise promise = Promise.promise(); catWebClient .get(catPort, catHost, catRelPath) - .addQueryParam("id", resourceID) + .addQueryParam("id", resourceId) .addQueryParam("rel", "resource") .send( catRelHandler -> { if (catRelHandler.succeeded()) { int totalHits = catRelHandler.result().bodyAsJsonObject().getInteger("totalHits"); JsonObject res = - new JsonObject().put(RESOURCE_ID, resourceID).put("totalHits", totalHits); + new JsonObject().put(RESOURCE_ID, resourceId).put("totalHits", totalHits); promise.complete(res); } else { - LOGGER.debug("Cat web client call to {} failed for id: {} ", catRelPath, resourceID); + LOGGER.debug( + "Cat web client call to {} failed for id: {} ", catRelPath, resourceId); promise.fail( - "Cat web client call to " + catItemPath + " failed for id: " + resourceID); + "Cat web client call to " + catItemPath + " failed for id: " + resourceId); } }); @@ -126,33 +124,36 @@ public Future getResourceCount(String resourceID) { } public Future searchApi(JsonObject params) { - Promise promise = Promise.promise(); JsonArray keysArray = new JsonArray(); JsonArray valuesArray = new JsonArray(); - params.forEach(entry -> { - keysArray.add(entry.getKey()); - JsonArray valueArray = new JsonArray().add(entry.getValue()); - valuesArray.add(valueArray.getList()); - }); + params.forEach( + entry -> { + keysArray.add(entry.getKey()); + JsonArray valueArray = new JsonArray().add(entry.getValue()); + valuesArray.add(valueArray.getList()); + }); LOGGER.debug(keysArray.getList().toString()); LOGGER.debug(valuesArray.getList().toString()); + Promise promise = Promise.promise(); catWebClient .get(catPort, catHost, "/iudx/cat/v1/search") .addQueryParam("property", keysArray.getList().toString()) .addQueryParam("value", valuesArray.getList().toString()) - .send(searchApiHandler -> { - if(searchApiHandler.succeeded()) { + .send( + searchApiHandler -> { + if (searchApiHandler.succeeded()) { + promise.complete(searchApiHandler.result().bodyAsJsonObject()); LOGGER.debug(searchApiHandler.result().bodyAsJsonObject()); } else { + promise.fail(searchApiHandler.cause()); LOGGER.error(searchApiHandler.cause()); } }); - promise.complete(); return promise.future(); } } diff --git a/src/main/java/iudx/data/marketplace/common/Constants.java b/src/main/java/iudx/data/marketplace/common/Constants.java index 75b2a5a5..2e212f11 100644 --- a/src/main/java/iudx/data/marketplace/common/Constants.java +++ b/src/main/java/iudx/data/marketplace/common/Constants.java @@ -32,9 +32,8 @@ public class Constants { public static final String RAZORPAY_SERVICE_ADDRESS = "iudx.data.marketplace.razorpay.service"; public static final String AUDITING_SERVICE_ADDRESS = "iudx.data.marketplace.server.auditing"; - public static final String LINKED_ACCOUNT_ADDRESS = "iudx.data.marketplace.apiserver.provider.linked.account.service"; + public static final String LINKED_ACCOUNT_ADDRESS = + "iudx.data.marketplace.apiserver.provider.linked.account.service"; public static final String WEBHOOK_SERVICE_ADDRESS = "iudx.data.marketplace.webhook.service"; public static final int JWT_LEEWAY_TIME = 30; - - } diff --git a/src/main/java/iudx/data/marketplace/common/HttpStatusCode.java b/src/main/java/iudx/data/marketplace/common/HttpStatusCode.java index fcd7f215..755f5069 100644 --- a/src/main/java/iudx/data/marketplace/common/HttpStatusCode.java +++ b/src/main/java/iudx/data/marketplace/common/HttpStatusCode.java @@ -71,6 +71,15 @@ public enum HttpStatusCode { this.urn = urn; } + public static HttpStatusCode getByValue(int value) { + for (HttpStatusCode status : values()) { + if (status.value == value) { + return status; + } + } + throw new IllegalArgumentException("Invalid status code: " + value); + } + public int getValue() { return value; } @@ -87,11 +96,4 @@ public String getUrn() { public String toString() { return value + " " + description; } - - public static HttpStatusCode getByValue(int value) { - for (HttpStatusCode status : values()) { - if (status.value == value) return status; - } - throw new IllegalArgumentException("Invalid status code: " + value); - } } diff --git a/src/main/java/iudx/data/marketplace/common/RespBuilder.java b/src/main/java/iudx/data/marketplace/common/RespBuilder.java index c727d0f3..9748af03 100644 --- a/src/main/java/iudx/data/marketplace/common/RespBuilder.java +++ b/src/main/java/iudx/data/marketplace/common/RespBuilder.java @@ -1,11 +1,11 @@ package iudx.data.marketplace.common; -import io.vertx.core.json.JsonArray; -import io.vertx.core.json.JsonObject; - import static iudx.data.marketplace.apiserver.util.Constants.*; import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; +import io.vertx.core.json.JsonArray; +import io.vertx.core.json.JsonObject; + public class RespBuilder { private JsonObject response = new JsonObject(); @@ -13,8 +13,8 @@ public RespBuilder withType(String type) { response.put(JSON_TYPE, type); return this; } - public RespBuilder withType(int statusCode) - { + + public RespBuilder withType(int statusCode) { response.put(JSON_TYPE, statusCode); return this; } @@ -38,6 +38,7 @@ public RespBuilder withResult(JsonObject result) { response.put(RESULTS, result); return this; } + public JsonObject getJsonResponse() { return response; } diff --git a/src/main/java/iudx/data/marketplace/common/ResponseUrn.java b/src/main/java/iudx/data/marketplace/common/ResponseUrn.java index b2871bcf..a46afe70 100644 --- a/src/main/java/iudx/data/marketplace/common/ResponseUrn.java +++ b/src/main/java/iudx/data/marketplace/common/ResponseUrn.java @@ -11,18 +11,18 @@ public enum ResponseUrn { INVALID_ATTR_VALUE_URN("urn:dx:dmp:invalidAttributeValue", "Invalid attribute value"), INVALID_OPERATION_URN("urn:dx:dmp:invalidOperation", "Invalid operation"), UNAUTHORIZED_ENDPOINT_URN( - "urn:dx:dmp:unauthorizedEndpoint", "Access to endpoint is not available"), + "urn:dx:dmp:unauthorizedEndpoint", "Access to endpoint is not available"), UNAUTHORIZED_RESOURCE_URN( - "urn,dx:dmp:unauthorizedResource", "Access to resource is not available"), + "urn,dx:dmp:unauthorizedResource", "Access to resource is not available"), EXPIRED_TOKEN_URN("urn:dx:dmp:expiredAuthorizationToken", "Token has expired"), MISSING_TOKEN_URN("urn:dx:dmp:missingAuthorizationToken", "Token needed and not present"), INVALID_TOKEN_URN("urn:dx:dmp:invalidAuthorizationToken", "Token is invalid"), RESOURCE_NOT_FOUND_URN("urn:dx:dmp:resourceNotFound", "Document of given id does not exist"), RESOURCE_ALREADY_EXISTS_URN( - "urn:dx:dmp:resourceAlreadyExists", "Document of given id already exists"), + "urn:dx:dmp:resourceAlreadyExists", "Document of given id already exists"), LIMIT_EXCEED_URN( - "urn:dx:dmp:requestLimitExceeded", "Operation exceeds the default value of limit"), + "urn:dx:dmp:requestLimitExceeded", "Operation exceeds the default value of limit"), PAYLOAD_TOO_LARGE_URN("urn:dx:dmp:payloadTooLarge", "Response size exceeds limit"), @@ -31,7 +31,7 @@ public enum ResponseUrn { INVALID_ID_VALUE_URN("urn:dx:dmp:invalidIdValue", "Invalid id"), INVALID_NAME_URN("urn:dx:dmp:invalidNameValue", "Invalid name"), INVALID_PAYLOAD_FORMAT_URN( - "urn:dx:dmp:invalidPayloadFormat", "Invalid json format in post request [schema mismatch]"), + "urn:dx:dmp:invalidPayloadFormat", "Invalid json format in post request [schema mismatch]"), INVALID_PARAM_VALUE_URN("urn:dx:dmp:invalidParamameterValue", "Invalid parameter value passed"), BAD_REQUEST_URN("urn:dx:dmp:badRequest", "bad request parameter"), INVALID_HEADER_VALUE_URN("urn:dx:dmp:invalidHeaderValue", "Invalid header value"), @@ -45,7 +45,7 @@ public enum ResponseUrn { PAYMENT_STATUS_NOT_FOUND("urn:dx:dmp:invalidPaymentStatus", "Payment status does not exist"), BACKING_SERVICE_FORMAT_URN( - "urn:dx:dmp:backend", "format error from backing service [cat,auth etc.]"), + "urn:dx:dmp:backend", "format error from backing service [cat,auth etc.]"), SCHEMA_READ_ERROR_URN("urn:dx:dmp:readError", "Fail to read file"), VERIFY_FORBIDDEN_URN("urn:apd:Deny", "Policy does not exist"), FORBIDDEN_URN("urn:dx:dmp:forbidden", "Resource is forbidden to access"), @@ -53,12 +53,16 @@ public enum ResponseUrn { YET_NOT_IMPLEMENTED_URN("urn:dx:dmp:general", "urn yet not implemented in backend verticle."), FORBIDDEN_PRODUCT_CREATION("urn:dx:dmp:forbidden", "Product creation is forbidden"), - //RazorPay related URNs + // RazorPay related URNs ORDER_NOT_CREATED("urn:dx:dmp:RazorPay:OrderNotCreatedError", "Order Not Created"), - ORDER_CREATION_FAILED("urn:dx:dmp:RazorPay:OrderCreationFailedError", "Order creation returned with error"), + ORDER_CREATION_FAILED( + "urn:dx:dmp:RazorPay:OrderCreationFailedError", "Order creation returned with error"), INVALID_PAYMENT("urn:dx:dmp:RazorPay:InvalidPayment", "Payment Signature verification failed"), - INVALID_WEBHOOK_REQUEST("urn:dx:dmp:RazorPay:InvalidWebhookRequest", "Webhook request validation failed - Invalid Signature/Payload"), - RAZORPAY_WEBHOOK_ERROR("urn:dx:dmp:RazorPay:WebhookFailedError", "Unexpected error while capturing webhook event"); + INVALID_WEBHOOK_REQUEST( + "urn:dx:dmp:RazorPay:InvalidWebhookRequest", + "Webhook request validation failed - Invalid Signature/Payload"), + RAZORPAY_WEBHOOK_ERROR( + "urn:dx:dmp:RazorPay:WebhookFailedError", "Unexpected error while capturing webhook event"); private final String urn; private final String message; @@ -68,6 +72,13 @@ public enum ResponseUrn { this.message = message; } + public static ResponseUrn fromCode(final String urn) { + return Stream.of(values()) + .filter(v -> v.urn.equalsIgnoreCase(urn)) + .findAny() + .orElse(YET_NOT_IMPLEMENTED_URN); // if backend service dont respond with urn + } + public String getUrn() { return urn; } @@ -76,14 +87,7 @@ public String getMessage() { return message; } - public static ResponseUrn fromCode(final String urn) { - return Stream.of(values()) - .filter(v -> v.urn.equalsIgnoreCase(urn)) - .findAny() - .orElse(YET_NOT_IMPLEMENTED_URN); // if backend service dont respond with urn - } - public String toString() { return "[" + urn + " : " + message + " ]"; } -} \ No newline at end of file +} diff --git a/src/main/java/iudx/data/marketplace/common/Util.java b/src/main/java/iudx/data/marketplace/common/Util.java index 56320ecb..be127e7b 100644 --- a/src/main/java/iudx/data/marketplace/common/Util.java +++ b/src/main/java/iudx/data/marketplace/common/Util.java @@ -3,7 +3,6 @@ import io.vertx.core.json.JsonObject; import iudx.data.marketplace.apiserver.util.Role; import iudx.data.marketplace.policies.User; - import java.util.List; public class Util { @@ -79,24 +78,23 @@ public JsonObject getUserJsonFromRowEntry(JsonObject row, Role role) { * @return creates a product json object with a given structure */ public JsonObject getProductInfo(JsonObject row) { - JsonObject productJson = - new JsonObject() - .put( - "product", - new JsonObject() + JsonObject productJson = new JsonObject().put("product", new JsonObject() .put("productId", row.getString("productId")) .put("productVariantId", row.getString("productVariantId")) .put("resources", row.getJsonArray("resources")) .put("productVariantName", row.getString("productVariantName")) .put("price", row.getFloat("price")) .put("expiryInMonths", row.getInteger("expiryInMonths"))); + removeRedundantKeys(row); + return productJson; + } + private void removeRedundantKeys(JsonObject row) { row.remove("productId"); row.remove("productVariantId"); row.remove("resources"); row.remove("price"); row.remove("expiryInMonths"); row.remove("productVariantName"); - return productJson; } } diff --git a/src/main/java/iudx/data/marketplace/consumer/ConsumerService.java b/src/main/java/iudx/data/marketplace/consumer/ConsumerService.java index 5c4a6f2a..51c5a652 100644 --- a/src/main/java/iudx/data/marketplace/consumer/ConsumerService.java +++ b/src/main/java/iudx/data/marketplace/consumer/ConsumerService.java @@ -10,82 +10,95 @@ import io.vertx.core.json.JsonObject; import iudx.data.marketplace.policies.User; -@VertxGen @ProxyGen +@VertxGen +@ProxyGen public interface ConsumerService { + /** + * The createProxy helps the code generation blocks to generate proxy code. + * + * @param vertx which is the vertx instance + * @param address which is the proxy address + * @return ProductServiceVertxEBProxy which is a service proxy + */ + @GenIgnore + static ConsumerService createProxy(Vertx vertx, String address) { + return new ConsumerServiceVertxEBProxy(vertx, address); + } + /** * The listResources method fetches some or all resources available on the IUDX marketplace + * * @param consumer as User object * @param request which is a JsonObject * @param handler which is a Request Handler - * @return ConsumerService which ia service + * @return ConsumerService which is a service */ @Fluent - ConsumerService listResources(User consumer, JsonObject request, Handler> handler); + ConsumerService listResources( + User consumer, JsonObject request, Handler> handler); /** * The listProviders method fetches all or one providers available on the IUDX marketplace + * * @param consumer as User object * @param request which is a JsonObject * @param handler which is a Request Handler - * @return ConsumerService which ia service + * @return ConsumerService which is a service */ @Fluent - ConsumerService listProviders(User consumer, JsonObject request, Handler> handler); + ConsumerService listProviders( + User consumer, JsonObject request, Handler> handler); /** * The listProducts method fetches some or all products available on the IUDX marketplace + * * @param consumer as User object * @param request which is a JsonObject * @param handler which is a Request Handler - * @return ConsumerService which ia service + * @return ConsumerService which is a service */ @Fluent - ConsumerService listProducts(User consumer, JsonObject request, Handler> handler); + ConsumerService listProducts( + User consumer, JsonObject request, Handler> handler); /** * The createOrder method creates an order for the consumer against a product variant - * @param request + * + * @param request to Create order as Json object containing product variant ID * @param user Consumer User - * @param handler - * @return + * @param handler which is a Request Handler + * @return ConsumerService which is a service */ @Fluent - ConsumerService createOrder(JsonObject request, User user, Handler> handler); + ConsumerService createOrder( + JsonObject request, User user, Handler> handler); /** - * The listProductVariants method fetches all the ACTIVE product variants of a given product + * The listProductVariants method fetches all the ACTIVE product variants of a given + * product + * * @param user as consumer User object * @param request containing the productId of a given product * @param handler AsyncResult JsonObject request handler * @return ConsumerService object */ @Fluent - ConsumerService listProductVariants(User user,JsonObject request, Handler> handler); + ConsumerService listProductVariants( + User user, JsonObject request, Handler> handler); /** - * The createProxy helps the code generation blocks to generate proxy code. + * List purchase will fetch invoice related info, provider, consumer and product variant related + * information After the purchase is made. Pending, successful, failed payments are displayed List + * purchase will list all the purchases if no query parameters are given It can also list + * purchases based on the productId, resourceId if it is given in the query parameter * - * @param vertx which is the vertx instance - * @param address which is the proxy address - * @return ProductServiceVertxEBProxy which is a service proxy - */ - @GenIgnore - static ConsumerService createProxy(Vertx vertx, String address) { - return new ConsumerServiceVertxEBProxy(vertx, address); - } - - /** - * List purchase will fetch invoice related info, provider, consumer and product variant related information - * After the purchase is made. Pending, successful, failed payments are displayed - * List purchase will list all the purchases if no query parameters are given - * It can also list purchases based on the productId, resourceId if it is given in the query parameter * @param user Consumer user * @param request query param if any * @param handler Asynchronous JsonObject handler that contains the list of purchases - * @return + * @return ConsumerService which is a service */ @Fluent - ConsumerService listPurchase(User user, JsonObject request, Handler> handler); - + ConsumerService listPurchase( + User user, JsonObject request, Handler> handler); } diff --git a/src/main/java/iudx/data/marketplace/consumer/ConsumerServiceImpl.java b/src/main/java/iudx/data/marketplace/consumer/ConsumerServiceImpl.java index 8d364c61..296ca04c 100644 --- a/src/main/java/iudx/data/marketplace/consumer/ConsumerServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/consumer/ConsumerServiceImpl.java @@ -70,12 +70,12 @@ public ConsumerService listResources( StringBuilder query = new StringBuilder(LIST_RESOURCES_QUERY.replace("$0", resourceTable)); if (request.containsKey("resourceId")) { - String resourceID = request.getString("resourceId"); - params.put("resourceId", resourceID); + String resourceId = request.getString("resourceId"); + params.put("resourceId", resourceId); query = new StringBuilder(LIST_RESOURCES_QUERY_4_RESOURCE.replace("$0", resourceTable)); } else if (request.containsKey("providerId")) { - String providerID = request.getString("providerId"); - params.put("providerId", providerID); + String providerId = request.getString("providerId"); + params.put("providerId", providerId); query = new StringBuilder(LIST_RESOURCES_QUERY_4_PROVIDER.replace("$0", resourceTable)); } LOGGER.debug("List resources query : {}", query); @@ -102,8 +102,8 @@ public ConsumerService listProviders( String query = LIST_PROVIDERS_QUERY; if (request.containsKey("providerId")) { - String providerID = request.getString("providerId"); - params.put("providerId", providerID); + String providerId = request.getString("providerId"); + params.put("providerId", providerId); query = LIST_PROVIDER_WITH_GIVEN_PROVIDER_ID; } LOGGER.debug("Query : " + query); @@ -140,12 +140,12 @@ public ConsumerService listProducts( .replace("$8", resourceTable)); if (request.containsKey("resourceId")) { - String resourceID = request.getString("resourceId"); - params.put("resourceId", resourceID); + String resourceId = request.getString("resourceId"); + params.put("resourceId", resourceId); query.append(" and rt._id=$2"); } else if (request.containsKey("providerId")) { - String providerID = request.getString("providerId"); - params.put("providerId", providerID); + String providerId = request.getString("providerId"); + params.put("providerId", providerId); query.append(" and pt.provider_id=$2"); } query.append(" group by pt.product_id, rt.resource_server"); @@ -170,7 +170,7 @@ public ConsumerService listProducts( @Override public ConsumerService createOrder( JsonObject request, User user, Handler> handler) { - String resourceServerUrl = user.getResourceServerUrl(); + // String resourceServerUrl = user.getResourceServerUrl(); String variantId = request.getString(PRODUCT_VARIANT_ID); String consumerId = user.getUserId(); @@ -228,21 +228,21 @@ public ConsumerService listPurchase( Future paymentFuture = executePurchaseQuery(query, resourceId, productId, user); - Future userResponseFuture = - paymentFuture.onComplete( - pgHandler -> { - if (pgHandler.succeeded()) { - JsonObject response = - new JsonObject() - .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) - .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) - .put(RESULTS, pgHandler.result()); - handler.handle(Future.succeededFuture(response)); - - } else { - handler.handle(Future.failedFuture(pgHandler.cause().getMessage())); - } - }); + // Future userResponseFuture = + paymentFuture.onComplete( + pgHandler -> { + if (pgHandler.succeeded()) { + JsonObject response = + new JsonObject() + .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) + .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) + .put(RESULTS, pgHandler.result()); + handler.handle(Future.succeededFuture(response)); + + } else { + handler.handle(Future.failedFuture(pgHandler.cause().getMessage())); + } + }); } catch (DxRuntimeException exception) { LOGGER.debug("Exception : " + exception.getMessage()); String failureMessage = @@ -364,8 +364,7 @@ public ConsumerService listProductVariants( return this; } - Future generateOrderEntry( - JsonObject orderInfo, String variantId, String consumerId) { + Future generateOrderEntry(JsonObject orderInfo, String variantId, String consumerId) { Promise promise = Promise.promise(); QueryContainer queryContainer = getQueryContainer(orderInfo, variantId, consumerId); diff --git a/src/main/java/iudx/data/marketplace/consumer/ConsumerVerticle.java b/src/main/java/iudx/data/marketplace/consumer/ConsumerVerticle.java index 23cadbc7..3613c5d5 100644 --- a/src/main/java/iudx/data/marketplace/consumer/ConsumerVerticle.java +++ b/src/main/java/iudx/data/marketplace/consumer/ConsumerVerticle.java @@ -1,5 +1,7 @@ package iudx.data.marketplace.consumer; +import static iudx.data.marketplace.common.Constants.*; + import io.vertx.core.AbstractVerticle; import io.vertx.core.eventbus.MessageConsumer; import io.vertx.core.json.JsonObject; @@ -10,8 +12,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.*; - public class ConsumerVerticle extends AbstractVerticle { public static final Logger LOGGER = LogManager.getLogger(ConsumerVerticle.class); private MessageConsumer consumer; @@ -30,7 +30,10 @@ public void start() throws Exception { consumerService = new ConsumerServiceImpl(config(), postgresService, razorPayService, util); binder = new ServiceBinder(vertx); - consumer = binder.setAddress(CONSUMER_SERVICE_ADDRESS).register(ConsumerService.class, consumerService); + consumer = + binder + .setAddress(CONSUMER_SERVICE_ADDRESS) + .register(ConsumerService.class, consumerService); LOGGER.info("Consumer Service started"); } diff --git a/src/main/java/iudx/data/marketplace/consumer/package-info.java b/src/main/java/iudx/data/marketplace/consumer/package-info.java index 75acd9e4..28670180 100644 --- a/src/main/java/iudx/data/marketplace/consumer/package-info.java +++ b/src/main/java/iudx/data/marketplace/consumer/package-info.java @@ -1,5 +1,6 @@ -@ModuleGen(groupPackage = "iudx.data.marketplace.consumer", -name = "iudx-data-marketplace-consumer-service") +@ModuleGen( + groupPackage = "iudx.data.marketplace.consumer", + name = "iudx-data-marketplace-consumer-service") package iudx.data.marketplace.consumer; -import io.vertx.codegen.annotations.ModuleGen; \ No newline at end of file +import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/consumer/util/Constants.java b/src/main/java/iudx/data/marketplace/consumer/util/Constants.java index f0855a64..0fab1e30 100644 --- a/src/main/java/iudx/data/marketplace/consumer/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/consumer/util/Constants.java @@ -30,30 +30,30 @@ public class Constants { + " ORDER BY modified_at DESC "; public static final String LIST_PROVIDERS_QUERY = - "SELECT DISTINCT U._id AS \"providerId\", COUNT(R._id) AS \"numberOfResources\", \n" - + "R.provider_name AS \"providerName\", \n" - + "R.resource_server AS \"resourceServerUrl\",\n" - + "U.modified_at AS \"updatedAt\"\n" - + ",U.created_at AS \"createdAt\"\n" - + "FROM user_table U\n" - + "INNER JOIN resource_entity R \n" - + "ON U._id = R.provider_id\n" - + "WHERE R.resource_server = $1 \n" - + "GROUP BY U._id, R.provider_name, R.resource_server, U.modified_at\n" - + "ORDER BY U.modified_at DESC"; + "SELECT DISTINCT U._id AS \"providerId\", COUNT(R._id) AS \"numberOfResources\", \n" + + "R.provider_name AS \"providerName\", \n" + + "R.resource_server AS \"resourceServerUrl\",\n" + + "U.modified_at AS \"updatedAt\"\n" + + ",U.created_at AS \"createdAt\"\n" + + "FROM user_table U\n" + + "INNER JOIN resource_entity R \n" + + "ON U._id = R.provider_id\n" + + "WHERE R.resource_server = $1 \n" + + "GROUP BY U._id, R.provider_name, R.resource_server, U.modified_at\n" + + "ORDER BY U.modified_at DESC"; public static final String LIST_PROVIDER_WITH_GIVEN_PROVIDER_ID = - "SELECT DISTINCT U._id AS \"providerId\", COUNT(R._id) AS \"numberOfResources\", \n" - + "R.provider_name AS \"providerName\", \n" - + "R.resource_server AS \"resourceServerUrl\",\n" - + "U.modified_at AS \"updatedAt\"\n" - + ",U.created_at AS \"createdAt\"\n" - + "FROM user_table U\n" - + "INNER JOIN resource_entity R \n" - + "ON U._id = R.provider_id\n" - + "WHERE R.resource_server = $1 \n" - + "AND U._id = $2 \n" - + "GROUP BY U._id, R.provider_name, R.resource_server, U.modified_at\n" - + "ORDER BY U.modified_at DESC"; + "SELECT DISTINCT U._id AS \"providerId\", COUNT(R._id) AS \"numberOfResources\", \n" + + "R.provider_name AS \"providerName\", \n" + + "R.resource_server AS \"resourceServerUrl\",\n" + + "U.modified_at AS \"updatedAt\"\n" + + ",U.created_at AS \"createdAt\"\n" + + "FROM user_table U\n" + + "INNER JOIN resource_entity R \n" + + "ON U._id = R.provider_id\n" + + "WHERE R.resource_server = $1 \n" + + "AND U._id = $2 \n" + + "GROUP BY U._id, R.provider_name, R.resource_server, U.modified_at\n" + + "ORDER BY U.modified_at DESC"; public static final String LIST_PRODUCTS = "select pt.product_id AS \"productId\", pt.provider_name AS \"providerName\", " @@ -67,12 +67,12 @@ public class Constants { + "where pt.status='ACTIVE' AND rt.resource_server = $1"; public static final String GET_PRODUCT_VARIANT_INFO = - "select pv._id, pv.product_variant_name, pv.product_id, pv.provider_id, pv.price, m.account_id " - + "from $0 as pv inner join $9 as m on pv.provider_id = m.provider_id " - + "where pv._id=$1 and pv.status=$2"; + "select pv._id, pv.product_variant_name, pv.product_id, pv.provider_id, pv.price, m.account_id " + + "from $0 as pv inner join $9 as m on pv.provider_id = m.provider_id " + + "where pv._id=$1 and pv.status=$2"; public static final String INSERT_ORDER_QUERY = - "insert into $0 (order_id, amount, currency, account_id, notes) values ('$1', $2, '$3', '$4', '$5')"; + "insert into $0 (order_id, amount, currency, account_id, notes) values ('$1', $2, '$3', '$4', '$5')"; public static final String LIST_FAILED_OR_PENDING_PAYMENTS = "SELECT DISTINCT I._id AS \"invoiceId\", P.\"providerId\",\n" + "U.email_id AS \"providerEmailId\", U.first_name AS \"providerFirstName\",\n" @@ -126,13 +126,14 @@ public class Constants { + " AND P.\"resourceServerUrl\" = '$3'"; public static final String LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER = - LIST_SUCCESSFUL_PAYMENTS + LIST_SUCCESSFUL_PAYMENTS + " WHERE \n" + " I.order_id = $1 AND I.consumer_id = '$2'" - + " AND P.\"resourceServerUrl\" = '$3'"; + + " AND P.\"resourceServerUrl\" = '$3'"; public static final String LIST_PENDING_PAYMENTS_4_CONSUMER = - LIST_FAILED_OR_PENDING_PAYMENTS + " WHERE I.consumer_id = '$1' AND I.payment_status = 'PENDING' " - + " AND P.\"resourceServerUrl\" = '$2'"; + LIST_FAILED_OR_PENDING_PAYMENTS + + " WHERE I.consumer_id = '$1' AND I.payment_status = 'PENDING' " + + " AND P.\"resourceServerUrl\" = '$2'"; public static final String LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT = LIST_FAILED_OR_PENDING_PAYMENTS + " WHERE\n" @@ -148,26 +149,25 @@ public class Constants { + " AND P.\"resourceServerUrl\" = '$3'"; public static final String LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER = - LIST_FAILED_OR_PENDING_PAYMENTS - + " WHERE \n" - + " I.order_id = $1 " - + " AND I.consumer_id = '$2' AND I.payment_status = 'PENDING' " - + " AND P.\"resourceServerUrl\" = '$3'"; - - public static final String LIST_FAILED_PAYMENTS_4_CONSUMER = LIST_PENDING_PAYMENTS_4_CONSUMER.replace("PENDING","FAILED"); - public static final String LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT = LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT - .replace("PENDING", "FAILED"); - public static final String LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE = LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE - .replace("PENDING", "FAILED"); + LIST_FAILED_OR_PENDING_PAYMENTS + + " WHERE \n" + + " I.order_id = $1 " + + " AND I.consumer_id = '$2' AND I.payment_status = 'PENDING' " + + " AND P.\"resourceServerUrl\" = '$3'"; + public static final String LIST_FAILED_PAYMENTS_4_CONSUMER = + LIST_PENDING_PAYMENTS_4_CONSUMER.replace("PENDING", "FAILED"); + public static final String LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT = + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT.replace("PENDING", "FAILED"); + public static final String LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE = + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE.replace("PENDING", "FAILED"); public static final String LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER = - LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER - .replace("PENDING", "FAILED"); + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER.replace("PENDING", "FAILED"); public static final String INSERT_INVOICE_QUERY = - "insert into $0 (_id, consumer_id, order_id, product_variant_id, payment_status, payment_time, expiry) " - + "values ('$1', '$2', '$3', '$4', '$5', '$6', (select validity from $p where _id = '$4'))"; + "insert into $0 (_id, consumer_id, order_id, product_variant_id, payment_status, payment_time, expiry) " + + "values ('$1', '$2', '$3', '$4', '$5', '$6', (select validity from $p where _id = '$4'))"; public static final String TRANSFER_ID = "id"; public static final String SOURCE = "source"; @@ -180,21 +180,21 @@ public class Constants { public static final String TRANSFERS = "transfers"; public static final String TABLES = "tables"; -// public static final String FETCH_ACTIVE_PRODUCT_VARIANTS = -// "SELECT _id AS \"productVariantId\"," -// + " product_variant_name AS \"productVariantName\", \"product_id\" AS \"productId\",\n" -// + "provider_id AS \"providerId\", resource_info AS \"resources\", \n" -// + "price AS \"price\", validity AS \"expiryInMonths\"\n" -// + " , modified_at AS \"updatedAt\" " -// + " , created_at AS \"createdAt\" " -// + "FROM product_variant\n" -// + "WHERE product_id = '$1'\n" -// + "AND status = 'ACTIVE' " -// + " ORDER BY modified_at DESC"; + // public static final String FETCH_ACTIVE_PRODUCT_VARIANTS = + // "SELECT _id AS \"productVariantId\"," + // + " product_variant_name AS \"productVariantName\", \"product_id\" AS + // \"productId\",\n" + // + "provider_id AS \"providerId\", resource_info AS \"resources\", \n" + // + "price AS \"price\", validity AS \"expiryInMonths\"\n" + // + " , modified_at AS \"updatedAt\" " + // + " , created_at AS \"createdAt\" " + // + "FROM product_variant\n" + // + "WHERE product_id = '$1'\n" + // + "AND status = 'ACTIVE' " + // + " ORDER BY modified_at DESC"; public static final String FETCH_ACTIVE_PRODUCT_VARIANTS = "SELECT * FROM product_variant_view P\n" + "WHERE P.\"productId\" = $1 \n" + "AND P.\"productVariantStatus\" = 'ACTIVE'\n" + "AND P.\"resourceServerUrl\" = $2\n"; - -} \ No newline at end of file +} diff --git a/src/main/java/iudx/data/marketplace/consumer/util/PaymentStatus.java b/src/main/java/iudx/data/marketplace/consumer/util/PaymentStatus.java index 8bfa42cd..4f4e005c 100644 --- a/src/main/java/iudx/data/marketplace/consumer/util/PaymentStatus.java +++ b/src/main/java/iudx/data/marketplace/consumer/util/PaymentStatus.java @@ -1,32 +1,29 @@ package iudx.data.marketplace.consumer.util; -import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; +import static iudx.data.marketplace.common.ResponseUrn.PAYMENT_STATUS_NOT_FOUND; +import iudx.data.marketplace.apiserver.exceptions.DxRuntimeException; import java.util.stream.Stream; -import static iudx.data.marketplace.common.ResponseUrn.PAYMENT_STATUS_NOT_FOUND; public enum PaymentStatus { PENDING("PENDING"), SUCCESSFUL("SUCCEEDED"), FAILED("FAILED"); private final String paymentStatus; - PaymentStatus(String value) - { - paymentStatus = value; - } - public String getPaymentStatus() - { - return paymentStatus; + PaymentStatus(String value) { + paymentStatus = value; } - public static PaymentStatus fromString(String value) - { + public static PaymentStatus fromString(String value) { return Stream.of(values()) - .filter(element -> element.getPaymentStatus().equalsIgnoreCase(value)) - .findAny() - .orElseThrow(() -> new DxRuntimeException(404, PAYMENT_STATUS_NOT_FOUND)); + .filter(element -> element.getPaymentStatus().equalsIgnoreCase(value)) + .findAny() + .orElseThrow(() -> new DxRuntimeException(404, PAYMENT_STATUS_NOT_FOUND)); } + public String getPaymentStatus() { + return paymentStatus; + } } diff --git a/src/main/java/iudx/data/marketplace/deploy/Deployer.java b/src/main/java/iudx/data/marketplace/deploy/Deployer.java index 9fcb32cc..7cc43a48 100644 --- a/src/main/java/iudx/data/marketplace/deploy/Deployer.java +++ b/src/main/java/iudx/data/marketplace/deploy/Deployer.java @@ -50,7 +50,8 @@ *
  • --config/-c : path to the config file *
  • --isClustered/-C : true for clustering and false for non-clustered mode *
  • --host/-i : the hostname for clustering or localhost for non-clustered mode - *
  • --modules/-m : comma separated list of module names to deploy, by default all is used to deploy every verticle + *
  • --modules/-m : comma separated list of module names to deploy, by default all is used to + * deploy every verticle * * Replace the fatjar file with respective path to fat jar for clustered or non-clustered mode * Replace the configs with the respective path to config.json @@ -67,9 +68,9 @@ public class Deployer { /** * Recursively deploy all modules. * - * @param vertx the vert.x instance + * @param vertx the vert.x instance * @param configs the JSON configuration - * @param i for recursive base case + * @param i for recursive base case */ public static void recursiveDeploy(Vertx vertx, JsonObject configs, int i) { if (i >= configs.getJsonArray("modules").size()) { @@ -93,20 +94,23 @@ public static void recursiveDeploy(Vertx vertx, JsonObject configs, int i) { deploymentOptions.setMaxWorkerExecuteTimeUnit(TimeUnit.MINUTES); } - vertx.deployVerticle(moduleName, deploymentOptions, ar -> { - if (ar.succeeded()) { - LOGGER.info("Deployed " + moduleName); - recursiveDeploy(vertx, configs, i + 1); - } else { - LOGGER.fatal("Failed to deploy " + moduleName + " cause:", ar.cause()); - } - }); + vertx.deployVerticle( + moduleName, + deploymentOptions, + ar -> { + if (ar.succeeded()) { + LOGGER.info("Deployed " + moduleName); + recursiveDeploy(vertx, configs, i + 1); + } else { + LOGGER.fatal("Failed to deploy " + moduleName + " cause:", ar.cause()); + } + }); } /** * Recursively deploy modules/verticles (if they exist) present in the `modules` list. * - * @param vertx the vert.x instance + * @param vertx the vert.x instance * @param configs the JSON configuration * @param modules the list of modules to deploy */ @@ -119,8 +123,11 @@ public static void recursiveDeploy(Vertx vertx, JsonObject configs, List String moduleName = modules.get(0); JsonObject config = - configuredModules.stream().map(obj -> (JsonObject) obj).filter(obj -> obj.getString("id").equals(moduleName)) - .findFirst().orElse(new JsonObject()); + configuredModules.stream() + .map(obj -> (JsonObject) obj) + .filter(obj -> obj.getString("id").equals(moduleName)) + .findFirst() + .orElse(new JsonObject()); if (config.isEmpty()) { LOGGER.fatal("Failed to deploy " + moduleName + " cause: Not Found"); @@ -130,7 +137,8 @@ public static void recursiveDeploy(Vertx vertx, JsonObject configs, List JsonObject commonConfigs = configs.getJsonObject("commonConfig"); config.mergeIn(commonConfigs, true); int numInstances = config.getInteger("verticleInstances"); - DeploymentOptions deploymentOptions = new DeploymentOptions().setInstances(numInstances).setConfig(config); + DeploymentOptions deploymentOptions = + new DeploymentOptions().setInstances(numInstances).setConfig(config); boolean isWorkerVerticle = config.getBoolean("isWorkerVerticle"); if (isWorkerVerticle) { LOGGER.info("worker verticle : " + config.getString("id")); @@ -141,15 +149,18 @@ public static void recursiveDeploy(Vertx vertx, JsonObject configs, List deploymentOptions.setMaxWorkerExecuteTimeUnit(TimeUnit.MINUTES); } - vertx.deployVerticle(moduleName, deploymentOptions, ar -> { - if (ar.succeeded()) { - LOGGER.info("Deployed " + moduleName); - modules.remove(0); - recursiveDeploy(vertx, configs, modules); - } else { - LOGGER.fatal("Failed to deploy " + moduleName + " cause:", ar.cause()); - } - }); + vertx.deployVerticle( + moduleName, + deploymentOptions, + ar -> { + if (ar.succeeded()) { + LOGGER.info("Deployed " + moduleName); + modules.remove(0); + recursiveDeploy(vertx, configs, modules); + } else { + LOGGER.fatal("Failed to deploy " + moduleName + " cause:", ar.cause()); + } + }); } private static JsonObject getConfigForModule(int moduleIndex, JsonObject configurations) { @@ -160,7 +171,8 @@ private static JsonObject getConfigForModule(int moduleIndex, JsonObject configu public static void deploy(String configPath) { EventBusOptions ebOptions = new EventBusOptions(); - VertxOptions options = new VertxOptions().setEventBusOptions(ebOptions).setMetricsOptions(getMetricsOptions()); + VertxOptions options = + new VertxOptions().setEventBusOptions(ebOptions).setMetricsOptions(getMetricsOptions()); String config; try { @@ -179,7 +191,6 @@ public static void deploy(String configPath) { setJvmMetrics(); recursiveDeploy(vertx, configuration, 0); - } private static void setVertxInstance(Vertx vertx) { @@ -188,28 +199,52 @@ private static void setVertxInstance(Vertx vertx) { public static void main(String[] args) { - CLI cli = CLI.create("DX DMP-APD Server").setSummary("A CLI to deploy the DMP-APD server") - .addOption(new Option().setLongName("help").setShortName("h").setFlag(true).setDescription("display help")) - .addOption( - new Option().setLongName("config").setShortName("c").setRequired(true).setDescription("configuration file")) - .addOption(new Option().setLongName("isClustered").setShortName("C").setRequired(true).setDefaultValue("false") - .setDescription("Is it being deployed in clustered mode")) - - .addOption(new Option().setLongName("host").setShortName("i").setRequired(true).setDefaultValue("localhost") - .setDescription("public host")) - - .addOption( - new TypedOption().setType(String.class).setLongName("modules").setShortName("m").setRequired(false) - .setDefaultValue("all").setParsedAsList(true).setDescription( - "comma separated list of verticle names to deploy. " - + - "If omitted, or if `all` is passed, all verticles are deployed")); + CLI cli = + CLI.create("DX DMP-APD Server") + .setSummary("A CLI to deploy the DMP-APD server") + .addOption( + new Option() + .setLongName("help") + .setShortName("h") + .setFlag(true) + .setDescription("display help")) + .addOption( + new Option() + .setLongName("config") + .setShortName("c") + .setRequired(true) + .setDescription("configuration file")) + .addOption( + new Option() + .setLongName("isClustered") + .setShortName("C") + .setRequired(true) + .setDefaultValue("false") + .setDescription("Is it being deployed in clustered mode")) + .addOption( + new Option() + .setLongName("host") + .setShortName("i") + .setRequired(true) + .setDefaultValue("localhost") + .setDescription("public host")) + .addOption( + new TypedOption() + .setType(String.class) + .setLongName("modules") + .setShortName("m") + .setRequired(false) + .setDefaultValue("all") + .setParsedAsList(true) + .setDescription( + "comma separated list of verticle names to deploy. " + + "If omitted, or if `all` is passed, all verticles are deployed")); StringBuilder usageString = new StringBuilder(); cli.usage(usageString); CommandLine commandLine = cli.parse(Arrays.asList(args), false); - boolean isDeploymentInClusteredMode = Boolean.parseBoolean(commandLine.getOptionValue("isClustered")); - + boolean isDeploymentInClusteredMode = + Boolean.parseBoolean(commandLine.getOptionValue("isClustered")); if (commandLine.isValid() && !commandLine.isFlagEnabled("help")) { String configPath = commandLine.getOptionValue("config"); @@ -218,7 +253,8 @@ public static void main(String[] args) { List modules = passedModules.stream().distinct().collect(Collectors.toList()); if (!isDeploymentInClusteredMode) { deploy(configPath); - } /* `all` is also passed by default if no -m option given.*/ else if (modules.contains("all")) { + } /* `all` is also passed by default if no -m option given.*/ else if (modules.contains( + "all")) { deployInClusteredMode(configPath, host, List.of()); } else { deployInClusteredMode(configPath, host, modules); @@ -230,13 +266,12 @@ public static void main(String[] args) { } } - /** * Deploy clustered vert.x instance. * * @param configPath the path for JSON config file - * @param host String - * @param modules list of modules to deploy. If list is empty, all modules are deployed + * @param host String + * @param modules list of modules to deploy. If list is empty, all modules are deployed */ public static void deployInClusteredMode(String configPath, String host, List modules) { String config; @@ -256,26 +291,31 @@ public static void deployInClusteredMode(String configPath, String host, List { - if (res.succeeded()) { - vertxInstance = res.result(); - LOGGER.debug(vertxInstance.isMetricsEnabled()); - setJvmMetrics(); - if (modules.isEmpty()) { - recursiveDeploy(vertxInstance, configuration, 0); - } else { - recursiveDeploy(vertxInstance, configuration, modules); - } - } else { - LOGGER.fatal("Could not join cluster"); - } - }); + Vertx.clusteredVertx( + options, + res -> { + if (res.succeeded()) { + vertxInstance = res.result(); + LOGGER.debug(vertxInstance.isMetricsEnabled()); + setJvmMetrics(); + if (modules.isEmpty()) { + recursiveDeploy(vertxInstance, configuration, 0); + } else { + recursiveDeploy(vertxInstance, configuration, modules); + } + } else { + LOGGER.fatal("Could not join cluster"); + } + }); } - - public static ClusterManager getClusterManager(String host, List zookeepers, String clusterId) { + public static ClusterManager getClusterManager( + String host, List zookeepers, String clusterId) { Config config = new Config(); config.getNetworkConfig().getJoin().getMulticastConfig().setEnabled(false); config.getNetworkConfig().setPublicAddress(host); @@ -283,18 +323,28 @@ public static ClusterManager getClusterManager(String host, List zookeep config.setProperty("hazelcast.logging.type", "log4j2"); DiscoveryStrategyConfig discoveryStrategyConfig = new DiscoveryStrategyConfig(new ZookeeperDiscoveryStrategyFactory()); - discoveryStrategyConfig.addProperty(ZookeeperDiscoveryProperties.ZOOKEEPER_URL.key(), String.join(",", zookeepers)); + discoveryStrategyConfig.addProperty( + ZookeeperDiscoveryProperties.ZOOKEEPER_URL.key(), String.join(",", zookeepers)); discoveryStrategyConfig.addProperty(ZookeeperDiscoveryProperties.GROUP.key(), clusterId); - config.getNetworkConfig().getJoin().getDiscoveryConfig().addDiscoveryStrategyConfig(discoveryStrategyConfig); + config + .getNetworkConfig() + .getJoin() + .getDiscoveryConfig() + .addDiscoveryStrategyConfig(discoveryStrategyConfig); return new HazelcastClusterManager(config); } public static MetricsOptions getMetricsOptions() { - return new MicrometerMetricsOptions().setPrometheusOptions( - new VertxPrometheusOptions().setEnabled(true).setStartEmbeddedServer(true) + return new MicrometerMetricsOptions() + .setPrometheusOptions( + new VertxPrometheusOptions() + .setEnabled(true) + .setStartEmbeddedServer(true) .setEmbeddedServerOptions(new HttpServerOptions().setPort(9000))) - .setLabels(EnumSet.of(Label.EB_ADDRESS, Label.EB_FAILURE, Label.HTTP_CODE, Label.HTTP_METHOD)).setEnabled(true); + .setLabels( + EnumSet.of(Label.EB_ADDRESS, Label.EB_FAILURE, Label.HTTP_CODE, Label.HTTP_METHOD)) + .setEnabled(true); } public static void setJvmMetrics() { @@ -317,14 +367,16 @@ public static void gracefulShutdown() { LOGGER.debug("number of verticles being undeployed are:" + deployIdSet.size()); // shutdown verticles for (String deploymentId : deployIdSet) { - vertxInstance.undeploy(deploymentId, handler -> { - if (handler.succeeded()) { - LOGGER.debug(deploymentId + " verticle successfully Undeployed"); - latchVerticles.countDown(); - } else { - LOGGER.warn(deploymentId + "Undeploy failed!"); - } - }); + vertxInstance.undeploy( + deploymentId, + handler -> { + if (handler.succeeded()) { + LOGGER.debug(deploymentId + " verticle successfully Undeployed"); + latchVerticles.countDown(); + } else { + LOGGER.warn(deploymentId + "Undeploy failed!"); + } + }); } try { @@ -339,14 +391,15 @@ public static void gracefulShutdown() { try { latchCluster.await(5, TimeUnit.SECONDS); // shutdown vertx - vertxInstance.close(handler -> { - if (handler.succeeded()) { - LOGGER.info("vertx closed succesfully"); - latchVertx.countDown(); - } else { - LOGGER.warn("Vertx didn't close properly, reason:" + handler.cause()); - } - }); + vertxInstance.close( + handler -> { + if (handler.succeeded()) { + LOGGER.info("vertx closed succesfully"); + latchVertx.countDown(); + } else { + LOGGER.warn("Vertx didn't close properly, reason:" + handler.cause()); + } + }); } catch (Exception e) { e.printStackTrace(); } @@ -364,5 +417,4 @@ public static void gracefulShutdown() { e.printStackTrace(); } } - } diff --git a/src/main/java/iudx/data/marketplace/policies/CreatePolicy.java b/src/main/java/iudx/data/marketplace/policies/CreatePolicy.java index fe24aa5d..40beb1e3 100644 --- a/src/main/java/iudx/data/marketplace/policies/CreatePolicy.java +++ b/src/main/java/iudx/data/marketplace/policies/CreatePolicy.java @@ -31,7 +31,8 @@ public class CreatePolicy { private int expiryInMonths; private String consumerEmailId; private String expiryAt; - private User provider; + + // private User provider; public CreatePolicy(PostgresService postgresService, AuditingService auditingService, Api api) { this.postgresService = postgresService; @@ -141,7 +142,6 @@ public Future createPolicy(String orderId) { return policyCreationFuture; }); return policyCreationFuture; - }); return future; diff --git a/src/main/java/iudx/data/marketplace/policies/DeletePolicy.java b/src/main/java/iudx/data/marketplace/policies/DeletePolicy.java index 20ec3b00..fda17d14 100644 --- a/src/main/java/iudx/data/marketplace/policies/DeletePolicy.java +++ b/src/main/java/iudx/data/marketplace/policies/DeletePolicy.java @@ -2,36 +2,22 @@ import static iudx.data.marketplace.apiserver.util.Constants.*; import static iudx.data.marketplace.auditing.util.Constants.*; -import static iudx.data.marketplace.auditing.util.Constants.RESPONSE_SIZE; -import static iudx.data.marketplace.auditing.util.Constants.USERID; import static iudx.data.marketplace.common.HttpStatusCode.BAD_REQUEST; import static iudx.data.marketplace.common.HttpStatusCode.FORBIDDEN; import static iudx.data.marketplace.common.ResponseUrn.FORBIDDEN_URN; import static iudx.data.marketplace.policies.util.Constants.CHECK_IF_POLICY_PRESENT_QUERY; import static iudx.data.marketplace.policies.util.Constants.DELETE_POLICY_QUERY; -import io.vertx.core.AsyncResult; import io.vertx.core.Future; -import io.vertx.core.Handler; import io.vertx.core.Promise; import io.vertx.core.http.HttpMethod; -import io.vertx.core.http.HttpServerRequest; -import io.vertx.core.http.HttpServerResponse; import io.vertx.core.json.JsonObject; -import io.vertx.ext.web.RoutingContext; -import io.vertx.pgclient.PgPool; -import io.vertx.sqlclient.Tuple; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.common.HttpStatusCode; import iudx.data.marketplace.common.ResponseUrn; import iudx.data.marketplace.policies.util.Status; import iudx.data.marketplace.postgres.PostgresService; -import iudx.data.marketplace.postgres.PostgresServiceImpl; - -import java.time.ZoneId; -import java.time.ZonedDateTime; -import java.time.temporal.ChronoUnit; import java.util.UUID; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -40,7 +26,6 @@ public class DeletePolicy { private static final Logger LOG = LoggerFactory.getLogger(DeletePolicy.class); private static final String FAILURE_MESSAGE = "Policy could not be deleted"; private final PostgresService postgresService; - private PgPool pool; private AuditingService auditingService; private Api api; @@ -69,9 +54,7 @@ private String getFailureResponse(JsonObject response, String detail) { public Future executeUpdateQuery(String query, UUID policyUuid, User user) { LOG.debug("inside executeUpdateQuery"); Promise promise = Promise.promise(); - Tuple tuple = Tuple.of(policyUuid); - JsonObject param = new JsonObject() - .put("$1", policyUuid.toString()); + JsonObject param = new JsonObject().put("$1", policyUuid.toString()); postgresService.executePreparedQuery( query, @@ -94,10 +77,12 @@ public Future executeUpdateQuery(String query, UUID policyUuid, User /* sending information for auditing */ /* audit info = Request body + response + extra information if any*/ - JsonObject auditInfo = new JsonObject() + JsonObject auditInfo = + new JsonObject() .put("policyId", policyUuid.toString()) .put("policyStatus", Status.DELETED.toString()); - auditingService.handleAuditLogs(user, auditInfo, api.getPoliciesUrl(), HttpMethod.DELETE.toString()); + auditingService.handleAuditLogs( + user, auditInfo, api.getPoliciesUrl(), HttpMethod.DELETE.toString()); promise.complete(responseJson); } @@ -105,17 +90,16 @@ public Future executeUpdateQuery(String query, UUID policyUuid, User LOG.debug("update query failed"); LOG.error("Failure while executing the query : {}", queryHandler.cause().getMessage()); promise.fail( - new JsonObject() - .put(TYPE, HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) - .put(TITLE, ResponseUrn.DB_ERROR_URN.getUrn()) - .put(DETAIL, "Policy could not be deleted, update query failed") - .encode()); + new JsonObject() + .put(TYPE, HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) + .put(TITLE, ResponseUrn.DB_ERROR_URN.getUrn()) + .put(DETAIL, "Policy could not be deleted, update query failed") + .encode()); } }); return promise.future(); } - /** * Queries postgres table to check if the policy given in the request is owned by the provider or * provider delegate, Checks if the policy that is about to be deleted is ACTIVE or DELETED Checks @@ -131,10 +115,9 @@ public Future verifyPolicy(User user, String query, UUID policyUuid) { String ownerId = user.getUserId(); LOG.info("What's the ownerId : " + ownerId); - JsonObject param = new JsonObject() - .put("$1", policyUuid.toString()); + JsonObject param = new JsonObject().put("$1", policyUuid.toString()); postgresService.executePreparedQuery( - query, + query, param, queryHandler -> { if (queryHandler.succeeded()) { diff --git a/src/main/java/iudx/data/marketplace/policies/FetchPolicyUsingPvId.java b/src/main/java/iudx/data/marketplace/policies/FetchPolicyUsingPvId.java index ecb51076..c5709481 100644 --- a/src/main/java/iudx/data/marketplace/policies/FetchPolicyUsingPvId.java +++ b/src/main/java/iudx/data/marketplace/policies/FetchPolicyUsingPvId.java @@ -1,5 +1,9 @@ package iudx.data.marketplace.policies; +import static iudx.data.marketplace.policies.util.Constants.FETCH_POLICY; +import static iudx.data.marketplace.policies.util.Constants.FETCH_PRODUCT_VARIANT; +import static iudx.data.marketplace.product.util.Constants.RESULTS; + import io.vertx.core.Future; import io.vertx.core.Promise; import io.vertx.core.json.JsonObject; @@ -7,15 +11,11 @@ import iudx.data.marketplace.common.RespBuilder; import iudx.data.marketplace.common.ResponseUrn; import iudx.data.marketplace.postgres.PostgresService; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.util.List; import java.util.stream.Collectors; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; -import static iudx.data.marketplace.policies.util.Constants.FETCH_POLICY; -import static iudx.data.marketplace.policies.util.Constants.FETCH_PRODUCT_VARIANT; -import static iudx.data.marketplace.product.util.Constants.RESULTS; public class FetchPolicyUsingPvId { private static final Logger LOG = LoggerFactory.getLogger(FetchPolicyUsingPvId.class); private PostgresService postgresService; diff --git a/src/main/java/iudx/data/marketplace/policies/GetPolicy.java b/src/main/java/iudx/data/marketplace/policies/GetPolicy.java index 07138fb9..317cb2e9 100644 --- a/src/main/java/iudx/data/marketplace/policies/GetPolicy.java +++ b/src/main/java/iudx/data/marketplace/policies/GetPolicy.java @@ -1,35 +1,28 @@ package iudx.data.marketplace.policies; +import static iudx.data.marketplace.apiserver.util.Constants.*; +import static iudx.data.marketplace.common.HttpStatusCode.BAD_REQUEST; +import static iudx.data.marketplace.policies.util.Constants.GET_POLICY_4_CONSUMER_QUERY; +import static iudx.data.marketplace.policies.util.Constants.GET_POLICY_4_PROVIDER_QUERY; + import io.vertx.core.Future; import io.vertx.core.Promise; -import io.vertx.core.json.JsonArray; import io.vertx.core.json.JsonObject; -import io.vertx.sqlclient.Tuple; import iudx.data.marketplace.apiserver.util.Role; - import iudx.data.marketplace.common.HttpStatusCode; import iudx.data.marketplace.common.ResponseUrn; import iudx.data.marketplace.postgres.PostgresService; -import iudx.data.marketplace.postgres.PostgresServiceImpl; import org.slf4j.Logger; import org.slf4j.LoggerFactory; - -import static iudx.data.marketplace.apiserver.util.Constants.*; -import static iudx.data.marketplace.common.HttpStatusCode.BAD_REQUEST; -import static iudx.data.marketplace.policies.util.Constants.GET_POLICY_4_CONSUMER_QUERY; -import static iudx.data.marketplace.policies.util.Constants.GET_POLICY_4_PROVIDER_QUERY; - public class GetPolicy { - private static final Logger LOG = LoggerFactory.getLogger(GetPolicy.class); - public static final String FAILURE_MESSAGE = "Policy could not be fetched"; - - private final PostgresService postgresService; + public static final String FAILURE_MESSAGE = "Policy could not be fetched"; + private static final Logger LOG = LoggerFactory.getLogger(GetPolicy.class); + private final PostgresService postgresService; public GetPolicy(PostgresService postgresService) { this.postgresService = postgresService; -} - + } public Future initiateGetPolicy(User user) { Role role = user.getUserRole(); @@ -64,9 +57,9 @@ public Future getProviderPolicy(User provider, String query) { String resourceServerUrl = provider.getResourceServerUrl(); LOG.trace(provider.toString()); - String finalQuery = query.replace("$1", "'" + ownerIdValue + "'") - .replace("$2", "'" + resourceServerUrl + "'"); -// Tuple tuple = Tuple.of(ownerIdValue, resourceServerUrl); + String finalQuery = + query.replace("$1", "'" + ownerIdValue + "'").replace("$2", "'" + resourceServerUrl + "'"); + // Tuple tuple = Tuple.of(ownerIdValue, resourceServerUrl); JsonObject jsonObject = new JsonObject() .put("email", provider.getEmailId()) @@ -105,7 +98,7 @@ public Future getConsumerPolicy(User consumer, String query) { String emailId = consumer.getEmailId(); String resourceServerUrl = consumer.getResourceServerUrl(); LOG.trace(consumer.toString()); -// Tuple tuple = Tuple.of("consumer@gmail.com", resourceServerUrl); + // Tuple tuple = Tuple.of("consumer@gmail.com", resourceServerUrl); JsonObject jsonObject = new JsonObject() .put("email", emailId) @@ -117,7 +110,8 @@ public Future getConsumerPolicy(User consumer, String query) { .put("id", consumer.getUserId()); JsonObject consumerInfo = new JsonObject().put("consumer", jsonObject); - String finalQuery = query + String finalQuery = + query .replace("$1", "'" + consumer.getEmailId() + "'") .replace("$2", "'" + resourceServerUrl + "'"); this.executeGetPolicy(finalQuery, consumerInfo, Role.CONSUMER) @@ -141,47 +135,44 @@ public Future getConsumerPolicy(User consumer, String query) { * @param information Information to be added in the response * @return the response as Future JsonObject type */ - private Future executeGetPolicy( - String query, JsonObject information, Role role) { + private Future executeGetPolicy(String query, JsonObject information, Role role) { Promise promise = Promise.promise(); - postgresService - .executeQuery(query, handler -> { - if(handler.succeeded()) - { + postgresService.executeQuery( + query, + handler -> { + if (handler.succeeded()) { boolean isResultFromDbEmpty = handler.result().getJsonArray(RESULTS).isEmpty(); if (!isResultFromDbEmpty) { - for(int i = 0; i < handler.result().getJsonArray(RESULTS).size() ; i++) - { + for (int i = 0; i < handler.result().getJsonArray(RESULTS).size(); i++) { JsonObject jsonObject = handler.result().getJsonArray(RESULTS).getJsonObject(i); jsonObject.mergeIn(information).mergeIn(getInformation(jsonObject, role)); } JsonObject response = - new JsonObject() - .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) - .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) - .put(RESULT, handler.result().getJsonArray(RESULTS)); + new JsonObject() + .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) + .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) + .put(RESULT, handler.result().getJsonArray(RESULTS)); promise.complete( - new JsonObject() - .put(RESULT, response) - .put(STATUS_CODE, HttpStatusCode.SUCCESS.getValue())); + new JsonObject() + .put(RESULT, response) + .put(STATUS_CODE, HttpStatusCode.SUCCESS.getValue())); } else { JsonObject response = - new JsonObject() - .put(TYPE, HttpStatusCode.NOT_FOUND.getValue()) - .put(TITLE, ResponseUrn.RESOURCE_NOT_FOUND_URN.getUrn()) - .put(DETAIL, "Policy Not found"); + new JsonObject() + .put(TYPE, HttpStatusCode.NOT_FOUND.getValue()) + .put(TITLE, ResponseUrn.RESOURCE_NOT_FOUND_URN.getUrn()) + .put(DETAIL, "Policy Not found"); LOG.error("No policy found!"); promise.fail(response.encode()); } - }else - { + } else { LOG.error("Failed : " + handler.cause()); JsonObject failureMessage = - new JsonObject() - .put(TYPE, HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) - .put(TITLE, ResponseUrn.DB_ERROR_URN.getUrn()) - .put(DETAIL, FAILURE_MESSAGE + ", Failure while executing query"); + new JsonObject() + .put(TYPE, HttpStatusCode.INTERNAL_SERVER_ERROR.getValue()) + .put(TITLE, ResponseUrn.DB_ERROR_URN.getUrn()) + .put(DETAIL, FAILURE_MESSAGE + ", Failure while executing query"); promise.fail(failureMessage.encode()); } }); diff --git a/src/main/java/iudx/data/marketplace/policies/PolicyService.java b/src/main/java/iudx/data/marketplace/policies/PolicyService.java index 39cb54ab..69f54721 100644 --- a/src/main/java/iudx/data/marketplace/policies/PolicyService.java +++ b/src/main/java/iudx/data/marketplace/policies/PolicyService.java @@ -25,5 +25,6 @@ static PolicyService createProxy(Vertx vertx, String address) { Future getPolicies(User user); Future verifyPolicy(JsonObject jsonObject); + Future checkPolicy(String productVariantId, User user); } diff --git a/src/main/java/iudx/data/marketplace/policies/PolicyServiceImpl.java b/src/main/java/iudx/data/marketplace/policies/PolicyServiceImpl.java index 1e2ff00f..71b75eef 100644 --- a/src/main/java/iudx/data/marketplace/policies/PolicyServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/policies/PolicyServiceImpl.java @@ -6,32 +6,32 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -public class PolicyServiceImpl implements PolicyService{ - private static final Logger LOG = LoggerFactory.getLogger(PolicyServiceImpl.class); - private final DeletePolicy deletePolicy; - private final GetPolicy getPolicy; - private final CreatePolicy createPolicy; - private final VerifyPolicy verifyPolicy; - private final FetchPolicyUsingPvId fetchPolicy; +public class PolicyServiceImpl implements PolicyService { + private static final Logger LOG = LoggerFactory.getLogger(PolicyServiceImpl.class); + private final DeletePolicy deletePolicy; + private final GetPolicy getPolicy; + private final CreatePolicy createPolicy; + private final VerifyPolicy verifyPolicy; + private final FetchPolicyUsingPvId fetchPolicy; - JsonObject config; + JsonObject config; - public PolicyServiceImpl( - DeletePolicy deletePolicy, - CreatePolicy createPolicy, - GetPolicy getPolicy, - VerifyPolicy verifyPolicy, - FetchPolicyUsingPvId fetchPolicyUsingPvId) { - this.deletePolicy = deletePolicy; - this.createPolicy = createPolicy; - this.getPolicy = getPolicy; - this.verifyPolicy = verifyPolicy; - this.fetchPolicy = fetchPolicyUsingPvId; - } + public PolicyServiceImpl( + DeletePolicy deletePolicy, + CreatePolicy createPolicy, + GetPolicy getPolicy, + VerifyPolicy verifyPolicy, + FetchPolicyUsingPvId fetchPolicyUsingPvId) { + this.deletePolicy = deletePolicy; + this.createPolicy = createPolicy; + this.getPolicy = getPolicy; + this.verifyPolicy = verifyPolicy; + this.fetchPolicy = fetchPolicyUsingPvId; + } - @Override - public Future createPolicy(String orderId) { - Promise promise = Promise.promise(); + @Override + public Future createPolicy(String orderId) { + Promise promise = Promise.promise(); createPolicy .createPolicy(orderId) .onComplete( @@ -42,78 +42,78 @@ public Future createPolicy(String orderId) { promise.fail(handler.cause().getMessage()); } }); - return promise.future(); - } + return promise.future(); + } - @Override - public Future deletePolicy(JsonObject policy, User user) { - Promise promise = Promise.promise(); - this.deletePolicy - .initiateDeletePolicy(policy, user) - .onComplete( - handler -> { - if (handler.succeeded()) { - LOG.info("Successfully deleted the policy"); - promise.complete(handler.result()); - } else { - LOG.error("Failed to delete the policy"); - promise.fail(handler.cause().getMessage()); - } - }); - return promise.future(); - } + @Override + public Future deletePolicy(JsonObject policy, User user) { + Promise promise = Promise.promise(); + this.deletePolicy + .initiateDeletePolicy(policy, user) + .onComplete( + handler -> { + if (handler.succeeded()) { + LOG.info("Successfully deleted the policy"); + promise.complete(handler.result()); + } else { + LOG.error("Failed to delete the policy"); + promise.fail(handler.cause().getMessage()); + } + }); + return promise.future(); + } - @Override - public Future getPolicies(User user) { - Promise promise = Promise.promise(); - this.getPolicy - .initiateGetPolicy(user) - .onComplete( - handler -> { - if (handler.succeeded()) { - LOG.info("GET policy successful"); - promise.complete(handler.result()); - } else { - LOG.error("Failed to execute GET policy"); - promise.fail(handler.cause().getMessage()); - } - }); - return promise.future(); - } + @Override + public Future getPolicies(User user) { + Promise promise = Promise.promise(); + this.getPolicy + .initiateGetPolicy(user) + .onComplete( + handler -> { + if (handler.succeeded()) { + LOG.info("GET policy successful"); + promise.complete(handler.result()); + } else { + LOG.error("Failed to execute GET policy"); + promise.fail(handler.cause().getMessage()); + } + }); + return promise.future(); + } - @Override - public Future verifyPolicy(JsonObject jsonObject) { - Promise promise = Promise.promise(); + @Override + public Future verifyPolicy(JsonObject jsonObject) { + Promise promise = Promise.promise(); - this.verifyPolicy - .initiateVerifyPolicy(jsonObject) - .onComplete( - handler -> { - if (handler.succeeded()) { - promise.complete(handler.result()); - } else { - LOG.error("Failed to verify policy"); - promise.fail(handler.cause().getMessage()); - } - }); - return promise.future(); - } + this.verifyPolicy + .initiateVerifyPolicy(jsonObject) + .onComplete( + handler -> { + if (handler.succeeded()) { + promise.complete(handler.result()); + } else { + LOG.error("Failed to verify policy"); + promise.fail(handler.cause().getMessage()); + } + }); + return promise.future(); + } - @Override - public Future checkPolicy(String productVariantId, User user) { - Promise promise = Promise.promise(); + @Override + public Future checkPolicy(String productVariantId, User user) { + Promise promise = Promise.promise(); - this.fetchPolicy - .checkIfPolicyExists(productVariantId, user) - .onComplete( - handler -> { - if (handler.succeeded()) { - promise.complete(handler.result()); - } else { - LOG.error("Failed to verify policy"); - promise.fail(handler.cause().getMessage()); - } - }); - return promise.future(); - } + this.fetchPolicy + .checkIfPolicyExists(productVariantId, user) + .onComplete( + handler -> { + if (handler.succeeded()) { + promise.complete(handler.result()); + } else { + LOG.error("Failed to verify policy"); + promise.fail(handler.cause().getMessage()); + } + }); + return promise.future(); + } } diff --git a/src/main/java/iudx/data/marketplace/policies/PolicyVerticle.java b/src/main/java/iudx/data/marketplace/policies/PolicyVerticle.java index 655e89a2..4d1ab071 100644 --- a/src/main/java/iudx/data/marketplace/policies/PolicyVerticle.java +++ b/src/main/java/iudx/data/marketplace/policies/PolicyVerticle.java @@ -1,25 +1,12 @@ package iudx.data.marketplace.policies; +import static iudx.data.marketplace.common.Constants.*; + import io.vertx.core.AbstractVerticle; -import io.vertx.core.Vertx; -import io.vertx.pgclient.PgConnectOptions; -import io.vertx.pgclient.PgPool; import io.vertx.serviceproxy.ServiceBinder; -import io.vertx.sqlclient.PoolOptions; -import iudx.data.marketplace.apiserver.ApiServerVerticle; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; -import iudx.data.marketplace.common.CatalogueService; import iudx.data.marketplace.postgres.PostgresService; -import iudx.data.marketplace.postgres.PostgresServiceImpl; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import iudx.data.marketplace.common.CatalogueService; -import iudx.data.marketplace.postgres.PostgresServiceImpl; - -import java.util.Map; - -import static iudx.data.marketplace.common.Constants.*; public class PolicyVerticle extends AbstractVerticle { @@ -29,14 +16,12 @@ public class PolicyVerticle extends AbstractVerticle { private CreatePolicy createPolicy; private VerifyPolicy verifyPolicy; private GetPolicy getPolicy; - private CatalogueService catalogueService; private AuditingService auditingService; private Api api; private FetchPolicyUsingPvId fetchPolicyUsingPvId; @Override public void start() { - catalogueService = new CatalogueService(vertx, config()); postgresServiceImpl = PostgresService.createProxy(vertx, POSTGRES_SERVICE_ADDRESS); auditingService = AuditingService.createProxy(vertx, AUDITING_SERVICE_ADDRESS); api = Api.getInstance(config().getString("dxApiBasePath")); @@ -46,7 +31,8 @@ public void start() { verifyPolicy = new VerifyPolicy(postgresServiceImpl); fetchPolicyUsingPvId = new FetchPolicyUsingPvId(postgresServiceImpl); policyService = - new PolicyServiceImpl(deletePolicy, createPolicy, getPolicy, verifyPolicy,fetchPolicyUsingPvId); + new PolicyServiceImpl( + deletePolicy, createPolicy, getPolicy, verifyPolicy, fetchPolicyUsingPvId); new ServiceBinder(vertx) .setAddress(POLICY_SERVICE_ADDRESS) diff --git a/src/main/java/iudx/data/marketplace/policies/User.java b/src/main/java/iudx/data/marketplace/policies/User.java index 8d4f3336..1d182336 100644 --- a/src/main/java/iudx/data/marketplace/policies/User.java +++ b/src/main/java/iudx/data/marketplace/policies/User.java @@ -1,14 +1,12 @@ package iudx.data.marketplace.policies; +import static iudx.data.marketplace.apiserver.util.Constants.*; + import io.vertx.codegen.annotations.DataObject; import io.vertx.core.json.JsonObject; import iudx.data.marketplace.apiserver.util.Role; -import iudx.data.marketplace.policies.UserConverter; - import java.util.Objects; -import static iudx.data.marketplace.apiserver.util.Constants.*; - /** * User class is used to initialize information about the user like id, role, email-Id etc.,
    * User class can store information about Consumer, Provider.
    @@ -96,8 +94,12 @@ public String toString() { @Override public boolean equals(Object o) { - if (this == o) return true; - if (!(o instanceof User)) return false; + if (this == o) { + return true; + } + if (!(o instanceof User)) { + return false; + } User user = (User) o; return Objects.equals(userId, user.userId) && userRole == user.userRole diff --git a/src/main/java/iudx/data/marketplace/policies/VerifyPolicy.java b/src/main/java/iudx/data/marketplace/policies/VerifyPolicy.java index e3399b1c..34845b54 100644 --- a/src/main/java/iudx/data/marketplace/policies/VerifyPolicy.java +++ b/src/main/java/iudx/data/marketplace/policies/VerifyPolicy.java @@ -1,30 +1,23 @@ package iudx.data.marketplace.policies; +import static iudx.data.marketplace.apiserver.util.Constants.*; +import static iudx.data.marketplace.common.HttpStatusCode.INTERNAL_SERVER_ERROR; +import static iudx.data.marketplace.common.HttpStatusCode.VERIFY_FORBIDDEN; +import static iudx.data.marketplace.policies.util.Constants.*; + import io.vertx.core.Future; import io.vertx.core.Promise; import io.vertx.core.json.JsonArray; import io.vertx.core.json.JsonObject; -import io.vertx.sqlclient.Row; -import io.vertx.sqlclient.Tuple; -import iudx.data.marketplace.common.CatalogueService; import iudx.data.marketplace.common.HttpStatusCode; import iudx.data.marketplace.common.ResponseUrn; import iudx.data.marketplace.policies.util.Status; import iudx.data.marketplace.postgres.PostgresService; -import iudx.data.marketplace.postgres.PostgresServiceImpl; +import java.util.UUID; import org.apache.commons.lang.StringUtils; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import java.util.HashSet; -import java.util.Set; -import java.util.UUID; - -import static iudx.data.marketplace.apiserver.util.Constants.*; -import static iudx.data.marketplace.common.HttpStatusCode.INTERNAL_SERVER_ERROR; -import static iudx.data.marketplace.common.HttpStatusCode.VERIFY_FORBIDDEN; -import static iudx.data.marketplace.policies.util.Constants.*; - public class VerifyPolicy { private static final Logger LOGGER = LogManager.getLogger(VerifyPolicy.class); private final PostgresService postgresService; @@ -41,17 +34,16 @@ public Future initiateVerifyPolicy(JsonObject request) { String userEmail = request.getJsonObject("user").getString("email"); UUID itemId = UUID.fromString(request.getJsonObject("item").getString("itemId")); - /*check if the orderId is present in the context object*/ - if(request.containsKey("context") && StringUtils.isNotBlank(request.getJsonObject("context").getString("orderId"))) - { - String orderId = request.getJsonObject("context").getString("orderId"); - setOrderId(orderId); - } + /*check if the orderId is present in the context object*/ + if (request.containsKey("context") + && StringUtils.isNotBlank(request.getJsonObject("context").getString("orderId"))) { + String orderId = request.getJsonObject("context").getString("orderId"); + setOrderId(orderId); + } Future checkForExistingPolicy = checkExistingPoliciesForId(itemId, ownerId, userEmail); - Future getPolicyDetail = checkForExistingPolicy.compose( isPolicyExist -> { @@ -79,60 +71,60 @@ public Future initiateVerifyPolicy(JsonObject request) { private Future checkExistingPoliciesForId( UUID itemId, UUID ownerId, String userEmailId) { - Tuple selectTuples = Tuple.of(itemId, ownerId, Status.ACTIVE, userEmailId); String query; - JsonObject params = new JsonObject() + JsonObject params = + new JsonObject() .put("itemId", itemId.toString()) .put("ownerId", ownerId.toString()) .put("status", Status.ACTIVE) .put("userEmailId", userEmailId); - if(StringUtils.isNotBlank(getOrderId())) - { - query = CHECK_POLICY_FROM_ORDER_ID; - params.put("orderId", getOrderId()); - } else { - query = CHECK_EXISTING_POLICY; - } - - Promise promise = Promise.promise(); - postgresService - .executePreparedQuery(query, params, handler -> { - if(handler.failed()){ - LOGGER.error( - "isPolicyForIdExist fail, DB execution failed :: {}", - handler.cause().getMessage()); + if (StringUtils.isNotBlank(getOrderId())) { + query = CHECK_POLICY_FROM_ORDER_ID; + params.put("orderId", getOrderId()); + } else { + query = CHECK_EXISTING_POLICY; + } + + Promise promise = Promise.promise(); + postgresService.executePreparedQuery( + query, + params, + handler -> { + if (handler.failed()) { + LOGGER.error( + "isPolicyForIdExist fail, DB execution failed :: {}", handler.cause().getMessage()); + promise.fail( + generateErrorResponse( + INTERNAL_SERVER_ERROR, INTERNAL_SERVER_ERROR.getDescription())); + } else { + JsonArray policy = handler.result().getJsonArray(RESULT); + boolean isPolicyNotPresent = policy.isEmpty(); + if (isPolicyNotPresent) { + LOGGER.error("No matching policy"); + promise.complete(new JsonObject()); + } else { + LOGGER.debug("policy exists : {} ", handler.result().encode()); + if (handler.result().getJsonArray(RESULT).size() > 1 + && query.equals(CHECK_POLICY_FROM_ORDER_ID)) { + LOGGER.fatal( + "Fetched more than 1 policy for a single" + + " resource with a single orderId : {}", + orderId); promise.fail( - generateErrorResponse( - INTERNAL_SERVER_ERROR, INTERNAL_SERVER_ERROR.getDescription())); - } - else - { - JsonArray policy = handler.result().getJsonArray(RESULT); - boolean isPolicyNotPresent = policy.isEmpty(); - if (isPolicyNotPresent) { - LOGGER.error("No matching policy"); - promise.complete(new JsonObject()); - } else { - LOGGER.debug("policy exists : {} ", handler.result().encode()); - if(handler.result().getJsonArray(RESULT).size() > 1 && query.equals(CHECK_POLICY_FROM_ORDER_ID)) - { - LOGGER.fatal("Fetched more than 1 policy for a single" + - " resource with a single orderId : {}",orderId); - promise.fail( - generateErrorResponse( - INTERNAL_SERVER_ERROR, INTERNAL_SERVER_ERROR.getDescription())); - return; - } - JsonObject result = handler.result().getJsonArray(RESULT).getJsonObject(0); - JsonObject constraints = result.getJsonObject("constraints"); - String policyId = result.getString("_id"); - JsonObject response = - new JsonObject().put("constraints", constraints).put("id", policyId); - promise.complete(response); - } + generateErrorResponse( + INTERNAL_SERVER_ERROR, INTERNAL_SERVER_ERROR.getDescription())); + return; + } + JsonObject result = handler.result().getJsonArray(RESULT).getJsonObject(0); + JsonObject constraints = result.getJsonObject("constraints"); + String policyId = result.getString("_id"); + JsonObject response = + new JsonObject().put("constraints", constraints).put("id", policyId); + promise.complete(response); } + } }); return promise.future(); @@ -146,13 +138,11 @@ public String generateErrorResponse(HttpStatusCode httpStatusCode, String errorM .encode(); } - private String getOrderId() { - return this.orderId; - } - private void setOrderId(String orderId) - { - this.orderId = orderId; - } - + private String getOrderId() { + return this.orderId; + } + private void setOrderId(String orderId) { + this.orderId = orderId; + } } diff --git a/src/main/java/iudx/data/marketplace/policies/util/Constants.java b/src/main/java/iudx/data/marketplace/policies/util/Constants.java index 2382b5cb..cc3244f1 100644 --- a/src/main/java/iudx/data/marketplace/policies/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/policies/util/Constants.java @@ -1,76 +1,76 @@ package iudx.data.marketplace.policies.util; public class Constants { - public static final String CHECK_EXISTING_POLICY = - "SELECT _id,constraints FROM policy " - + "WHERE resource_id =$1::UUID AND provider_id = $2::UUID AND status = $3::policy_status" - + " AND consumer_email_id = $4::text AND expiry_at > now()"; + public static final String CHECK_EXISTING_POLICY = + "SELECT _id,constraints FROM policy " + + "WHERE resource_id =$1::UUID AND provider_id = $2::UUID AND status = $3::policy_status" + + " AND consumer_email_id = $4::text AND expiry_at > now()"; - public static final String CHECK_POLICY_FROM_ORDER_ID = - " SELECT _id,constraints FROM policy " + - " WHERE resource_id =$1::UUID " + - " AND provider_id = $2::UUID AND status = $3::policy_status " + - " AND consumer_email_id = $4::text " + - " AND expiry_at > now() " + - " AND invoice_id = ( SELECT I._id FROM invoice AS I WHERE I.order_id = $5::text)"; + public static final String CHECK_POLICY_FROM_ORDER_ID = + " SELECT _id,constraints FROM policy " + + " WHERE resource_id =$1::UUID " + + " AND provider_id = $2::UUID AND status = $3::policy_status " + + " AND consumer_email_id = $4::text " + + " AND expiry_at > now() " + + " AND invoice_id = ( SELECT I._id FROM invoice AS I WHERE I.order_id = $5::text)"; - public static final String CREATE_POLICY_QUERY = - "INSERT INTO public.policy( " + - " _id, resource_id, invoice_id, constraints, provider_id, consumer_email_id, expiry_at, " + - " status, product_variant_id) " + - " VALUES ('$1', '$2', '$3', '$4'::JSON, '$5', '$6', '$7', '$8', '$9') RETURNING _id;"; + public static final String CREATE_POLICY_QUERY = + "INSERT INTO public.policy( " + + " _id, resource_id, invoice_id, constraints, provider_id, consumer_email_id, expiry_at, " + + " status, product_variant_id) " + + " VALUES ('$1', '$2', '$3', '$4'::JSON, '$5', '$6', '$7', '$8', '$9') RETURNING _id;"; - public static final String GET_POLICY_4_PROVIDER_QUERY = - "SELECT P._id AS \"policyId\", P.resource_id AS \"resourceId\",\n" - + "RE.resource_server AS \"resourceServerUrl\",\n" - + "P.invoice_id AS \"purchaseId\",\n" - + "RE.resource_name AS \"resourceName\",\n" - + "P.product_variant_id AS \"productVariantId\",\n" - + "RE.accesspolicy AS \"accessPolicy\",\n" - + "P.consumer_email_id AS \"consumerEmailId\",\n" - + "U.first_name AS \"consumerFirstName\",\n" - + "U.last_name AS \"consumerLastName\", U._id AS \"consumerId\",\n" - + "P.status AS \"status\", P.expiry_at AS \"expiryAt\",\n" - + "P.constraints AS \"constraints\" " - + " ,P.modified_at AS \"updatedAt\" " - + " ,P.created_at AS \"createdAt\" " - + " FROM policy AS P \n" - + "LEFT JOIN user_table AS U\n" - + "ON P.consumer_email_id = U.email_id \n" - + "INNER JOIN resource_entity AS RE\n" - + "ON RE._id = P.resource_id\n" - + "AND P.provider_id = $1::uuid \n" - + "AND RE.resource_server = $2 " - + " ORDER BY P.modified_at DESC"; - public static final String GET_POLICY_4_CONSUMER_QUERY = - "SELECT P._id AS \"policyId\", P.resource_id AS \"resourceId\",\n" - + "RE.resource_server AS \"resourceServerUrl\",\n" - + "P.invoice_id AS \"purchaseId\",\n" - + "RE.resource_name AS \"resourceName\",\n" - + "P.product_variant_id AS \"productVariantId\",\n" - + "RE.accesspolicy AS \"accessPolicy\",\n" - + "P.provider_id AS \"providerId\", U.first_name AS \"providerFirstName\",\n" - + "U.last_name AS \"providerLastName\", U.email_id AS \"providerEmailId\",\n" - + "P.status as \"status\", P.expiry_at AS \"expiryAt\",\n" - + "P.constraints AS \"constraints\" \n" - + " ,P.modified_at AS \"updatedAt\" " - + " ,P.created_at AS \"createdAt\" " - + "FROM policy AS P \n" - + "INNER JOIN user_table AS U\n" - + "ON P.provider_id = U._id \n" - + "INNER JOIN resource_entity AS RE\n" - + "ON RE._id = P.resource_id\n" - + "AND P.consumer_email_id = $1 \n" - + "AND RE.resource_server = $2 " - + " ORDER BY P.modified_at DESC"; - public static final String DELETE_POLICY_QUERY = - "UPDATE policy SET status='DELETED' " - + "WHERE _id = $1::uuid AND expiry_at > NOW() RETURNING _id"; - public static final String CHECK_IF_POLICY_PRESENT_QUERY = - "SELECT p.provider_id, p.status, r.resource_server" - + " FROM policy p" - + " INNER JOIN resource_entity r ON p.resource_id = r._id" - + " WHERE p._id = $1;"; + public static final String GET_POLICY_4_PROVIDER_QUERY = + "SELECT P._id AS \"policyId\", P.resource_id AS \"resourceId\",\n" + + "RE.resource_server AS \"resourceServerUrl\",\n" + + "P.invoice_id AS \"purchaseId\",\n" + + "RE.resource_name AS \"resourceName\",\n" + + "P.product_variant_id AS \"productVariantId\",\n" + + "RE.accesspolicy AS \"accessPolicy\",\n" + + "P.consumer_email_id AS \"consumerEmailId\",\n" + + "U.first_name AS \"consumerFirstName\",\n" + + "U.last_name AS \"consumerLastName\", U._id AS \"consumerId\",\n" + + "P.status AS \"status\", P.expiry_at AS \"expiryAt\",\n" + + "P.constraints AS \"constraints\" " + + " ,P.modified_at AS \"updatedAt\" " + + " ,P.created_at AS \"createdAt\" " + + " FROM policy AS P \n" + + "LEFT JOIN user_table AS U\n" + + "ON P.consumer_email_id = U.email_id \n" + + "INNER JOIN resource_entity AS RE\n" + + "ON RE._id = P.resource_id\n" + + "AND P.provider_id = $1::uuid \n" + + "AND RE.resource_server = $2 " + + " ORDER BY P.modified_at DESC"; + public static final String GET_POLICY_4_CONSUMER_QUERY = + "SELECT P._id AS \"policyId\", P.resource_id AS \"resourceId\",\n" + + "RE.resource_server AS \"resourceServerUrl\",\n" + + "P.invoice_id AS \"purchaseId\",\n" + + "RE.resource_name AS \"resourceName\",\n" + + "P.product_variant_id AS \"productVariantId\",\n" + + "RE.accesspolicy AS \"accessPolicy\",\n" + + "P.provider_id AS \"providerId\", U.first_name AS \"providerFirstName\",\n" + + "U.last_name AS \"providerLastName\", U.email_id AS \"providerEmailId\",\n" + + "P.status as \"status\", P.expiry_at AS \"expiryAt\",\n" + + "P.constraints AS \"constraints\" \n" + + " ,P.modified_at AS \"updatedAt\" " + + " ,P.created_at AS \"createdAt\" " + + "FROM policy AS P \n" + + "INNER JOIN user_table AS U\n" + + "ON P.provider_id = U._id \n" + + "INNER JOIN resource_entity AS RE\n" + + "ON RE._id = P.resource_id\n" + + "AND P.consumer_email_id = $1 \n" + + "AND RE.resource_server = $2 " + + " ORDER BY P.modified_at DESC"; + public static final String DELETE_POLICY_QUERY = + "UPDATE policy SET status='DELETED' " + + "WHERE _id = $1::uuid AND expiry_at > NOW() RETURNING _id"; + public static final String CHECK_IF_POLICY_PRESENT_QUERY = + "SELECT p.provider_id, p.status, r.resource_server" + + " FROM policy p" + + " INNER JOIN resource_entity r ON p.resource_id = r._id" + + " WHERE p._id = $1;"; public static final String GET_REQUIRED_INFO_QUERY = "SELECT DISTINCT I._id AS \"invoiceId\", I.product_variant_id AS \"productVariantId\", I.expiry, " @@ -88,17 +88,16 @@ public class Constants { + " WHERE payment_status = 'SUCCEEDED' " + " AND order_id = '$1';"; - public static final String FETCH_PRODUCT_VARIANT = - " SELECT \"resourceServerUrl\", \"resources\" " - + "FROM product_variant_view " - + "WHERE \"productVariantId\" = '$1' " - + "AND \"productVariantStatus\" = 'ACTIVE'"; + public static final String FETCH_PRODUCT_VARIANT = + " SELECT \"resourceServerUrl\", \"resources\" " + + "FROM product_variant_view " + + "WHERE \"productVariantId\" = '$1' " + + "AND \"productVariantStatus\" = 'ACTIVE'"; - - public static final String FETCH_POLICY = - " SELECT DISTINCT resource_id AS \"resources\" FROM policy " - + "WHERE resource_id = ANY($1) " - + "AND status = 'ACTIVE' " - + " AND consumer_email_id = $2" - + " AND expiry_at > NOW(); "; -} \ No newline at end of file + public static final String FETCH_POLICY = + " SELECT DISTINCT resource_id AS \"resources\" FROM policy " + + "WHERE resource_id = ANY($1) " + + "AND status = 'ACTIVE' " + + " AND consumer_email_id = $2" + + " AND expiry_at > NOW(); "; +} diff --git a/src/main/java/iudx/data/marketplace/policies/util/Status.java b/src/main/java/iudx/data/marketplace/policies/util/Status.java index 3a34c53e..7a39cadd 100644 --- a/src/main/java/iudx/data/marketplace/policies/util/Status.java +++ b/src/main/java/iudx/data/marketplace/policies/util/Status.java @@ -1,5 +1,6 @@ package iudx.data.marketplace.policies.util; + public enum Status { - ACTIVE, - DELETED; + ACTIVE, + DELETED; } diff --git a/src/main/java/iudx/data/marketplace/postgres/PostgresService.java b/src/main/java/iudx/data/marketplace/postgres/PostgresService.java index 15667a15..addec458 100644 --- a/src/main/java/iudx/data/marketplace/postgres/PostgresService.java +++ b/src/main/java/iudx/data/marketplace/postgres/PostgresService.java @@ -8,16 +8,15 @@ import io.vertx.core.Handler; import io.vertx.core.Vertx; import io.vertx.core.json.JsonObject; - import java.util.List; /** - * The Postgres Service + * The Postgres Service * - *

    Postgres Service

    + *

    Postgres Service

    * - *

    The Postgres Service in the IUDX Data Marketplace defines the operations to be performed - * on the marketplace database

    + *

    The Postgres Service in the IUDX Data Marketplace defines the operations to be performed on + * the marketplace database * * @see io.vertx.codegen.annotations.ProxyGen * @see io.vertx.codegen.annotations.VertxGen @@ -28,6 +27,18 @@ @ProxyGen public interface PostgresService { + /** + * The createProxy helps the code generation blocks to generate proxy code. + * + * @param vertx which is the vertx instance + * @param address which is the proxy address + * @return PostgresServiceVertxRBProxy which is a service proxy + */ + @GenIgnore + static PostgresService createProxy(Vertx vertx, String address) { + return new PostgresServiceVertxEBProxy(vertx, address); + } + /** * The executeQuery implements single query operations with the database. * @@ -49,7 +60,8 @@ public interface PostgresService { PostgresService executeCountQuery(final String query, Handler> handler); /** - * The executePreparedQuery implements a single query operation with configurable queryParams on the database. + * The executePreparedQuery implements a single query operation with configurable queryParams on + * the database. * * @param query which is a String * @param queryparams which is a JsonObject @@ -61,26 +73,18 @@ PostgresService executePreparedQuery( final String query, final JsonObject queryparams, Handler> handler); /** - * The executeTransaction implements a transaction operation(with multiple queries) on the database. + * The executeTransaction implements a transaction operation(with multiple queries) on the + * database. * * @param queries which is a List of String * @param handler which is a Request Handler * @return PostgresService which ia a service */ @Fluent - PostgresService executeTransaction(final List queries, Handler> handler); - - /** - * The createProxy helps the code generation blocks to generate proxy code. - * @param vertx which is the vertx instance - * @param address which is the proxy address - * @return PostgresServiceVertxRBProxy which is a service proxy - */ - @GenIgnore - static PostgresService createProxy(Vertx vertx, String address) { - return new PostgresServiceVertxEBProxy(vertx, address); - } + PostgresService executeTransaction( + final List queries, Handler> handler); @Fluent - PostgresService checkPolicy(final String query,final JsonObject param, Handler> handler); + PostgresService checkPolicy( + final String query, final JsonObject param, Handler> handler); } diff --git a/src/main/java/iudx/data/marketplace/postgres/PostgresServiceImpl.java b/src/main/java/iudx/data/marketplace/postgres/PostgresServiceImpl.java index ef2a7345..12f0a2fc 100644 --- a/src/main/java/iudx/data/marketplace/postgres/PostgresServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/postgres/PostgresServiceImpl.java @@ -1,5 +1,8 @@ package iudx.data.marketplace.postgres; +import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; +import static iudx.data.marketplace.apiserver.util.Constants.STATUS_CODE; + import io.vertx.core.*; import io.vertx.core.AsyncResult; import io.vertx.core.Future; @@ -14,28 +17,58 @@ import iudx.data.marketplace.common.HttpStatusCode; import iudx.data.marketplace.common.RespBuilder; import iudx.data.marketplace.common.ResponseUrn; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - import java.util.ArrayList; import java.util.List; import java.util.UUID; import java.util.concurrent.ConcurrentLinkedQueue; import java.util.stream.Collector; import java.util.stream.Collectors; - -import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; -import static iudx.data.marketplace.apiserver.util.Constants.STATUS_CODE; - +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class PostgresServiceImpl implements PostgresService { private static final Logger LOGGER = LogManager.getLogger(PostgresServiceImpl.class); private final PgPool client; + public PostgresServiceImpl(final PgPool pgclient) { this.client = pgclient; } + private static Future executeBatch( + SqlConnection conn, ConcurrentLinkedQueue statements) { + try { + var statement = statements.poll(); + if (statement == null) { + return Future.succeededFuture(); + } + Promise promise = Promise.promise(); + + Collector> rowCollector = + Collectors.mapping(row -> row.toJson(), Collectors.toList()); + conn.query(statement) + .collecting(rowCollector) + .execute() + .map(rows -> rows.value()) + .onSuccess( + successHandler -> { + executeBatch(conn, statements) + .onComplete( + h -> { + promise.complete(); + }); + }) + .onFailure( + failureHandler -> { + LOGGER.debug("Failure : {}", failureHandler.getMessage()); + LOGGER.error("Fail db"); + promise.fail(failureHandler); + }); + return promise.future(); + } catch (Throwable t) { + return Future.failedFuture(t); + } + } @Override public PostgresService executeQuery( @@ -61,8 +94,8 @@ public PostgresService executeQuery( }) .onFailure( failureHandler -> { - LOGGER.debug("Failure : {}",failureHandler.getMessage() ); - String response = + LOGGER.debug("Failure : {}", failureHandler.getMessage()); + String response = new RespBuilder() .withType(ResponseUrn.DB_ERROR_URN.getUrn()) .withTitle(ResponseUrn.DB_ERROR_URN.getMessage()) @@ -86,8 +119,8 @@ public PostgresService executeCountQuery( }) .onFailure( failureHandler -> { - LOGGER.debug("Failure : {}",failureHandler.getMessage() ); - String response = + LOGGER.debug("Failure : {}", failureHandler.getMessage()); + String response = new RespBuilder() .withType(ResponseUrn.DB_ERROR_URN.getUrn()) .withTitle(ResponseUrn.DB_ERROR_URN.getMessage()) @@ -98,39 +131,6 @@ public PostgresService executeCountQuery( return this; } - private static Future executeBatch( - SqlConnection conn, ConcurrentLinkedQueue statements) { - try { - var statement = statements.poll(); - if (statement == null) { - return Future.succeededFuture(); - } - Promise promise = Promise.promise(); - - Collector> rowCollector = - Collectors.mapping(row -> row.toJson(), Collectors.toList()); - conn.query(statement) - .collecting(rowCollector) - .execute() - .map(rows -> rows.value()) - .onSuccess( - successHandler -> { - executeBatch(conn, statements).onComplete(h -> { - promise.complete(); - }); - }) - .onFailure( - failureHandler -> { - LOGGER.debug("Failure : {}",failureHandler.getMessage() ); - LOGGER.error("Fail db"); - promise.fail(failureHandler); - }); - return promise.future(); - } catch (Throwable t) { - return Future.failedFuture(t); - } - } - @Override public PostgresService executeTransaction( final List queries, Handler> handler) { @@ -139,8 +139,7 @@ public PostgresService executeTransaction( .withTransaction( connection -> { ConcurrentLinkedQueue statements = new ConcurrentLinkedQueue<>(queries); - Future eB = executeBatch(connection, statements); - return eB; + return executeBatch(connection, statements); }) .onComplete( completeHandler -> { @@ -154,8 +153,8 @@ public PostgresService executeTransaction( handler.handle(Future.succeededFuture(responseJson)); } else { LOGGER.debug("transaction failed"); - LOGGER.debug("Failure : {}",completeHandler.cause().getMessage()); - String response = + LOGGER.debug("Failure : {}", completeHandler.cause().getMessage()); + String response = new RespBuilder() .withType(ResponseUrn.DB_ERROR_URN.getUrn()) .withTitle(ResponseUrn.DB_ERROR_URN.getMessage()) @@ -202,7 +201,7 @@ public PostgresService executePreparedQuery( }) .onFailure( failureHandler -> { - LOGGER.debug("Failure : {}",failureHandler.getMessage()); + LOGGER.debug("Failure : {}", failureHandler.getMessage()); String response = new RespBuilder() .withType(ResponseUrn.DB_ERROR_URN.getUrn()) @@ -224,10 +223,10 @@ public PostgresService checkPolicy( LOGGER.debug("query params : " + queryParams.encode()); // Tuple tuple = Tuple.of(resourceIds,consumerEmailId); - UUID[] ids = resourceIds.stream().map(e -> UUID.fromString(e.toString())).toArray(UUID[]::new); + UUID[] ids = resourceIds.stream().map(e -> UUID.fromString(e.toString())).toArray(UUID[]::new); Tuple tuple = Tuple.of(ids, consumerEmailId); - Collector> rowCollector = + Collector> rowCollector = Collectors.mapping(row -> row.toJson(), Collectors.toList()); client @@ -243,8 +242,11 @@ public PostgresService checkPolicy( LOGGER.debug("response from DB from fetch policy : {}", successHandler); if (successHandler.isEmpty()) { LOGGER.error("Empty from DB while fetching policy related info"); - JsonObject response = new JsonObject() - .put(RESULTS, new RespBuilder() + JsonObject response = + new JsonObject() + .put( + RESULTS, + new RespBuilder() .withType(HttpStatusCode.NO_CONTENT.getValue()) .withTitle(HttpStatusCode.NO_CONTENT.getUrn()) .getJsonResponse()); @@ -253,10 +255,13 @@ public PostgresService checkPolicy( response.put(STATUS_CODE, HttpStatusCode.NO_CONTENT.getValue()))); } else { - List resourceId = successHandler.stream().map(e -> e.getString("resources")).collect(Collectors.toList()); + List resourceId = + successHandler.stream() + .map(e -> e.getString("resources")) + .collect(Collectors.toList()); LOGGER.info( "Policy exists for the resource IDs : {} present in the product variant", - resourceId); + resourceId); JsonObject responseJson = new JsonObject() .put( @@ -264,8 +269,9 @@ public PostgresService checkPolicy( new RespBuilder() .withType(ResponseUrn.SUCCESS_URN.getUrn()) .withTitle(ResponseUrn.SUCCESS_URN.getMessage()) - .withDetail("Policy exists for the resource ID(s) : " + - resourceId + .withDetail( + "Policy exists for the resource ID(s) : " + + resourceId + " from the product variant") .getJsonResponse()) .put(STATUS_CODE, HttpStatusCode.SUCCESS.getValue()); diff --git a/src/main/java/iudx/data/marketplace/postgres/PostgresVerticle.java b/src/main/java/iudx/data/marketplace/postgres/PostgresVerticle.java index 77cc2504..2c84ea1d 100644 --- a/src/main/java/iudx/data/marketplace/postgres/PostgresVerticle.java +++ b/src/main/java/iudx/data/marketplace/postgres/PostgresVerticle.java @@ -1,5 +1,7 @@ package iudx.data.marketplace.postgres; +import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; + import io.vertx.core.AbstractVerticle; import io.vertx.core.eventbus.MessageConsumer; import io.vertx.core.json.JsonObject; @@ -10,8 +12,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; - public class PostgresVerticle extends AbstractVerticle { private static final Logger LOGGER = LogManager.getLogger(PostgresVerticle.class); private MessageConsumer consumer; @@ -21,7 +21,7 @@ public class PostgresVerticle extends AbstractVerticle { private PoolOptions poolOptions; private PgPool pool; - private String databaseIP; + private String databaseIp; private int databasePort; private String databaseName; private String databaseUserName; @@ -33,7 +33,7 @@ public class PostgresVerticle extends AbstractVerticle { @Override public void start() throws Exception { - databaseIP = config().getString("databaseIP"); + databaseIp = config().getString("databaseIP"); databasePort = config().getInteger("databasePort"); databaseName = config().getString("databaseName"); databaseUserName = config().getString("databaseUserName"); @@ -43,7 +43,7 @@ public void start() throws Exception { this.connectOptions = new PgConnectOptions() .setPort(databasePort) - .setHost(databaseIP) + .setHost(databaseIp) .setDatabase(databaseName) .setUser(databaseUserName) .setPassword(databasePassword) diff --git a/src/main/java/iudx/data/marketplace/postgres/package-info.java b/src/main/java/iudx/data/marketplace/postgres/package-info.java index 411dd09c..b44b8964 100644 --- a/src/main/java/iudx/data/marketplace/postgres/package-info.java +++ b/src/main/java/iudx/data/marketplace/postgres/package-info.java @@ -1,5 +1,6 @@ -@ModuleGen(groupPackage = "iudx.data.marketplace.postgres", - name="iudx-data-marketplace-postgres-service") +@ModuleGen( + groupPackage = "iudx.data.marketplace.postgres", + name = "iudx-data-marketplace-postgres-service") package iudx.data.marketplace.postgres; -import io.vertx.codegen.annotations.ModuleGen; \ No newline at end of file +import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/product/ProductService.java b/src/main/java/iudx/data/marketplace/product/ProductService.java index 6401480d..bbe044f2 100644 --- a/src/main/java/iudx/data/marketplace/product/ProductService.java +++ b/src/main/java/iudx/data/marketplace/product/ProductService.java @@ -10,7 +10,8 @@ import io.vertx.core.json.JsonObject; import iudx.data.marketplace.policies.User; -@VertxGen @ProxyGen +@VertxGen +@ProxyGen public interface ProductService { /** @@ -25,7 +26,6 @@ static ProductService createProxy(Vertx vertx, String address) { return new ProductServiceVertxEBProxy(vertx, address); } - /** * The createProduct method implements the creation of a product on the IUDX data marketplace. * @@ -34,7 +34,8 @@ static ProductService createProxy(Vertx vertx, String address) { * @return ProductService which is a service */ @Fluent - ProductService createProduct(User user, JsonObject request, Handler> handler); + ProductService createProduct( + User user, JsonObject request, Handler> handler); /** * The deleteProduct method implements the soft delete of a product on the IUDX data marketplace. @@ -44,7 +45,8 @@ static ProductService createProxy(Vertx vertx, String address) { * @return ProductService which is a service */ @Fluent - ProductService deleteProduct(User user, JsonObject request, Handler> handler); + ProductService deleteProduct( + User user, JsonObject request, Handler> handler); /** * The listProduct method fetches some or all the products available on the IUDX data marketplace @@ -54,6 +56,6 @@ static ProductService createProxy(Vertx vertx, String address) { * @return ProductService which is a service */ @Fluent - ProductService listProducts(User user, JsonObject request, Handler> handler); - + ProductService listProducts( + User user, JsonObject request, Handler> handler); } diff --git a/src/main/java/iudx/data/marketplace/product/ProductServiceImpl.java b/src/main/java/iudx/data/marketplace/product/ProductServiceImpl.java index 4b1a329d..c8076675 100644 --- a/src/main/java/iudx/data/marketplace/product/ProductServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/product/ProductServiceImpl.java @@ -1,7 +1,6 @@ package iudx.data.marketplace.product; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.*; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.FAILURE_MESSAGE; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.*; import static iudx.data.marketplace.apiserver.util.Constants.RESULTS; import static iudx.data.marketplace.common.Constants.*; import static iudx.data.marketplace.product.util.Constants.*; @@ -62,34 +61,33 @@ private static boolean isSameProviderForAll(JsonArray resourceDetails) { return sameProviderForAll; } - private boolean isSameApdUrlForAll(JsonArray resourceDetails) { - LOGGER.debug("current APD URL is : {}", this.apdUrl); - String currentApdUrl = this.apdUrl; - boolean sameApdUrl = true; - for (int i = 0; i < resourceDetails.size() && sameApdUrl; i++) { - String apdUrlOfResource = resourceDetails.getJsonObject(i).getString(APD_URL); - LOGGER.debug("APD URL of the current resource is : {}", apdUrlOfResource); - sameApdUrl = - apdUrlOfResource.equals(currentApdUrl); - } - return sameApdUrl; + private boolean isSameApdUrlForAll(JsonArray resourceDetails) { + LOGGER.debug("current APD URL is : {}", this.apdUrl); + String currentApdUrl = this.apdUrl; + boolean sameApdUrl = true; + for (int i = 0; i < resourceDetails.size() && sameApdUrl; i++) { + String apdUrlOfResource = resourceDetails.getJsonObject(i).getString(APD_URL); + LOGGER.debug("APD URL of the current resource is : {}", apdUrlOfResource); + sameApdUrl = apdUrlOfResource.equals(currentApdUrl); } + return sameApdUrl; + } @Override public ProductService createProduct( User user, JsonObject request, Handler> handler) { JsonArray resourceDetails = new JsonArray(); - String providerID = user.getUserId(); - String productID = - URN_PREFIX.concat(providerID).concat(":").concat(request.getString(PRODUCT_ID)); + String providerId = user.getUserId(); + String productId = + URN_PREFIX.concat(providerId).concat(":").concat(request.getString(PRODUCT_ID)); /* Check Merchant Account Existence on RazorPay */ checkMerchantAccountStatus(user) .compose( merchantAccountStatus -> { List itemFutures = - fetchItemDetailsFromCat(request, providerID, productID, resourceDetails); + fetchItemDetailsFromCat(request, providerId, productId, resourceDetails); return CompositeFuture.all(itemFutures); }) @@ -109,7 +107,7 @@ public ProductService createProduct( if (!sameProviderForAll) { return Future.failedFuture("The resources listed belong to different providers"); } else { - return checkIfProductExists(providerID, productID); + return checkIfProductExists(providerId, productId); } }) /* Check if product already exists */ @@ -129,7 +127,7 @@ public ProductService createProduct( if (!completeHandler .result() .getString("ownerUserId") - .equalsIgnoreCase(providerID)) { + .equalsIgnoreCase(providerId)) { handler.handle( Future.failedFuture( @@ -156,7 +154,7 @@ public ProductService createProduct( new RespBuilder() .withType(ResponseUrn.SUCCESS_URN.getUrn()) .withTitle(ResponseUrn.SUCCESS_URN.getMessage()) - .withResult(new JsonObject().put(PRODUCT_ID, productID)) + .withResult(new JsonObject().put(PRODUCT_ID, productId)) .withDetail("Product created successfully") .getJsonResponse(); handler.handle(Future.succeededFuture(result)); @@ -194,8 +192,8 @@ public ProductService createProduct( } private List fetchItemDetailsFromCat( - JsonObject request, String providerID, String productID, JsonArray resourceDetails) { - request.put(PROVIDER_ID, providerID).put(PRODUCT_ID, productID); + JsonObject request, String providerId, String productId, JsonArray resourceDetails) { + request.put(PROVIDER_ID, providerId).put(PRODUCT_ID, productId); JsonArray resourceIds = request.getJsonArray(RESOURCE_IDS); @@ -217,14 +215,14 @@ private List fetchItemDetailsFromCat( return itemFutures; } - Future checkIfProductExists(String providerID, String productID) { + Future checkIfProductExists(String providerId, String productId) { Promise promise = Promise.promise(); StringBuilder query = new StringBuilder( SELECT_PRODUCT_QUERY .replace("$0", productTableName) - .replace("$1", providerID) - .replace("$2", productID)); + .replace("$1", providerId) + .replace("$2", productId)); LOGGER.debug("checkQuery: {}", query); pgService.executeCountQuery( @@ -248,15 +246,15 @@ Future checkIfProductExists(String providerID, String productID) { public ProductService deleteProduct( User user, JsonObject request, Handler> handler) { - String providerID = user.getUserId(); - String productID = request.getString(PRODUCT_ID); + String providerId = user.getUserId(); + String productId = request.getString(PRODUCT_ID); JsonObject params = - new JsonObject().put(STATUS, Status.INACTIVE.toString()).put(PRODUCT_ID, productID); + new JsonObject().put(STATUS, Status.INACTIVE.toString()).put(PRODUCT_ID, productId); JsonObject deleteProductVariantParams = - new JsonObject().put(PRODUCT_ID, productID).put(PROVIDER_ID, providerID); + new JsonObject().put(PRODUCT_ID, productId).put(PROVIDER_ID, providerId); - checkIfProductExists(providerID, productID) + checkIfProductExists(providerId, productId) .onComplete( existsHandler -> { LOGGER.error(existsHandler.result()); @@ -330,12 +328,12 @@ public ProductService deleteProduct( public ProductService listProducts( User user, JsonObject request, Handler> handler) { - String providerID = user.getUserId(); + String providerId = user.getUserId(); String resourceServerUrl = user.getResourceServerUrl(); JsonObject params = new JsonObject() .put(STATUS, Status.ACTIVE.toString()) - .put(PROVIDER_ID, providerID) + .put(PROVIDER_ID, providerId) .put("resourceServerUrl", resourceServerUrl); if (request.containsKey("resourceId")) { @@ -425,13 +423,13 @@ public Future fetchRazorpayDetailsOfProvider(String query, String pr if (!handler.result().getJsonArray(RESULTS).isEmpty()) { JsonObject result = handler.result().getJsonArray(RESULTS).getJsonObject(0); String accountId = result.getString("account_id"); - String rzp_account_product_id = result.getString("rzp_account_product_id"); + String rzpAccountProductId = result.getString("rzp_account_product_id"); String status = result.getString("status"); LOGGER.info( "Provider with _id : {} , with accountId {}, accountProductId {} has status : {}", providerId, accountId, - rzp_account_product_id, + rzpAccountProductId, status); promise.complete(result); } else { diff --git a/src/main/java/iudx/data/marketplace/product/ProductVerticle.java b/src/main/java/iudx/data/marketplace/product/ProductVerticle.java index da45c675..85006b05 100644 --- a/src/main/java/iudx/data/marketplace/product/ProductVerticle.java +++ b/src/main/java/iudx/data/marketplace/product/ProductVerticle.java @@ -1,5 +1,7 @@ package iudx.data.marketplace.product; +import static iudx.data.marketplace.common.Constants.*; + import io.vertx.core.AbstractVerticle; import io.vertx.core.eventbus.MessageConsumer; import io.vertx.core.json.JsonObject; @@ -10,8 +12,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.*; - public class ProductVerticle extends AbstractVerticle { private static final Logger LOGGER = LogManager.getLogger(ProductVerticle.class); private MessageConsumer consumer; @@ -30,13 +30,17 @@ public void start() throws Exception { razorPayService = RazorPayService.createProxy(vertx, RAZORPAY_SERVICE_ADDRESS); isAccountActivationCheckBeingDone = config().getBoolean("isAccountActivationCheckBeingDone"); - if(!isAccountActivationCheckBeingDone) - { - LOGGER.warn("\n\n" +"account activation check is set to false. Enable it in production" + "\n\n" ); + if (!isAccountActivationCheckBeingDone) { + LOGGER.warn( + "\n\n" + "account activation check is set to false. Enable it in production" + "\n\n"); } - productService = new ProductServiceImpl(config(), postgresService, catService, razorPayService, isAccountActivationCheckBeingDone); - - + productService = + new ProductServiceImpl( + config(), + postgresService, + catService, + razorPayService, + isAccountActivationCheckBeingDone); binder = new ServiceBinder(vertx); consumer = diff --git a/src/main/java/iudx/data/marketplace/product/util/Constants.java b/src/main/java/iudx/data/marketplace/product/util/Constants.java index fba34b66..fa908af2 100644 --- a/src/main/java/iudx/data/marketplace/product/util/Constants.java +++ b/src/main/java/iudx/data/marketplace/product/util/Constants.java @@ -24,16 +24,20 @@ public class Constants { public static final String INSERT_PRODUCT_QUERY = "insert into $0 (product_id, provider_id, provider_name, status) values ('$1', '$2', '$3', '$4')"; public static final String INSERT_RESOURCE_QUERY = - "insert into $0 (_id, resource_name, provider_id, provider_name, resource_server, accessPolicy) values ('$1', '$2', '$3', '$4', '$5', '$6') on conflict (_id) do nothing"; + "insert into $0 (_id, resource_name, provider_id, provider_name, resource_server, accessPolicy)" + + + " values ('$1', '$2', '$3', '$4', '$5', '$6') on conflict (_id) do nothing"; public static final String INSERT_P_R_REL_QUERY = "insert into $0 (product_id, resource_id) values ('$1', '$2')"; - public static final String DELETE_PRODUCT_QUERY = "update $0 set status=$1 where product_id=$2 and status = 'ACTIVE' returning product_id"; - public static final String DELETE_PV_QUERY = "UPDATE product_variant SET status = 'INACTIVE' WHERE \n " + - "product_id = $1 \n " + - "AND provider_id = $2 \n " + - "RETURNING _id"; + public static final String DELETE_PRODUCT_QUERY = + "update $0 set status=$1 where product_id=$2 and status = 'ACTIVE' returning product_id"; + public static final String DELETE_PV_QUERY = + "UPDATE product_variant SET status = 'INACTIVE' WHERE \n " + + "product_id = $1 \n " + + "AND provider_id = $2 \n " + + "RETURNING _id"; public static final String LIST_PRODUCT_FOR_RESOURCE = "select pt.product_id AS \"productId\", pt.provider_name AS \"providerName\", " + " pt.modified_at AS \"updatedAt\" , pt.created_at AS \"createdAt\" ," @@ -59,12 +63,15 @@ public class Constants { + "group by pt.product_id"; public static final String INSERT_PV_QUERY = - "insert into $0 (_id, provider_id, product_id, product_variant_name, resource_info, price, validity, status)" + - " values ('$1', '$2', '$3', '$4','$5'::JSON, '$6', $7, '$s') RETURNING _id"; + "insert into $0 (_id, provider_id, product_id, product_variant_name, resource_info, price, validity, status)" + + " values ('$1', '$2', '$3', '$4','$5'::JSON, '$6', $7, '$s') RETURNING _id"; - public static final String UPDATE_PV_STATUS = "update $0 set status='$4' where product_id='$1' and product_variant_name='$2' and status='$3'"; - public static final String CHECK_IF_PV_EXISTS = "SELECT * FROM product_variant WHERE product_id = '$1' AND product_variant_name = '$2' AND status = 'ACTIVE'"; - public static final String CHECK_IF_PRODUCT_EXISTS = "SELECT * FROM product WHERE product_id = '$1' "; + public static final String UPDATE_PV_STATUS = + "update $0 set status='$4' where product_id='$1' and product_variant_name='$2' and status='$3'"; + public static final String CHECK_IF_PV_EXISTS = + "SELECT * FROM product_variant WHERE product_id = '$1' AND product_variant_name = '$2' AND status = 'ACTIVE'"; + public static final String CHECK_IF_PRODUCT_EXISTS = + "SELECT * FROM product WHERE product_id = '$1' "; public static final String UPDATE_PV_STATUS_QUERY = "update $0 set status='$4' where _id='$1' and status='$3' RETURNING _id"; public static final String SELECT_PV_QUERY = @@ -109,8 +116,9 @@ public class Constants { + " INNER JOIN user_table U\n" + " ON U._id = I.consumer_id "; public static final String LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER = - LIST_SUCCESSFUL_PURCHASE + "WHERE P.\"providerId\" = '$1' " - + " AND P.\"resourceServerUrl\" = '$2'"; + LIST_SUCCESSFUL_PURCHASE + + "WHERE P.\"providerId\" = '$1' " + + " AND P.\"resourceServerUrl\" = '$2'"; public static final String LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT = LIST_SUCCESSFUL_PURCHASE + "WHERE\n" @@ -129,7 +137,7 @@ public class Constants { public static final String LIST_PENDING_PAYMENTS_4_PROVIDER = LIST_FAILED_OR_PENDING_PAYMENTS + "WHERE P.\"providerId\" = '$1' AND I.payment_status = 'PENDING' " - + " AND P.\"resourceServerUrl\" = '$2'"; + + " AND P.\"resourceServerUrl\" = '$2'"; public static final String LIST_PENDING_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT = LIST_FAILED_OR_PENDING_PAYMENTS + "WHERE\n" diff --git a/src/main/java/iudx/data/marketplace/product/util/QueryBuilder.java b/src/main/java/iudx/data/marketplace/product/util/QueryBuilder.java index 58eba946..1e038481 100644 --- a/src/main/java/iudx/data/marketplace/product/util/QueryBuilder.java +++ b/src/main/java/iudx/data/marketplace/product/util/QueryBuilder.java @@ -4,6 +4,7 @@ import static iudx.data.marketplace.common.Constants.*; import static iudx.data.marketplace.consumer.util.Constants.*; import static iudx.data.marketplace.product.util.Constants.*; +import static iudx.data.marketplace.product.util.Constants.PRODUCT_VARIANT_NAME; import io.vertx.core.json.JsonArray; import io.vertx.core.json.JsonObject; @@ -11,7 +12,6 @@ import java.util.List; import java.util.UUID; import java.util.function.Supplier; - import org.apache.commons.lang.StringUtils; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -19,8 +19,11 @@ public class QueryBuilder { public static final Logger LOGGER = LogManager.getLogger(QueryBuilder.class); - private String productTable, resourceTable, productResourceRelationTable, productVariantTable; - private Supplier supplier; + private final String productTable; + private final String resourceTable; + private final String productResourceRelationTable; + private final String productVariantTable; + private final Supplier supplier; public QueryBuilder(JsonArray tables) { this.productTable = tables.getString(0); @@ -31,46 +34,40 @@ public QueryBuilder(JsonArray tables) { } public List buildCreateProductQueries(JsonObject request, JsonArray resourceDetails) { - String productID = request.getString(PRODUCT_ID); - String providerID = request.getString(PROVIDER_ID); + String productId = request.getString(PRODUCT_ID); + String providerId = request.getString(PROVIDER_ID); String providerName = request.getString(PROVIDER_NAME); List queries = new ArrayList(); // Product Table entry queries.add( - new StringBuilder( - INSERT_PRODUCT_QUERY - .replace("$0", productTable) - .replace("$1", productID) - .replace("$2", providerID) - .replace("$3", providerName) - .replace("$4", Status.ACTIVE.toString())) - .toString()); + INSERT_PRODUCT_QUERY + .replace("$0", productTable) + .replace("$1", productId) + .replace("$2", providerId) + .replace("$3", providerName) + .replace("$4", Status.ACTIVE.toString())); // Resource Table entry resourceDetails.forEach( - resource -> { - queries.add( - new StringBuilder( - INSERT_RESOURCE_QUERY - .replace("$0", resourceTable) - .replace("$1", ((JsonObject) resource).getString(RESOURCE_ID)) - .replace("$2", ((JsonObject) resource).getString(RESOURCE_NAME)) - .replace("$3", providerID) - .replace("$4", providerName) - .replace("$5", request.getString(RESOURCE_SERVER)) - .replace("$6", ((JsonObject) resource).getString("accessPolicy"))) - .toString()); - - // Product-Resource relationship table entry - queries.add( - new StringBuilder( - INSERT_P_R_REL_QUERY - .replace("$0", productResourceRelationTable) - .replace("$1", productID) - .replace("$2", ((JsonObject) resource).getString(RESOURCE_ID))) - .toString()); - }); + resource -> { + queries.add( + INSERT_RESOURCE_QUERY + .replace("$0", resourceTable) + .replace("$1", ((JsonObject) resource).getString(RESOURCE_ID)) + .replace("$2", ((JsonObject) resource).getString(RESOURCE_NAME)) + .replace("$3", providerId) + .replace("$4", providerName) + .replace("$5", request.getString(RESOURCE_SERVER)) + .replace("$6", ((JsonObject) resource).getString("accessPolicy"))); + + // Product-Resource relationship table entry + queries.add( + INSERT_P_R_REL_QUERY + .replace("$0", productResourceRelationTable) + .replace("$1", productId) + .replace("$2", ((JsonObject) resource).getString(RESOURCE_ID))); + }); LOGGER.debug("Queries : " + queries); return queries; @@ -80,11 +77,11 @@ public String buildListProductsQuery(JsonObject request) { StringBuilder query; query = - new StringBuilder( - LIST_PRODUCT_FOR_RESOURCE - .replace("$0", productTable) - .replace("$9", productResourceRelationTable) - .replace("$8", resourceTable)); + new StringBuilder( + LIST_PRODUCT_FOR_RESOURCE + .replace("$0", productTable) + .replace("$9", productResourceRelationTable) + .replace("$8", resourceTable)); if (request.containsKey("resourceId")) { query.append(" and rt._id=$4"); } @@ -94,15 +91,15 @@ public String buildListProductsQuery(JsonObject request) { return query.toString(); } - public String buildProductDetailsQuery(String productID, String providerId) { + public String buildProductDetailsQuery(String productId, String providerId) { StringBuilder query = - new StringBuilder( - SELECT_PRODUCT_DETAILS - .replace("$0", productTable) - .replace("$9", productResourceRelationTable) - .replace("$8", resourceTable) - .replace("$1", productID) - .replace("$2", providerId)); + new StringBuilder( + SELECT_PRODUCT_DETAILS + .replace("$0", productTable) + .replace("$9", productResourceRelationTable) + .replace("$8", resourceTable) + .replace("$1", productId) + .replace("$2", providerId)); return query.toString(); } @@ -111,62 +108,41 @@ public String buildCreateProductVariantQuery(JsonObject request) { JsonArray resources = request.getJsonArray(RESOURCES_ARRAY); - // UUID for each product variant. - String pvID = supplier.get(); + String pvId = supplier.get(); LOGGER.debug("request is : " + request.encodePrettily()); StringBuilder query = - new StringBuilder( - INSERT_PV_QUERY - .replace("$0", productVariantTable) - .replace("$1", pvID) - .replace("$2", request.getString("provider_id")) - .replace("$3", request.getString(PRODUCT_ID)) - .replace("$4", request.getString(Constants.PRODUCT_VARIANT_NAME)) - .replace("$5", resources.encode()) - .replace("$6", request.getDouble(PRICE).toString()) - .replace("$7", request.getInteger(DURATION).toString()) - .replace("$s", Status.ACTIVE.toString())); + new StringBuilder( + INSERT_PV_QUERY + .replace("$0", productVariantTable) + .replace("$1", pvId) + .replace("$2", request.getString("provider_id")) + .replace("$3", request.getString(PRODUCT_ID)) + .replace("$4", request.getString(PRODUCT_VARIANT_NAME)) + .replace("$5", resources.encode()) + .replace("$6", request.getDouble(PRICE).toString()) + .replace("$7", request.getInteger(DURATION).toString()) + .replace("$s", Status.ACTIVE.toString())); LOGGER.debug(query); return query.toString(); } - public String updateProductVariantStatusQuery(String productID, String variant) { + public String updateProductVariantStatusQuery(String productId, String variant) { StringBuilder query = - new StringBuilder( - UPDATE_PV_STATUS - .replace("$0", productVariantTable) - .replace("$1", productID) - .replace("$2", variant) - .replace("$3", Status.ACTIVE.toString()) - .replace("$4", Status.INACTIVE.toString())); + new StringBuilder( + UPDATE_PV_STATUS + .replace("$0", productVariantTable) + .replace("$1", productId) + .replace("$2", variant) + .replace("$3", Status.ACTIVE.toString()) + .replace("$4", Status.INACTIVE.toString())); LOGGER.debug("Query to update pv status : {}", query); return query.toString(); } - public String checkProductVariantExistence(String productId, String variantName) - { - StringBuilder query = - new StringBuilder(CHECK_IF_PV_EXISTS - .replace("$1", productId) - .replace("$2", variantName)); - LOGGER.debug("Query to check pv existence : {}", query); - return query.toString(); - } - - public String checkIfProductExists(String productId, String providerId) - { - StringBuilder query = new StringBuilder( - CHECK_IF_PRODUCT_EXISTS - .replace("$1", productId) - ); - LOGGER.debug("Query to check if product exists : {}", query); - return query.toString(); - } - public String updateProductVariantStatusQuery(String productVariantId) { StringBuilder query = new StringBuilder( @@ -180,25 +156,39 @@ public String updateProductVariantStatusQuery(String productVariantId) { return query.toString(); } - public String selectProductVariant(String productID, String variantName) { + public String checkProductVariantExistence(String productId, String variantName) { + StringBuilder query = + new StringBuilder(CHECK_IF_PV_EXISTS.replace("$1", productId).replace("$2", variantName)); + LOGGER.debug("Query to check pv existence : {}", query); + return query.toString(); + } + + public String checkIfProductExists(String productId, String providerId) { + StringBuilder query = new StringBuilder(CHECK_IF_PRODUCT_EXISTS.replace("$1", productId)); + LOGGER.debug("Query to check if product exists : {}", query); + return query.toString(); + } + + + + public String selectProductVariant(String productId, String variantName) { StringBuilder query = - new StringBuilder( - SELECT_PV_QUERY - .replace("$0", productVariantTable) - .replace("$1", productID) - .replace("$2", variantName) - .replace("$3", Status.ACTIVE.toString())); + new StringBuilder( + SELECT_PV_QUERY + .replace("$0", productVariantTable) + .replace("$1", productId) + .replace("$2", variantName) + .replace("$3", Status.ACTIVE.toString())); LOGGER.debug("select product variant query : {}", query); return query.toString(); } public String listProductVariants(JsonObject request, String providerId) { - StringBuilder query = new StringBuilder( - FETCH_ACTIVE_PRODUCT_VARIANTS); + StringBuilder query = new StringBuilder(FETCH_ACTIVE_PRODUCT_VARIANTS); query.append(" AND P.\"providerId\"=$3"); - if(request.containsKey(Constants.PRODUCT_VARIANT_NAME)) { + if (request.containsKey(PRODUCT_VARIANT_NAME)) { query.append(" AND P.\"productVariantName\"=$4"); } query.append(" ORDER BY P.\"updatedAt\" DESC"); @@ -215,121 +205,133 @@ public JsonObject buildMessageForRmq(JsonObject request) { return request; } - public String listPurchaseForProviderDuringPendingStatus(String providerId, String resourceId, String productId, String rsUrl) - { + public String listPurchaseForProviderDuringPendingStatus( + String providerId, String resourceId, String productId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); StringBuilder query = - new StringBuilder(LIST_PENDING_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2", rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_PENDING_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_PENDING_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_PENDING_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_PENDING_PAYMENTS_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_PENDING_PAYMENTS_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } query.append(" \n ORDER BY I.modified_at DESC "); LOGGER.debug("Query :" + query); return query.toString(); } - public String listPurchaseForProviderDuringFailedPayment(String providerId, String resourceId, String productId, String rsUrl) - { + public String listPurchaseForProviderDuringFailedPayment( + String providerId, String resourceId, String productId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); StringBuilder query = - new StringBuilder(LIST_FAILED_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2",rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_FAILED_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_FAILED_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_FAILED_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_FAILED_PAYMENTS_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_FAILED_PAYMENTS_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } query.append(" \n ORDER BY I.modified_at DESC "); LOGGER.debug("Query :" + query); return query.toString(); } - public String listSuccessfulPurchaseForProvider(String providerId, String resourceId, String productId, - String rsUrl) - { + public String listSuccessfulPurchaseForProvider( + String providerId, String resourceId, String productId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); StringBuilder query = - new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2", rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER.replace("$1", providerId).replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", providerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_PROVIDER_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", providerId) + .replace("$3", rsUrl)); } - query.append(" \n ORDER BY I.modified_at DESC "); LOGGER.debug("Query :" + query); return query.toString(); } - public String listPurchaseForConsumerDuringPendingPayment(String consumerId, String resourceId, String productId, String orderId, String rsUrl) - { + + public String listPurchaseForConsumerDuringPendingPayment( + String consumerId, String resourceId, String productId, String orderId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); boolean isOrderIdPresent = StringUtils.isNotBlank(orderId); StringBuilder query = - new StringBuilder(LIST_PENDING_PAYMENTS_4_CONSUMER.replace("$1", consumerId).replace("$2",rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_PENDING_PAYMENTS_4_CONSUMER.replace("$1", consumerId).replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isOrderIdPresent) - { - query = new StringBuilder(LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER - .replace("$1", orderId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isOrderIdPresent) { + query = + new StringBuilder( + LIST_PENDING_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER + .replace("$1", orderId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } query.append(" \n ORDER BY I.modified_at DESC "); @@ -337,81 +339,85 @@ public String listPurchaseForConsumerDuringPendingPayment(String consumerId, Str return query.toString(); } - - public String listPurchaseForConsumerDuringFailurePayment(String consumerId, String resourceId, String productId, String orderId, String rsUrl) - { + public String listPurchaseForConsumerDuringFailurePayment( + String consumerId, String resourceId, String productId, String orderId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); boolean isOrderIdPresent = StringUtils.isNotBlank(orderId); StringBuilder query = - new StringBuilder(LIST_FAILED_PAYMENTS_4_CONSUMER.replace("$1", consumerId).replace("$2", rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_FAILED_PAYMENTS_4_CONSUMER.replace("$1", consumerId).replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isOrderIdPresent) - { - query = new StringBuilder(LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER - .replace("$1", orderId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isOrderIdPresent) { + query = + new StringBuilder( + LIST_FAILED_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER + .replace("$1", orderId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } query.append(" \n ORDER BY I.modified_at DESC "); LOGGER.debug("Query :" + query); return query.toString(); } - public String listPurchaseForConsumerDuringSuccessfulPayment(String consumerId, String resourceId, String productId, String orderId, String rsUrl) - { + public String listPurchaseForConsumerDuringSuccessfulPayment( + String consumerId, String resourceId, String productId, String orderId, String rsUrl) { boolean isProductIdPresent = StringUtils.isNotBlank(productId); boolean isResourceIdPresent = StringUtils.isNotBlank(resourceId); boolean isOrderIdPresent = StringUtils.isNotBlank(orderId); StringBuilder query = - new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_PAYMENTS_4_CONSUMER.replace("$1", consumerId).replace("$2", rsUrl)); - - if(isProductIdPresent && !isResourceIdPresent) - { - query = new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT - .replace("$1", productId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_PAYMENTS_4_CONSUMER + .replace("$1", consumerId) + .replace("$2", rsUrl)); + + if (isProductIdPresent && !isResourceIdPresent) { + query = + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_PRODUCT + .replace("$1", productId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isResourceIdPresent && !isProductIdPresent) - { - query = new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE - .replace("$1", resourceId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isResourceIdPresent && !isProductIdPresent) { + query = + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_RESOURCE + .replace("$1", resourceId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } - if(isOrderIdPresent) - { - query = new StringBuilder(LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER - .replace("$1", orderId) - .replace("$2", consumerId) - .replace("$3", rsUrl)); + if (isOrderIdPresent) { + query = + new StringBuilder( + LIST_SUCCESSFUL_PAYMENTS_4_CONSUMER_WITH_GIVEN_ORDER + .replace("$1", orderId) + .replace("$2", consumerId) + .replace("$3", rsUrl)); } query.append(" \n ORDER BY I.modified_at DESC "); LOGGER.debug("Query :" + query); return query.toString(); } - - - - - -} \ No newline at end of file +} diff --git a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantService.java b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantService.java index b3b696df..17961645 100644 --- a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantService.java +++ b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantService.java @@ -10,7 +10,8 @@ import io.vertx.core.json.JsonObject; import iudx.data.marketplace.policies.User; -@VertxGen @ProxyGen +@VertxGen +@ProxyGen public interface ProductVariantService { /** @@ -26,56 +27,66 @@ static ProductVariantService createProxy(Vertx vertx, String address) { } /** - * The createProductVariant method implements the creation of a product variant on the IUDX data marketplace. + * The createProductVariant method implements the creation of a product variant on the IUDX data + * marketplace. * * @param request which is a JsonObject * @param handler which is a Request Handler * @return ProductVariantService which is a service */ @Fluent - ProductVariantService createProductVariant(User user, JsonObject request, Handler> handler); + ProductVariantService createProductVariant( + User user, JsonObject request, Handler> handler); /** - * The updateProductVariant method implements the update of a product variant on the IUDX data marketplace. + * The updateProductVariant method implements the update of a product variant on the IUDX data + * marketplace. * * @param request which is a JsonObject * @param handler which is a Request Handler * @return ProductVariantService which is a service */ @Fluent - ProductVariantService updateProductVariant(User user, JsonObject request, Handler> handler); + ProductVariantService updateProductVariant( + User user, JsonObject request, Handler> handler); /** - * The deleteProductVariant method implements the soft delete of a product variant on the IUDX data marketplace. + * The deleteProductVariant method implements the soft delete of a product variant on the IUDX + * data marketplace. * * @param request which is a JsonObject * @param handler which is a Request Handler * @return ProductVariantService which is a service */ @Fluent - ProductVariantService deleteProductVariant(User user, JsonObject request, Handler> handler); + ProductVariantService deleteProductVariant( + User user, JsonObject request, Handler> handler); /** - * The listProductVariant method implements the fetch of product variant(s) on the IUDX data marketplace. + * The listProductVariant method implements the fetch of product variant(s) on the IUDX data + * marketplace. + * * @param user which is the calling user Object * @param request which is a JsonObject * @param handler which is a Request Handler * @return ProductVariantService which is a service */ @Fluent - ProductVariantService listProductVariants(User user, JsonObject request, Handler> handler); - + ProductVariantService listProductVariants( + User user, JsonObject request, Handler> handler); /** - * List purchase will fetch invoice related info, provider, consumer and product variant related information - * After the purchase is made. Both successful and failed payments are displayed - * List purchase will list all the purchases if no query parameters are given - * It can also list purchases based on the productId, resourceId if it is given in the query parameter + * List purchase will fetch invoice related info, provider, consumer and product variant related + * information After the purchase is made. Both successful and failed payments are displayed List + * purchase will list all the purchases if no query parameters are given It can also list + * purchases based on the productId, resourceId if it is given in the query parameter + * * @param user Provider user * @param request query param if any * @param handler Asynchronous JsonObject handler that contains the list of purchases - * @return + * @return ProductVariantService which is a service */ @Fluent - ProductVariantService listPurchase(User user, JsonObject request, Handler> handler); + ProductVariantService listPurchase( + User user, JsonObject request, Handler> handler); } diff --git a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantServiceImpl.java b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantServiceImpl.java index 10112b0c..764098c8 100644 --- a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantServiceImpl.java @@ -40,25 +40,25 @@ public ProductVariantServiceImpl(JsonObject config, PostgresService postgresServ @Override public ProductVariantService createProductVariant( User user, JsonObject request, Handler> handler) { - String productID = request.getString(PRODUCT_ID); + String productId = request.getString(PRODUCT_ID); String variantName = request.getString(PRODUCT_VARIANT_NAME); String providerId = user.getUserId(); - Future productDetailsFuture = getProductDetails(productID, providerId); + Future productDetailsFuture = getProductDetails(productId, providerId); JsonArray resources = request.getJsonArray(RESOURCES_ARRAY); - Future checkIfProductExists = checkForExistenceOfProduct(productID, providerId); + Future checkIfProductExists = checkForExistenceOfProduct(productId, providerId); Future checkForExistence = checkIfProductExists.compose( isProductFound -> { if (isProductFound) { - return checkIfProductVariantExists(productID, variantName); + return checkIfProductVariantExists(productId, variantName); } else { String failureMessage = new RespBuilder() .withType(ResponseUrn.BAD_REQUEST_URN.getUrn()) .withTitle(ResponseUrn.BAD_REQUEST_URN.getMessage()) .withDetail( - "Product Variant cannot be created as product is in INACTIVE state or is not found") + "Product Variant cannot be created as product is in INACTIVE state or is not found") .getResponse(); return Future.failedFuture(failureMessage); } @@ -92,9 +92,9 @@ public ProductVariantService createProductVariant( JsonObject res = pdfHandler.result().getJsonArray(RESULTS).getJsonObject(0); JsonArray resResources = res.getJsonArray(RESOURCES_ARRAY); if (resources.size() != resResources.size()) { - /* if the number of resources listed while creating product variant != - * number of resources listed while creating product - * then bad request is thrown and returned without creating product variant */ + /* if the number of resources listed while creating product variant != + * number of resources listed while creating product + * then bad request is thrown and returned without creating product variant */ String detail = "Number of resources is incorrect, required : " + resResources.size(); String failureMessage = @@ -106,12 +106,13 @@ public ProductVariantService createProductVariant( handler.handle(Future.failedFuture(failureMessage)); return; } - int i, j; + int i; + int j; for (i = 0; i < resources.size(); i++) { for (j = 0; j < resResources.size(); j++) { - String reqID = resources.getJsonObject(i).getString(ID); - String resID = resResources.getJsonObject(j).getString(ID); - if (reqID.equalsIgnoreCase(resID)) { + String reqId = resources.getJsonObject(i).getString(ID); + String resId = resResources.getJsonObject(j).getString(ID); + if (reqId.equalsIgnoreCase(resId)) { resResources.getJsonObject(j).mergeIn(resources.getJsonObject(i)); break; } @@ -139,7 +140,7 @@ public ProductVariantService createProductVariant( .add( new JsonObject() .put("productVariantId", productVariantId) - .put("productId", productID) + .put("productId", productId) .put(PRODUCT_VARIANT_NAME, variantName))) .withDetail("Product Variant created successfully"); handler.handle(Future.succeededFuture(respBuilder.getJsonResponse())); @@ -154,15 +155,18 @@ public ProductVariantService createProductVariant( return this; } - private Future checkIfProductVariantExists(String productID, String variantName) { + private Future checkIfProductVariantExists(String productId, String variantName) { Promise promise = Promise.promise(); - String query = queryBuilder.selectProductVariant(productID, variantName); + String query = queryBuilder.selectProductVariant(productId, variantName); pgService.executeCountQuery( query, handler -> { if (handler.succeeded()) { - if (handler.result().getInteger("totalHits") != 0) promise.complete(true); - else promise.complete(false); + if (handler.result().getInteger("totalHits") != 0) { + promise.complete(true); + } else { + promise.complete(false); + } } else { promise.fail(handler.cause()); } @@ -170,10 +174,10 @@ private Future checkIfProductVariantExists(String productID, String var return promise.future(); } - Future getProductDetails(String productID, String providerId) { + Future getProductDetails(String productId, String providerId) { Promise promise = Promise.promise(); - String query = queryBuilder.buildProductDetailsQuery(productID, providerId); + String query = queryBuilder.buildProductDetailsQuery(productId, providerId); LOGGER.debug(query); pgService.executeQuery( query, @@ -242,10 +246,10 @@ Future checkForExistenceOfProduct(String productId, String providerId) public ProductVariantService updateProductVariant( User user, JsonObject request, Handler> handler) { - String productID = request.getString(PRODUCT_ID); + String productId = request.getString(PRODUCT_ID); String variant = request.getString(PRODUCT_VARIANT_NAME); /* check if the product variant exists */ - String query = queryBuilder.checkProductVariantExistence(productID, variant); + String query = queryBuilder.checkProductVariantExistence(productId, variant); pgService.executeQuery( query, existenceHandler -> { @@ -254,7 +258,7 @@ public ProductVariantService updateProductVariant( if (!isEmpty) { Future updateProductVariantFuture = - updateProductVariantStatus(productID, variant); + updateProductVariantStatus(productId, variant); updateProductVariantFuture.onComplete( updateHandler -> { if (updateHandler.result()) { @@ -284,7 +288,9 @@ public ProductVariantService updateProductVariant( .withType(ResponseUrn.RESOURCE_NOT_FOUND_URN.getUrn()) .withTitle(ResponseUrn.RESOURCE_NOT_FOUND_URN.getMessage()) .withDetail( - "Product Variant cannot be updated as the product is in INACTIVE state or product is not found") + "Product Variant cannot be updated as the product is in INACTIVE state or " + + + "product is not found") .getResponse())); } @@ -297,9 +303,9 @@ public ProductVariantService updateProductVariant( return this; } - Future updateProductVariantStatus(String productID, String variant) { + Future updateProductVariantStatus(String productId, String variant) { Promise promise = Promise.promise(); - String query = queryBuilder.updateProductVariantStatusQuery(productID, variant); + String query = queryBuilder.updateProductVariantStatusQuery(productId, variant); pgService.executeQuery( query, @@ -446,21 +452,21 @@ public ProductVariantService listPurchase( } Future paymentFuture = executePurchaseQuery(query, resourceId, productId, user); - Future userResponseFuture = - paymentFuture.onComplete( - pgHandler -> { - if (pgHandler.succeeded()) { - JsonObject response = - new JsonObject() - .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) - .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) - .put(RESULTS, pgHandler.result()); - handler.handle(Future.succeededFuture(response)); - - } else { - handler.handle(Future.failedFuture(pgHandler.cause().getMessage())); - } - }); + // Future userResponseFuture = + paymentFuture.onComplete( + pgHandler -> { + if (pgHandler.succeeded()) { + JsonObject response = + new JsonObject() + .put(TYPE, ResponseUrn.SUCCESS_URN.getUrn()) + .put(TITLE, ResponseUrn.SUCCESS_URN.getMessage()) + .put(RESULTS, pgHandler.result()); + handler.handle(Future.succeededFuture(response)); + + } else { + handler.handle(Future.failedFuture(pgHandler.cause().getMessage())); + } + }); } catch (DxRuntimeException exception) { LOGGER.debug("Exception : " + exception.getMessage()); diff --git a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantVerticle.java b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantVerticle.java index 04e3e96f..90e088c8 100644 --- a/src/main/java/iudx/data/marketplace/product/variant/ProductVariantVerticle.java +++ b/src/main/java/iudx/data/marketplace/product/variant/ProductVariantVerticle.java @@ -1,5 +1,8 @@ package iudx.data.marketplace.product.variant; +import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; +import static iudx.data.marketplace.common.Constants.PRODUCT_VARIANT_SERVICE_ADDRESS; + import io.vertx.core.AbstractVerticle; import io.vertx.core.eventbus.MessageConsumer; import io.vertx.core.json.JsonObject; @@ -9,13 +12,10 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; -import static iudx.data.marketplace.common.Constants.PRODUCT_VARIANT_SERVICE_ADDRESS; - public class ProductVariantVerticle extends AbstractVerticle { public static final Logger LOGGER = LogManager.getLogger(ProductVariantVerticle.class); private MessageConsumer consumer; - private ServiceBinder binder; + private ServiceBinder binder; private PostgresService postgresService; private ProductVariantService variantService; private Util util; @@ -27,7 +27,10 @@ public void start() throws Exception { variantService = new ProductVariantServiceImpl(config(), postgresService, util); binder = new ServiceBinder(vertx); - consumer = binder.setAddress(PRODUCT_VARIANT_SERVICE_ADDRESS).register(ProductVariantService.class, variantService); + consumer = + binder + .setAddress(PRODUCT_VARIANT_SERVICE_ADDRESS) + .register(ProductVariantService.class, variantService); LOGGER.info("Product Variant Service started"); } @@ -36,4 +39,3 @@ public void stop() { binder.unregister(consumer); } } - diff --git a/src/main/java/iudx/data/marketplace/product/variant/package-info.java b/src/main/java/iudx/data/marketplace/product/variant/package-info.java index b745e7eb..3f457137 100644 --- a/src/main/java/iudx/data/marketplace/product/variant/package-info.java +++ b/src/main/java/iudx/data/marketplace/product/variant/package-info.java @@ -1,5 +1,6 @@ -@ModuleGen(groupPackage = "iudx.data.marketplace.product.variant", -name = "iudx-data-marketplace-product-variant-service") +@ModuleGen( + groupPackage = "iudx.data.marketplace.product.variant", + name = "iudx-data-marketplace-product-variant-service") package iudx.data.marketplace.product.variant; -import io.vertx.codegen.annotations.ModuleGen; \ No newline at end of file +import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/razorpay/Constants.java b/src/main/java/iudx/data/marketplace/razorpay/Constants.java index b9527e25..b609f821 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/Constants.java +++ b/src/main/java/iudx/data/marketplace/razorpay/Constants.java @@ -27,5 +27,6 @@ public class Constants { public static final String RAZORPAY_PAYMENT_ID = "razorpay_payment_id"; public static final String RAZORPAY_SIGNATURE = "razorpay_signature"; - public static final String RECORD_PAYMENT = "insert into $0 (order_id, payment_id, payment_signature) values ($1,$2,$3) on conflict do nothing"; + public static final String RECORD_PAYMENT = + "insert into $0 (order_id, payment_id, payment_signature) values ($1,$2,$3) on conflict do nothing"; } diff --git a/src/main/java/iudx/data/marketplace/razorpay/RazorPayService.java b/src/main/java/iudx/data/marketplace/razorpay/RazorPayService.java index 48f2e4cf..05718c26 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/RazorPayService.java +++ b/src/main/java/iudx/data/marketplace/razorpay/RazorPayService.java @@ -7,7 +7,8 @@ import io.vertx.core.Vertx; import io.vertx.core.json.JsonObject; -@VertxGen @ProxyGen +@VertxGen +@ProxyGen public interface RazorPayService { /** * The createProxy helps the code generation blocks to generate proxy code. @@ -22,19 +23,20 @@ static RazorPayService createProxy(Vertx vertx, String address) { } /** - * The create order method implements the creation of an order using the razorpayClient - * This method also creates a transfer from the order to the respective merchant account + * The create order method implements the creation of an order using the razorpayClient This + * method also creates a transfer from the order to the respective merchant account * * @param request which is a JsonObject - * @retun Future which is a vertx Future + * @retun Future JsonObject which is a vertx Future */ Future createOrder(JsonObject request); /** - * The verifyPayment method verifies the payment signature for every payment that is made using RazorPay - * This method also creates a payment record in the marketplace database + * The verifyPayment method verifies the payment signature for every payment that is made using + * RazorPay This method also creates a payment record in the marketplace database + * * @param request which is a JsonObject - * @retun Future which is a vertx Future + * @retun Future JsonObject which is a vertx Future */ Future verifyPayment(JsonObject request); @@ -42,48 +44,54 @@ static RazorPayService createProxy(Vertx vertx, String address) { * Accepts the terms and conditions of behalf of the merchant after a linked account is created *
    * The terms and conditions are accepted for route as a Razorpay product + * * @param info contains accountId generated by Razorpay * @return productId as success response in Future JsonObject, failure of type Future if any - * @see Request product configuration + * @see Request + * product configuration */ Future requestProductConfiguration(JsonObject info); /** + * Checks if the account is activated by the Merchant by completing the required KYC or adding + * their bank account details * - * Checks if the account is activated by the Merchant by completing the required KYC or - * adding their bank account details * @param request - contains productId and accountId generated by Razorpay - * @return status as active as success response in Future JsonObject, failure if the - *
    status is any of ( - *
    requested - *
    needs_clarification - *
    under_review - *
    suspended - *
    ) - * @see Fetch a product configuration + * @return status as active as success response in Future JsonObject, failure if the
    + * status is any of (
    + * requested
    + * needs_clarification
    + * under_review
    + * suspended
    + * ) + * @see Fetch + * a product configuration */ Future fetchProductConfiguration(JsonObject request); - /** * Creates Linked account for the merchant through DMP in Payment Gateway + * * @param request Required details to create linked account * @return Future of type JsonObject as success response, failure if any */ Future createLinkedAccount(String request); - /** * Fetches a linked account from Razorpay + * * @param accountId Razorpay ID generated after creating a linked account * @return Linked account information as Future of type JsonObject when as success response. - * Failure if any + * Failure if any */ Future fetchLinkedAccount(String accountId); /** - * Updates the account information after creating a linked account - *
    All the information except businessType, email could be updated + * Updates the account information after creating a linked account
    + * All the information except businessType, email could be updated + * * @param request Fields to be updated as JSON string * @param accountId Razorpay generated ID after creating a linked account * @return Future of type boolean after updating successfully or failure if any @@ -91,8 +99,9 @@ static RazorPayService createProxy(Vertx vertx, String address) { Future updateLinkedAccount(String request, String accountId); /** - * Captures webhook event from RazorPay related to payment and order, - * it also triggers the flow of policy creation + * Captures webhook event from RazorPay related to payment and order, it also triggers the flow of + * policy creation + * * @return Future of type JsonObject as success response, failure if any */ Future webhookSignatureValidator(JsonObject request, String signatureHeader); diff --git a/src/main/java/iudx/data/marketplace/razorpay/RazorPayServiceImpl.java b/src/main/java/iudx/data/marketplace/razorpay/RazorPayServiceImpl.java index bdf5100c..eeb7f272 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/RazorPayServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/razorpay/RazorPayServiceImpl.java @@ -1,7 +1,7 @@ package iudx.data.marketplace.razorpay; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.ACCOUNT_TYPE; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.FAILURE_MESSAGE; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.ACCOUNT_TYPE; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.FAILURE_MESSAGE; import static iudx.data.marketplace.product.util.Constants.*; import static iudx.data.marketplace.razorpay.Constants.*; @@ -47,7 +47,7 @@ public Future createOrder(JsonObject request) { Promise promise = Promise.promise(); LOGGER.debug(request); - Integer amountInPaise = (int) (Double.parseDouble((request.getString(PRICE))) * 100); + Integer amountInPaise = (int) (Double.parseDouble(request.getString(PRICE)) * 100); JSONObject orderRequest = new JSONObject() .put(AMOUNT, amountInPaise) @@ -76,9 +76,7 @@ public Future createOrder(JsonObject request) { String status = order.get(STATUS); if (!status.equals(CREATED)) { throw new DxRuntimeException( - 400, - ResponseUrn.ORDER_NOT_CREATED, - ("Order creation returned with status : " + status)); + 400, ResponseUrn.ORDER_NOT_CREATED, "Order creation returned with status : " + status); } JSONArray transfersArray = order.get(TRANFERS); JSONObject transferResponse = transfersArray.getJSONObject(0); @@ -264,7 +262,8 @@ public Future fetchProductConfiguration(JsonObject request) { } else { LOGGER.error("Linked account not activated"); String detail = - "To activate linked account please complete the KYC, filling account information etc., in your Razorpay merchant dashboard"; + "To activate linked account please complete the KYC, filling account information etc., " + + "in your Razorpay merchant dashboard"; promise.fail(detail); } } catch (RazorpayException e) { @@ -300,7 +299,7 @@ public Future createLinkedAccount(String request) { return promise.future(); } - Future recordPayment(JsonObject request) { + Future recordPayment(JsonObject request) { Promise promise = Promise.promise(); StringBuilder query = new StringBuilder(RECORD_PAYMENT.replace("$0", paymentTable)); diff --git a/src/main/java/iudx/data/marketplace/razorpay/RazorPayVerticle.java b/src/main/java/iudx/data/marketplace/razorpay/RazorPayVerticle.java index f1c4ebf8..9297c1fe 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/RazorPayVerticle.java +++ b/src/main/java/iudx/data/marketplace/razorpay/RazorPayVerticle.java @@ -1,5 +1,10 @@ package iudx.data.marketplace.razorpay; +import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; +import static iudx.data.marketplace.common.Constants.RAZORPAY_SERVICE_ADDRESS; +import static iudx.data.marketplace.razorpay.Constants.RAZORPAY_KEY; +import static iudx.data.marketplace.razorpay.Constants.RAZORPAY_SECRET; + import com.razorpay.RazorpayClient; import com.razorpay.RazorpayException; import io.vertx.core.AbstractVerticle; @@ -10,11 +15,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.POSTGRES_SERVICE_ADDRESS; -import static iudx.data.marketplace.common.Constants.RAZORPAY_SERVICE_ADDRESS; -import static iudx.data.marketplace.razorpay.Constants.RAZORPAY_KEY; -import static iudx.data.marketplace.razorpay.Constants.RAZORPAY_SECRET; - public class RazorPayVerticle extends AbstractVerticle { private static final Logger LOGGER = LogManager.getLogger(AbstractVerticle.class); private MessageConsumer consumer; diff --git a/src/main/java/iudx/data/marketplace/razorpay/package-info.java b/src/main/java/iudx/data/marketplace/razorpay/package-info.java index f0bba14d..9c44228c 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/package-info.java +++ b/src/main/java/iudx/data/marketplace/razorpay/package-info.java @@ -1,6 +1,7 @@ @ModuleGen( groupPackage = "iudx.data.marketplace.razorpay", - name = "iudx-data-marketplace-razorpay-service", useFutures = true) + name = "iudx-data-marketplace-razorpay-service", + useFutures = true) package iudx.data.marketplace.razorpay; -import io.vertx.codegen.annotations.ModuleGen; \ No newline at end of file +import io.vertx.codegen.annotations.ModuleGen; diff --git a/src/main/java/iudx/data/marketplace/razorpay/util/ErrorMessageBuilder.java b/src/main/java/iudx/data/marketplace/razorpay/util/ErrorMessageBuilder.java index af94b4b7..24193f24 100644 --- a/src/main/java/iudx/data/marketplace/razorpay/util/ErrorMessageBuilder.java +++ b/src/main/java/iudx/data/marketplace/razorpay/util/ErrorMessageBuilder.java @@ -1,11 +1,10 @@ package iudx.data.marketplace.razorpay.util; -import iudx.data.marketplace.common.ResponseUrn; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.FAILURE_MESSAGE; +import iudx.data.marketplace.common.ResponseUrn; import java.util.Map; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.FAILURE_MESSAGE; - public class ErrorMessageBuilder { public static Map initialiseMap() { diff --git a/src/main/java/iudx/data/marketplace/webhook/WebhookService.java b/src/main/java/iudx/data/marketplace/webhook/WebhookService.java index 173304b9..ed3f8823 100644 --- a/src/main/java/iudx/data/marketplace/webhook/WebhookService.java +++ b/src/main/java/iudx/data/marketplace/webhook/WebhookService.java @@ -7,22 +7,10 @@ import io.vertx.core.Vertx; import io.vertx.core.json.JsonObject; -@VertxGen @ProxyGen +@VertxGen +@ProxyGen public interface WebhookService { - /** - * @param orderId which is a String generated from Razorpay - * @return Future which is a vertx Future - */ - Future recordOrderPaid(String orderId); - - /** - * @param orderId which is a String generated from Razorpay - * @return Future which is a vertx Future - */ - Future recordPaymentFailure(String orderId); - - /** * The createProxy helps the code generation blocks to generate proxy code. * @@ -34,4 +22,16 @@ public interface WebhookService { static WebhookService createProxy(Vertx vertx, String address) { return new WebhookServiceVertxEBProxy(vertx, address); } + + /** + * @param orderId which is a String generated from Razorpay + * @return Future JsonObject which is a vertx Future + */ + Future recordOrderPaid(String orderId); + + /** + * @param orderId which is a String generated from Razorpay + * @return Future Void which is a vertx Future + */ + Future recordPaymentFailure(String orderId); } diff --git a/src/main/java/iudx/data/marketplace/webhook/WebhookServiceImpl.java b/src/main/java/iudx/data/marketplace/webhook/WebhookServiceImpl.java index 70f740db..938437c6 100644 --- a/src/main/java/iudx/data/marketplace/webhook/WebhookServiceImpl.java +++ b/src/main/java/iudx/data/marketplace/webhook/WebhookServiceImpl.java @@ -54,14 +54,16 @@ Future updatePaymentStatusForInvoice(String orderId, PaymentStatus payment new StringBuilder(UPDATE_PAYMENT_STATUS_QUERY.replace("$0", invoiceTable)); JsonObject params = - new JsonObject().put(PAYMENT_STATUS, paymentStatus.getPaymentStatus()).put(ORDER_ID, orderId); + new JsonObject() + .put(PAYMENT_STATUS, paymentStatus.getPaymentStatus()) + .put(ORDER_ID, orderId); postgresService.executePreparedQuery( query.toString(), params, pgHandler -> { if (pgHandler.succeeded()) { - LOGGER.debug("Result after updating : {}", pgHandler.result().encode()); + LOGGER.debug("Result after updating : {}", pgHandler.result().encode()); promise.complete(); } else { promise.fail(pgHandler.cause()); diff --git a/src/main/java/iudx/data/marketplace/webhook/WebhookVerticle.java b/src/main/java/iudx/data/marketplace/webhook/WebhookVerticle.java index 00479736..72948215 100644 --- a/src/main/java/iudx/data/marketplace/webhook/WebhookVerticle.java +++ b/src/main/java/iudx/data/marketplace/webhook/WebhookVerticle.java @@ -1,23 +1,19 @@ package iudx.data.marketplace.webhook; +import static iudx.data.marketplace.common.Constants.*; +import static iudx.data.marketplace.product.util.Constants.TABLES; + import io.vertx.core.AbstractVerticle; -import io.vertx.core.eventbus.MessageConsumer; -import io.vertx.core.json.JsonObject; import io.vertx.serviceproxy.ServiceBinder; import iudx.data.marketplace.policies.PolicyService; import iudx.data.marketplace.postgres.PostgresService; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import static iudx.data.marketplace.common.Constants.*; -import static iudx.data.marketplace.product.util.Constants.TABLES; - public class WebhookVerticle extends AbstractVerticle { private static final Logger LOGGER = LogManager.getLogger(WebhookVerticle.class); - - private MessageConsumer consumer; private ServiceBinder binder; private PostgresService postgresService; private PolicyService policyService; @@ -33,9 +29,8 @@ public void start() { webhookService = new WebhookServiceImpl(postgresService, policyService, invoiceTable); binder = new ServiceBinder(vertx); - consumer = binder - .setAddress(WEBHOOK_SERVICE_ADDRESS) - .register(WebhookService.class, webhookService); + // MessageConsumer consumer = + binder.setAddress(WEBHOOK_SERVICE_ADDRESS).register(WebhookService.class, webhookService); LOGGER.info("webhook Service started"); } } diff --git a/src/test/java/iudx/data/marketplace/apiserver/handlers/ValidationHandlerTest.java b/src/test/java/iudx/data/marketplace/apiserver/handlers/ValidationHandlerTest.java index b21a770c..22eb2093 100644 --- a/src/test/java/iudx/data/marketplace/apiserver/handlers/ValidationHandlerTest.java +++ b/src/test/java/iudx/data/marketplace/apiserver/handlers/ValidationHandlerTest.java @@ -114,7 +114,7 @@ public void testHandleMethod( when(routingContext.body()).thenReturn(requestBody); when(routingContext.body().asJsonObject()).thenReturn(req); when(routingContext.pathParams()).thenReturn(hashMap); - validationHandler = new ValidationHandler(vertx, requestType); + validationHandler = new ValidationHandler(requestType); validationHandler.handle(routingContext); verify(routingContext, times(numberOfInvocations)).request(); verify(routingContext, times(numberOfInvocations)).body(); diff --git a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestCreateLinkedAccount.java b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestCreateLinkedAccount.java index dfa55b22..5fb2f220 100644 --- a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestCreateLinkedAccount.java +++ b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestCreateLinkedAccount.java @@ -6,6 +6,7 @@ import io.vertx.core.json.JsonObject; import io.vertx.junit5.VertxExtension; import io.vertx.junit5.VertxTestContext; +import iudx.data.marketplace.apiserver.provider.linkedaccount.CreateLinkedAccount; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.common.HttpStatusCode; @@ -24,7 +25,7 @@ import org.mockito.junit.jupiter.MockitoExtension; import org.mockito.stubbing.Answer; -import static iudx.data.marketplace.apiserver.provider.linkedAccount.util.Constants.FAILURE_MESSAGE; +import static iudx.data.marketplace.apiserver.provider.linkedaccount.util.Constants.FAILURE_MESSAGE; import static iudx.data.marketplace.apiserver.util.Constants.*; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.mockito.ArgumentMatchers.any; diff --git a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestFetchLinkedAccount.java b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestFetchLinkedAccount.java index e66c33b5..72b1696c 100644 --- a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestFetchLinkedAccount.java +++ b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestFetchLinkedAccount.java @@ -7,6 +7,7 @@ import io.vertx.core.json.JsonObject; import io.vertx.junit5.VertxExtension; import io.vertx.junit5.VertxTestContext; +import iudx.data.marketplace.apiserver.provider.linkedaccount.FetchLinkedAccount; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.common.HttpStatusCode; import iudx.data.marketplace.common.RespBuilder; diff --git a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestUpdateLinkedAccount.java b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestUpdateLinkedAccount.java index d365ee23..6e07d08d 100644 --- a/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestUpdateLinkedAccount.java +++ b/src/test/java/iudx/data/marketplace/apiserver/provider/linkedAccount/TestUpdateLinkedAccount.java @@ -7,6 +7,7 @@ import io.vertx.core.json.JsonObject; import io.vertx.junit5.VertxExtension; import io.vertx.junit5.VertxTestContext; +import iudx.data.marketplace.apiserver.provider.linkedaccount.UpdateLinkedAccount; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.common.HttpStatusCode; diff --git a/src/test/java/iudx/data/marketplace/authenticator/AuthServiceTest.java b/src/test/java/iudx/data/marketplace/authenticator/AuthServiceTest.java index f1046608..4cf4040f 100644 --- a/src/test/java/iudx/data/marketplace/authenticator/AuthServiceTest.java +++ b/src/test/java/iudx/data/marketplace/authenticator/AuthServiceTest.java @@ -59,7 +59,7 @@ public static void setup(Vertx vertx, VertxTestContext testContext) { JWTAuth jwtAuth = JWTAuth.create(vertx, jwtAuthOptions); catService = mock(CatalogueService.class); - authenticationServiceImpl = new AuthenticationServiceImpl(vertx, jwtAuth, config, api); + authenticationServiceImpl = new AuthenticationServiceImpl( jwtAuth, config, api); testContext.completeNow(); } @@ -176,7 +176,7 @@ public void testTokenIntrospectForVerifyFailure(Vertx vertx, VertxTestContext ve JWTAuth jwtAuth = JWTAuth.create(vertx, jwtAuthOptions); catService = mock(CatalogueService.class); - AuthenticationServiceImpl authenticationServiceImpl = new AuthenticationServiceImpl(vertx, jwtAuth, config, api); + AuthenticationServiceImpl authenticationServiceImpl = new AuthenticationServiceImpl( jwtAuth, config, api); JsonObject authInfo = new JsonObject() .put(TOKEN, JwtHelper.providerToken); diff --git a/src/test/java/iudx/data/marketplace/consumer/ConsumerServiceTest.java b/src/test/java/iudx/data/marketplace/consumer/ConsumerServiceTest.java index 712b03ff..2b410c73 100644 --- a/src/test/java/iudx/data/marketplace/consumer/ConsumerServiceTest.java +++ b/src/test/java/iudx/data/marketplace/consumer/ConsumerServiceTest.java @@ -351,7 +351,7 @@ public AsyncResult answer(InvocationOnMock invocationOnMock) @DisplayName("Test Create Order - Success") public void testCreateOrderSuccess(VertxTestContext testContext) { - when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); + lenient().when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); when(consumer.getUserId()).thenReturn("consumer-id"); request.put(PRODUCT_VARIANT_ID, "pv-id"); doAnswer( @@ -386,7 +386,7 @@ public void testCreateOrderSuccess(VertxTestContext testContext) { @DisplayName("Test Order Create - Get Order Related Info Failed") public void testOrderCreateRelatedInfoFailed(VertxTestContext testContext) { - when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); + lenient().when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); when(consumer.getUserId()).thenReturn("consumer-id"); request.put(PRODUCT_VARIANT_ID, "pv-id"); doAnswer(Answer -> Future.failedFuture("Expected Message")).when(consumerServiceSpy).getOrderRelatedInfo(anyString()); @@ -405,7 +405,7 @@ public void testOrderCreateRelatedInfoFailed(VertxTestContext testContext) { @DisplayName("Test Order Create - RazorPay create order Failed") public void testOrderCreateRazorpayFailed(VertxTestContext testContext) { - when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); + lenient().when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); when(consumer.getUserId()).thenReturn("consumer-id"); request.put(PRODUCT_VARIANT_ID, "pv-id"); doAnswer( @@ -434,7 +434,7 @@ public void testOrderCreateRazorpayFailed(VertxTestContext testContext) { @DisplayName("Test Order Create - Generate Order Entry Failed") public void testOrderCreateGenerateOrderFailed(VertxTestContext testContext) { - when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); + lenient().when(consumer.getResourceServerUrl()).thenReturn("rs.iudx.io"); when(consumer.getUserId()).thenReturn("consumer-id"); request.put(PRODUCT_VARIANT_ID, "pv-id"); doAnswer( diff --git a/src/test/java/iudx/data/marketplace/policy/TestCreatePolicy.java b/src/test/java/iudx/data/marketplace/policy/TestCreatePolicy.java index de6001f1..c105b065 100644 --- a/src/test/java/iudx/data/marketplace/policy/TestCreatePolicy.java +++ b/src/test/java/iudx/data/marketplace/policy/TestCreatePolicy.java @@ -7,8 +7,6 @@ import io.vertx.core.json.JsonObject; import io.vertx.junit5.VertxExtension; import io.vertx.junit5.VertxTestContext; -import iudx.data.marketplace.apiserver.provider.linkedAccount.CreateLinkedAccount; -import iudx.data.marketplace.apiserver.provider.linkedAccount.TestCreateLinkedAccount; import iudx.data.marketplace.auditing.AuditingService; import iudx.data.marketplace.common.Api; import iudx.data.marketplace.policies.CreatePolicy;