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.i18n.Msg; 024import ca.uhn.fhir.rest.annotation.Delete; 025import ca.uhn.fhir.rest.api.RequestTypeEnum; 026import ca.uhn.fhir.rest.api.RestOperationTypeEnum; 027import ca.uhn.fhir.rest.client.impl.BaseHttpClientInvocation; 028import ca.uhn.fhir.rest.server.exceptions.InternalErrorException; 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.List; 036import java.util.Map; 037import java.util.Set; 038 039public class DeleteMethodBinding extends BaseOutcomeReturningMethodBindingWithResourceIdButNoResourceBody { 040 041 public DeleteMethodBinding(Method theMethod, FhirContext theContext, Object theProvider) { 042 super( 043 theMethod, 044 theContext, 045 theProvider, 046 Delete.class, 047 theMethod.getAnnotation(Delete.class).type()); 048 } 049 050 @Override 051 public RestOperationTypeEnum getRestOperationType() { 052 return RestOperationTypeEnum.DELETE; 053 } 054 055 @Override 056 protected Set<RequestTypeEnum> provideAllowableRequestTypes() { 057 return Collections.singleton(RequestTypeEnum.DELETE); 058 } 059 060 @Override 061 protected BaseHttpClientInvocation createClientInvocation(Object[] theArgs, IBaseResource theResource) { 062 StringBuilder urlExtension = new StringBuilder(); 063 urlExtension.append(getContext().getResourceType(theResource)); 064 065 return new HttpPostClientInvocation(getContext(), theResource, urlExtension.toString()); 066 } 067 068 @Override 069 protected boolean allowVoidReturnType() { 070 return true; 071 } 072 073 @Override 074 public BaseHttpClientInvocation invokeClient(Object[] theArgs) throws InternalErrorException { 075 IIdType id = (IIdType) theArgs[getIdParameterIndex()]; 076 if (id == null) { 077 throw new NullPointerException(Msg.code(1472) + "ID can not be null"); 078 } 079 080 if (id.hasResourceType() == false) { 081 id = id.withResourceType(getResourceName()); 082 } else if (getResourceName().equals(id.getResourceType()) == false) { 083 throw new InvalidRequestException(Msg.code(1473) + "ID parameter has the wrong resource type, expected '" 084 + getResourceName() + "', found: " + id.getResourceType()); 085 } 086 087 HttpDeleteClientInvocation retVal = createDeleteInvocation(getContext(), id, Collections.emptyMap()); 088 089 for (int idx = 0; idx < theArgs.length; idx++) { 090 IParameter nextParam = getParameters().get(idx); 091 nextParam.translateClientArgumentIntoQueryArgument(getContext(), theArgs[idx], null, null); 092 } 093 094 return retVal; 095 } 096 097 public static HttpDeleteClientInvocation createDeleteInvocation( 098 FhirContext theContext, IIdType theId, Map<String, List<String>> theAdditionalParams) { 099 return new HttpDeleteClientInvocation(theContext, theId, theAdditionalParams); 100 } 101 102 @Override 103 protected String getMatchingOperation() { 104 return null; 105 } 106 107 public static HttpDeleteClientInvocation createDeleteInvocation( 108 FhirContext theContext, String theSearchUrl, Map<String, List<String>> theParams) { 109 return new HttpDeleteClientInvocation(theContext, theSearchUrl, theParams); 110 } 111}