From 4fcb0654e81a0e3abf400dbbbd8d2bedbbf5864d Mon Sep 17 00:00:00 2001 From: Thomas <> Date: Tue, 11 Jun 2024 14:43:12 +0200 Subject: feat(core): add method parameter to define custom max. age for pendingRequestId --- .../java/at/gv/egiz/eaaf/core/api/IRequestStorage.java | 12 ++++++++++++ .../api/utils/IPendingRequestIdGenerationStrategy.java | 18 +++++++++++++++--- 2 files changed, 27 insertions(+), 3 deletions(-) (limited to 'eaaf_core_api/src') diff --git a/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/IRequestStorage.java b/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/IRequestStorage.java index 93ce5695..fa9e2252 100644 --- a/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/IRequestStorage.java +++ b/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/IRequestStorage.java @@ -41,6 +41,18 @@ public interface IRequestStorage { */ IRequest getPendingRequest(String pendingReqID) throws PendingReqIdValidationException; + /** + * Get a pending-request from storage. + * + * @param pendingReqID Id of the pending request + * @param maxPendingRequestIdAge Maximum token life-time in seconds. In case of + * < 0, default value will be used + * @return Pending Request Object + * @throws PendingReqIdValidationException if the pendingRequestId was invalid + */ + IRequest getPendingRequest(String pendingReqID, int maxPendingRequestIdAge) + throws PendingReqIdValidationException; + /** * Store a pending-request in storage. * diff --git a/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/utils/IPendingRequestIdGenerationStrategy.java b/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/utils/IPendingRequestIdGenerationStrategy.java index d5dc8aca..ddf3b291 100644 --- a/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/utils/IPendingRequestIdGenerationStrategy.java +++ b/eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/utils/IPendingRequestIdGenerationStrategy.java @@ -1,10 +1,9 @@ package at.gv.egiz.eaaf.core.api.utils; -import javax.annotation.Nonnull; -import javax.annotation.Nullable; - import at.gv.egiz.eaaf.core.exceptions.EaafException; import at.gv.egiz.eaaf.core.exceptions.PendingReqIdValidationException; +import jakarta.annotation.Nonnull; +import jakarta.annotation.Nullable; public interface IPendingRequestIdGenerationStrategy { @@ -27,6 +26,19 @@ public interface IPendingRequestIdGenerationStrategy { @Nonnull String validateAndGetPendingRequestId(@Nullable String pendingReqId) throws PendingReqIdValidationException; + /** + * Validate a pendingRequestId according to implemented strategy. + * + * @param pendingReqId pending-request Id that should be validated + * @param maxTokenAge Maximum token life-time in seconds. In case of < 0, + * default value will be used + * @return internalPendingRequestId + * @throws PendingReqIdValidationException In case of a token validation error + */ + @Nonnull + String validateAndGetPendingRequestId(@Nullable String pendingReqId, @Nonnull int maxTokenAge) + throws PendingReqIdValidationException; + /** * Get the internal pendingReqId without any validation. * -- cgit v1.2.3