From d3990d858d789064f7fd65d0a5f0baaa01ca2063 Mon Sep 17 00:00:00 2001 From: Adesh_Singh Date: Fri, 21 Jun 2024 18:56:57 +0530 Subject: [PATCH 1/5] [EDGPATRON-134]-Added Get external patron endpoint --- ramls/edge-patron.raml | 42 +++++++++++++++++++ .../java/org/folio/edge/patron/Constants.java | 1 + .../org/folio/edge/patron/MainVerticle.java | 3 ++ .../org/folio/edge/patron/PatronHandler.java | 10 +++++ .../edge/patron/utils/PatronOkapiClient.java | 11 +++++ .../folio/edge/patron/MainVerticleTest.java | 18 +++++++- .../edge/patron/utils/PatronMockOkapi.java | 3 ++ 7 files changed, 86 insertions(+), 2 deletions(-) diff --git a/ramls/edge-patron.raml b/ramls/edge-patron.raml index a965adb..6400b04 100644 --- a/ramls/edge-patron.raml +++ b/ramls/edge-patron.raml @@ -77,6 +77,48 @@ types: body: text/plain: example: internal server error, contact administrator + /external-patrons: + displayName: Get Accounts of External Patrons + description: Get accounts of external patrons based on flag + get: + description: Return external_patrons detail + queryParameters: + expired: + description: | + Indicates to return only expired patron + required: false + type: boolean + default: false + apikey: + description: "API Key" + type: string + responses: + 200: + description: Returns the external patron accounts collection + body: + application/json: + type: external_patron_collection + example: !include examples/external_patron_collection.json + 400: + description: Bad request + body: + text/plain: + example: unable to process request -- constraint violation + 401: + description: Not authorized to perform requested action + body: + text/plain: + example: unable to get account -- unauthorized + 403: + description: Access Denied + body: + text/plain: + example: Access Denied + 500: + description: Internal server error, e.g. due to misconfiguration + body: + text/plain: + example: internal server error, contact administrator /by-email/{emailId}: displayName: Get Accounts By email description: Service endpoints that manage accounts by an existing email diff --git a/src/main/java/org/folio/edge/patron/Constants.java b/src/main/java/org/folio/edge/patron/Constants.java index 5e76604..e019d48 100644 --- a/src/main/java/org/folio/edge/patron/Constants.java +++ b/src/main/java/org/folio/edge/patron/Constants.java @@ -24,6 +24,7 @@ public class Constants { public static final String PARAM_INSTANCE_ID = "instanceId"; public static final String PARAM_HOLD_ID = "holdId"; public static final String PARAM_EMAIL_ID = "emailId"; + public static final String PARAM_EXPIRED = "expired"; public static final String PARAM_REQUEST_ID = "requestId"; public static final String MSG_ACCESS_DENIED = "Access Denied"; diff --git a/src/main/java/org/folio/edge/patron/MainVerticle.java b/src/main/java/org/folio/edge/patron/MainVerticle.java index 7de4ba9..3483ab4 100644 --- a/src/main/java/org/folio/edge/patron/MainVerticle.java +++ b/src/main/java/org/folio/edge/patron/MainVerticle.java @@ -60,6 +60,9 @@ public Router defineRoutes() { router.route(HttpMethod.GET, "/patron/account/:patronId/by-email/:emailId") .handler(patronHandler::handleGetExtPatronAccountByEmail); + router.route(HttpMethod.GET, "/patron/account/:patronId/external-patrons") + .handler(patronHandler::handleGetExtPatronsAccounts); + router.route(HttpMethod.POST, "/patron/account/:patronId/item/:itemId/renew") .handler(patronHandler::handleRenew); diff --git a/src/main/java/org/folio/edge/patron/PatronHandler.java b/src/main/java/org/folio/edge/patron/PatronHandler.java index 66d81fb..559e35e 100644 --- a/src/main/java/org/folio/edge/patron/PatronHandler.java +++ b/src/main/java/org/folio/edge/patron/PatronHandler.java @@ -9,6 +9,7 @@ import static org.folio.edge.patron.Constants.MSG_INTERNAL_SERVER_ERROR; import static org.folio.edge.patron.Constants.MSG_REQUEST_TIMEOUT; import static org.folio.edge.patron.Constants.PARAM_EMAIL_ID; +import static org.folio.edge.patron.Constants.PARAM_EXPIRED; import static org.folio.edge.patron.Constants.PARAM_HOLD_ID; import static org.folio.edge.patron.Constants.PARAM_INCLUDE_CHARGES; import static org.folio.edge.patron.Constants.PARAM_INCLUDE_HOLDS; @@ -148,6 +149,15 @@ public void handleGetExtPatronAccountByEmail(RoutingContext ctx) { t -> handleProxyException(ctx, t))); } + public void handleGetExtPatronsAccounts(RoutingContext ctx) { + handleCommon(ctx, + new String[] { PARAM_PATRON_ID, PARAM_EXPIRED }, + new String[] {}, + (client, params) -> ((PatronOkapiClient) client).getExtPatronAccounts( + Boolean.parseBoolean(params.get(PARAM_EXPIRED)), + resp -> handleProxyResponse(ctx, resp), + t -> handleProxyException(ctx, t))); + } public void handlePlaceItemHold(RoutingContext ctx) { if (ctx.body().asJsonObject() == null) { diff --git a/src/main/java/org/folio/edge/patron/utils/PatronOkapiClient.java b/src/main/java/org/folio/edge/patron/utils/PatronOkapiClient.java index e874b0c..6cef343 100644 --- a/src/main/java/org/folio/edge/patron/utils/PatronOkapiClient.java +++ b/src/main/java/org/folio/edge/patron/utils/PatronOkapiClient.java @@ -103,6 +103,17 @@ public void getExtPatronAccountByEmail(String email, Handler> responseHandler, + Handler exceptionHandler) { + String url = String.format("%s/patron/account?expired=%s", okapiURL, expired); + get( + url, + tenant, + null, + responseHandler, + exceptionHandler); + } + public void renewItem(String patronId, String itemId, Handler> responseHandler, Handler exceptionHandler) { post( diff --git a/src/test/java/org/folio/edge/patron/MainVerticleTest.java b/src/test/java/org/folio/edge/patron/MainVerticleTest.java index af070bc..3fe7d78 100644 --- a/src/test/java/org/folio/edge/patron/MainVerticleTest.java +++ b/src/test/java/org/folio/edge/patron/MainVerticleTest.java @@ -635,9 +635,7 @@ public void testRenewRequesMaxRenewalWithEmptyErrors(TestContext context) throws .statusCode(expectedStatusCode) .extract() .response(); - ErrorMessage msg = ErrorMessage.fromJson(resp.body().asString()); - assertEquals("No error message found", msg.message); assertEquals(expectedStatusCode, msg.httpStatusCode); } @@ -731,6 +729,22 @@ public void testPostExternalLCPatron(TestContext context) throws Exception { .response(); } + @Test + public void testGetExternalLCPatrons(TestContext context) throws Exception { + logger.info("=== Test get external patron ==="); + int expectedStatusCode = 200; + RestAssured + .with() + .contentType(APPLICATION_JSON) + .get( + String.format("/patron/account/%s/external-patrons?apikey=%s&expired=false",UUID.randomUUID(), apiKey)) + .then() + .statusCode(expectedStatusCode) + .header(HttpHeaders.CONTENT_TYPE, APPLICATION_JSON) + .extract() + .response(); + } + @Test public void testPlaceInstanceHoldInstanceNotFound(TestContext context) throws Exception { logger.info("=== Test place instance hold w/ instance not found ==="); diff --git a/src/test/java/org/folio/edge/patron/utils/PatronMockOkapi.java b/src/test/java/org/folio/edge/patron/utils/PatronMockOkapi.java index 580e39d..9884616 100644 --- a/src/test/java/org/folio/edge/patron/utils/PatronMockOkapi.java +++ b/src/test/java/org/folio/edge/patron/utils/PatronMockOkapi.java @@ -135,6 +135,9 @@ public Router defineRoutes() { router.route(HttpMethod.GET, "/patron/account/:patronId") .handler(this::getAccountHandler); + router.route(HttpMethod.GET, "/patron/account") + .handler(this::getExtPatronAccountHandler); + router.route(HttpMethod.GET, "/patron/account/by-email/:emailId") .handler(this::getExtPatronAccountHandler); From f412f496caf4f4bdaaf6a0d53a92ec216bf51c31 Mon Sep 17 00:00:00 2001 From: Adesh_Singh Date: Fri, 21 Jun 2024 18:58:43 +0530 Subject: [PATCH 2/5] [EDGPATRON-134]-Added Get external patron endpoint --- .../examples/external_patron_collection.json | 50 +++++++++++++++++++ ramls/raml-util | 2 +- 2 files changed, 51 insertions(+), 1 deletion(-) create mode 100644 ramls/examples/external_patron_collection.json diff --git a/ramls/examples/external_patron_collection.json b/ramls/examples/external_patron_collection.json new file mode 100644 index 0000000..a2d182d --- /dev/null +++ b/ramls/examples/external_patron_collection.json @@ -0,0 +1,50 @@ +{ + "externalPatrons": [ + { + "generalInfo": { + "externalSystemId": "ext123", + "firstName": "John", + "preferredFirstName": "Johnny", + "middleName": "Michael", + "lastName": "Doe" + }, + "address0": { + "addressLine0": "123 Main St", + "addressLine1": "", + "city": "Anytown", + "province": "California", + "zip": "12345", + "country": "USA" + }, + "contactInfo": { + "phone": "123-456-7890", + "mobilePhone": "987-654-3210", + "email": "john.doe@example.com" + }, + "preferredEmailCommunication": ["Support", "Programs"] + }, + { + "generalInfo": { + "externalSystemId": "ext456", + "firstName": "Jane", + "preferredFirstName": "Janey", + "lastName": "Smith" + }, + "address0": { + "addressLine0": "456 Oak Ave", + "addressLine1": "Apt 2B", + "city": "Smallville", + "province": "Kansas", + "zip": "54321", + "country": "USA" + }, + "contactInfo": { + "phone": "987-654-3210", + "mobilePhone": "123-456-7890", + "email": "jane.smith@example.com" + }, + "preferredEmailCommunication": ["Programs", "Service"] + } + ], + "totalRecords": 2 +} diff --git a/ramls/raml-util b/ramls/raml-util index 4aaeffa..16cd5d6 160000 --- a/ramls/raml-util +++ b/ramls/raml-util @@ -1 +1 @@ -Subproject commit 4aaeffa22d5461b41ac761870dcfce58bf8db387 +Subproject commit 16cd5d6024fcb4517ba5f341f73a6c3dbc1b964b From 3469174c3a390a87e2f63e8c0f299ef0f64912d6 Mon Sep 17 00:00:00 2001 From: Adesh_Singh Date: Mon, 24 Jun 2024 15:46:38 +0530 Subject: [PATCH 3/5] [EDGPATRON-134]-Added Get external patron endpoint --- ramls/edge-patron.raml | 1 + src/test/java/org/folio/edge/patron/MainVerticleTest.java | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/ramls/edge-patron.raml b/ramls/edge-patron.raml index 6400b04..27401fb 100644 --- a/ramls/edge-patron.raml +++ b/ramls/edge-patron.raml @@ -18,6 +18,7 @@ types: money: !include money.json item: !include item.json external_patron: !include external_patron.json + external_patron_collection: !include external_patron_collection.json allowedServicePoints: !include allowed-service-points-response.json hold-cancellation: !include hold-cancellation.json errors: !include raml-util/schemas/errors.schema diff --git a/src/test/java/org/folio/edge/patron/MainVerticleTest.java b/src/test/java/org/folio/edge/patron/MainVerticleTest.java index 3fe7d78..717decc 100644 --- a/src/test/java/org/folio/edge/patron/MainVerticleTest.java +++ b/src/test/java/org/folio/edge/patron/MainVerticleTest.java @@ -730,7 +730,7 @@ public void testPostExternalLCPatron(TestContext context) throws Exception { } @Test - public void testGetExternalLCPatrons(TestContext context) throws Exception { + public void testGetExternalLCPatrons(TestContext context) { logger.info("=== Test get external patron ==="); int expectedStatusCode = 200; RestAssured From d1cd46620a3b882248396d6c8592210a76f9a0a1 Mon Sep 17 00:00:00 2001 From: Adesh_Singh Date: Mon, 24 Jun 2024 15:52:24 +0530 Subject: [PATCH 4/5] [EDGPATRON-134]-Added Get external patron endpoint --- ramls/external_patron_collection.json | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 ramls/external_patron_collection.json diff --git a/ramls/external_patron_collection.json b/ramls/external_patron_collection.json new file mode 100644 index 0000000..4066f36 --- /dev/null +++ b/ramls/external_patron_collection.json @@ -0,0 +1,23 @@ +{ + "$schema": "http://json-schema.org/draft-04/schema#", + "type": "object", + "description": "Collection of external patrons", + "properties": { + "externalPatrons": { + "description": "List of external patron items", + "type": "array", + "id": "externalPatron", + "items": { + "type": "object", + "$ref": "external_patron.json" + } + }, + "totalRecords": { + "type": "integer" + } + }, + "required": [ + "externalPatrons", + "totalRecords" + ] +} From 8a5880a344864d17bc8213bd1f90f4eb12cf6a79 Mon Sep 17 00:00:00 2001 From: Adesh_Singh Date: Mon, 24 Jun 2024 16:22:24 +0530 Subject: [PATCH 5/5] [EDGPATRON-134]-Added Get external patron endpoint --- ramls/raml-util | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ramls/raml-util b/ramls/raml-util index 16cd5d6..d93a160 160000 --- a/ramls/raml-util +++ b/ramls/raml-util @@ -1 +1 @@ -Subproject commit 16cd5d6024fcb4517ba5f341f73a6c3dbc1b964b +Subproject commit d93a160488e29d0fce564fe5e47fd74b804818e8