001/*-
002 * #%L
003 * HAPI FHIR - Server Framework
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.rest.api.server.cdshooks;
021
022import com.fasterxml.jackson.annotation.JsonProperty;
023import jakarta.annotation.Nonnull;
024import org.hl7.fhir.instance.model.api.IBaseResource;
025
026import java.util.Collections;
027import java.util.HashSet;
028import java.util.LinkedHashMap;
029import java.util.Map;
030import java.util.Set;
031
032/**
033 * Represents a CDS Hooks Service Request
034 *
035 * @see <a href="https://cds-hooks.hl7.org/ballots/2020Sep/">Version 1.1 of the CDS Hooks Specification</a>
036 */
037public class CdsServiceRequestJson extends BaseCdsServiceJson {
038        @JsonProperty(value = "hook", required = true)
039        String myHook;
040
041        @JsonProperty(value = "hookInstance", required = true)
042        String myHookInstance;
043
044        @JsonProperty("fhirServer")
045        String myFhirServer;
046
047        @JsonProperty("fhirAuthorization")
048        CdsServiceRequestAuthorizationJson myServiceRequestAuthorizationJson;
049
050        @JsonProperty(value = "context", required = true)
051        CdsServiceRequestContextJson myContext;
052
053        @JsonProperty("prefetch")
054        Map<String, IBaseResource> myPrefetch;
055
056        public String getHookInstance() {
057                return myHookInstance;
058        }
059
060        public CdsServiceRequestJson setHookInstance(String theHookInstance) {
061                myHookInstance = theHookInstance;
062                return this;
063        }
064
065        public String getFhirServer() {
066                return myFhirServer;
067        }
068
069        public CdsServiceRequestJson setFhirServer(String theFhirServer) {
070                myFhirServer = theFhirServer;
071                return this;
072        }
073
074        public String getHook() {
075                return myHook;
076        }
077
078        public CdsServiceRequestJson setHook(String theHook) {
079                myHook = theHook;
080                return this;
081        }
082
083        public CdsServiceRequestContextJson getContext() {
084                if (myContext == null) {
085                        myContext = new CdsServiceRequestContextJson();
086                }
087                return myContext;
088        }
089
090        public CdsServiceRequestJson setContext(CdsServiceRequestContextJson theContext) {
091                myContext = theContext;
092                return this;
093        }
094
095        public CdsServiceRequestAuthorizationJson getServiceRequestAuthorizationJson() {
096                if (myServiceRequestAuthorizationJson == null) {
097                        myServiceRequestAuthorizationJson = new CdsServiceRequestAuthorizationJson();
098                }
099                return myServiceRequestAuthorizationJson;
100        }
101
102        public CdsServiceRequestJson setServiceRequestAuthorizationJson(
103                        CdsServiceRequestAuthorizationJson theServiceRequestAuthorizationJson) {
104                myServiceRequestAuthorizationJson = theServiceRequestAuthorizationJson;
105                return this;
106        }
107
108        public void addPrefetch(String theKey, IBaseResource theResource) {
109                if (myPrefetch == null) {
110                        myPrefetch = new LinkedHashMap<>();
111                }
112                myPrefetch.put(theKey, theResource);
113        }
114
115        public IBaseResource getPrefetch(String theKey) {
116                if (myPrefetch == null) {
117                        return null;
118                }
119                return myPrefetch.get(theKey);
120        }
121
122        public void addContext(String theKey, Object theValue) {
123                getContext().put(theKey, theValue);
124        }
125
126        @Nonnull
127        public Set<String> getPrefetchKeys() {
128                if (myPrefetch == null) {
129                        return new HashSet<>();
130                }
131                return Collections.unmodifiableSet(myPrefetch.keySet());
132        }
133}