summaryrefslogtreecommitdiff
path: root/eaaf_core_api/src
diff options
context:
space:
mode:
Diffstat (limited to 'eaaf_core_api/src')
-rw-r--r--eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/IRequestStorage.java12
-rw-r--r--eaaf_core_api/src/main/java/at/gv/egiz/eaaf/core/api/utils/IPendingRequestIdGenerationStrategy.java18
2 files changed, 27 insertions, 3 deletions
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
@@ -42,6 +42,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.
*
* @param pendingRequest Pending-Request object to store
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 {
@@ -28,6 +27,19 @@ public interface IPendingRequestIdGenerationStrategy {
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.
*
* @param externalPendingReqId pending-request Id that should be validated