Add time and date attributes to DecisionRequest
These are optional for clients, but may be necessary in
configurations where the application enforcing a guard is
running in a different time zone. Allows some flexibility
instead of always using the time zone that the xacml pdp
is running in.
Issue-ID: POLICY-2810
Change-Id: I4057e5956e59803cc9505fae0ee4e2f67eaf0358
Signed-off-by: Pamela Dragosh <pdragosh@research.att.com>
diff --git a/models-decisions/src/main/java/org/onap/policy/models/decisions/concepts/DecisionRequest.java b/models-decisions/src/main/java/org/onap/policy/models/decisions/concepts/DecisionRequest.java
index ca1e9e2..163d2cf 100644
--- a/models-decisions/src/main/java/org/onap/policy/models/decisions/concepts/DecisionRequest.java
+++ b/models-decisions/src/main/java/org/onap/policy/models/decisions/concepts/DecisionRequest.java
@@ -2,7 +2,7 @@
* ============LICENSE_START=======================================================
* ONAP Policy Decision Models
* ================================================================================
- * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
+ * Copyright (C) 2019, 2021 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -21,6 +21,10 @@
package org.onap.policy.models.decisions.concepts;
import com.google.gson.annotations.SerializedName;
+import java.time.LocalDate;
+import java.time.OffsetDateTime;
+import java.time.OffsetTime;
+import java.time.ZoneOffset;
import java.util.HashMap;
import java.util.Map;
import lombok.Data;
@@ -53,6 +57,18 @@
@SerializedName("action")
private String action;
+ @SerializedName("currentDateTime")
+ private OffsetDateTime currentDateTime;
+
+ @SerializedName("currentDate")
+ private LocalDate currentDate;
+
+ @SerializedName("currentTime")
+ private OffsetTime currentTime;
+
+ @SerializedName("timeZone")
+ private ZoneOffset timeZone;
+
@SerializedName("resource")
private Map<String, Object> resource;
@@ -71,6 +87,10 @@
this.getContext().putAll(request.getContext());
}
this.setAction(request.getAction());
+ this.setCurrentDate(request.getCurrentDate());
+ this.setCurrentDateTime(request.getCurrentDateTime());
+ this.setCurrentTime(request.getCurrentTime());
+ this.setTimeZone(request.getTimeZone());
if (request.getResource() != null) {
this.setResource(new HashMap<>());
this.getResource().putAll(request.getResource());