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.bulk;
021
022import ca.uhn.fhir.interceptor.model.RequestPartitionId;
023import ca.uhn.fhir.model.api.BaseBatchJobParameters;
024import ca.uhn.fhir.rest.server.util.JsonDateDeserializer;
025import ca.uhn.fhir.rest.server.util.JsonDateSerializer;
026import com.fasterxml.jackson.annotation.JsonProperty;
027import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
028import com.fasterxml.jackson.databind.annotation.JsonSerialize;
029
030import java.util.ArrayList;
031import java.util.Collection;
032import java.util.Date;
033import java.util.List;
034
035public class BulkExportJobParameters extends BaseBatchJobParameters {
036
037        /**
038         * List of resource types to export.
039         */
040        @JsonProperty("resourceTypes")
041        private List<String> myResourceTypes;
042
043        /**
044         * The start date from when we should start doing the export.
045         */
046        @JsonSerialize(using = JsonDateSerializer.class)
047        @JsonDeserialize(using = JsonDateDeserializer.class)
048        @JsonProperty("since")
049        private Date mySince;
050
051        /**
052         * The end date to which we should stop doing the export.
053         */
054        @JsonSerialize(using = JsonDateSerializer.class)
055        @JsonDeserialize(using = JsonDateDeserializer.class)
056        @JsonProperty("until")
057        private Date myUntil;
058
059        @JsonProperty("exportId")
060        private String myExportId;
061
062        /**
063         * Filters are used to narrow down the resources to export.
064         * Eg:
065         * Patient/123?group=a
066         * "group=a" is a filter
067         */
068        @JsonProperty("filters")
069        private List<String> myFilters;
070
071        /**
072         * URLs to be applied by the inMemoryMatcher after the SQL select
073         */
074        @JsonProperty("postFetchFilterUrls")
075        private List<String> myPostFetchFilterUrls;
076
077        /**
078         * Output format.
079         * Currently unsupported (all outputs are ndjson)
080         */
081        @JsonProperty("outputFormat")
082        private String myOutputFormat;
083
084        /**
085         * Export style - Patient, Group or Everything
086         */
087        @JsonProperty("exportStyle")
088        private ExportStyle myExportStyle;
089
090        /**
091         * Patient id(s)
092         */
093        @JsonProperty("patientIds")
094        private List<String> myPatientIds = new ArrayList<>();
095
096        /**
097         * The request which originated the request.
098         */
099        @JsonProperty("originalRequestUrl")
100        private String myOriginalRequestUrl;
101
102        /**
103         * The group id
104         */
105        @JsonProperty("groupId")
106        private String myGroupId;
107
108        /**
109         * For group export;
110         * whether or not to expand mdm
111         */
112        @JsonProperty("expandMdm")
113        private boolean myExpandMdm;
114
115        /**
116         * The partition for the request if applicable.
117         */
118        @JsonProperty("partitionId")
119        private RequestPartitionId myPartitionId;
120
121        @JsonProperty("binarySecurityContextIdentifierSystem")
122        private String myBinarySecurityContextIdentifierSystem;
123
124        @JsonProperty("binarySecurityContextIdentifierValue")
125        private String myBinarySecurityContextIdentifierValue;
126
127        public String getExportIdentifier() {
128                return myExportId;
129        }
130
131        public void setExportIdentifier(String theExportId) {
132                myExportId = theExportId;
133        }
134
135        public List<String> getResourceTypes() {
136                if (myResourceTypes == null) {
137                        myResourceTypes = new ArrayList<>();
138                }
139                return myResourceTypes;
140        }
141
142        public void setResourceTypes(Collection<String> theResourceTypes) {
143                getResourceTypes().clear();
144                if (theResourceTypes != null) {
145                        getResourceTypes().addAll(theResourceTypes);
146                }
147        }
148
149        public Date getSince() {
150                return mySince;
151        }
152
153        public void setSince(Date theSince) {
154                mySince = theSince;
155        }
156
157        public Date getUntil() {
158                return myUntil;
159        }
160
161        public void setUntil(Date theUntil) {
162                myUntil = theUntil;
163        }
164
165        public List<String> getFilters() {
166                if (myFilters == null) {
167                        myFilters = new ArrayList<>();
168                }
169                return myFilters;
170        }
171
172        public void setFilters(Collection<String> theFilters) {
173                getFilters().clear();
174                if (theFilters != null) {
175                        getFilters().addAll(theFilters);
176                }
177        }
178
179        public List<String> getPostFetchFilterUrls() {
180                if (myPostFetchFilterUrls == null) {
181                        myPostFetchFilterUrls = new ArrayList<>();
182                }
183                return myPostFetchFilterUrls;
184        }
185
186        public void setPostFetchFilterUrls(Collection<String> thePostFetchFilterUrls) {
187                getPostFetchFilterUrls().clear();
188                if (thePostFetchFilterUrls != null) {
189                        getPostFetchFilterUrls().addAll(thePostFetchFilterUrls);
190                }
191        }
192
193        public String getOutputFormat() {
194                return myOutputFormat;
195        }
196
197        public void setOutputFormat(String theOutputFormat) {
198                myOutputFormat = theOutputFormat;
199        }
200
201        public ExportStyle getExportStyle() {
202                return myExportStyle;
203        }
204
205        public void setExportStyle(ExportStyle theExportStyle) {
206                myExportStyle = theExportStyle;
207        }
208
209        public List<String> getPatientIds() {
210                if (myPatientIds == null) {
211                        myPatientIds = new ArrayList<>();
212                }
213                return myPatientIds;
214        }
215
216        public void setPatientIds(Collection<String> thePatientIds) {
217                getPatientIds().clear();
218                if (thePatientIds != null) {
219                        getPatientIds().addAll(thePatientIds);
220                }
221        }
222
223        public String getGroupId() {
224                return myGroupId;
225        }
226
227        public void setGroupId(String theGroupId) {
228                myGroupId = theGroupId;
229        }
230
231        public boolean isExpandMdm() {
232                return myExpandMdm;
233        }
234
235        public void setExpandMdm(boolean theExpandMdm) {
236                myExpandMdm = theExpandMdm;
237        }
238
239        public String getOriginalRequestUrl() {
240                return myOriginalRequestUrl;
241        }
242
243        public void setOriginalRequestUrl(String theOriginalRequestUrl) {
244                this.myOriginalRequestUrl = theOriginalRequestUrl;
245        }
246
247        public RequestPartitionId getPartitionId() {
248                return myPartitionId;
249        }
250
251        public void setPartitionId(RequestPartitionId thePartitionId) {
252                this.myPartitionId = thePartitionId;
253        }
254
255        /**
256         * Sets a value to place in the generated Binary resource's
257         * Binary.securityContext.identifier
258         */
259        public void setBinarySecurityContextIdentifierSystem(String theBinarySecurityContextIdentifierSystem) {
260                myBinarySecurityContextIdentifierSystem = theBinarySecurityContextIdentifierSystem;
261        }
262
263        /**
264         * Sets a value to place in the generated Binary resource's
265         * Binary.securityContext.identifier
266         */
267        public String getBinarySecurityContextIdentifierSystem() {
268                return myBinarySecurityContextIdentifierSystem;
269        }
270
271        /**
272         * Sets a value to place in the generated Binary resource's
273         * Binary.securityContext.identifier
274         */
275        public void setBinarySecurityContextIdentifierValue(String theBinarySecurityContextIdentifierValue) {
276                myBinarySecurityContextIdentifierValue = theBinarySecurityContextIdentifierValue;
277        }
278
279        /**
280         * Sets a value to place in the generated Binary resource's
281         * Binary.securityContext.identifier
282         */
283        public String getBinarySecurityContextIdentifierValue() {
284                return myBinarySecurityContextIdentifierValue;
285        }
286
287        public enum ExportStyle {
288                PATIENT,
289                GROUP,
290                SYSTEM
291        }
292}