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.server.provider; 021 022public class ProviderConstants { 023 public static final String SUBSCRIPTION_TRIGGERING_PARAM_RESOURCE_ID = "resourceId"; 024 public static final String SUBSCRIPTION_TRIGGERING_PARAM_SEARCH_URL = "searchUrl"; 025 026 /** 027 * Operation name: add partition 028 */ 029 public static final String PARTITION_MANAGEMENT_CREATE_PARTITION = "$partition-management-create-partition"; 030 031 /** 032 * Operation name: update partition 033 */ 034 public static final String PARTITION_MANAGEMENT_UPDATE_PARTITION = "$partition-management-update-partition"; 035 036 /** 037 * Operation name: update partition 038 */ 039 public static final String PARTITION_MANAGEMENT_DELETE_PARTITION = "$partition-management-delete-partition"; 040 041 /** 042 * Operation name: read partition 043 */ 044 public static final String PARTITION_MANAGEMENT_READ_PARTITION = "$partition-management-read-partition"; 045 046 /** 047 * Operation name: list partitions 048 */ 049 public static final String PARTITION_MANAGEMENT_LIST_PARTITIONS = "$partition-management-list-partitions"; 050 051 public static final String PARTITION_MANAGEMENT_PARTITION_ID = "id"; 052 public static final String PARTITION_MANAGEMENT_PARTITION_NAME = "name"; 053 public static final String PARTITION_MANAGEMENT_PARTITION_DESC = "description"; 054 055 public static final String DEFAULT_PARTITION_NAME = "DEFAULT"; 056 public static final String ALL_PARTITIONS_TENANT_NAME = "_ALL"; 057 058 /** 059 * Operation name: diff 060 */ 061 public static final String DIFF_OPERATION_NAME = "$diff"; 062 063 public static final String DIFF_FROM_VERSION_PARAMETER = "fromVersion"; 064 065 public static final String DIFF_FROM_PARAMETER = "from"; 066 public static final String DIFF_TO_PARAMETER = "to"; 067 public static final String DIFF_INCLUDE_META_PARAMETER = "includeMeta"; 068 069 /** 070 * MDM Operations 071 */ 072 public static final String PATIENT_MATCH = "$match"; 073 074 public static final String MDM_MATCH = "$mdm-match"; 075 public static final String MDM_MATCH_RESOURCE = "resource"; 076 public static final String MDM_RESOURCE_TYPE = "resourceType"; 077 public static final String MDM_MERGE_GOLDEN_RESOURCES = "$mdm-merge-golden-resources"; 078 public static final String MDM_MERGE_GR_FROM_GOLDEN_RESOURCE_ID = "fromGoldenResourceId"; 079 public static final String MDM_MERGE_GR_TO_GOLDEN_RESOURCE_ID = "toGoldenResourceId"; 080 public static final String MDM_MERGE_RESOURCE = "resource"; 081 082 public static final String MDM_UPDATE_LINK = "$mdm-update-link"; 083 public static final String MDM_UPDATE_LINK_GOLDEN_RESOURCE_ID = "goldenResourceId"; 084 public static final String MDM_UPDATE_LINK_RESOURCE_ID = "resourceId"; 085 public static final String MDM_UPDATE_LINK_MATCH_RESULT = "matchResult"; 086 087 public static final String MDM_CREATE_LINK = "$mdm-create-link"; 088 public static final String MDM_CREATE_LINK_GOLDEN_RESOURCE_ID = "goldenResourceId"; 089 public static final String MDM_CREATE_LINK_RESOURCE_ID = "resourceId"; 090 public static final String MDM_CREATE_LINK_MATCH_RESULT = "matchResult"; 091 092 public static final String MDM_QUERY_LINKS = "$mdm-query-links"; 093 public static final String MDM_LINK_HISTORY = "$mdm-link-history"; 094 public static final String MDM_QUERY_LINKS_GOLDEN_RESOURCE_ID = "goldenResourceId"; 095 public static final String MDM_QUERY_LINKS_RESOURCE_ID = "resourceId"; 096 public static final String MDM_QUERY_PARTITION_IDS = "partitionIds"; 097 public static final String MDM_QUERY_LINKS_MATCH_RESULT = "matchResult"; 098 public static final String MDM_QUERY_LINKS_LINK_SOURCE = "linkSource"; 099 100 public static final String MDM_DUPLICATE_GOLDEN_RESOURCES = "$mdm-duplicate-golden-resources"; 101 public static final String MDM_NOT_DUPLICATE = "$mdm-not-duplicate"; 102 103 public static final String OPERATION_MDM_CLEAR = "$mdm-clear"; 104 public static final String OPERATION_MDM_CLEAR_RESOURCE_NAME = "resourceType"; 105 public static final String OPERATION_MDM_BATCH_SIZE = "batchSize"; 106 public static final String OPERATION_MDM_SUBMIT = "$mdm-submit"; 107 public static final String OPERATION_MDM_SUBMIT_OUT_PARAM_SUBMITTED = "submitted"; 108 public static final String MDM_BATCH_RUN_CRITERIA = "criteria"; 109 public static final String MDM_BATCH_RUN_RESOURCE_TYPE = "resourceType"; 110 111 /** 112 * Clinical Reasoning Operations 113 */ 114 public static final String CR_OPERATION_EVALUATE_MEASURE = "$evaluate-measure"; 115 116 public static final String CR_OPERATION_CARE_GAPS = "$care-gaps"; 117 public static final String CR_OPERATION_SUBMIT_DATA = "$submit-data"; 118 public static final String CR_OPERATION_EVALUATE = "$evaluate"; 119 public static final String CR_OPERATION_CQL = "$cql"; 120 public static final String CR_OPERATION_APPLY = "$apply"; 121 public static final String CR_OPERATION_R5_APPLY = "$r5.apply"; 122 public static final String CR_OPERATION_PREPOPULATE = "$prepopulate"; 123 public static final String CR_OPERATION_POPULATE = "$populate"; 124 public static final String CR_OPERATION_EXTRACT = "$extract"; 125 public static final String CR_OPERATION_PACKAGE = "$package"; 126 public static final String CR_OPERATION_QUESTIONNAIRE = "$questionnaire"; 127 public static final String CR_OPERATION_COLLECTDATA = "$collect-data"; 128 public static final String CR_OPERATION_DATAREQUIREMENTS = "$data-requirements"; 129 /** 130 * Operation name for the $meta operation 131 */ 132 public static final String OPERATION_META = "$meta"; 133 134 /** 135 * Operation name for the $expunge operation 136 */ 137 public static final String OPERATION_EXPUNGE = "$expunge"; 138 139 /** 140 * Parameter name for the $expunge operation 141 */ 142 public static final String OPERATION_EXPUNGE_PARAM_LIMIT = "limit"; 143 /** 144 * Parameter name for the $expunge operation 145 */ 146 public static final String OPERATION_EXPUNGE_PARAM_EXPUNGE_DELETED_RESOURCES = "expungeDeletedResources"; 147 /** 148 * Parameter name for the $expunge operation 149 */ 150 public static final String OPERATION_EXPUNGE_PARAM_EXPUNGE_PREVIOUS_VERSIONS = "expungePreviousVersions"; 151 /** 152 * Parameter name for the $expunge operation 153 */ 154 public static final String OPERATION_EXPUNGE_PARAM_EXPUNGE_EVERYTHING = "expungeEverything"; 155 /** 156 * Output parameter name for the $expunge operation 157 */ 158 public static final String OPERATION_EXPUNGE_OUT_PARAM_EXPUNGE_COUNT = "count"; 159 160 /** 161 * Operation name for the $delete-expunge operation 162 */ 163 public static final String OPERATION_DELETE_EXPUNGE = "$delete-expunge"; 164 165 /** 166 * url of resources to delete for the $delete-expunge operation 167 */ 168 public static final String OPERATION_DELETE_EXPUNGE_URL = "url"; 169 170 /** 171 * Number of resources to delete at a time for the $delete-expunge operation 172 */ 173 public static final String OPERATION_DELETE_BATCH_SIZE = "batchSize"; 174 /** 175 * Should we cascade the $delete-expunge operation 176 */ 177 public static final String OPERATION_DELETE_CASCADE = "cascade"; 178 /** 179 * How many rounds for the $delete-expunge operation 180 */ 181 public static final String OPERATION_DELETE_CASCADE_MAX_ROUNDS = "cascadeMaxRounds"; 182 183 /** 184 * The Spring Batch job id of the delete expunge job created by a $delete-expunge operation 185 */ 186 public static final String OPERATION_BATCH_RESPONSE_JOB_ID = "jobId"; 187 188 /** 189 * Operation name for the $reindex operation 190 */ 191 public static final String OPERATION_REINDEX = "$reindex"; 192 193 /** 194 * Operation name for the $reindex operation 195 */ 196 public static final String OPERATION_REINDEX_DRYRUN = "$reindex-dryrun"; 197 198 /** 199 * Operation name for the $invalidate-expansion operation 200 */ 201 public static final String OPERATION_INVALIDATE_EXPANSION = "$invalidate-expansion"; 202 203 /** 204 * url of resources to delete for the $delete-expunge operation 205 */ 206 public static final String OPERATION_REINDEX_PARAM_URL = "url"; 207 208 /** 209 * Number of resources to delete at a time for the $delete-expunge operation 210 */ 211 public static final String OPERATION_REINDEX_PARAM_BATCH_SIZE = "batchSize"; 212 213 /** 214 * Whether all resource types should be reindexed 215 */ 216 @Deprecated(since = "7.3.4") 217 public static final String OPERATION_REINDEX_PARAM_EVERYTHING = "everything"; 218 219 /** 220 * The Spring Batch job id of the delete expunge job created by a $delete-expunge operation 221 */ 222 public static final String OPERATION_REINDEX_RESPONSE_JOB_ID = "jobId"; 223 224 /** 225 * Operation name for the $reindex-terminology operation 226 */ 227 public static final String OPERATION_REINDEX_TERMINOLOGY = "$reindex-terminology"; 228 229 @Deprecated 230 public static final String MARK_ALL_RESOURCES_FOR_REINDEXING = "$mark-all-resources-for-reindexing"; 231 /** 232 * @see ProviderConstants#OPERATION_REINDEX 233 * @deprecated 234 */ 235 @Deprecated 236 public static final String PERFORM_REINDEXING_PASS = "$perform-reindexing-pass"; 237 238 /** 239 * Operation name for the "$export-poll-status" operation 240 */ 241 public static final String OPERATION_EXPORT_POLL_STATUS = "$export-poll-status"; 242 243 /** 244 * Operation name for the "$export" operation 245 */ 246 public static final String OPERATION_EXPORT = "$export"; 247 248 /** 249 * Operation name for the "$hapi.fhir.replace-references" operation 250 */ 251 public static final String OPERATION_REPLACE_REFERENCES = "$hapi.fhir.replace-references"; 252 253 /** 254 * Parameter for source reference of the "$hapi.fhir.replace-references" operation 255 */ 256 public static final String OPERATION_REPLACE_REFERENCES_PARAM_SOURCE_REFERENCE_ID = "source-reference-id"; 257 258 /** 259 * Parameter for target reference of the "$hapi.fhir.replace-references" operation 260 */ 261 public static final String OPERATION_REPLACE_REFERENCES_PARAM_TARGET_REFERENCE_ID = "target-reference-id"; 262 263 /** 264 * If the request is being performed synchronously and the number of resources that need to change 265 * exceeds this amount, the operation will fail with 412 Precondition Failed. 266 */ 267 public static final String OPERATION_REPLACE_REFERENCES_RESOURCE_LIMIT = "resource-limit"; 268 269 /** 270 * $hapi.fhir.replace-references output Parameters names 271 */ 272 public static final String OPERATION_REPLACE_REFERENCES_OUTPUT_PARAM_TASK = "task"; 273 274 public static final String OPERATION_REPLACE_REFERENCES_OUTPUT_PARAM_OUTCOME = "outcome"; 275 276 /** 277 * Operation name for the Resource "$merge" operation 278 * Hapi-fhir use is based on https://www.hl7.org/fhir/patient-operation-merge.html 279 */ 280 public static final String OPERATION_MERGE = "$merge"; 281 /** 282 * Patient $merge operation parameters 283 */ 284 public static final String OPERATION_MERGE_PARAM_SOURCE_PATIENT = "source-patient"; 285 286 public static final String OPERATION_MERGE_PARAM_SOURCE_PATIENT_IDENTIFIER = "source-patient-identifier"; 287 public static final String OPERATION_MERGE_PARAM_TARGET_PATIENT = "target-patient"; 288 public static final String OPERATION_MERGE_PARAM_TARGET_PATIENT_IDENTIFIER = "target-patient-identifier"; 289 public static final String OPERATION_MERGE_PARAM_RESULT_PATIENT = "result-patient"; 290 public static final String OPERATION_MERGE_PARAM_BATCH_SIZE = "batch-size"; 291 public static final String OPERATION_MERGE_PARAM_PREVIEW = "preview"; 292 public static final String OPERATION_MERGE_PARAM_DELETE_SOURCE = "delete-source"; 293 public static final String OPERATION_MERGE_OUTPUT_PARAM_INPUT = "input"; 294 public static final String OPERATION_MERGE_OUTPUT_PARAM_OUTCOME = OPERATION_REPLACE_REFERENCES_OUTPUT_PARAM_OUTCOME; 295 public static final String OPERATION_MERGE_OUTPUT_PARAM_RESULT = "result"; 296 public static final String OPERATION_MERGE_OUTPUT_PARAM_TASK = OPERATION_REPLACE_REFERENCES_OUTPUT_PARAM_TASK; 297 298 public static final String HAPI_BATCH_JOB_ID_SYSTEM = "http://hapifhir.io/batch/jobId"; 299 public static final String OPERATION_REPLACE_REFERENCES_RESOURCE_LIMIT_DEFAULT_STRING = "512"; 300 public static final Integer OPERATION_REPLACE_REFERENCES_RESOURCE_LIMIT_DEFAULT = 301 Integer.parseInt(OPERATION_REPLACE_REFERENCES_RESOURCE_LIMIT_DEFAULT_STRING); 302}