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.util; 021 022import ca.uhn.fhir.context.FhirContext; 023import ca.uhn.fhir.context.RuntimeResourceDefinition; 024import jakarta.annotation.Nonnull; 025import org.hl7.fhir.instance.model.api.IBase; 026import org.hl7.fhir.instance.model.api.IBaseCoding; 027import org.hl7.fhir.instance.model.api.IBaseReference; 028import org.hl7.fhir.instance.model.api.IBaseResource; 029import org.hl7.fhir.instance.model.api.IIdType; 030import org.hl7.fhir.instance.model.api.IPrimitiveType; 031 032import java.util.Date; 033 034/** 035 * This class can be used to generate <code>Composition</code> resources in 036 * a version independent way. 037 * 038 * @since 6.4.0 039 */ 040public class CompositionBuilder { 041 042 private final FhirContext myCtx; 043 private final IBaseResource myComposition; 044 private final RuntimeResourceDefinition myCompositionDef; 045 private final FhirTerser myTerser; 046 047 public CompositionBuilder(@Nonnull FhirContext theFhirContext) { 048 myCtx = theFhirContext; 049 myCompositionDef = myCtx.getResourceDefinition("Composition"); 050 myTerser = myCtx.newTerser(); 051 myComposition = myCompositionDef.newInstance(); 052 } 053 054 @SuppressWarnings("unchecked") 055 public <T extends IBaseResource> T getComposition() { 056 return (T) myComposition; 057 } 058 059 /** 060 * Add a value to <code>Composition.author</code> 061 */ 062 public void addAuthor(IIdType theAuthorId) { 063 IBaseReference reference = myTerser.addElement(myComposition, "Composition.author"); 064 reference.setReference(theAuthorId.getValue()); 065 } 066 067 /** 068 * Set a value in <code>Composition.status</code> 069 */ 070 public void setStatus(String theStatusCode) { 071 myTerser.setElement(myComposition, "Composition.status", theStatusCode); 072 } 073 074 /** 075 * Set a value in <code>Composition.subject</code> 076 */ 077 public void setSubject(IIdType theSubject) { 078 myTerser.setElement(myComposition, "Composition.subject.reference", theSubject.getValue()); 079 } 080 081 /** 082 * Add a Coding to <code>Composition.type.coding</code> 083 */ 084 public void addTypeCoding(String theSystem, String theCode, String theDisplay) { 085 IBaseCoding coding = myTerser.addElement(myComposition, "Composition.type.coding"); 086 coding.setCode(theCode); 087 coding.setSystem(theSystem); 088 coding.setDisplay(theDisplay); 089 } 090 091 /** 092 * Set a value in <code>Composition.date</code> 093 */ 094 public void setDate(IPrimitiveType<Date> theDate) { 095 myTerser.setElement(myComposition, "Composition.date", theDate.getValueAsString()); 096 } 097 098 /** 099 * Set a value in <code>Composition.title</code> 100 */ 101 public void setTitle(String theTitle) { 102 myTerser.setElement(myComposition, "Composition.title", theTitle); 103 } 104 105 /** 106 * Set a value in <code>Composition.confidentiality</code> 107 */ 108 public void setConfidentiality(String theConfidentiality) { 109 myTerser.setElement(myComposition, "Composition.confidentiality", theConfidentiality); 110 } 111 112 /** 113 * Set a value in <code>Composition.id</code> 114 */ 115 public void setId(IIdType theId) { 116 myComposition.setId(theId.getValue()); 117 } 118 119 public SectionBuilder addSection() { 120 IBase section = myTerser.addElement(myComposition, "Composition.section"); 121 return new SectionBuilder(section); 122 } 123 124 public class SectionBuilder { 125 126 private final IBase mySection; 127 128 /** 129 * Constructor 130 */ 131 private SectionBuilder(IBase theSection) { 132 mySection = theSection; 133 } 134 135 /** 136 * Sets the section title 137 */ 138 public void setTitle(String theTitle) { 139 myTerser.setElement(mySection, "title", theTitle); 140 } 141 142 /** 143 * Add a coding to section.code 144 */ 145 public void addCodeCoding(String theSystem, String theCode, String theDisplay) { 146 IBaseCoding coding = myTerser.addElement(mySection, "code.coding"); 147 coding.setCode(theCode); 148 coding.setSystem(theSystem); 149 coding.setDisplay(theDisplay); 150 } 151 152 /** 153 * Adds a reference to entry.reference 154 */ 155 public void addEntry(IIdType theReference) { 156 IBaseReference entry = myTerser.addElement(mySection, "entry"); 157 entry.setReference(theReference.getValue()); 158 } 159 160 /** 161 * Adds narrative text to the section 162 */ 163 public void setText(String theStatus, String theDivHtml) { 164 IBase text = myTerser.addElement(mySection, "text"); 165 myTerser.setElement(text, "status", theStatus); 166 myTerser.setElement(text, "div", theDivHtml); 167 } 168 } 169}