001/*
002 * #%L
003 * HAPI FHIR - Client 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.client.method;
021
022import ca.uhn.fhir.context.FhirContext;
023import ca.uhn.fhir.context.FhirVersionEnum;
024import ca.uhn.fhir.i18n.Msg;
025import ca.uhn.fhir.rest.annotation.Create;
026import ca.uhn.fhir.rest.api.RequestTypeEnum;
027import ca.uhn.fhir.rest.api.RestOperationTypeEnum;
028import ca.uhn.fhir.rest.client.impl.BaseHttpClientInvocation;
029import ca.uhn.fhir.rest.server.exceptions.InvalidRequestException;
030import org.hl7.fhir.instance.model.api.IBaseResource;
031import org.hl7.fhir.instance.model.api.IIdType;
032
033import java.lang.reflect.Method;
034import java.util.Collections;
035import java.util.Set;
036
037import static org.apache.commons.lang3.StringUtils.isNotBlank;
038
039public class CreateMethodBinding extends BaseOutcomeReturningMethodBindingWithResourceParam {
040
041        public CreateMethodBinding(Method theMethod, FhirContext theContext, Object theProvider) {
042                super(theMethod, theContext, Create.class, theProvider);
043        }
044
045        @Override
046        protected BaseHttpClientInvocation createClientInvocation(Object[] theArgs, IBaseResource theResource) {
047                FhirContext context = getContext();
048
049                BaseHttpClientInvocation retVal = MethodUtil.createCreateInvocation(theResource, context);
050
051                if (theArgs != null) {
052                        for (int idx = 0; idx < theArgs.length; idx++) {
053                                IParameter nextParam = getParameters().get(idx);
054                                nextParam.translateClientArgumentIntoQueryArgument(getContext(), theArgs[idx], null, null);
055                        }
056                }
057
058                return retVal;
059        }
060
061        @Override
062        protected String getMatchingOperation() {
063                return null;
064        }
065
066        @Override
067        public RestOperationTypeEnum getRestOperationType() {
068                return RestOperationTypeEnum.CREATE;
069        }
070
071        @Override
072        protected Set<RequestTypeEnum> provideAllowableRequestTypes() {
073                return Collections.singleton(RequestTypeEnum.POST);
074        }
075
076        @Override
077        protected void validateResourceIdAndUrlIdForNonConditionalOperation(
078                        IBaseResource theResource, String theResourceId, String theUrlId, String theMatchUrl) {
079                if (isNotBlank(theUrlId)) {
080                        String msg = getContext()
081                                        .getLocalizer()
082                                        .getMessage(BaseOutcomeReturningMethodBindingWithResourceParam.class, "idInUrlForCreate", theUrlId);
083                        throw new InvalidRequestException(Msg.code(1411) + msg);
084                }
085                if (getContext().getVersion().getVersion().isOlderThan(FhirVersionEnum.DSTU3)) {
086                        if (isNotBlank(theResourceId)) {
087                                String msg = getContext()
088                                                .getLocalizer()
089                                                .getMessage(
090                                                                BaseOutcomeReturningMethodBindingWithResourceParam.class,
091                                                                "idInBodyForCreate",
092                                                                theResourceId);
093                                throw new InvalidRequestException(Msg.code(1412) + msg);
094                        }
095                } else {
096                        theResource.setId((IIdType) null);
097                }
098        }
099}