001/*-
002 * #%L
003 * HAPI FHIR - Core Library
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.model.api;
021
022import com.fasterxml.jackson.annotation.JsonProperty;
023import org.apache.commons.lang3.Validate;
024
025import java.util.HashMap;
026import java.util.Map;
027
028import static org.apache.commons.lang3.StringUtils.isNotBlank;
029
030public abstract class BaseBatchJobParameters implements IModelJson {
031        /**
032         * A serializable map of key-value pairs that can be
033         * added to any extending job.
034         */
035        @JsonProperty("userData")
036        private Map<String, Object> myUserData;
037
038        public Map<String, Object> getUserData() {
039                if (myUserData == null) {
040                        myUserData = new HashMap<>();
041                }
042                return myUserData;
043        }
044
045        public void setUserData(String theKey, Object theValue) {
046                Validate.isTrue(isNotBlank(theKey), "Invalid key; key must be non-empty, non-null.");
047                if (theValue == null) {
048                        getUserData().remove(theKey);
049                } else {
050                        Validate.isTrue(
051                                        validateValue(theValue),
052                                        String.format(
053                                                        "Invalid data type provided %s", theValue.getClass().getName()));
054                        getUserData().put(theKey, theValue);
055                }
056        }
057
058        private boolean validateValue(Object theValue) {
059                if (theValue instanceof Boolean) {
060                        return true;
061                }
062                if (theValue instanceof Number) {
063                        return true;
064                }
065                if (theValue instanceof String) {
066                        return true;
067                }
068                return false;
069        }
070}