package org.hl7.fhir.dstu2016may.model; /* Copyright (c) 2011+, HL7, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of HL7 nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ // Generated on Sun, May 8, 2016 03:05+1000 for FHIR v1.4.0 import java.util.ArrayList; import java.util.Date; import java.util.List; import org.hl7.fhir.dstu2016may.model.Enumerations.ConformanceResourceStatus; import org.hl7.fhir.dstu2016may.model.Enumerations.ConformanceResourceStatusEnumFactory; import org.hl7.fhir.dstu2016may.model.Enumerations.SearchParamType; import org.hl7.fhir.dstu2016may.model.Enumerations.SearchParamTypeEnumFactory; import org.hl7.fhir.exceptions.FHIRException; import org.hl7.fhir.instance.model.api.IBaseBackboneElement; import org.hl7.fhir.instance.model.api.IBaseConformance; import org.hl7.fhir.utilities.Utilities; import ca.uhn.fhir.model.api.annotation.Block; import ca.uhn.fhir.model.api.annotation.Child; import ca.uhn.fhir.model.api.annotation.Description; import ca.uhn.fhir.model.api.annotation.ResourceDef; import ca.uhn.fhir.model.api.annotation.SearchParamDefinition; /** * A conformance statement is a set of capabilities of a FHIR Server that may be used as a statement of actual server functionality or a statement of required or desired server implementation. */ @ResourceDef(name="Conformance", profile="http://hl7.org/fhir/Profile/Conformance") public class Conformance extends DomainResource implements IBaseConformance { public enum ConformanceStatementKind { /** * The Conformance instance represents the present capabilities of a specific system instance. This is the kind returned by OPTIONS for a FHIR server end-point. */ INSTANCE, /** * The Conformance instance represents the capabilities of a system or piece of software, independent of a particular installation. */ CAPABILITY, /** * The Conformance instance represents a set of requirements for other systems to meet; e.g. as part of an implementation guide or 'request for proposal'. */ REQUIREMENTS, /** * added to help the parsers */ NULL; public static ConformanceStatementKind fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("instance".equals(codeString)) return INSTANCE; if ("capability".equals(codeString)) return CAPABILITY; if ("requirements".equals(codeString)) return REQUIREMENTS; throw new FHIRException("Unknown ConformanceStatementKind code '"+codeString+"'"); } public String toCode() { switch (this) { case INSTANCE: return "instance"; case CAPABILITY: return "capability"; case REQUIREMENTS: return "requirements"; default: return "?"; } } public String getSystem() { switch (this) { case INSTANCE: return "http://hl7.org/fhir/conformance-statement-kind"; case CAPABILITY: return "http://hl7.org/fhir/conformance-statement-kind"; case REQUIREMENTS: return "http://hl7.org/fhir/conformance-statement-kind"; default: return "?"; } } public String getDefinition() { switch (this) { case INSTANCE: return "The Conformance instance represents the present capabilities of a specific system instance. This is the kind returned by OPTIONS for a FHIR server end-point."; case CAPABILITY: return "The Conformance instance represents the capabilities of a system or piece of software, independent of a particular installation."; case REQUIREMENTS: return "The Conformance instance represents a set of requirements for other systems to meet; e.g. as part of an implementation guide or 'request for proposal'."; default: return "?"; } } public String getDisplay() { switch (this) { case INSTANCE: return "Instance"; case CAPABILITY: return "Capability"; case REQUIREMENTS: return "Requirements"; default: return "?"; } } } public static class ConformanceStatementKindEnumFactory implements EnumFactory<ConformanceStatementKind> { public ConformanceStatementKind fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("instance".equals(codeString)) return ConformanceStatementKind.INSTANCE; if ("capability".equals(codeString)) return ConformanceStatementKind.CAPABILITY; if ("requirements".equals(codeString)) return ConformanceStatementKind.REQUIREMENTS; throw new IllegalArgumentException("Unknown ConformanceStatementKind code '"+codeString+"'"); } public Enumeration<ConformanceStatementKind> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("instance".equals(codeString)) return new Enumeration<ConformanceStatementKind>(this, ConformanceStatementKind.INSTANCE); if ("capability".equals(codeString)) return new Enumeration<ConformanceStatementKind>(this, ConformanceStatementKind.CAPABILITY); if ("requirements".equals(codeString)) return new Enumeration<ConformanceStatementKind>(this, ConformanceStatementKind.REQUIREMENTS); throw new FHIRException("Unknown ConformanceStatementKind code '"+codeString+"'"); } public String toCode(ConformanceStatementKind code) { if (code == ConformanceStatementKind.INSTANCE) return "instance"; if (code == ConformanceStatementKind.CAPABILITY) return "capability"; if (code == ConformanceStatementKind.REQUIREMENTS) return "requirements"; return "?"; } public String toSystem(ConformanceStatementKind code) { return code.getSystem(); } } public enum UnknownContentCode { /** * The application does not accept either unknown elements or extensions. */ NO, /** * The application accepts unknown extensions, but not unknown elements. */ EXTENSIONS, /** * The application accepts unknown elements, but not unknown extensions. */ ELEMENTS, /** * The application accepts unknown elements and extensions. */ BOTH, /** * added to help the parsers */ NULL; public static UnknownContentCode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("no".equals(codeString)) return NO; if ("extensions".equals(codeString)) return EXTENSIONS; if ("elements".equals(codeString)) return ELEMENTS; if ("both".equals(codeString)) return BOTH; throw new FHIRException("Unknown UnknownContentCode code '"+codeString+"'"); } public String toCode() { switch (this) { case NO: return "no"; case EXTENSIONS: return "extensions"; case ELEMENTS: return "elements"; case BOTH: return "both"; default: return "?"; } } public String getSystem() { switch (this) { case NO: return "http://hl7.org/fhir/unknown-content-code"; case EXTENSIONS: return "http://hl7.org/fhir/unknown-content-code"; case ELEMENTS: return "http://hl7.org/fhir/unknown-content-code"; case BOTH: return "http://hl7.org/fhir/unknown-content-code"; default: return "?"; } } public String getDefinition() { switch (this) { case NO: return "The application does not accept either unknown elements or extensions."; case EXTENSIONS: return "The application accepts unknown extensions, but not unknown elements."; case ELEMENTS: return "The application accepts unknown elements, but not unknown extensions."; case BOTH: return "The application accepts unknown elements and extensions."; default: return "?"; } } public String getDisplay() { switch (this) { case NO: return "Neither Elements or Extensions"; case EXTENSIONS: return "Unknown Extensions"; case ELEMENTS: return "Unknown Elements"; case BOTH: return "Unknown Elements and Extensions"; default: return "?"; } } } public static class UnknownContentCodeEnumFactory implements EnumFactory<UnknownContentCode> { public UnknownContentCode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("no".equals(codeString)) return UnknownContentCode.NO; if ("extensions".equals(codeString)) return UnknownContentCode.EXTENSIONS; if ("elements".equals(codeString)) return UnknownContentCode.ELEMENTS; if ("both".equals(codeString)) return UnknownContentCode.BOTH; throw new IllegalArgumentException("Unknown UnknownContentCode code '"+codeString+"'"); } public Enumeration<UnknownContentCode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("no".equals(codeString)) return new Enumeration<UnknownContentCode>(this, UnknownContentCode.NO); if ("extensions".equals(codeString)) return new Enumeration<UnknownContentCode>(this, UnknownContentCode.EXTENSIONS); if ("elements".equals(codeString)) return new Enumeration<UnknownContentCode>(this, UnknownContentCode.ELEMENTS); if ("both".equals(codeString)) return new Enumeration<UnknownContentCode>(this, UnknownContentCode.BOTH); throw new FHIRException("Unknown UnknownContentCode code '"+codeString+"'"); } public String toCode(UnknownContentCode code) { if (code == UnknownContentCode.NO) return "no"; if (code == UnknownContentCode.EXTENSIONS) return "extensions"; if (code == UnknownContentCode.ELEMENTS) return "elements"; if (code == UnknownContentCode.BOTH) return "both"; return "?"; } public String toSystem(UnknownContentCode code) { return code.getSystem(); } } public enum RestfulConformanceMode { /** * The application acts as a client for this resource. */ CLIENT, /** * The application acts as a server for this resource. */ SERVER, /** * added to help the parsers */ NULL; public static RestfulConformanceMode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("client".equals(codeString)) return CLIENT; if ("server".equals(codeString)) return SERVER; throw new FHIRException("Unknown RestfulConformanceMode code '"+codeString+"'"); } public String toCode() { switch (this) { case CLIENT: return "client"; case SERVER: return "server"; default: return "?"; } } public String getSystem() { switch (this) { case CLIENT: return "http://hl7.org/fhir/restful-conformance-mode"; case SERVER: return "http://hl7.org/fhir/restful-conformance-mode"; default: return "?"; } } public String getDefinition() { switch (this) { case CLIENT: return "The application acts as a client for this resource."; case SERVER: return "The application acts as a server for this resource."; default: return "?"; } } public String getDisplay() { switch (this) { case CLIENT: return "Client"; case SERVER: return "Server"; default: return "?"; } } } public static class RestfulConformanceModeEnumFactory implements EnumFactory<RestfulConformanceMode> { public RestfulConformanceMode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("client".equals(codeString)) return RestfulConformanceMode.CLIENT; if ("server".equals(codeString)) return RestfulConformanceMode.SERVER; throw new IllegalArgumentException("Unknown RestfulConformanceMode code '"+codeString+"'"); } public Enumeration<RestfulConformanceMode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("client".equals(codeString)) return new Enumeration<RestfulConformanceMode>(this, RestfulConformanceMode.CLIENT); if ("server".equals(codeString)) return new Enumeration<RestfulConformanceMode>(this, RestfulConformanceMode.SERVER); throw new FHIRException("Unknown RestfulConformanceMode code '"+codeString+"'"); } public String toCode(RestfulConformanceMode code) { if (code == RestfulConformanceMode.CLIENT) return "client"; if (code == RestfulConformanceMode.SERVER) return "server"; return "?"; } public String toSystem(RestfulConformanceMode code) { return code.getSystem(); } } public enum TypeRestfulInteraction { /** * null */ READ, /** * null */ VREAD, /** * null */ UPDATE, /** * null */ DELETE, /** * null */ HISTORYINSTANCE, /** * null */ HISTORYTYPE, /** * null */ CREATE, /** * null */ SEARCHTYPE, /** * added to help the parsers */ NULL; public static TypeRestfulInteraction fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("read".equals(codeString)) return READ; if ("vread".equals(codeString)) return VREAD; if ("update".equals(codeString)) return UPDATE; if ("delete".equals(codeString)) return DELETE; if ("history-instance".equals(codeString)) return HISTORYINSTANCE; if ("history-type".equals(codeString)) return HISTORYTYPE; if ("create".equals(codeString)) return CREATE; if ("search-type".equals(codeString)) return SEARCHTYPE; throw new FHIRException("Unknown TypeRestfulInteraction code '"+codeString+"'"); } public String toCode() { switch (this) { case READ: return "read"; case VREAD: return "vread"; case UPDATE: return "update"; case DELETE: return "delete"; case HISTORYINSTANCE: return "history-instance"; case HISTORYTYPE: return "history-type"; case CREATE: return "create"; case SEARCHTYPE: return "search-type"; default: return "?"; } } public String getSystem() { switch (this) { case READ: return "http://hl7.org/fhir/restful-interaction"; case VREAD: return "http://hl7.org/fhir/restful-interaction"; case UPDATE: return "http://hl7.org/fhir/restful-interaction"; case DELETE: return "http://hl7.org/fhir/restful-interaction"; case HISTORYINSTANCE: return "http://hl7.org/fhir/restful-interaction"; case HISTORYTYPE: return "http://hl7.org/fhir/restful-interaction"; case CREATE: return "http://hl7.org/fhir/restful-interaction"; case SEARCHTYPE: return "http://hl7.org/fhir/restful-interaction"; default: return "?"; } } public String getDefinition() { switch (this) { case READ: return ""; case VREAD: return ""; case UPDATE: return ""; case DELETE: return ""; case HISTORYINSTANCE: return ""; case HISTORYTYPE: return ""; case CREATE: return ""; case SEARCHTYPE: return ""; default: return "?"; } } public String getDisplay() { switch (this) { case READ: return "read"; case VREAD: return "vread"; case UPDATE: return "update"; case DELETE: return "delete"; case HISTORYINSTANCE: return "history-instance"; case HISTORYTYPE: return "history-type"; case CREATE: return "create"; case SEARCHTYPE: return "search-type"; default: return "?"; } } } public static class TypeRestfulInteractionEnumFactory implements EnumFactory<TypeRestfulInteraction> { public TypeRestfulInteraction fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("read".equals(codeString)) return TypeRestfulInteraction.READ; if ("vread".equals(codeString)) return TypeRestfulInteraction.VREAD; if ("update".equals(codeString)) return TypeRestfulInteraction.UPDATE; if ("delete".equals(codeString)) return TypeRestfulInteraction.DELETE; if ("history-instance".equals(codeString)) return TypeRestfulInteraction.HISTORYINSTANCE; if ("history-type".equals(codeString)) return TypeRestfulInteraction.HISTORYTYPE; if ("create".equals(codeString)) return TypeRestfulInteraction.CREATE; if ("search-type".equals(codeString)) return TypeRestfulInteraction.SEARCHTYPE; throw new IllegalArgumentException("Unknown TypeRestfulInteraction code '"+codeString+"'"); } public Enumeration<TypeRestfulInteraction> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("read".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.READ); if ("vread".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.VREAD); if ("update".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.UPDATE); if ("delete".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.DELETE); if ("history-instance".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.HISTORYINSTANCE); if ("history-type".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.HISTORYTYPE); if ("create".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.CREATE); if ("search-type".equals(codeString)) return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.SEARCHTYPE); throw new FHIRException("Unknown TypeRestfulInteraction code '"+codeString+"'"); } public String toCode(TypeRestfulInteraction code) { if (code == TypeRestfulInteraction.READ) return "read"; if (code == TypeRestfulInteraction.VREAD) return "vread"; if (code == TypeRestfulInteraction.UPDATE) return "update"; if (code == TypeRestfulInteraction.DELETE) return "delete"; if (code == TypeRestfulInteraction.HISTORYINSTANCE) return "history-instance"; if (code == TypeRestfulInteraction.HISTORYTYPE) return "history-type"; if (code == TypeRestfulInteraction.CREATE) return "create"; if (code == TypeRestfulInteraction.SEARCHTYPE) return "search-type"; return "?"; } public String toSystem(TypeRestfulInteraction code) { return code.getSystem(); } } public enum ResourceVersionPolicy { /** * VersionId meta-property is not supported (server) or used (client). */ NOVERSION, /** * VersionId meta-property is supported (server) or used (client). */ VERSIONED, /** * VersionId is must be correct for updates (server) or will be specified (If-match header) for updates (client). */ VERSIONEDUPDATE, /** * added to help the parsers */ NULL; public static ResourceVersionPolicy fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("no-version".equals(codeString)) return NOVERSION; if ("versioned".equals(codeString)) return VERSIONED; if ("versioned-update".equals(codeString)) return VERSIONEDUPDATE; throw new FHIRException("Unknown ResourceVersionPolicy code '"+codeString+"'"); } public String toCode() { switch (this) { case NOVERSION: return "no-version"; case VERSIONED: return "versioned"; case VERSIONEDUPDATE: return "versioned-update"; default: return "?"; } } public String getSystem() { switch (this) { case NOVERSION: return "http://hl7.org/fhir/versioning-policy"; case VERSIONED: return "http://hl7.org/fhir/versioning-policy"; case VERSIONEDUPDATE: return "http://hl7.org/fhir/versioning-policy"; default: return "?"; } } public String getDefinition() { switch (this) { case NOVERSION: return "VersionId meta-property is not supported (server) or used (client)."; case VERSIONED: return "VersionId meta-property is supported (server) or used (client)."; case VERSIONEDUPDATE: return "VersionId is must be correct for updates (server) or will be specified (If-match header) for updates (client)."; default: return "?"; } } public String getDisplay() { switch (this) { case NOVERSION: return "No VersionId Support"; case VERSIONED: return "Versioned"; case VERSIONEDUPDATE: return "VersionId tracked fully"; default: return "?"; } } } public static class ResourceVersionPolicyEnumFactory implements EnumFactory<ResourceVersionPolicy> { public ResourceVersionPolicy fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("no-version".equals(codeString)) return ResourceVersionPolicy.NOVERSION; if ("versioned".equals(codeString)) return ResourceVersionPolicy.VERSIONED; if ("versioned-update".equals(codeString)) return ResourceVersionPolicy.VERSIONEDUPDATE; throw new IllegalArgumentException("Unknown ResourceVersionPolicy code '"+codeString+"'"); } public Enumeration<ResourceVersionPolicy> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("no-version".equals(codeString)) return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.NOVERSION); if ("versioned".equals(codeString)) return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.VERSIONED); if ("versioned-update".equals(codeString)) return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.VERSIONEDUPDATE); throw new FHIRException("Unknown ResourceVersionPolicy code '"+codeString+"'"); } public String toCode(ResourceVersionPolicy code) { if (code == ResourceVersionPolicy.NOVERSION) return "no-version"; if (code == ResourceVersionPolicy.VERSIONED) return "versioned"; if (code == ResourceVersionPolicy.VERSIONEDUPDATE) return "versioned-update"; return "?"; } public String toSystem(ResourceVersionPolicy code) { return code.getSystem(); } } public enum ConditionalDeleteStatus { /** * No support for conditional deletes. */ NOTSUPPORTED, /** * Conditional deletes are supported, but only single resources at a time. */ SINGLE, /** * Conditional deletes are supported, and multiple resources can be deleted in a single interaction. */ MULTIPLE, /** * added to help the parsers */ NULL; public static ConditionalDeleteStatus fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return NOTSUPPORTED; if ("single".equals(codeString)) return SINGLE; if ("multiple".equals(codeString)) return MULTIPLE; throw new FHIRException("Unknown ConditionalDeleteStatus code '"+codeString+"'"); } public String toCode() { switch (this) { case NOTSUPPORTED: return "not-supported"; case SINGLE: return "single"; case MULTIPLE: return "multiple"; default: return "?"; } } public String getSystem() { switch (this) { case NOTSUPPORTED: return "http://hl7.org/fhir/conditional-delete-status"; case SINGLE: return "http://hl7.org/fhir/conditional-delete-status"; case MULTIPLE: return "http://hl7.org/fhir/conditional-delete-status"; default: return "?"; } } public String getDefinition() { switch (this) { case NOTSUPPORTED: return "No support for conditional deletes."; case SINGLE: return "Conditional deletes are supported, but only single resources at a time."; case MULTIPLE: return "Conditional deletes are supported, and multiple resources can be deleted in a single interaction."; default: return "?"; } } public String getDisplay() { switch (this) { case NOTSUPPORTED: return "Not Supported"; case SINGLE: return "Single Deletes Supported"; case MULTIPLE: return "Multiple Deletes Supported"; default: return "?"; } } } public static class ConditionalDeleteStatusEnumFactory implements EnumFactory<ConditionalDeleteStatus> { public ConditionalDeleteStatus fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return ConditionalDeleteStatus.NOTSUPPORTED; if ("single".equals(codeString)) return ConditionalDeleteStatus.SINGLE; if ("multiple".equals(codeString)) return ConditionalDeleteStatus.MULTIPLE; throw new IllegalArgumentException("Unknown ConditionalDeleteStatus code '"+codeString+"'"); } public Enumeration<ConditionalDeleteStatus> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.NOTSUPPORTED); if ("single".equals(codeString)) return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.SINGLE); if ("multiple".equals(codeString)) return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.MULTIPLE); throw new FHIRException("Unknown ConditionalDeleteStatus code '"+codeString+"'"); } public String toCode(ConditionalDeleteStatus code) { if (code == ConditionalDeleteStatus.NOTSUPPORTED) return "not-supported"; if (code == ConditionalDeleteStatus.SINGLE) return "single"; if (code == ConditionalDeleteStatus.MULTIPLE) return "multiple"; return "?"; } public String toSystem(ConditionalDeleteStatus code) { return code.getSystem(); } } public enum SearchModifierCode { /** * The search parameter returns resources that have a value or not. */ MISSING, /** * The search parameter returns resources that have a value that exactly matches the supplied parameter (the whole string, including casing and accents). */ EXACT, /** * The search parameter returns resources that include the supplied parameter value anywhere within the field being searched. */ CONTAINS, /** * The search parameter returns resources that do not contain a match . */ NOT, /** * The search parameter is processed as a string that searches text associated with the code/value - either CodeableConcept.text, Coding.display, or Identifier.type.text. */ TEXT, /** * The search parameter is a URI (relative or absolute) that identifies a value set, and the search parameter tests whether the coding is in the specified value set. */ IN, /** * The search parameter is a URI (relative or absolute) that identifies a value set, and the search parameter tests whether the coding is not in the specified value set. */ NOTIN, /** * The search parameter tests whether the value in a resource is subsumed by the specified value (is-a, or hierarchical relationships). */ BELOW, /** * The search parameter tests whether the value in a resource subsumes the specified value (is-a, or hierarchical relationships). */ ABOVE, /** * The search parameter only applies to the Resource Type specified as a modifier (e.g. the modifier is not actually :type, but :Patient etc.). */ TYPE, /** * added to help the parsers */ NULL; public static SearchModifierCode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("missing".equals(codeString)) return MISSING; if ("exact".equals(codeString)) return EXACT; if ("contains".equals(codeString)) return CONTAINS; if ("not".equals(codeString)) return NOT; if ("text".equals(codeString)) return TEXT; if ("in".equals(codeString)) return IN; if ("not-in".equals(codeString)) return NOTIN; if ("below".equals(codeString)) return BELOW; if ("above".equals(codeString)) return ABOVE; if ("type".equals(codeString)) return TYPE; throw new FHIRException("Unknown SearchModifierCode code '"+codeString+"'"); } public String toCode() { switch (this) { case MISSING: return "missing"; case EXACT: return "exact"; case CONTAINS: return "contains"; case NOT: return "not"; case TEXT: return "text"; case IN: return "in"; case NOTIN: return "not-in"; case BELOW: return "below"; case ABOVE: return "above"; case TYPE: return "type"; default: return "?"; } } public String getSystem() { switch (this) { case MISSING: return "http://hl7.org/fhir/search-modifier-code"; case EXACT: return "http://hl7.org/fhir/search-modifier-code"; case CONTAINS: return "http://hl7.org/fhir/search-modifier-code"; case NOT: return "http://hl7.org/fhir/search-modifier-code"; case TEXT: return "http://hl7.org/fhir/search-modifier-code"; case IN: return "http://hl7.org/fhir/search-modifier-code"; case NOTIN: return "http://hl7.org/fhir/search-modifier-code"; case BELOW: return "http://hl7.org/fhir/search-modifier-code"; case ABOVE: return "http://hl7.org/fhir/search-modifier-code"; case TYPE: return "http://hl7.org/fhir/search-modifier-code"; default: return "?"; } } public String getDefinition() { switch (this) { case MISSING: return "The search parameter returns resources that have a value or not."; case EXACT: return "The search parameter returns resources that have a value that exactly matches the supplied parameter (the whole string, including casing and accents)."; case CONTAINS: return "The search parameter returns resources that include the supplied parameter value anywhere within the field being searched."; case NOT: return "The search parameter returns resources that do not contain a match ."; case TEXT: return "The search parameter is processed as a string that searches text associated with the code/value - either CodeableConcept.text, Coding.display, or Identifier.type.text."; case IN: return "The search parameter is a URI (relative or absolute) that identifies a value set, and the search parameter tests whether the coding is in the specified value set."; case NOTIN: return "The search parameter is a URI (relative or absolute) that identifies a value set, and the search parameter tests whether the coding is not in the specified value set."; case BELOW: return "The search parameter tests whether the value in a resource is subsumed by the specified value (is-a, or hierarchical relationships)."; case ABOVE: return "The search parameter tests whether the value in a resource subsumes the specified value (is-a, or hierarchical relationships)."; case TYPE: return "The search parameter only applies to the Resource Type specified as a modifier (e.g. the modifier is not actually :type, but :Patient etc.)."; default: return "?"; } } public String getDisplay() { switch (this) { case MISSING: return "Missing"; case EXACT: return "Exact"; case CONTAINS: return "Contains"; case NOT: return "Not"; case TEXT: return "Text"; case IN: return "In"; case NOTIN: return "Not In"; case BELOW: return "Below"; case ABOVE: return "Above"; case TYPE: return "Type"; default: return "?"; } } } public static class SearchModifierCodeEnumFactory implements EnumFactory<SearchModifierCode> { public SearchModifierCode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("missing".equals(codeString)) return SearchModifierCode.MISSING; if ("exact".equals(codeString)) return SearchModifierCode.EXACT; if ("contains".equals(codeString)) return SearchModifierCode.CONTAINS; if ("not".equals(codeString)) return SearchModifierCode.NOT; if ("text".equals(codeString)) return SearchModifierCode.TEXT; if ("in".equals(codeString)) return SearchModifierCode.IN; if ("not-in".equals(codeString)) return SearchModifierCode.NOTIN; if ("below".equals(codeString)) return SearchModifierCode.BELOW; if ("above".equals(codeString)) return SearchModifierCode.ABOVE; if ("type".equals(codeString)) return SearchModifierCode.TYPE; throw new IllegalArgumentException("Unknown SearchModifierCode code '"+codeString+"'"); } public Enumeration<SearchModifierCode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("missing".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.MISSING); if ("exact".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.EXACT); if ("contains".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.CONTAINS); if ("not".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.NOT); if ("text".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.TEXT); if ("in".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.IN); if ("not-in".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.NOTIN); if ("below".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.BELOW); if ("above".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.ABOVE); if ("type".equals(codeString)) return new Enumeration<SearchModifierCode>(this, SearchModifierCode.TYPE); throw new FHIRException("Unknown SearchModifierCode code '"+codeString+"'"); } public String toCode(SearchModifierCode code) { if (code == SearchModifierCode.MISSING) return "missing"; if (code == SearchModifierCode.EXACT) return "exact"; if (code == SearchModifierCode.CONTAINS) return "contains"; if (code == SearchModifierCode.NOT) return "not"; if (code == SearchModifierCode.TEXT) return "text"; if (code == SearchModifierCode.IN) return "in"; if (code == SearchModifierCode.NOTIN) return "not-in"; if (code == SearchModifierCode.BELOW) return "below"; if (code == SearchModifierCode.ABOVE) return "above"; if (code == SearchModifierCode.TYPE) return "type"; return "?"; } public String toSystem(SearchModifierCode code) { return code.getSystem(); } } public enum SystemRestfulInteraction { /** * null */ TRANSACTION, /** * null */ SEARCHSYSTEM, /** * null */ HISTORYSYSTEM, /** * added to help the parsers */ NULL; public static SystemRestfulInteraction fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("transaction".equals(codeString)) return TRANSACTION; if ("search-system".equals(codeString)) return SEARCHSYSTEM; if ("history-system".equals(codeString)) return HISTORYSYSTEM; throw new FHIRException("Unknown SystemRestfulInteraction code '"+codeString+"'"); } public String toCode() { switch (this) { case TRANSACTION: return "transaction"; case SEARCHSYSTEM: return "search-system"; case HISTORYSYSTEM: return "history-system"; default: return "?"; } } public String getSystem() { switch (this) { case TRANSACTION: return "http://hl7.org/fhir/restful-interaction"; case SEARCHSYSTEM: return "http://hl7.org/fhir/restful-interaction"; case HISTORYSYSTEM: return "http://hl7.org/fhir/restful-interaction"; default: return "?"; } } public String getDefinition() { switch (this) { case TRANSACTION: return ""; case SEARCHSYSTEM: return ""; case HISTORYSYSTEM: return ""; default: return "?"; } } public String getDisplay() { switch (this) { case TRANSACTION: return "transaction"; case SEARCHSYSTEM: return "search-system"; case HISTORYSYSTEM: return "history-system"; default: return "?"; } } } public static class SystemRestfulInteractionEnumFactory implements EnumFactory<SystemRestfulInteraction> { public SystemRestfulInteraction fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("transaction".equals(codeString)) return SystemRestfulInteraction.TRANSACTION; if ("search-system".equals(codeString)) return SystemRestfulInteraction.SEARCHSYSTEM; if ("history-system".equals(codeString)) return SystemRestfulInteraction.HISTORYSYSTEM; throw new IllegalArgumentException("Unknown SystemRestfulInteraction code '"+codeString+"'"); } public Enumeration<SystemRestfulInteraction> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("transaction".equals(codeString)) return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.TRANSACTION); if ("search-system".equals(codeString)) return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.SEARCHSYSTEM); if ("history-system".equals(codeString)) return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.HISTORYSYSTEM); throw new FHIRException("Unknown SystemRestfulInteraction code '"+codeString+"'"); } public String toCode(SystemRestfulInteraction code) { if (code == SystemRestfulInteraction.TRANSACTION) return "transaction"; if (code == SystemRestfulInteraction.SEARCHSYSTEM) return "search-system"; if (code == SystemRestfulInteraction.HISTORYSYSTEM) return "history-system"; return "?"; } public String toSystem(SystemRestfulInteraction code) { return code.getSystem(); } } public enum TransactionMode { /** * Neither batch or transaction is supported. */ NOTSUPPORTED, /** * Batches are supported. */ BATCH, /** * Transactions are supported. */ TRANSACTION, /** * Both batches and transactions are supported. */ BOTH, /** * added to help the parsers */ NULL; public static TransactionMode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return NOTSUPPORTED; if ("batch".equals(codeString)) return BATCH; if ("transaction".equals(codeString)) return TRANSACTION; if ("both".equals(codeString)) return BOTH; throw new FHIRException("Unknown TransactionMode code '"+codeString+"'"); } public String toCode() { switch (this) { case NOTSUPPORTED: return "not-supported"; case BATCH: return "batch"; case TRANSACTION: return "transaction"; case BOTH: return "both"; default: return "?"; } } public String getSystem() { switch (this) { case NOTSUPPORTED: return "http://hl7.org/fhir/transaction-mode"; case BATCH: return "http://hl7.org/fhir/transaction-mode"; case TRANSACTION: return "http://hl7.org/fhir/transaction-mode"; case BOTH: return "http://hl7.org/fhir/transaction-mode"; default: return "?"; } } public String getDefinition() { switch (this) { case NOTSUPPORTED: return "Neither batch or transaction is supported."; case BATCH: return "Batches are supported."; case TRANSACTION: return "Transactions are supported."; case BOTH: return "Both batches and transactions are supported."; default: return "?"; } } public String getDisplay() { switch (this) { case NOTSUPPORTED: return "None"; case BATCH: return "Batches supported"; case TRANSACTION: return "Transactions Supported"; case BOTH: return "Batches & Transactions"; default: return "?"; } } } public static class TransactionModeEnumFactory implements EnumFactory<TransactionMode> { public TransactionMode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return TransactionMode.NOTSUPPORTED; if ("batch".equals(codeString)) return TransactionMode.BATCH; if ("transaction".equals(codeString)) return TransactionMode.TRANSACTION; if ("both".equals(codeString)) return TransactionMode.BOTH; throw new IllegalArgumentException("Unknown TransactionMode code '"+codeString+"'"); } public Enumeration<TransactionMode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("not-supported".equals(codeString)) return new Enumeration<TransactionMode>(this, TransactionMode.NOTSUPPORTED); if ("batch".equals(codeString)) return new Enumeration<TransactionMode>(this, TransactionMode.BATCH); if ("transaction".equals(codeString)) return new Enumeration<TransactionMode>(this, TransactionMode.TRANSACTION); if ("both".equals(codeString)) return new Enumeration<TransactionMode>(this, TransactionMode.BOTH); throw new FHIRException("Unknown TransactionMode code '"+codeString+"'"); } public String toCode(TransactionMode code) { if (code == TransactionMode.NOTSUPPORTED) return "not-supported"; if (code == TransactionMode.BATCH) return "batch"; if (code == TransactionMode.TRANSACTION) return "transaction"; if (code == TransactionMode.BOTH) return "both"; return "?"; } public String toSystem(TransactionMode code) { return code.getSystem(); } } public enum MessageSignificanceCategory { /** * The message represents/requests a change that should not be processed more than once; e.g. Making a booking for an appointment. */ CONSEQUENCE, /** * The message represents a response to query for current information. Retrospective processing is wrong and/or wasteful. */ CURRENCY, /** * The content is not necessarily intended to be current, and it can be reprocessed, though there may be version issues created by processing old notifications. */ NOTIFICATION, /** * added to help the parsers */ NULL; public static MessageSignificanceCategory fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("Consequence".equals(codeString)) return CONSEQUENCE; if ("Currency".equals(codeString)) return CURRENCY; if ("Notification".equals(codeString)) return NOTIFICATION; throw new FHIRException("Unknown MessageSignificanceCategory code '"+codeString+"'"); } public String toCode() { switch (this) { case CONSEQUENCE: return "Consequence"; case CURRENCY: return "Currency"; case NOTIFICATION: return "Notification"; default: return "?"; } } public String getSystem() { switch (this) { case CONSEQUENCE: return "http://hl7.org/fhir/message-significance-category"; case CURRENCY: return "http://hl7.org/fhir/message-significance-category"; case NOTIFICATION: return "http://hl7.org/fhir/message-significance-category"; default: return "?"; } } public String getDefinition() { switch (this) { case CONSEQUENCE: return "The message represents/requests a change that should not be processed more than once; e.g. Making a booking for an appointment."; case CURRENCY: return "The message represents a response to query for current information. Retrospective processing is wrong and/or wasteful."; case NOTIFICATION: return "The content is not necessarily intended to be current, and it can be reprocessed, though there may be version issues created by processing old notifications."; default: return "?"; } } public String getDisplay() { switch (this) { case CONSEQUENCE: return "Consequence"; case CURRENCY: return "Currency"; case NOTIFICATION: return "Notification"; default: return "?"; } } } public static class MessageSignificanceCategoryEnumFactory implements EnumFactory<MessageSignificanceCategory> { public MessageSignificanceCategory fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("Consequence".equals(codeString)) return MessageSignificanceCategory.CONSEQUENCE; if ("Currency".equals(codeString)) return MessageSignificanceCategory.CURRENCY; if ("Notification".equals(codeString)) return MessageSignificanceCategory.NOTIFICATION; throw new IllegalArgumentException("Unknown MessageSignificanceCategory code '"+codeString+"'"); } public Enumeration<MessageSignificanceCategory> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("Consequence".equals(codeString)) return new Enumeration<MessageSignificanceCategory>(this, MessageSignificanceCategory.CONSEQUENCE); if ("Currency".equals(codeString)) return new Enumeration<MessageSignificanceCategory>(this, MessageSignificanceCategory.CURRENCY); if ("Notification".equals(codeString)) return new Enumeration<MessageSignificanceCategory>(this, MessageSignificanceCategory.NOTIFICATION); throw new FHIRException("Unknown MessageSignificanceCategory code '"+codeString+"'"); } public String toCode(MessageSignificanceCategory code) { if (code == MessageSignificanceCategory.CONSEQUENCE) return "Consequence"; if (code == MessageSignificanceCategory.CURRENCY) return "Currency"; if (code == MessageSignificanceCategory.NOTIFICATION) return "Notification"; return "?"; } public String toSystem(MessageSignificanceCategory code) { return code.getSystem(); } } public enum ConformanceEventMode { /** * The application sends requests and receives responses. */ SENDER, /** * The application receives requests and sends responses. */ RECEIVER, /** * added to help the parsers */ NULL; public static ConformanceEventMode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("sender".equals(codeString)) return SENDER; if ("receiver".equals(codeString)) return RECEIVER; throw new FHIRException("Unknown ConformanceEventMode code '"+codeString+"'"); } public String toCode() { switch (this) { case SENDER: return "sender"; case RECEIVER: return "receiver"; default: return "?"; } } public String getSystem() { switch (this) { case SENDER: return "http://hl7.org/fhir/message-conformance-event-mode"; case RECEIVER: return "http://hl7.org/fhir/message-conformance-event-mode"; default: return "?"; } } public String getDefinition() { switch (this) { case SENDER: return "The application sends requests and receives responses."; case RECEIVER: return "The application receives requests and sends responses."; default: return "?"; } } public String getDisplay() { switch (this) { case SENDER: return "Sender"; case RECEIVER: return "Receiver"; default: return "?"; } } } public static class ConformanceEventModeEnumFactory implements EnumFactory<ConformanceEventMode> { public ConformanceEventMode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("sender".equals(codeString)) return ConformanceEventMode.SENDER; if ("receiver".equals(codeString)) return ConformanceEventMode.RECEIVER; throw new IllegalArgumentException("Unknown ConformanceEventMode code '"+codeString+"'"); } public Enumeration<ConformanceEventMode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("sender".equals(codeString)) return new Enumeration<ConformanceEventMode>(this, ConformanceEventMode.SENDER); if ("receiver".equals(codeString)) return new Enumeration<ConformanceEventMode>(this, ConformanceEventMode.RECEIVER); throw new FHIRException("Unknown ConformanceEventMode code '"+codeString+"'"); } public String toCode(ConformanceEventMode code) { if (code == ConformanceEventMode.SENDER) return "sender"; if (code == ConformanceEventMode.RECEIVER) return "receiver"; return "?"; } public String toSystem(ConformanceEventMode code) { return code.getSystem(); } } public enum DocumentMode { /** * The application produces documents of the specified type. */ PRODUCER, /** * The application consumes documents of the specified type. */ CONSUMER, /** * added to help the parsers */ NULL; public static DocumentMode fromCode(String codeString) throws FHIRException { if (codeString == null || "".equals(codeString)) return null; if ("producer".equals(codeString)) return PRODUCER; if ("consumer".equals(codeString)) return CONSUMER; throw new FHIRException("Unknown DocumentMode code '"+codeString+"'"); } public String toCode() { switch (this) { case PRODUCER: return "producer"; case CONSUMER: return "consumer"; default: return "?"; } } public String getSystem() { switch (this) { case PRODUCER: return "http://hl7.org/fhir/document-mode"; case CONSUMER: return "http://hl7.org/fhir/document-mode"; default: return "?"; } } public String getDefinition() { switch (this) { case PRODUCER: return "The application produces documents of the specified type."; case CONSUMER: return "The application consumes documents of the specified type."; default: return "?"; } } public String getDisplay() { switch (this) { case PRODUCER: return "Producer"; case CONSUMER: return "Consumer"; default: return "?"; } } } public static class DocumentModeEnumFactory implements EnumFactory<DocumentMode> { public DocumentMode fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("producer".equals(codeString)) return DocumentMode.PRODUCER; if ("consumer".equals(codeString)) return DocumentMode.CONSUMER; throw new IllegalArgumentException("Unknown DocumentMode code '"+codeString+"'"); } public Enumeration<DocumentMode> fromType(Base code) throws FHIRException { if (code == null || code.isEmpty()) return null; String codeString = ((PrimitiveType) code).asStringValue(); if (codeString == null || "".equals(codeString)) return null; if ("producer".equals(codeString)) return new Enumeration<DocumentMode>(this, DocumentMode.PRODUCER); if ("consumer".equals(codeString)) return new Enumeration<DocumentMode>(this, DocumentMode.CONSUMER); throw new FHIRException("Unknown DocumentMode code '"+codeString+"'"); } public String toCode(DocumentMode code) { if (code == DocumentMode.PRODUCER) return "producer"; if (code == DocumentMode.CONSUMER) return "consumer"; return "?"; } public String toSystem(DocumentMode code) { return code.getSystem(); } } @Block() public static class ConformanceContactComponent extends BackboneElement implements IBaseBackboneElement { /** * The name of an individual to contact regarding the conformance. */ @Child(name = "name", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Name of an individual to contact", formalDefinition="The name of an individual to contact regarding the conformance." ) protected StringType name; /** * Contact details for individual (if a name was provided) or the publisher. */ @Child(name = "telecom", type = {ContactPoint.class}, order=2, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="Contact details for individual or publisher", formalDefinition="Contact details for individual (if a name was provided) or the publisher." ) protected List<ContactPoint> telecom; private static final long serialVersionUID = -1179697803L; /** * Constructor */ public ConformanceContactComponent() { super(); } /** * @return {@link #name} (The name of an individual to contact regarding the conformance.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public StringType getNameElement() { if (this.name == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceContactComponent.name"); else if (Configuration.doAutoCreate()) this.name = new StringType(); // bb return this.name; } public boolean hasNameElement() { return this.name != null && !this.name.isEmpty(); } public boolean hasName() { return this.name != null && !this.name.isEmpty(); } /** * @param value {@link #name} (The name of an individual to contact regarding the conformance.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public ConformanceContactComponent setNameElement(StringType value) { this.name = value; return this; } /** * @return The name of an individual to contact regarding the conformance. */ public String getName() { return this.name == null ? null : this.name.getValue(); } /** * @param value The name of an individual to contact regarding the conformance. */ public ConformanceContactComponent setName(String value) { if (Utilities.noString(value)) this.name = null; else { if (this.name == null) this.name = new StringType(); this.name.setValue(value); } return this; } /** * @return {@link #telecom} (Contact details for individual (if a name was provided) or the publisher.) */ public List<ContactPoint> getTelecom() { if (this.telecom == null) this.telecom = new ArrayList<ContactPoint>(); return this.telecom; } public boolean hasTelecom() { if (this.telecom == null) return false; for (ContactPoint item : this.telecom) if (!item.isEmpty()) return true; return false; } /** * @return {@link #telecom} (Contact details for individual (if a name was provided) or the publisher.) */ // syntactic sugar public ContactPoint addTelecom() { //3 ContactPoint t = new ContactPoint(); if (this.telecom == null) this.telecom = new ArrayList<ContactPoint>(); this.telecom.add(t); return t; } // syntactic sugar public ConformanceContactComponent addTelecom(ContactPoint t) { //3 if (t == null) return this; if (this.telecom == null) this.telecom = new ArrayList<ContactPoint>(); this.telecom.add(t); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("name", "string", "The name of an individual to contact regarding the conformance.", 0, java.lang.Integer.MAX_VALUE, name)); childrenList.add(new Property("telecom", "ContactPoint", "Contact details for individual (if a name was provided) or the publisher.", 0, java.lang.Integer.MAX_VALUE, telecom)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType case -1429363305: /*telecom*/ return this.telecom == null ? new Base[0] : this.telecom.toArray(new Base[this.telecom.size()]); // ContactPoint default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3373707: // name this.name = castToString(value); // StringType break; case -1429363305: // telecom this.getTelecom().add(castToContactPoint(value)); // ContactPoint break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("name")) this.name = castToString(value); // StringType else if (name.equals("telecom")) this.getTelecom().add(castToContactPoint(value)); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3373707: throw new FHIRException("Cannot make property name as it is not a complex type"); // StringType case -1429363305: return addTelecom(); // ContactPoint default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("name")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.name"); } else if (name.equals("telecom")) { return addTelecom(); } else return super.addChild(name); } public ConformanceContactComponent copy() { ConformanceContactComponent dst = new ConformanceContactComponent(); copyValues(dst); dst.name = name == null ? null : name.copy(); if (telecom != null) { dst.telecom = new ArrayList<ContactPoint>(); for (ContactPoint i : telecom) dst.telecom.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceContactComponent)) return false; ConformanceContactComponent o = (ConformanceContactComponent) other; return compareDeep(name, o.name, true) && compareDeep(telecom, o.telecom, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceContactComponent)) return false; ConformanceContactComponent o = (ConformanceContactComponent) other; return compareValues(name, o.name, true); } public boolean isEmpty() { return super.isEmpty() && (name == null || name.isEmpty()) && (telecom == null || telecom.isEmpty()) ; } public String fhirType() { return "Conformance.contact"; } } @Block() public static class ConformanceSoftwareComponent extends BackboneElement implements IBaseBackboneElement { /** * Name software is known by. */ @Child(name = "name", type = {StringType.class}, order=1, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="A name the software is known by", formalDefinition="Name software is known by." ) protected StringType name; /** * The version identifier for the software covered by this statement. */ @Child(name = "version", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Version covered by this statement", formalDefinition="The version identifier for the software covered by this statement." ) protected StringType version; /** * Date this version of the software released. */ @Child(name = "releaseDate", type = {DateTimeType.class}, order=3, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Date this version released", formalDefinition="Date this version of the software released." ) protected DateTimeType releaseDate; private static final long serialVersionUID = 1819769027L; /** * Constructor */ public ConformanceSoftwareComponent() { super(); } /** * Constructor */ public ConformanceSoftwareComponent(StringType name) { super(); this.name = name; } /** * @return {@link #name} (Name software is known by.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public StringType getNameElement() { if (this.name == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceSoftwareComponent.name"); else if (Configuration.doAutoCreate()) this.name = new StringType(); // bb return this.name; } public boolean hasNameElement() { return this.name != null && !this.name.isEmpty(); } public boolean hasName() { return this.name != null && !this.name.isEmpty(); } /** * @param value {@link #name} (Name software is known by.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public ConformanceSoftwareComponent setNameElement(StringType value) { this.name = value; return this; } /** * @return Name software is known by. */ public String getName() { return this.name == null ? null : this.name.getValue(); } /** * @param value Name software is known by. */ public ConformanceSoftwareComponent setName(String value) { if (this.name == null) this.name = new StringType(); this.name.setValue(value); return this; } /** * @return {@link #version} (The version identifier for the software covered by this statement.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public StringType getVersionElement() { if (this.version == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceSoftwareComponent.version"); else if (Configuration.doAutoCreate()) this.version = new StringType(); // bb return this.version; } public boolean hasVersionElement() { return this.version != null && !this.version.isEmpty(); } public boolean hasVersion() { return this.version != null && !this.version.isEmpty(); } /** * @param value {@link #version} (The version identifier for the software covered by this statement.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public ConformanceSoftwareComponent setVersionElement(StringType value) { this.version = value; return this; } /** * @return The version identifier for the software covered by this statement. */ public String getVersion() { return this.version == null ? null : this.version.getValue(); } /** * @param value The version identifier for the software covered by this statement. */ public ConformanceSoftwareComponent setVersion(String value) { if (Utilities.noString(value)) this.version = null; else { if (this.version == null) this.version = new StringType(); this.version.setValue(value); } return this; } /** * @return {@link #releaseDate} (Date this version of the software released.). This is the underlying object with id, value and extensions. The accessor "getReleaseDate" gives direct access to the value */ public DateTimeType getReleaseDateElement() { if (this.releaseDate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceSoftwareComponent.releaseDate"); else if (Configuration.doAutoCreate()) this.releaseDate = new DateTimeType(); // bb return this.releaseDate; } public boolean hasReleaseDateElement() { return this.releaseDate != null && !this.releaseDate.isEmpty(); } public boolean hasReleaseDate() { return this.releaseDate != null && !this.releaseDate.isEmpty(); } /** * @param value {@link #releaseDate} (Date this version of the software released.). This is the underlying object with id, value and extensions. The accessor "getReleaseDate" gives direct access to the value */ public ConformanceSoftwareComponent setReleaseDateElement(DateTimeType value) { this.releaseDate = value; return this; } /** * @return Date this version of the software released. */ public Date getReleaseDate() { return this.releaseDate == null ? null : this.releaseDate.getValue(); } /** * @param value Date this version of the software released. */ public ConformanceSoftwareComponent setReleaseDate(Date value) { if (value == null) this.releaseDate = null; else { if (this.releaseDate == null) this.releaseDate = new DateTimeType(); this.releaseDate.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("name", "string", "Name software is known by.", 0, java.lang.Integer.MAX_VALUE, name)); childrenList.add(new Property("version", "string", "The version identifier for the software covered by this statement.", 0, java.lang.Integer.MAX_VALUE, version)); childrenList.add(new Property("releaseDate", "dateTime", "Date this version of the software released.", 0, java.lang.Integer.MAX_VALUE, releaseDate)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType case 351608024: /*version*/ return this.version == null ? new Base[0] : new Base[] {this.version}; // StringType case 212873301: /*releaseDate*/ return this.releaseDate == null ? new Base[0] : new Base[] {this.releaseDate}; // DateTimeType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3373707: // name this.name = castToString(value); // StringType break; case 351608024: // version this.version = castToString(value); // StringType break; case 212873301: // releaseDate this.releaseDate = castToDateTime(value); // DateTimeType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("name")) this.name = castToString(value); // StringType else if (name.equals("version")) this.version = castToString(value); // StringType else if (name.equals("releaseDate")) this.releaseDate = castToDateTime(value); // DateTimeType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3373707: throw new FHIRException("Cannot make property name as it is not a complex type"); // StringType case 351608024: throw new FHIRException("Cannot make property version as it is not a complex type"); // StringType case 212873301: throw new FHIRException("Cannot make property releaseDate as it is not a complex type"); // DateTimeType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("name")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.name"); } else if (name.equals("version")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.version"); } else if (name.equals("releaseDate")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.releaseDate"); } else return super.addChild(name); } public ConformanceSoftwareComponent copy() { ConformanceSoftwareComponent dst = new ConformanceSoftwareComponent(); copyValues(dst); dst.name = name == null ? null : name.copy(); dst.version = version == null ? null : version.copy(); dst.releaseDate = releaseDate == null ? null : releaseDate.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceSoftwareComponent)) return false; ConformanceSoftwareComponent o = (ConformanceSoftwareComponent) other; return compareDeep(name, o.name, true) && compareDeep(version, o.version, true) && compareDeep(releaseDate, o.releaseDate, true) ; } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceSoftwareComponent)) return false; ConformanceSoftwareComponent o = (ConformanceSoftwareComponent) other; return compareValues(name, o.name, true) && compareValues(version, o.version, true) && compareValues(releaseDate, o.releaseDate, true) ; } public boolean isEmpty() { return super.isEmpty() && (name == null || name.isEmpty()) && (version == null || version.isEmpty()) && (releaseDate == null || releaseDate.isEmpty()); } public String fhirType() { return "Conformance.software"; } } @Block() public static class ConformanceImplementationComponent extends BackboneElement implements IBaseBackboneElement { /** * Information about the specific installation that this conformance statement relates to. */ @Child(name = "description", type = {StringType.class}, order=1, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="Describes this specific instance", formalDefinition="Information about the specific installation that this conformance statement relates to." ) protected StringType description; /** * An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces. */ @Child(name = "url", type = {UriType.class}, order=2, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Base URL for the installation", formalDefinition="An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces." ) protected UriType url; private static final long serialVersionUID = -289238508L; /** * Constructor */ public ConformanceImplementationComponent() { super(); } /** * Constructor */ public ConformanceImplementationComponent(StringType description) { super(); this.description = description; } /** * @return {@link #description} (Information about the specific installation that this conformance statement relates to.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public StringType getDescriptionElement() { if (this.description == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceImplementationComponent.description"); else if (Configuration.doAutoCreate()) this.description = new StringType(); // bb return this.description; } public boolean hasDescriptionElement() { return this.description != null && !this.description.isEmpty(); } public boolean hasDescription() { return this.description != null && !this.description.isEmpty(); } /** * @param value {@link #description} (Information about the specific installation that this conformance statement relates to.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public ConformanceImplementationComponent setDescriptionElement(StringType value) { this.description = value; return this; } /** * @return Information about the specific installation that this conformance statement relates to. */ public String getDescription() { return this.description == null ? null : this.description.getValue(); } /** * @param value Information about the specific installation that this conformance statement relates to. */ public ConformanceImplementationComponent setDescription(String value) { if (this.description == null) this.description = new StringType(); this.description.setValue(value); return this; } /** * @return {@link #url} (An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public UriType getUrlElement() { if (this.url == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceImplementationComponent.url"); else if (Configuration.doAutoCreate()) this.url = new UriType(); // bb return this.url; } public boolean hasUrlElement() { return this.url != null && !this.url.isEmpty(); } public boolean hasUrl() { return this.url != null && !this.url.isEmpty(); } /** * @param value {@link #url} (An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public ConformanceImplementationComponent setUrlElement(UriType value) { this.url = value; return this; } /** * @return An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces. */ public String getUrl() { return this.url == null ? null : this.url.getValue(); } /** * @param value An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces. */ public ConformanceImplementationComponent setUrl(String value) { if (Utilities.noString(value)) this.url = null; else { if (this.url == null) this.url = new UriType(); this.url.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("description", "string", "Information about the specific installation that this conformance statement relates to.", 0, java.lang.Integer.MAX_VALUE, description)); childrenList.add(new Property("url", "uri", "An absolute base URL for the implementation. This forms the base for REST interfaces as well as the mailbox and document interfaces.", 0, java.lang.Integer.MAX_VALUE, url)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // StringType case 116079: /*url*/ return this.url == null ? new Base[0] : new Base[] {this.url}; // UriType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case -1724546052: // description this.description = castToString(value); // StringType break; case 116079: // url this.url = castToUri(value); // UriType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("description")) this.description = castToString(value); // StringType else if (name.equals("url")) this.url = castToUri(value); // UriType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case -1724546052: throw new FHIRException("Cannot make property description as it is not a complex type"); // StringType case 116079: throw new FHIRException("Cannot make property url as it is not a complex type"); // UriType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("description")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.description"); } else if (name.equals("url")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.url"); } else return super.addChild(name); } public ConformanceImplementationComponent copy() { ConformanceImplementationComponent dst = new ConformanceImplementationComponent(); copyValues(dst); dst.description = description == null ? null : description.copy(); dst.url = url == null ? null : url.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceImplementationComponent)) return false; ConformanceImplementationComponent o = (ConformanceImplementationComponent) other; return compareDeep(description, o.description, true) && compareDeep(url, o.url, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceImplementationComponent)) return false; ConformanceImplementationComponent o = (ConformanceImplementationComponent) other; return compareValues(description, o.description, true) && compareValues(url, o.url, true); } public boolean isEmpty() { return super.isEmpty() && (description == null || description.isEmpty()) && (url == null || url.isEmpty()) ; } public String fhirType() { return "Conformance.implementation"; } } @Block() public static class ConformanceRestComponent extends BackboneElement implements IBaseBackboneElement { /** * Identifies whether this portion of the statement is describing ability to initiate or receive restful operations. */ @Child(name = "mode", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="client | server", formalDefinition="Identifies whether this portion of the statement is describing ability to initiate or receive restful operations." ) protected Enumeration<RestfulConformanceMode> mode; /** * Information about the system's restful capabilities that apply across all applications, such as security. */ @Child(name = "documentation", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="General description of implementation", formalDefinition="Information about the system's restful capabilities that apply across all applications, such as security." ) protected StringType documentation; /** * Information about security implementation from an interface perspective - what a client needs to know. */ @Child(name = "security", type = {}, order=3, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Information about security of implementation", formalDefinition="Information about security implementation from an interface perspective - what a client needs to know." ) protected ConformanceRestSecurityComponent security; /** * A specification of the restful capabilities of the solution for a specific resource type. */ @Child(name = "resource", type = {}, order=4, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="Resource served on the REST interface", formalDefinition="A specification of the restful capabilities of the solution for a specific resource type." ) protected List<ConformanceRestResourceComponent> resource; /** * A specification of restful operations supported by the system. */ @Child(name = "interaction", type = {}, order=5, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="What operations are supported?", formalDefinition="A specification of restful operations supported by the system." ) protected List<SystemInteractionComponent> interaction; /** * A code that indicates how transactions are supported. */ @Child(name = "transactionMode", type = {CodeType.class}, order=6, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="not-supported | batch | transaction | both", formalDefinition="A code that indicates how transactions are supported." ) protected Enumeration<TransactionMode> transactionMode; /** * Search parameters that are supported for searching all resources for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation. */ @Child(name = "searchParam", type = {ConformanceRestResourceSearchParamComponent.class}, order=7, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Search params for searching all resources", formalDefinition="Search parameters that are supported for searching all resources for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation." ) protected List<ConformanceRestResourceSearchParamComponent> searchParam; /** * Definition of an operation or a named query and with its parameters and their meaning and type. */ @Child(name = "operation", type = {}, order=8, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Definition of an operation or a custom query", formalDefinition="Definition of an operation or a named query and with its parameters and their meaning and type." ) protected List<ConformanceRestOperationComponent> operation; /** * An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL. */ @Child(name = "compartment", type = {UriType.class}, order=9, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Compartments served/used by system", formalDefinition="An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL." ) protected List<UriType> compartment; private static final long serialVersionUID = 931983837L; /** * Constructor */ public ConformanceRestComponent() { super(); } /** * Constructor */ public ConformanceRestComponent(Enumeration<RestfulConformanceMode> mode) { super(); this.mode = mode; } /** * @return {@link #mode} (Identifies whether this portion of the statement is describing ability to initiate or receive restful operations.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public Enumeration<RestfulConformanceMode> getModeElement() { if (this.mode == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestComponent.mode"); else if (Configuration.doAutoCreate()) this.mode = new Enumeration<RestfulConformanceMode>(new RestfulConformanceModeEnumFactory()); // bb return this.mode; } public boolean hasModeElement() { return this.mode != null && !this.mode.isEmpty(); } public boolean hasMode() { return this.mode != null && !this.mode.isEmpty(); } /** * @param value {@link #mode} (Identifies whether this portion of the statement is describing ability to initiate or receive restful operations.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public ConformanceRestComponent setModeElement(Enumeration<RestfulConformanceMode> value) { this.mode = value; return this; } /** * @return Identifies whether this portion of the statement is describing ability to initiate or receive restful operations. */ public RestfulConformanceMode getMode() { return this.mode == null ? null : this.mode.getValue(); } /** * @param value Identifies whether this portion of the statement is describing ability to initiate or receive restful operations. */ public ConformanceRestComponent setMode(RestfulConformanceMode value) { if (this.mode == null) this.mode = new Enumeration<RestfulConformanceMode>(new RestfulConformanceModeEnumFactory()); this.mode.setValue(value); return this; } /** * @return {@link #documentation} (Information about the system's restful capabilities that apply across all applications, such as security.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (Information about the system's restful capabilities that apply across all applications, such as security.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ConformanceRestComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return Information about the system's restful capabilities that apply across all applications, such as security. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value Information about the system's restful capabilities that apply across all applications, such as security. */ public ConformanceRestComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } /** * @return {@link #security} (Information about security implementation from an interface perspective - what a client needs to know.) */ public ConformanceRestSecurityComponent getSecurity() { if (this.security == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestComponent.security"); else if (Configuration.doAutoCreate()) this.security = new ConformanceRestSecurityComponent(); // cc return this.security; } public boolean hasSecurity() { return this.security != null && !this.security.isEmpty(); } /** * @param value {@link #security} (Information about security implementation from an interface perspective - what a client needs to know.) */ public ConformanceRestComponent setSecurity(ConformanceRestSecurityComponent value) { this.security = value; return this; } /** * @return {@link #resource} (A specification of the restful capabilities of the solution for a specific resource type.) */ public List<ConformanceRestResourceComponent> getResource() { if (this.resource == null) this.resource = new ArrayList<ConformanceRestResourceComponent>(); return this.resource; } public boolean hasResource() { if (this.resource == null) return false; for (ConformanceRestResourceComponent item : this.resource) if (!item.isEmpty()) return true; return false; } /** * @return {@link #resource} (A specification of the restful capabilities of the solution for a specific resource type.) */ // syntactic sugar public ConformanceRestResourceComponent addResource() { //3 ConformanceRestResourceComponent t = new ConformanceRestResourceComponent(); if (this.resource == null) this.resource = new ArrayList<ConformanceRestResourceComponent>(); this.resource.add(t); return t; } // syntactic sugar public ConformanceRestComponent addResource(ConformanceRestResourceComponent t) { //3 if (t == null) return this; if (this.resource == null) this.resource = new ArrayList<ConformanceRestResourceComponent>(); this.resource.add(t); return this; } /** * @return {@link #interaction} (A specification of restful operations supported by the system.) */ public List<SystemInteractionComponent> getInteraction() { if (this.interaction == null) this.interaction = new ArrayList<SystemInteractionComponent>(); return this.interaction; } public boolean hasInteraction() { if (this.interaction == null) return false; for (SystemInteractionComponent item : this.interaction) if (!item.isEmpty()) return true; return false; } /** * @return {@link #interaction} (A specification of restful operations supported by the system.) */ // syntactic sugar public SystemInteractionComponent addInteraction() { //3 SystemInteractionComponent t = new SystemInteractionComponent(); if (this.interaction == null) this.interaction = new ArrayList<SystemInteractionComponent>(); this.interaction.add(t); return t; } // syntactic sugar public ConformanceRestComponent addInteraction(SystemInteractionComponent t) { //3 if (t == null) return this; if (this.interaction == null) this.interaction = new ArrayList<SystemInteractionComponent>(); this.interaction.add(t); return this; } /** * @return {@link #transactionMode} (A code that indicates how transactions are supported.). This is the underlying object with id, value and extensions. The accessor "getTransactionMode" gives direct access to the value */ public Enumeration<TransactionMode> getTransactionModeElement() { if (this.transactionMode == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestComponent.transactionMode"); else if (Configuration.doAutoCreate()) this.transactionMode = new Enumeration<TransactionMode>(new TransactionModeEnumFactory()); // bb return this.transactionMode; } public boolean hasTransactionModeElement() { return this.transactionMode != null && !this.transactionMode.isEmpty(); } public boolean hasTransactionMode() { return this.transactionMode != null && !this.transactionMode.isEmpty(); } /** * @param value {@link #transactionMode} (A code that indicates how transactions are supported.). This is the underlying object with id, value and extensions. The accessor "getTransactionMode" gives direct access to the value */ public ConformanceRestComponent setTransactionModeElement(Enumeration<TransactionMode> value) { this.transactionMode = value; return this; } /** * @return A code that indicates how transactions are supported. */ public TransactionMode getTransactionMode() { return this.transactionMode == null ? null : this.transactionMode.getValue(); } /** * @param value A code that indicates how transactions are supported. */ public ConformanceRestComponent setTransactionMode(TransactionMode value) { if (value == null) this.transactionMode = null; else { if (this.transactionMode == null) this.transactionMode = new Enumeration<TransactionMode>(new TransactionModeEnumFactory()); this.transactionMode.setValue(value); } return this; } /** * @return {@link #searchParam} (Search parameters that are supported for searching all resources for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.) */ public List<ConformanceRestResourceSearchParamComponent> getSearchParam() { if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); return this.searchParam; } public boolean hasSearchParam() { if (this.searchParam == null) return false; for (ConformanceRestResourceSearchParamComponent item : this.searchParam) if (!item.isEmpty()) return true; return false; } /** * @return {@link #searchParam} (Search parameters that are supported for searching all resources for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.) */ // syntactic sugar public ConformanceRestResourceSearchParamComponent addSearchParam() { //3 ConformanceRestResourceSearchParamComponent t = new ConformanceRestResourceSearchParamComponent(); if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); this.searchParam.add(t); return t; } // syntactic sugar public ConformanceRestComponent addSearchParam(ConformanceRestResourceSearchParamComponent t) { //3 if (t == null) return this; if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); this.searchParam.add(t); return this; } /** * @return {@link #operation} (Definition of an operation or a named query and with its parameters and their meaning and type.) */ public List<ConformanceRestOperationComponent> getOperation() { if (this.operation == null) this.operation = new ArrayList<ConformanceRestOperationComponent>(); return this.operation; } public boolean hasOperation() { if (this.operation == null) return false; for (ConformanceRestOperationComponent item : this.operation) if (!item.isEmpty()) return true; return false; } /** * @return {@link #operation} (Definition of an operation or a named query and with its parameters and their meaning and type.) */ // syntactic sugar public ConformanceRestOperationComponent addOperation() { //3 ConformanceRestOperationComponent t = new ConformanceRestOperationComponent(); if (this.operation == null) this.operation = new ArrayList<ConformanceRestOperationComponent>(); this.operation.add(t); return t; } // syntactic sugar public ConformanceRestComponent addOperation(ConformanceRestOperationComponent t) { //3 if (t == null) return this; if (this.operation == null) this.operation = new ArrayList<ConformanceRestOperationComponent>(); this.operation.add(t); return this; } /** * @return {@link #compartment} (An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL.) */ public List<UriType> getCompartment() { if (this.compartment == null) this.compartment = new ArrayList<UriType>(); return this.compartment; } public boolean hasCompartment() { if (this.compartment == null) return false; for (UriType item : this.compartment) if (!item.isEmpty()) return true; return false; } /** * @return {@link #compartment} (An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL.) */ // syntactic sugar public UriType addCompartmentElement() {//2 UriType t = new UriType(); if (this.compartment == null) this.compartment = new ArrayList<UriType>(); this.compartment.add(t); return t; } /** * @param value {@link #compartment} (An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL.) */ public ConformanceRestComponent addCompartment(String value) { //1 UriType t = new UriType(); t.setValue(value); if (this.compartment == null) this.compartment = new ArrayList<UriType>(); this.compartment.add(t); return this; } /** * @param value {@link #compartment} (An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL.) */ public boolean hasCompartment(String value) { if (this.compartment == null) return false; for (UriType v : this.compartment) if (v.equals(value)) // uri return true; return false; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("mode", "code", "Identifies whether this portion of the statement is describing ability to initiate or receive restful operations.", 0, java.lang.Integer.MAX_VALUE, mode)); childrenList.add(new Property("documentation", "string", "Information about the system's restful capabilities that apply across all applications, such as security.", 0, java.lang.Integer.MAX_VALUE, documentation)); childrenList.add(new Property("security", "", "Information about security implementation from an interface perspective - what a client needs to know.", 0, java.lang.Integer.MAX_VALUE, security)); childrenList.add(new Property("resource", "", "A specification of the restful capabilities of the solution for a specific resource type.", 0, java.lang.Integer.MAX_VALUE, resource)); childrenList.add(new Property("interaction", "", "A specification of restful operations supported by the system.", 0, java.lang.Integer.MAX_VALUE, interaction)); childrenList.add(new Property("transactionMode", "code", "A code that indicates how transactions are supported.", 0, java.lang.Integer.MAX_VALUE, transactionMode)); childrenList.add(new Property("searchParam", "@Conformance.rest.resource.searchParam", "Search parameters that are supported for searching all resources for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.", 0, java.lang.Integer.MAX_VALUE, searchParam)); childrenList.add(new Property("operation", "", "Definition of an operation or a named query and with its parameters and their meaning and type.", 0, java.lang.Integer.MAX_VALUE, operation)); childrenList.add(new Property("compartment", "uri", "An absolute URI which is a reference to the definition of a compartment that the system supports. The reference is to a CompartmentDefinition resource by it's canonical URL.", 0, java.lang.Integer.MAX_VALUE, compartment)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3357091: /*mode*/ return this.mode == null ? new Base[0] : new Base[] {this.mode}; // Enumeration<RestfulConformanceMode> case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType case 949122880: /*security*/ return this.security == null ? new Base[0] : new Base[] {this.security}; // ConformanceRestSecurityComponent case -341064690: /*resource*/ return this.resource == null ? new Base[0] : this.resource.toArray(new Base[this.resource.size()]); // ConformanceRestResourceComponent case 1844104722: /*interaction*/ return this.interaction == null ? new Base[0] : this.interaction.toArray(new Base[this.interaction.size()]); // SystemInteractionComponent case 1262805409: /*transactionMode*/ return this.transactionMode == null ? new Base[0] : new Base[] {this.transactionMode}; // Enumeration<TransactionMode> case -553645115: /*searchParam*/ return this.searchParam == null ? new Base[0] : this.searchParam.toArray(new Base[this.searchParam.size()]); // ConformanceRestResourceSearchParamComponent case 1662702951: /*operation*/ return this.operation == null ? new Base[0] : this.operation.toArray(new Base[this.operation.size()]); // ConformanceRestOperationComponent case -397756334: /*compartment*/ return this.compartment == null ? new Base[0] : this.compartment.toArray(new Base[this.compartment.size()]); // UriType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3357091: // mode this.mode = new RestfulConformanceModeEnumFactory().fromType(value); // Enumeration<RestfulConformanceMode> break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; case 949122880: // security this.security = (ConformanceRestSecurityComponent) value; // ConformanceRestSecurityComponent break; case -341064690: // resource this.getResource().add((ConformanceRestResourceComponent) value); // ConformanceRestResourceComponent break; case 1844104722: // interaction this.getInteraction().add((SystemInteractionComponent) value); // SystemInteractionComponent break; case 1262805409: // transactionMode this.transactionMode = new TransactionModeEnumFactory().fromType(value); // Enumeration<TransactionMode> break; case -553645115: // searchParam this.getSearchParam().add((ConformanceRestResourceSearchParamComponent) value); // ConformanceRestResourceSearchParamComponent break; case 1662702951: // operation this.getOperation().add((ConformanceRestOperationComponent) value); // ConformanceRestOperationComponent break; case -397756334: // compartment this.getCompartment().add(castToUri(value)); // UriType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("mode")) this.mode = new RestfulConformanceModeEnumFactory().fromType(value); // Enumeration<RestfulConformanceMode> else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else if (name.equals("security")) this.security = (ConformanceRestSecurityComponent) value; // ConformanceRestSecurityComponent else if (name.equals("resource")) this.getResource().add((ConformanceRestResourceComponent) value); else if (name.equals("interaction")) this.getInteraction().add((SystemInteractionComponent) value); else if (name.equals("transactionMode")) this.transactionMode = new TransactionModeEnumFactory().fromType(value); // Enumeration<TransactionMode> else if (name.equals("searchParam")) this.getSearchParam().add((ConformanceRestResourceSearchParamComponent) value); else if (name.equals("operation")) this.getOperation().add((ConformanceRestOperationComponent) value); else if (name.equals("compartment")) this.getCompartment().add(castToUri(value)); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3357091: throw new FHIRException("Cannot make property mode as it is not a complex type"); // Enumeration<RestfulConformanceMode> case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType case 949122880: return getSecurity(); // ConformanceRestSecurityComponent case -341064690: return addResource(); // ConformanceRestResourceComponent case 1844104722: return addInteraction(); // SystemInteractionComponent case 1262805409: throw new FHIRException("Cannot make property transactionMode as it is not a complex type"); // Enumeration<TransactionMode> case -553645115: return addSearchParam(); // ConformanceRestResourceSearchParamComponent case 1662702951: return addOperation(); // ConformanceRestOperationComponent case -397756334: throw new FHIRException("Cannot make property compartment as it is not a complex type"); // UriType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("mode")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.mode"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else if (name.equals("security")) { this.security = new ConformanceRestSecurityComponent(); return this.security; } else if (name.equals("resource")) { return addResource(); } else if (name.equals("interaction")) { return addInteraction(); } else if (name.equals("transactionMode")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.transactionMode"); } else if (name.equals("searchParam")) { return addSearchParam(); } else if (name.equals("operation")) { return addOperation(); } else if (name.equals("compartment")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.compartment"); } else return super.addChild(name); } public ConformanceRestComponent copy() { ConformanceRestComponent dst = new ConformanceRestComponent(); copyValues(dst); dst.mode = mode == null ? null : mode.copy(); dst.documentation = documentation == null ? null : documentation.copy(); dst.security = security == null ? null : security.copy(); if (resource != null) { dst.resource = new ArrayList<ConformanceRestResourceComponent>(); for (ConformanceRestResourceComponent i : resource) dst.resource.add(i.copy()); }; if (interaction != null) { dst.interaction = new ArrayList<SystemInteractionComponent>(); for (SystemInteractionComponent i : interaction) dst.interaction.add(i.copy()); }; dst.transactionMode = transactionMode == null ? null : transactionMode.copy(); if (searchParam != null) { dst.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); for (ConformanceRestResourceSearchParamComponent i : searchParam) dst.searchParam.add(i.copy()); }; if (operation != null) { dst.operation = new ArrayList<ConformanceRestOperationComponent>(); for (ConformanceRestOperationComponent i : operation) dst.operation.add(i.copy()); }; if (compartment != null) { dst.compartment = new ArrayList<UriType>(); for (UriType i : compartment) dst.compartment.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestComponent)) return false; ConformanceRestComponent o = (ConformanceRestComponent) other; return compareDeep(mode, o.mode, true) && compareDeep(documentation, o.documentation, true) && compareDeep(security, o.security, true) && compareDeep(resource, o.resource, true) && compareDeep(interaction, o.interaction, true) && compareDeep(transactionMode, o.transactionMode, true) && compareDeep(searchParam, o.searchParam, true) && compareDeep(operation, o.operation, true) && compareDeep(compartment, o.compartment, true) ; } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestComponent)) return false; ConformanceRestComponent o = (ConformanceRestComponent) other; return compareValues(mode, o.mode, true) && compareValues(documentation, o.documentation, true) && compareValues(transactionMode, o.transactionMode, true) && compareValues(compartment, o.compartment, true); } public boolean isEmpty() { return super.isEmpty() && (mode == null || mode.isEmpty()) && (documentation == null || documentation.isEmpty()) && (security == null || security.isEmpty()) && (resource == null || resource.isEmpty()) && (interaction == null || interaction.isEmpty()) && (transactionMode == null || transactionMode.isEmpty()) && (searchParam == null || searchParam.isEmpty()) && (operation == null || operation.isEmpty()) && (compartment == null || compartment.isEmpty()) ; } public String fhirType() { return "Conformance.rest"; } } @Block() public static class ConformanceRestSecurityComponent extends BackboneElement implements IBaseBackboneElement { /** * Server adds CORS headers when responding to requests - this enables javascript applications to use the server. */ @Child(name = "cors", type = {BooleanType.class}, order=1, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Adds CORS Headers (http://enable-cors.org/)", formalDefinition="Server adds CORS headers when responding to requests - this enables javascript applications to use the server." ) protected BooleanType cors; /** * Types of security services are supported/required by the system. */ @Child(name = "service", type = {CodeableConcept.class}, order=2, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="OAuth | SMART-on-FHIR | NTLM | Basic | Kerberos | Certificates", formalDefinition="Types of security services are supported/required by the system." ) protected List<CodeableConcept> service; /** * General description of how security works. */ @Child(name = "description", type = {StringType.class}, order=3, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="General description of how security works", formalDefinition="General description of how security works." ) protected StringType description; /** * Certificates associated with security profiles. */ @Child(name = "certificate", type = {}, order=4, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Certificates associated with security profiles", formalDefinition="Certificates associated with security profiles." ) protected List<ConformanceRestSecurityCertificateComponent> certificate; private static final long serialVersionUID = 391663952L; /** * Constructor */ public ConformanceRestSecurityComponent() { super(); } /** * @return {@link #cors} (Server adds CORS headers when responding to requests - this enables javascript applications to use the server.). This is the underlying object with id, value and extensions. The accessor "getCors" gives direct access to the value */ public BooleanType getCorsElement() { if (this.cors == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestSecurityComponent.cors"); else if (Configuration.doAutoCreate()) this.cors = new BooleanType(); // bb return this.cors; } public boolean hasCorsElement() { return this.cors != null && !this.cors.isEmpty(); } public boolean hasCors() { return this.cors != null && !this.cors.isEmpty(); } /** * @param value {@link #cors} (Server adds CORS headers when responding to requests - this enables javascript applications to use the server.). This is the underlying object with id, value and extensions. The accessor "getCors" gives direct access to the value */ public ConformanceRestSecurityComponent setCorsElement(BooleanType value) { this.cors = value; return this; } /** * @return Server adds CORS headers when responding to requests - this enables javascript applications to use the server. */ public boolean getCors() { return this.cors == null || this.cors.isEmpty() ? false : this.cors.getValue(); } /** * @param value Server adds CORS headers when responding to requests - this enables javascript applications to use the server. */ public ConformanceRestSecurityComponent setCors(boolean value) { if (this.cors == null) this.cors = new BooleanType(); this.cors.setValue(value); return this; } /** * @return {@link #service} (Types of security services are supported/required by the system.) */ public List<CodeableConcept> getService() { if (this.service == null) this.service = new ArrayList<CodeableConcept>(); return this.service; } public boolean hasService() { if (this.service == null) return false; for (CodeableConcept item : this.service) if (!item.isEmpty()) return true; return false; } /** * @return {@link #service} (Types of security services are supported/required by the system.) */ // syntactic sugar public CodeableConcept addService() { //3 CodeableConcept t = new CodeableConcept(); if (this.service == null) this.service = new ArrayList<CodeableConcept>(); this.service.add(t); return t; } // syntactic sugar public ConformanceRestSecurityComponent addService(CodeableConcept t) { //3 if (t == null) return this; if (this.service == null) this.service = new ArrayList<CodeableConcept>(); this.service.add(t); return this; } /** * @return {@link #description} (General description of how security works.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public StringType getDescriptionElement() { if (this.description == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestSecurityComponent.description"); else if (Configuration.doAutoCreate()) this.description = new StringType(); // bb return this.description; } public boolean hasDescriptionElement() { return this.description != null && !this.description.isEmpty(); } public boolean hasDescription() { return this.description != null && !this.description.isEmpty(); } /** * @param value {@link #description} (General description of how security works.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public ConformanceRestSecurityComponent setDescriptionElement(StringType value) { this.description = value; return this; } /** * @return General description of how security works. */ public String getDescription() { return this.description == null ? null : this.description.getValue(); } /** * @param value General description of how security works. */ public ConformanceRestSecurityComponent setDescription(String value) { if (Utilities.noString(value)) this.description = null; else { if (this.description == null) this.description = new StringType(); this.description.setValue(value); } return this; } /** * @return {@link #certificate} (Certificates associated with security profiles.) */ public List<ConformanceRestSecurityCertificateComponent> getCertificate() { if (this.certificate == null) this.certificate = new ArrayList<ConformanceRestSecurityCertificateComponent>(); return this.certificate; } public boolean hasCertificate() { if (this.certificate == null) return false; for (ConformanceRestSecurityCertificateComponent item : this.certificate) if (!item.isEmpty()) return true; return false; } /** * @return {@link #certificate} (Certificates associated with security profiles.) */ // syntactic sugar public ConformanceRestSecurityCertificateComponent addCertificate() { //3 ConformanceRestSecurityCertificateComponent t = new ConformanceRestSecurityCertificateComponent(); if (this.certificate == null) this.certificate = new ArrayList<ConformanceRestSecurityCertificateComponent>(); this.certificate.add(t); return t; } // syntactic sugar public ConformanceRestSecurityComponent addCertificate(ConformanceRestSecurityCertificateComponent t) { //3 if (t == null) return this; if (this.certificate == null) this.certificate = new ArrayList<ConformanceRestSecurityCertificateComponent>(); this.certificate.add(t); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("cors", "boolean", "Server adds CORS headers when responding to requests - this enables javascript applications to use the server.", 0, java.lang.Integer.MAX_VALUE, cors)); childrenList.add(new Property("service", "CodeableConcept", "Types of security services are supported/required by the system.", 0, java.lang.Integer.MAX_VALUE, service)); childrenList.add(new Property("description", "string", "General description of how security works.", 0, java.lang.Integer.MAX_VALUE, description)); childrenList.add(new Property("certificate", "", "Certificates associated with security profiles.", 0, java.lang.Integer.MAX_VALUE, certificate)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3059629: /*cors*/ return this.cors == null ? new Base[0] : new Base[] {this.cors}; // BooleanType case 1984153269: /*service*/ return this.service == null ? new Base[0] : this.service.toArray(new Base[this.service.size()]); // CodeableConcept case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // StringType case 1952399767: /*certificate*/ return this.certificate == null ? new Base[0] : this.certificate.toArray(new Base[this.certificate.size()]); // ConformanceRestSecurityCertificateComponent default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3059629: // cors this.cors = castToBoolean(value); // BooleanType break; case 1984153269: // service this.getService().add(castToCodeableConcept(value)); // CodeableConcept break; case -1724546052: // description this.description = castToString(value); // StringType break; case 1952399767: // certificate this.getCertificate().add((ConformanceRestSecurityCertificateComponent) value); // ConformanceRestSecurityCertificateComponent break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("cors")) this.cors = castToBoolean(value); // BooleanType else if (name.equals("service")) this.getService().add(castToCodeableConcept(value)); else if (name.equals("description")) this.description = castToString(value); // StringType else if (name.equals("certificate")) this.getCertificate().add((ConformanceRestSecurityCertificateComponent) value); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3059629: throw new FHIRException("Cannot make property cors as it is not a complex type"); // BooleanType case 1984153269: return addService(); // CodeableConcept case -1724546052: throw new FHIRException("Cannot make property description as it is not a complex type"); // StringType case 1952399767: return addCertificate(); // ConformanceRestSecurityCertificateComponent default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("cors")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.cors"); } else if (name.equals("service")) { return addService(); } else if (name.equals("description")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.description"); } else if (name.equals("certificate")) { return addCertificate(); } else return super.addChild(name); } public ConformanceRestSecurityComponent copy() { ConformanceRestSecurityComponent dst = new ConformanceRestSecurityComponent(); copyValues(dst); dst.cors = cors == null ? null : cors.copy(); if (service != null) { dst.service = new ArrayList<CodeableConcept>(); for (CodeableConcept i : service) dst.service.add(i.copy()); }; dst.description = description == null ? null : description.copy(); if (certificate != null) { dst.certificate = new ArrayList<ConformanceRestSecurityCertificateComponent>(); for (ConformanceRestSecurityCertificateComponent i : certificate) dst.certificate.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestSecurityComponent)) return false; ConformanceRestSecurityComponent o = (ConformanceRestSecurityComponent) other; return compareDeep(cors, o.cors, true) && compareDeep(service, o.service, true) && compareDeep(description, o.description, true) && compareDeep(certificate, o.certificate, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestSecurityComponent)) return false; ConformanceRestSecurityComponent o = (ConformanceRestSecurityComponent) other; return compareValues(cors, o.cors, true) && compareValues(description, o.description, true); } public boolean isEmpty() { return super.isEmpty() && (cors == null || cors.isEmpty()) && (service == null || service.isEmpty()) && (description == null || description.isEmpty()) && (certificate == null || certificate.isEmpty()) ; } public String fhirType() { return "Conformance.rest.security"; } } @Block() public static class ConformanceRestSecurityCertificateComponent extends BackboneElement implements IBaseBackboneElement { /** * Mime type for certificate. */ @Child(name = "type", type = {CodeType.class}, order=1, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Mime type for certificate", formalDefinition="Mime type for certificate." ) protected CodeType type; /** * Actual certificate. */ @Child(name = "blob", type = {Base64BinaryType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Actual certificate", formalDefinition="Actual certificate." ) protected Base64BinaryType blob; private static final long serialVersionUID = 2092655854L; /** * Constructor */ public ConformanceRestSecurityCertificateComponent() { super(); } /** * @return {@link #type} (Mime type for certificate.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public CodeType getTypeElement() { if (this.type == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestSecurityCertificateComponent.type"); else if (Configuration.doAutoCreate()) this.type = new CodeType(); // bb return this.type; } public boolean hasTypeElement() { return this.type != null && !this.type.isEmpty(); } public boolean hasType() { return this.type != null && !this.type.isEmpty(); } /** * @param value {@link #type} (Mime type for certificate.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public ConformanceRestSecurityCertificateComponent setTypeElement(CodeType value) { this.type = value; return this; } /** * @return Mime type for certificate. */ public String getType() { return this.type == null ? null : this.type.getValue(); } /** * @param value Mime type for certificate. */ public ConformanceRestSecurityCertificateComponent setType(String value) { if (Utilities.noString(value)) this.type = null; else { if (this.type == null) this.type = new CodeType(); this.type.setValue(value); } return this; } /** * @return {@link #blob} (Actual certificate.). This is the underlying object with id, value and extensions. The accessor "getBlob" gives direct access to the value */ public Base64BinaryType getBlobElement() { if (this.blob == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestSecurityCertificateComponent.blob"); else if (Configuration.doAutoCreate()) this.blob = new Base64BinaryType(); // bb return this.blob; } public boolean hasBlobElement() { return this.blob != null && !this.blob.isEmpty(); } public boolean hasBlob() { return this.blob != null && !this.blob.isEmpty(); } /** * @param value {@link #blob} (Actual certificate.). This is the underlying object with id, value and extensions. The accessor "getBlob" gives direct access to the value */ public ConformanceRestSecurityCertificateComponent setBlobElement(Base64BinaryType value) { this.blob = value; return this; } /** * @return Actual certificate. */ public byte[] getBlob() { return this.blob == null ? null : this.blob.getValue(); } /** * @param value Actual certificate. */ public ConformanceRestSecurityCertificateComponent setBlob(byte[] value) { if (value == null) this.blob = null; else { if (this.blob == null) this.blob = new Base64BinaryType(); this.blob.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("type", "code", "Mime type for certificate.", 0, java.lang.Integer.MAX_VALUE, type)); childrenList.add(new Property("blob", "base64Binary", "Actual certificate.", 0, java.lang.Integer.MAX_VALUE, blob)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // CodeType case 3026845: /*blob*/ return this.blob == null ? new Base[0] : new Base[] {this.blob}; // Base64BinaryType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3575610: // type this.type = castToCode(value); // CodeType break; case 3026845: // blob this.blob = castToBase64Binary(value); // Base64BinaryType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("type")) this.type = castToCode(value); // CodeType else if (name.equals("blob")) this.blob = castToBase64Binary(value); // Base64BinaryType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3575610: throw new FHIRException("Cannot make property type as it is not a complex type"); // CodeType case 3026845: throw new FHIRException("Cannot make property blob as it is not a complex type"); // Base64BinaryType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("type")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.type"); } else if (name.equals("blob")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.blob"); } else return super.addChild(name); } public ConformanceRestSecurityCertificateComponent copy() { ConformanceRestSecurityCertificateComponent dst = new ConformanceRestSecurityCertificateComponent(); copyValues(dst); dst.type = type == null ? null : type.copy(); dst.blob = blob == null ? null : blob.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestSecurityCertificateComponent)) return false; ConformanceRestSecurityCertificateComponent o = (ConformanceRestSecurityCertificateComponent) other; return compareDeep(type, o.type, true) && compareDeep(blob, o.blob, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestSecurityCertificateComponent)) return false; ConformanceRestSecurityCertificateComponent o = (ConformanceRestSecurityCertificateComponent) other; return compareValues(type, o.type, true) && compareValues(blob, o.blob, true); } public boolean isEmpty() { return super.isEmpty() && (type == null || type.isEmpty()) && (blob == null || blob.isEmpty()) ; } public String fhirType() { return "Conformance.rest.security.certificate"; } } @Block() public static class ConformanceRestResourceComponent extends BackboneElement implements IBaseBackboneElement { /** * A type of resource exposed via the restful interface. */ @Child(name = "type", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="A resource type that is supported", formalDefinition="A type of resource exposed via the restful interface." ) protected CodeType type; /** * A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}. */ @Child(name = "profile", type = {StructureDefinition.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Base System profile for all uses of resource", formalDefinition="A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}." ) protected Reference profile; /** * The actual object that is the target of the reference (A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ protected StructureDefinition profileTarget; /** * Identifies a restful operation supported by the solution. */ @Child(name = "interaction", type = {}, order=3, min=1, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="What operations are supported?", formalDefinition="Identifies a restful operation supported by the solution." ) protected List<ResourceInteractionComponent> interaction; /** * This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API. */ @Child(name = "versioning", type = {CodeType.class}, order=4, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="no-version | versioned | versioned-update", formalDefinition="This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API." ) protected Enumeration<ResourceVersionPolicy> versioning; /** * A flag for whether the server is able to return past versions as part of the vRead operation. */ @Child(name = "readHistory", type = {BooleanType.class}, order=5, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Whether vRead can return past versions", formalDefinition="A flag for whether the server is able to return past versions as part of the vRead operation." ) protected BooleanType readHistory; /** * A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server. */ @Child(name = "updateCreate", type = {BooleanType.class}, order=6, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="If update can commit to a new identity", formalDefinition="A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server." ) protected BooleanType updateCreate; /** * A flag that indicates that the server supports conditional create. */ @Child(name = "conditionalCreate", type = {BooleanType.class}, order=7, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="If allows/uses conditional create", formalDefinition="A flag that indicates that the server supports conditional create." ) protected BooleanType conditionalCreate; /** * A flag that indicates that the server supports conditional update. */ @Child(name = "conditionalUpdate", type = {BooleanType.class}, order=8, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="If allows/uses conditional update", formalDefinition="A flag that indicates that the server supports conditional update." ) protected BooleanType conditionalUpdate; /** * A code that indicates how the server supports conditional delete. */ @Child(name = "conditionalDelete", type = {CodeType.class}, order=9, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="not-supported | single | multiple - how conditional delete is supported", formalDefinition="A code that indicates how the server supports conditional delete." ) protected Enumeration<ConditionalDeleteStatus> conditionalDelete; /** * A list of _include values supported by the server. */ @Child(name = "searchInclude", type = {StringType.class}, order=10, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="_include values supported by the server", formalDefinition="A list of _include values supported by the server." ) protected List<StringType> searchInclude; /** * A list of _revinclude (reverse include) values supported by the server. */ @Child(name = "searchRevInclude", type = {StringType.class}, order=11, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="_revinclude values supported by the server", formalDefinition="A list of _revinclude (reverse include) values supported by the server." ) protected List<StringType> searchRevInclude; /** * Search parameters for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation. */ @Child(name = "searchParam", type = {}, order=12, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Search params supported by implementation", formalDefinition="Search parameters for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation." ) protected List<ConformanceRestResourceSearchParamComponent> searchParam; private static final long serialVersionUID = 1781959905L; /** * Constructor */ public ConformanceRestResourceComponent() { super(); } /** * Constructor */ public ConformanceRestResourceComponent(CodeType type) { super(); this.type = type; } /** * @return {@link #type} (A type of resource exposed via the restful interface.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public CodeType getTypeElement() { if (this.type == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.type"); else if (Configuration.doAutoCreate()) this.type = new CodeType(); // bb return this.type; } public boolean hasTypeElement() { return this.type != null && !this.type.isEmpty(); } public boolean hasType() { return this.type != null && !this.type.isEmpty(); } /** * @param value {@link #type} (A type of resource exposed via the restful interface.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public ConformanceRestResourceComponent setTypeElement(CodeType value) { this.type = value; return this; } /** * @return A type of resource exposed via the restful interface. */ public String getType() { return this.type == null ? null : this.type.getValue(); } /** * @param value A type of resource exposed via the restful interface. */ public ConformanceRestResourceComponent setType(String value) { if (this.type == null) this.type = new CodeType(); this.type.setValue(value); return this; } /** * @return {@link #profile} (A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public Reference getProfile() { if (this.profile == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.profile"); else if (Configuration.doAutoCreate()) this.profile = new Reference(); // cc return this.profile; } public boolean hasProfile() { return this.profile != null && !this.profile.isEmpty(); } /** * @param value {@link #profile} (A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public ConformanceRestResourceComponent setProfile(Reference value) { this.profile = value; return this; } /** * @return {@link #profile} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public StructureDefinition getProfileTarget() { if (this.profileTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.profile"); else if (Configuration.doAutoCreate()) this.profileTarget = new StructureDefinition(); // aa return this.profileTarget; } /** * @param value {@link #profile} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public ConformanceRestResourceComponent setProfileTarget(StructureDefinition value) { this.profileTarget = value; return this; } /** * @return {@link #interaction} (Identifies a restful operation supported by the solution.) */ public List<ResourceInteractionComponent> getInteraction() { if (this.interaction == null) this.interaction = new ArrayList<ResourceInteractionComponent>(); return this.interaction; } public boolean hasInteraction() { if (this.interaction == null) return false; for (ResourceInteractionComponent item : this.interaction) if (!item.isEmpty()) return true; return false; } /** * @return {@link #interaction} (Identifies a restful operation supported by the solution.) */ // syntactic sugar public ResourceInteractionComponent addInteraction() { //3 ResourceInteractionComponent t = new ResourceInteractionComponent(); if (this.interaction == null) this.interaction = new ArrayList<ResourceInteractionComponent>(); this.interaction.add(t); return t; } // syntactic sugar public ConformanceRestResourceComponent addInteraction(ResourceInteractionComponent t) { //3 if (t == null) return this; if (this.interaction == null) this.interaction = new ArrayList<ResourceInteractionComponent>(); this.interaction.add(t); return this; } /** * @return {@link #versioning} (This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API.). This is the underlying object with id, value and extensions. The accessor "getVersioning" gives direct access to the value */ public Enumeration<ResourceVersionPolicy> getVersioningElement() { if (this.versioning == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.versioning"); else if (Configuration.doAutoCreate()) this.versioning = new Enumeration<ResourceVersionPolicy>(new ResourceVersionPolicyEnumFactory()); // bb return this.versioning; } public boolean hasVersioningElement() { return this.versioning != null && !this.versioning.isEmpty(); } public boolean hasVersioning() { return this.versioning != null && !this.versioning.isEmpty(); } /** * @param value {@link #versioning} (This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API.). This is the underlying object with id, value and extensions. The accessor "getVersioning" gives direct access to the value */ public ConformanceRestResourceComponent setVersioningElement(Enumeration<ResourceVersionPolicy> value) { this.versioning = value; return this; } /** * @return This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API. */ public ResourceVersionPolicy getVersioning() { return this.versioning == null ? null : this.versioning.getValue(); } /** * @param value This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API. */ public ConformanceRestResourceComponent setVersioning(ResourceVersionPolicy value) { if (value == null) this.versioning = null; else { if (this.versioning == null) this.versioning = new Enumeration<ResourceVersionPolicy>(new ResourceVersionPolicyEnumFactory()); this.versioning.setValue(value); } return this; } /** * @return {@link #readHistory} (A flag for whether the server is able to return past versions as part of the vRead operation.). This is the underlying object with id, value and extensions. The accessor "getReadHistory" gives direct access to the value */ public BooleanType getReadHistoryElement() { if (this.readHistory == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.readHistory"); else if (Configuration.doAutoCreate()) this.readHistory = new BooleanType(); // bb return this.readHistory; } public boolean hasReadHistoryElement() { return this.readHistory != null && !this.readHistory.isEmpty(); } public boolean hasReadHistory() { return this.readHistory != null && !this.readHistory.isEmpty(); } /** * @param value {@link #readHistory} (A flag for whether the server is able to return past versions as part of the vRead operation.). This is the underlying object with id, value and extensions. The accessor "getReadHistory" gives direct access to the value */ public ConformanceRestResourceComponent setReadHistoryElement(BooleanType value) { this.readHistory = value; return this; } /** * @return A flag for whether the server is able to return past versions as part of the vRead operation. */ public boolean getReadHistory() { return this.readHistory == null || this.readHistory.isEmpty() ? false : this.readHistory.getValue(); } /** * @param value A flag for whether the server is able to return past versions as part of the vRead operation. */ public ConformanceRestResourceComponent setReadHistory(boolean value) { if (this.readHistory == null) this.readHistory = new BooleanType(); this.readHistory.setValue(value); return this; } /** * @return {@link #updateCreate} (A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server.). This is the underlying object with id, value and extensions. The accessor "getUpdateCreate" gives direct access to the value */ public BooleanType getUpdateCreateElement() { if (this.updateCreate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.updateCreate"); else if (Configuration.doAutoCreate()) this.updateCreate = new BooleanType(); // bb return this.updateCreate; } public boolean hasUpdateCreateElement() { return this.updateCreate != null && !this.updateCreate.isEmpty(); } public boolean hasUpdateCreate() { return this.updateCreate != null && !this.updateCreate.isEmpty(); } /** * @param value {@link #updateCreate} (A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server.). This is the underlying object with id, value and extensions. The accessor "getUpdateCreate" gives direct access to the value */ public ConformanceRestResourceComponent setUpdateCreateElement(BooleanType value) { this.updateCreate = value; return this; } /** * @return A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server. */ public boolean getUpdateCreate() { return this.updateCreate == null || this.updateCreate.isEmpty() ? false : this.updateCreate.getValue(); } /** * @param value A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server. */ public ConformanceRestResourceComponent setUpdateCreate(boolean value) { if (this.updateCreate == null) this.updateCreate = new BooleanType(); this.updateCreate.setValue(value); return this; } /** * @return {@link #conditionalCreate} (A flag that indicates that the server supports conditional create.). This is the underlying object with id, value and extensions. The accessor "getConditionalCreate" gives direct access to the value */ public BooleanType getConditionalCreateElement() { if (this.conditionalCreate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.conditionalCreate"); else if (Configuration.doAutoCreate()) this.conditionalCreate = new BooleanType(); // bb return this.conditionalCreate; } public boolean hasConditionalCreateElement() { return this.conditionalCreate != null && !this.conditionalCreate.isEmpty(); } public boolean hasConditionalCreate() { return this.conditionalCreate != null && !this.conditionalCreate.isEmpty(); } /** * @param value {@link #conditionalCreate} (A flag that indicates that the server supports conditional create.). This is the underlying object with id, value and extensions. The accessor "getConditionalCreate" gives direct access to the value */ public ConformanceRestResourceComponent setConditionalCreateElement(BooleanType value) { this.conditionalCreate = value; return this; } /** * @return A flag that indicates that the server supports conditional create. */ public boolean getConditionalCreate() { return this.conditionalCreate == null || this.conditionalCreate.isEmpty() ? false : this.conditionalCreate.getValue(); } /** * @param value A flag that indicates that the server supports conditional create. */ public ConformanceRestResourceComponent setConditionalCreate(boolean value) { if (this.conditionalCreate == null) this.conditionalCreate = new BooleanType(); this.conditionalCreate.setValue(value); return this; } /** * @return {@link #conditionalUpdate} (A flag that indicates that the server supports conditional update.). This is the underlying object with id, value and extensions. The accessor "getConditionalUpdate" gives direct access to the value */ public BooleanType getConditionalUpdateElement() { if (this.conditionalUpdate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.conditionalUpdate"); else if (Configuration.doAutoCreate()) this.conditionalUpdate = new BooleanType(); // bb return this.conditionalUpdate; } public boolean hasConditionalUpdateElement() { return this.conditionalUpdate != null && !this.conditionalUpdate.isEmpty(); } public boolean hasConditionalUpdate() { return this.conditionalUpdate != null && !this.conditionalUpdate.isEmpty(); } /** * @param value {@link #conditionalUpdate} (A flag that indicates that the server supports conditional update.). This is the underlying object with id, value and extensions. The accessor "getConditionalUpdate" gives direct access to the value */ public ConformanceRestResourceComponent setConditionalUpdateElement(BooleanType value) { this.conditionalUpdate = value; return this; } /** * @return A flag that indicates that the server supports conditional update. */ public boolean getConditionalUpdate() { return this.conditionalUpdate == null || this.conditionalUpdate.isEmpty() ? false : this.conditionalUpdate.getValue(); } /** * @param value A flag that indicates that the server supports conditional update. */ public ConformanceRestResourceComponent setConditionalUpdate(boolean value) { if (this.conditionalUpdate == null) this.conditionalUpdate = new BooleanType(); this.conditionalUpdate.setValue(value); return this; } /** * @return {@link #conditionalDelete} (A code that indicates how the server supports conditional delete.). This is the underlying object with id, value and extensions. The accessor "getConditionalDelete" gives direct access to the value */ public Enumeration<ConditionalDeleteStatus> getConditionalDeleteElement() { if (this.conditionalDelete == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceComponent.conditionalDelete"); else if (Configuration.doAutoCreate()) this.conditionalDelete = new Enumeration<ConditionalDeleteStatus>(new ConditionalDeleteStatusEnumFactory()); // bb return this.conditionalDelete; } public boolean hasConditionalDeleteElement() { return this.conditionalDelete != null && !this.conditionalDelete.isEmpty(); } public boolean hasConditionalDelete() { return this.conditionalDelete != null && !this.conditionalDelete.isEmpty(); } /** * @param value {@link #conditionalDelete} (A code that indicates how the server supports conditional delete.). This is the underlying object with id, value and extensions. The accessor "getConditionalDelete" gives direct access to the value */ public ConformanceRestResourceComponent setConditionalDeleteElement(Enumeration<ConditionalDeleteStatus> value) { this.conditionalDelete = value; return this; } /** * @return A code that indicates how the server supports conditional delete. */ public ConditionalDeleteStatus getConditionalDelete() { return this.conditionalDelete == null ? null : this.conditionalDelete.getValue(); } /** * @param value A code that indicates how the server supports conditional delete. */ public ConformanceRestResourceComponent setConditionalDelete(ConditionalDeleteStatus value) { if (value == null) this.conditionalDelete = null; else { if (this.conditionalDelete == null) this.conditionalDelete = new Enumeration<ConditionalDeleteStatus>(new ConditionalDeleteStatusEnumFactory()); this.conditionalDelete.setValue(value); } return this; } /** * @return {@link #searchInclude} (A list of _include values supported by the server.) */ public List<StringType> getSearchInclude() { if (this.searchInclude == null) this.searchInclude = new ArrayList<StringType>(); return this.searchInclude; } public boolean hasSearchInclude() { if (this.searchInclude == null) return false; for (StringType item : this.searchInclude) if (!item.isEmpty()) return true; return false; } /** * @return {@link #searchInclude} (A list of _include values supported by the server.) */ // syntactic sugar public StringType addSearchIncludeElement() {//2 StringType t = new StringType(); if (this.searchInclude == null) this.searchInclude = new ArrayList<StringType>(); this.searchInclude.add(t); return t; } /** * @param value {@link #searchInclude} (A list of _include values supported by the server.) */ public ConformanceRestResourceComponent addSearchInclude(String value) { //1 StringType t = new StringType(); t.setValue(value); if (this.searchInclude == null) this.searchInclude = new ArrayList<StringType>(); this.searchInclude.add(t); return this; } /** * @param value {@link #searchInclude} (A list of _include values supported by the server.) */ public boolean hasSearchInclude(String value) { if (this.searchInclude == null) return false; for (StringType v : this.searchInclude) if (v.equals(value)) // string return true; return false; } /** * @return {@link #searchRevInclude} (A list of _revinclude (reverse include) values supported by the server.) */ public List<StringType> getSearchRevInclude() { if (this.searchRevInclude == null) this.searchRevInclude = new ArrayList<StringType>(); return this.searchRevInclude; } public boolean hasSearchRevInclude() { if (this.searchRevInclude == null) return false; for (StringType item : this.searchRevInclude) if (!item.isEmpty()) return true; return false; } /** * @return {@link #searchRevInclude} (A list of _revinclude (reverse include) values supported by the server.) */ // syntactic sugar public StringType addSearchRevIncludeElement() {//2 StringType t = new StringType(); if (this.searchRevInclude == null) this.searchRevInclude = new ArrayList<StringType>(); this.searchRevInclude.add(t); return t; } /** * @param value {@link #searchRevInclude} (A list of _revinclude (reverse include) values supported by the server.) */ public ConformanceRestResourceComponent addSearchRevInclude(String value) { //1 StringType t = new StringType(); t.setValue(value); if (this.searchRevInclude == null) this.searchRevInclude = new ArrayList<StringType>(); this.searchRevInclude.add(t); return this; } /** * @param value {@link #searchRevInclude} (A list of _revinclude (reverse include) values supported by the server.) */ public boolean hasSearchRevInclude(String value) { if (this.searchRevInclude == null) return false; for (StringType v : this.searchRevInclude) if (v.equals(value)) // string return true; return false; } /** * @return {@link #searchParam} (Search parameters for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.) */ public List<ConformanceRestResourceSearchParamComponent> getSearchParam() { if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); return this.searchParam; } public boolean hasSearchParam() { if (this.searchParam == null) return false; for (ConformanceRestResourceSearchParamComponent item : this.searchParam) if (!item.isEmpty()) return true; return false; } /** * @return {@link #searchParam} (Search parameters for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.) */ // syntactic sugar public ConformanceRestResourceSearchParamComponent addSearchParam() { //3 ConformanceRestResourceSearchParamComponent t = new ConformanceRestResourceSearchParamComponent(); if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); this.searchParam.add(t); return t; } // syntactic sugar public ConformanceRestResourceComponent addSearchParam(ConformanceRestResourceSearchParamComponent t) { //3 if (t == null) return this; if (this.searchParam == null) this.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); this.searchParam.add(t); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("type", "code", "A type of resource exposed via the restful interface.", 0, java.lang.Integer.MAX_VALUE, type)); childrenList.add(new Property("profile", "Reference(StructureDefinition)", "A specification of the profile that describes the solution's overall support for the resource, including any constraints on cardinality, bindings, lengths or other limitations. See further discussion in [Using Profiles]{profiling.html#profile-uses}.", 0, java.lang.Integer.MAX_VALUE, profile)); childrenList.add(new Property("interaction", "", "Identifies a restful operation supported by the solution.", 0, java.lang.Integer.MAX_VALUE, interaction)); childrenList.add(new Property("versioning", "code", "This field is set to no-version to specify that the system does not support (server) or use (client) versioning for this resource type. If this has some other value, the server must at least correctly track and populate the versionId meta-property on resources. If the value is 'versioned-update', then the server supports all the versioning features, including using e-tags for version integrity in the API.", 0, java.lang.Integer.MAX_VALUE, versioning)); childrenList.add(new Property("readHistory", "boolean", "A flag for whether the server is able to return past versions as part of the vRead operation.", 0, java.lang.Integer.MAX_VALUE, readHistory)); childrenList.add(new Property("updateCreate", "boolean", "A flag to indicate that the server allows or needs to allow the client to create new identities on the server (e.g. that is, the client PUTs to a location where there is no existing resource). Allowing this operation means that the server allows the client to create new identities on the server.", 0, java.lang.Integer.MAX_VALUE, updateCreate)); childrenList.add(new Property("conditionalCreate", "boolean", "A flag that indicates that the server supports conditional create.", 0, java.lang.Integer.MAX_VALUE, conditionalCreate)); childrenList.add(new Property("conditionalUpdate", "boolean", "A flag that indicates that the server supports conditional update.", 0, java.lang.Integer.MAX_VALUE, conditionalUpdate)); childrenList.add(new Property("conditionalDelete", "code", "A code that indicates how the server supports conditional delete.", 0, java.lang.Integer.MAX_VALUE, conditionalDelete)); childrenList.add(new Property("searchInclude", "string", "A list of _include values supported by the server.", 0, java.lang.Integer.MAX_VALUE, searchInclude)); childrenList.add(new Property("searchRevInclude", "string", "A list of _revinclude (reverse include) values supported by the server.", 0, java.lang.Integer.MAX_VALUE, searchRevInclude)); childrenList.add(new Property("searchParam", "", "Search parameters for implementations to support and/or make use of - either references to ones defined in the specification, or additional ones defined for/by the implementation.", 0, java.lang.Integer.MAX_VALUE, searchParam)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // CodeType case -309425751: /*profile*/ return this.profile == null ? new Base[0] : new Base[] {this.profile}; // Reference case 1844104722: /*interaction*/ return this.interaction == null ? new Base[0] : this.interaction.toArray(new Base[this.interaction.size()]); // ResourceInteractionComponent case -670487542: /*versioning*/ return this.versioning == null ? new Base[0] : new Base[] {this.versioning}; // Enumeration<ResourceVersionPolicy> case 187518494: /*readHistory*/ return this.readHistory == null ? new Base[0] : new Base[] {this.readHistory}; // BooleanType case -1400550619: /*updateCreate*/ return this.updateCreate == null ? new Base[0] : new Base[] {this.updateCreate}; // BooleanType case 6401826: /*conditionalCreate*/ return this.conditionalCreate == null ? new Base[0] : new Base[] {this.conditionalCreate}; // BooleanType case 519849711: /*conditionalUpdate*/ return this.conditionalUpdate == null ? new Base[0] : new Base[] {this.conditionalUpdate}; // BooleanType case 23237585: /*conditionalDelete*/ return this.conditionalDelete == null ? new Base[0] : new Base[] {this.conditionalDelete}; // Enumeration<ConditionalDeleteStatus> case -1035904544: /*searchInclude*/ return this.searchInclude == null ? new Base[0] : this.searchInclude.toArray(new Base[this.searchInclude.size()]); // StringType case -2123884979: /*searchRevInclude*/ return this.searchRevInclude == null ? new Base[0] : this.searchRevInclude.toArray(new Base[this.searchRevInclude.size()]); // StringType case -553645115: /*searchParam*/ return this.searchParam == null ? new Base[0] : this.searchParam.toArray(new Base[this.searchParam.size()]); // ConformanceRestResourceSearchParamComponent default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3575610: // type this.type = castToCode(value); // CodeType break; case -309425751: // profile this.profile = castToReference(value); // Reference break; case 1844104722: // interaction this.getInteraction().add((ResourceInteractionComponent) value); // ResourceInteractionComponent break; case -670487542: // versioning this.versioning = new ResourceVersionPolicyEnumFactory().fromType(value); // Enumeration<ResourceVersionPolicy> break; case 187518494: // readHistory this.readHistory = castToBoolean(value); // BooleanType break; case -1400550619: // updateCreate this.updateCreate = castToBoolean(value); // BooleanType break; case 6401826: // conditionalCreate this.conditionalCreate = castToBoolean(value); // BooleanType break; case 519849711: // conditionalUpdate this.conditionalUpdate = castToBoolean(value); // BooleanType break; case 23237585: // conditionalDelete this.conditionalDelete = new ConditionalDeleteStatusEnumFactory().fromType(value); // Enumeration<ConditionalDeleteStatus> break; case -1035904544: // searchInclude this.getSearchInclude().add(castToString(value)); // StringType break; case -2123884979: // searchRevInclude this.getSearchRevInclude().add(castToString(value)); // StringType break; case -553645115: // searchParam this.getSearchParam().add((ConformanceRestResourceSearchParamComponent) value); // ConformanceRestResourceSearchParamComponent break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("type")) this.type = castToCode(value); // CodeType else if (name.equals("profile")) this.profile = castToReference(value); // Reference else if (name.equals("interaction")) this.getInteraction().add((ResourceInteractionComponent) value); else if (name.equals("versioning")) this.versioning = new ResourceVersionPolicyEnumFactory().fromType(value); // Enumeration<ResourceVersionPolicy> else if (name.equals("readHistory")) this.readHistory = castToBoolean(value); // BooleanType else if (name.equals("updateCreate")) this.updateCreate = castToBoolean(value); // BooleanType else if (name.equals("conditionalCreate")) this.conditionalCreate = castToBoolean(value); // BooleanType else if (name.equals("conditionalUpdate")) this.conditionalUpdate = castToBoolean(value); // BooleanType else if (name.equals("conditionalDelete")) this.conditionalDelete = new ConditionalDeleteStatusEnumFactory().fromType(value); // Enumeration<ConditionalDeleteStatus> else if (name.equals("searchInclude")) this.getSearchInclude().add(castToString(value)); else if (name.equals("searchRevInclude")) this.getSearchRevInclude().add(castToString(value)); else if (name.equals("searchParam")) this.getSearchParam().add((ConformanceRestResourceSearchParamComponent) value); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3575610: throw new FHIRException("Cannot make property type as it is not a complex type"); // CodeType case -309425751: return getProfile(); // Reference case 1844104722: return addInteraction(); // ResourceInteractionComponent case -670487542: throw new FHIRException("Cannot make property versioning as it is not a complex type"); // Enumeration<ResourceVersionPolicy> case 187518494: throw new FHIRException("Cannot make property readHistory as it is not a complex type"); // BooleanType case -1400550619: throw new FHIRException("Cannot make property updateCreate as it is not a complex type"); // BooleanType case 6401826: throw new FHIRException("Cannot make property conditionalCreate as it is not a complex type"); // BooleanType case 519849711: throw new FHIRException("Cannot make property conditionalUpdate as it is not a complex type"); // BooleanType case 23237585: throw new FHIRException("Cannot make property conditionalDelete as it is not a complex type"); // Enumeration<ConditionalDeleteStatus> case -1035904544: throw new FHIRException("Cannot make property searchInclude as it is not a complex type"); // StringType case -2123884979: throw new FHIRException("Cannot make property searchRevInclude as it is not a complex type"); // StringType case -553645115: return addSearchParam(); // ConformanceRestResourceSearchParamComponent default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("type")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.type"); } else if (name.equals("profile")) { this.profile = new Reference(); return this.profile; } else if (name.equals("interaction")) { return addInteraction(); } else if (name.equals("versioning")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.versioning"); } else if (name.equals("readHistory")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.readHistory"); } else if (name.equals("updateCreate")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.updateCreate"); } else if (name.equals("conditionalCreate")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.conditionalCreate"); } else if (name.equals("conditionalUpdate")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.conditionalUpdate"); } else if (name.equals("conditionalDelete")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.conditionalDelete"); } else if (name.equals("searchInclude")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.searchInclude"); } else if (name.equals("searchRevInclude")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.searchRevInclude"); } else if (name.equals("searchParam")) { return addSearchParam(); } else return super.addChild(name); } public ConformanceRestResourceComponent copy() { ConformanceRestResourceComponent dst = new ConformanceRestResourceComponent(); copyValues(dst); dst.type = type == null ? null : type.copy(); dst.profile = profile == null ? null : profile.copy(); if (interaction != null) { dst.interaction = new ArrayList<ResourceInteractionComponent>(); for (ResourceInteractionComponent i : interaction) dst.interaction.add(i.copy()); }; dst.versioning = versioning == null ? null : versioning.copy(); dst.readHistory = readHistory == null ? null : readHistory.copy(); dst.updateCreate = updateCreate == null ? null : updateCreate.copy(); dst.conditionalCreate = conditionalCreate == null ? null : conditionalCreate.copy(); dst.conditionalUpdate = conditionalUpdate == null ? null : conditionalUpdate.copy(); dst.conditionalDelete = conditionalDelete == null ? null : conditionalDelete.copy(); if (searchInclude != null) { dst.searchInclude = new ArrayList<StringType>(); for (StringType i : searchInclude) dst.searchInclude.add(i.copy()); }; if (searchRevInclude != null) { dst.searchRevInclude = new ArrayList<StringType>(); for (StringType i : searchRevInclude) dst.searchRevInclude.add(i.copy()); }; if (searchParam != null) { dst.searchParam = new ArrayList<ConformanceRestResourceSearchParamComponent>(); for (ConformanceRestResourceSearchParamComponent i : searchParam) dst.searchParam.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestResourceComponent)) return false; ConformanceRestResourceComponent o = (ConformanceRestResourceComponent) other; return compareDeep(type, o.type, true) && compareDeep(profile, o.profile, true) && compareDeep(interaction, o.interaction, true) && compareDeep(versioning, o.versioning, true) && compareDeep(readHistory, o.readHistory, true) && compareDeep(updateCreate, o.updateCreate, true) && compareDeep(conditionalCreate, o.conditionalCreate, true) && compareDeep(conditionalUpdate, o.conditionalUpdate, true) && compareDeep(conditionalDelete, o.conditionalDelete, true) && compareDeep(searchInclude, o.searchInclude, true) && compareDeep(searchRevInclude, o.searchRevInclude, true) && compareDeep(searchParam, o.searchParam, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestResourceComponent)) return false; ConformanceRestResourceComponent o = (ConformanceRestResourceComponent) other; return compareValues(type, o.type, true) && compareValues(versioning, o.versioning, true) && compareValues(readHistory, o.readHistory, true) && compareValues(updateCreate, o.updateCreate, true) && compareValues(conditionalCreate, o.conditionalCreate, true) && compareValues(conditionalUpdate, o.conditionalUpdate, true) && compareValues(conditionalDelete, o.conditionalDelete, true) && compareValues(searchInclude, o.searchInclude, true) && compareValues(searchRevInclude, o.searchRevInclude, true) ; } public boolean isEmpty() { return super.isEmpty() && (type == null || type.isEmpty()) && (profile == null || profile.isEmpty()) && (interaction == null || interaction.isEmpty()) && (versioning == null || versioning.isEmpty()) && (readHistory == null || readHistory.isEmpty()) && (updateCreate == null || updateCreate.isEmpty()) && (conditionalCreate == null || conditionalCreate.isEmpty()) && (conditionalUpdate == null || conditionalUpdate.isEmpty()) && (conditionalDelete == null || conditionalDelete.isEmpty()) && (searchInclude == null || searchInclude.isEmpty()) && (searchRevInclude == null || searchRevInclude.isEmpty()) && (searchParam == null || searchParam.isEmpty()) ; } public String fhirType() { return "Conformance.rest.resource"; } } @Block() public static class ResourceInteractionComponent extends BackboneElement implements IBaseBackboneElement { /** * Coded identifier of the operation, supported by the system resource. */ @Child(name = "code", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="read | vread | update | delete | history-instance | history-type | create | search-type", formalDefinition="Coded identifier of the operation, supported by the system resource." ) protected Enumeration<TypeRestfulInteraction> code; /** * Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'. */ @Child(name = "documentation", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Anything special about operation behavior", formalDefinition="Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'." ) protected StringType documentation; private static final long serialVersionUID = -437507806L; /** * Constructor */ public ResourceInteractionComponent() { super(); } /** * Constructor */ public ResourceInteractionComponent(Enumeration<TypeRestfulInteraction> code) { super(); this.code = code; } /** * @return {@link #code} (Coded identifier of the operation, supported by the system resource.). This is the underlying object with id, value and extensions. The accessor "getCode" gives direct access to the value */ public Enumeration<TypeRestfulInteraction> getCodeElement() { if (this.code == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ResourceInteractionComponent.code"); else if (Configuration.doAutoCreate()) this.code = new Enumeration<TypeRestfulInteraction>(new TypeRestfulInteractionEnumFactory()); // bb return this.code; } public boolean hasCodeElement() { return this.code != null && !this.code.isEmpty(); } public boolean hasCode() { return this.code != null && !this.code.isEmpty(); } /** * @param value {@link #code} (Coded identifier of the operation, supported by the system resource.). This is the underlying object with id, value and extensions. The accessor "getCode" gives direct access to the value */ public ResourceInteractionComponent setCodeElement(Enumeration<TypeRestfulInteraction> value) { this.code = value; return this; } /** * @return Coded identifier of the operation, supported by the system resource. */ public TypeRestfulInteraction getCode() { return this.code == null ? null : this.code.getValue(); } /** * @param value Coded identifier of the operation, supported by the system resource. */ public ResourceInteractionComponent setCode(TypeRestfulInteraction value) { if (this.code == null) this.code = new Enumeration<TypeRestfulInteraction>(new TypeRestfulInteractionEnumFactory()); this.code.setValue(value); return this; } /** * @return {@link #documentation} (Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ResourceInteractionComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ResourceInteractionComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'. */ public ResourceInteractionComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("code", "code", "Coded identifier of the operation, supported by the system resource.", 0, java.lang.Integer.MAX_VALUE, code)); childrenList.add(new Property("documentation", "string", "Guidance specific to the implementation of this operation, such as 'delete is a logical delete' or 'updates are only allowed with version id' or 'creates permitted from pre-authorized certificates only'.", 0, java.lang.Integer.MAX_VALUE, documentation)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3059181: /*code*/ return this.code == null ? new Base[0] : new Base[] {this.code}; // Enumeration<TypeRestfulInteraction> case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3059181: // code this.code = new TypeRestfulInteractionEnumFactory().fromType(value); // Enumeration<TypeRestfulInteraction> break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("code")) this.code = new TypeRestfulInteractionEnumFactory().fromType(value); // Enumeration<TypeRestfulInteraction> else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3059181: throw new FHIRException("Cannot make property code as it is not a complex type"); // Enumeration<TypeRestfulInteraction> case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("code")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.code"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else return super.addChild(name); } public ResourceInteractionComponent copy() { ResourceInteractionComponent dst = new ResourceInteractionComponent(); copyValues(dst); dst.code = code == null ? null : code.copy(); dst.documentation = documentation == null ? null : documentation.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ResourceInteractionComponent)) return false; ResourceInteractionComponent o = (ResourceInteractionComponent) other; return compareDeep(code, o.code, true) && compareDeep(documentation, o.documentation, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ResourceInteractionComponent)) return false; ResourceInteractionComponent o = (ResourceInteractionComponent) other; return compareValues(code, o.code, true) && compareValues(documentation, o.documentation, true); } public boolean isEmpty() { return super.isEmpty() && (code == null || code.isEmpty()) && (documentation == null || documentation.isEmpty()) ; } public String fhirType() { return "Conformance.rest.resource.interaction"; } } @Block() public static class ConformanceRestResourceSearchParamComponent extends BackboneElement implements IBaseBackboneElement { /** * The name of the search parameter used in the interface. */ @Child(name = "name", type = {StringType.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Name of search parameter", formalDefinition="The name of the search parameter used in the interface." ) protected StringType name; /** * An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]). */ @Child(name = "definition", type = {UriType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Source of definition for parameter", formalDefinition="An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]])." ) protected UriType definition; /** * The type of value a search parameter refers to, and how the content is interpreted. */ @Child(name = "type", type = {CodeType.class}, order=3, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="number | date | string | token | reference | composite | quantity | uri", formalDefinition="The type of value a search parameter refers to, and how the content is interpreted." ) protected Enumeration<SearchParamType> type; /** * This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms. */ @Child(name = "documentation", type = {StringType.class}, order=4, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Server-specific usage", formalDefinition="This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms." ) protected StringType documentation; /** * Types of resource (if a resource is referenced). */ @Child(name = "target", type = {CodeType.class}, order=5, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Types of resource (if a resource reference)", formalDefinition="Types of resource (if a resource is referenced)." ) protected List<CodeType> target; /** * A modifier supported for the search parameter. */ @Child(name = "modifier", type = {CodeType.class}, order=6, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="missing | exact | contains | not | text | in | not-in | below | above | type", formalDefinition="A modifier supported for the search parameter." ) protected List<Enumeration<SearchModifierCode>> modifier; /** * Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type. */ @Child(name = "chain", type = {StringType.class}, order=7, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Chained names supported", formalDefinition="Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type." ) protected List<StringType> chain; private static final long serialVersionUID = -1020405086L; /** * Constructor */ public ConformanceRestResourceSearchParamComponent() { super(); } /** * Constructor */ public ConformanceRestResourceSearchParamComponent(StringType name, Enumeration<SearchParamType> type) { super(); this.name = name; this.type = type; } /** * @return {@link #name} (The name of the search parameter used in the interface.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public StringType getNameElement() { if (this.name == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceSearchParamComponent.name"); else if (Configuration.doAutoCreate()) this.name = new StringType(); // bb return this.name; } public boolean hasNameElement() { return this.name != null && !this.name.isEmpty(); } public boolean hasName() { return this.name != null && !this.name.isEmpty(); } /** * @param value {@link #name} (The name of the search parameter used in the interface.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public ConformanceRestResourceSearchParamComponent setNameElement(StringType value) { this.name = value; return this; } /** * @return The name of the search parameter used in the interface. */ public String getName() { return this.name == null ? null : this.name.getValue(); } /** * @param value The name of the search parameter used in the interface. */ public ConformanceRestResourceSearchParamComponent setName(String value) { if (this.name == null) this.name = new StringType(); this.name.setValue(value); return this; } /** * @return {@link #definition} (An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]).). This is the underlying object with id, value and extensions. The accessor "getDefinition" gives direct access to the value */ public UriType getDefinitionElement() { if (this.definition == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceSearchParamComponent.definition"); else if (Configuration.doAutoCreate()) this.definition = new UriType(); // bb return this.definition; } public boolean hasDefinitionElement() { return this.definition != null && !this.definition.isEmpty(); } public boolean hasDefinition() { return this.definition != null && !this.definition.isEmpty(); } /** * @param value {@link #definition} (An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]).). This is the underlying object with id, value and extensions. The accessor "getDefinition" gives direct access to the value */ public ConformanceRestResourceSearchParamComponent setDefinitionElement(UriType value) { this.definition = value; return this; } /** * @return An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]). */ public String getDefinition() { return this.definition == null ? null : this.definition.getValue(); } /** * @param value An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]). */ public ConformanceRestResourceSearchParamComponent setDefinition(String value) { if (Utilities.noString(value)) this.definition = null; else { if (this.definition == null) this.definition = new UriType(); this.definition.setValue(value); } return this; } /** * @return {@link #type} (The type of value a search parameter refers to, and how the content is interpreted.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public Enumeration<SearchParamType> getTypeElement() { if (this.type == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceSearchParamComponent.type"); else if (Configuration.doAutoCreate()) this.type = new Enumeration<SearchParamType>(new SearchParamTypeEnumFactory()); // bb return this.type; } public boolean hasTypeElement() { return this.type != null && !this.type.isEmpty(); } public boolean hasType() { return this.type != null && !this.type.isEmpty(); } /** * @param value {@link #type} (The type of value a search parameter refers to, and how the content is interpreted.). This is the underlying object with id, value and extensions. The accessor "getType" gives direct access to the value */ public ConformanceRestResourceSearchParamComponent setTypeElement(Enumeration<SearchParamType> value) { this.type = value; return this; } /** * @return The type of value a search parameter refers to, and how the content is interpreted. */ public SearchParamType getType() { return this.type == null ? null : this.type.getValue(); } /** * @param value The type of value a search parameter refers to, and how the content is interpreted. */ public ConformanceRestResourceSearchParamComponent setType(SearchParamType value) { if (this.type == null) this.type = new Enumeration<SearchParamType>(new SearchParamTypeEnumFactory()); this.type.setValue(value); return this; } /** * @return {@link #documentation} (This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestResourceSearchParamComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ConformanceRestResourceSearchParamComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms. */ public ConformanceRestResourceSearchParamComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } /** * @return {@link #target} (Types of resource (if a resource is referenced).) */ public List<CodeType> getTarget() { if (this.target == null) this.target = new ArrayList<CodeType>(); return this.target; } public boolean hasTarget() { if (this.target == null) return false; for (CodeType item : this.target) if (!item.isEmpty()) return true; return false; } /** * @return {@link #target} (Types of resource (if a resource is referenced).) */ // syntactic sugar public CodeType addTargetElement() {//2 CodeType t = new CodeType(); if (this.target == null) this.target = new ArrayList<CodeType>(); this.target.add(t); return t; } /** * @param value {@link #target} (Types of resource (if a resource is referenced).) */ public ConformanceRestResourceSearchParamComponent addTarget(String value) { //1 CodeType t = new CodeType(); t.setValue(value); if (this.target == null) this.target = new ArrayList<CodeType>(); this.target.add(t); return this; } /** * @param value {@link #target} (Types of resource (if a resource is referenced).) */ public boolean hasTarget(String value) { if (this.target == null) return false; for (CodeType v : this.target) if (v.equals(value)) // code return true; return false; } /** * @return {@link #modifier} (A modifier supported for the search parameter.) */ public List<Enumeration<SearchModifierCode>> getModifier() { if (this.modifier == null) this.modifier = new ArrayList<Enumeration<SearchModifierCode>>(); return this.modifier; } public boolean hasModifier() { if (this.modifier == null) return false; for (Enumeration<SearchModifierCode> item : this.modifier) if (!item.isEmpty()) return true; return false; } /** * @return {@link #modifier} (A modifier supported for the search parameter.) */ // syntactic sugar public Enumeration<SearchModifierCode> addModifierElement() {//2 Enumeration<SearchModifierCode> t = new Enumeration<SearchModifierCode>(new SearchModifierCodeEnumFactory()); if (this.modifier == null) this.modifier = new ArrayList<Enumeration<SearchModifierCode>>(); this.modifier.add(t); return t; } /** * @param value {@link #modifier} (A modifier supported for the search parameter.) */ public ConformanceRestResourceSearchParamComponent addModifier(SearchModifierCode value) { //1 Enumeration<SearchModifierCode> t = new Enumeration<SearchModifierCode>(new SearchModifierCodeEnumFactory()); t.setValue(value); if (this.modifier == null) this.modifier = new ArrayList<Enumeration<SearchModifierCode>>(); this.modifier.add(t); return this; } /** * @param value {@link #modifier} (A modifier supported for the search parameter.) */ public boolean hasModifier(SearchModifierCode value) { if (this.modifier == null) return false; for (Enumeration<SearchModifierCode> v : this.modifier) if (v.getValue().equals(value)) // code return true; return false; } /** * @return {@link #chain} (Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type.) */ public List<StringType> getChain() { if (this.chain == null) this.chain = new ArrayList<StringType>(); return this.chain; } public boolean hasChain() { if (this.chain == null) return false; for (StringType item : this.chain) if (!item.isEmpty()) return true; return false; } /** * @return {@link #chain} (Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type.) */ // syntactic sugar public StringType addChainElement() {//2 StringType t = new StringType(); if (this.chain == null) this.chain = new ArrayList<StringType>(); this.chain.add(t); return t; } /** * @param value {@link #chain} (Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type.) */ public ConformanceRestResourceSearchParamComponent addChain(String value) { //1 StringType t = new StringType(); t.setValue(value); if (this.chain == null) this.chain = new ArrayList<StringType>(); this.chain.add(t); return this; } /** * @param value {@link #chain} (Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type.) */ public boolean hasChain(String value) { if (this.chain == null) return false; for (StringType v : this.chain) if (v.equals(value)) // string return true; return false; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("name", "string", "The name of the search parameter used in the interface.", 0, java.lang.Integer.MAX_VALUE, name)); childrenList.add(new Property("definition", "uri", "An absolute URI that is a formal reference to where this parameter was first defined, so that a client can be confident of the meaning of the search parameter (a reference to [[[SearchParameter.url]]]).", 0, java.lang.Integer.MAX_VALUE, definition)); childrenList.add(new Property("type", "code", "The type of value a search parameter refers to, and how the content is interpreted.", 0, java.lang.Integer.MAX_VALUE, type)); childrenList.add(new Property("documentation", "string", "This allows documentation of any distinct behaviors about how the search parameter is used. For example, text matching algorithms.", 0, java.lang.Integer.MAX_VALUE, documentation)); childrenList.add(new Property("target", "code", "Types of resource (if a resource is referenced).", 0, java.lang.Integer.MAX_VALUE, target)); childrenList.add(new Property("modifier", "code", "A modifier supported for the search parameter.", 0, java.lang.Integer.MAX_VALUE, modifier)); childrenList.add(new Property("chain", "string", "Contains the names of any search parameters which may be chained to the containing search parameter. Chained parameters may be added to search parameters of type reference, and specify that resources will only be returned if they contain a reference to a resource which matches the chained parameter value. Values for this field should be drawn from Conformance.rest.resource.searchParam.name on the target resource type.", 0, java.lang.Integer.MAX_VALUE, chain)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType case -1014418093: /*definition*/ return this.definition == null ? new Base[0] : new Base[] {this.definition}; // UriType case 3575610: /*type*/ return this.type == null ? new Base[0] : new Base[] {this.type}; // Enumeration<SearchParamType> case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType case -880905839: /*target*/ return this.target == null ? new Base[0] : this.target.toArray(new Base[this.target.size()]); // CodeType case -615513385: /*modifier*/ return this.modifier == null ? new Base[0] : this.modifier.toArray(new Base[this.modifier.size()]); // Enumeration<SearchModifierCode> case 94623425: /*chain*/ return this.chain == null ? new Base[0] : this.chain.toArray(new Base[this.chain.size()]); // StringType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3373707: // name this.name = castToString(value); // StringType break; case -1014418093: // definition this.definition = castToUri(value); // UriType break; case 3575610: // type this.type = new SearchParamTypeEnumFactory().fromType(value); // Enumeration<SearchParamType> break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; case -880905839: // target this.getTarget().add(castToCode(value)); // CodeType break; case -615513385: // modifier this.getModifier().add(new SearchModifierCodeEnumFactory().fromType(value)); // Enumeration<SearchModifierCode> break; case 94623425: // chain this.getChain().add(castToString(value)); // StringType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("name")) this.name = castToString(value); // StringType else if (name.equals("definition")) this.definition = castToUri(value); // UriType else if (name.equals("type")) this.type = new SearchParamTypeEnumFactory().fromType(value); // Enumeration<SearchParamType> else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else if (name.equals("target")) this.getTarget().add(castToCode(value)); else if (name.equals("modifier")) this.getModifier().add(new SearchModifierCodeEnumFactory().fromType(value)); else if (name.equals("chain")) this.getChain().add(castToString(value)); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3373707: throw new FHIRException("Cannot make property name as it is not a complex type"); // StringType case -1014418093: throw new FHIRException("Cannot make property definition as it is not a complex type"); // UriType case 3575610: throw new FHIRException("Cannot make property type as it is not a complex type"); // Enumeration<SearchParamType> case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType case -880905839: throw new FHIRException("Cannot make property target as it is not a complex type"); // CodeType case -615513385: throw new FHIRException("Cannot make property modifier as it is not a complex type"); // Enumeration<SearchModifierCode> case 94623425: throw new FHIRException("Cannot make property chain as it is not a complex type"); // StringType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("name")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.name"); } else if (name.equals("definition")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.definition"); } else if (name.equals("type")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.type"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else if (name.equals("target")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.target"); } else if (name.equals("modifier")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.modifier"); } else if (name.equals("chain")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.chain"); } else return super.addChild(name); } public ConformanceRestResourceSearchParamComponent copy() { ConformanceRestResourceSearchParamComponent dst = new ConformanceRestResourceSearchParamComponent(); copyValues(dst); dst.name = name == null ? null : name.copy(); dst.definition = definition == null ? null : definition.copy(); dst.type = type == null ? null : type.copy(); dst.documentation = documentation == null ? null : documentation.copy(); if (target != null) { dst.target = new ArrayList<CodeType>(); for (CodeType i : target) dst.target.add(i.copy()); }; if (modifier != null) { dst.modifier = new ArrayList<Enumeration<SearchModifierCode>>(); for (Enumeration<SearchModifierCode> i : modifier) dst.modifier.add(i.copy()); }; if (chain != null) { dst.chain = new ArrayList<StringType>(); for (StringType i : chain) dst.chain.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestResourceSearchParamComponent)) return false; ConformanceRestResourceSearchParamComponent o = (ConformanceRestResourceSearchParamComponent) other; return compareDeep(name, o.name, true) && compareDeep(definition, o.definition, true) && compareDeep(type, o.type, true) && compareDeep(documentation, o.documentation, true) && compareDeep(target, o.target, true) && compareDeep(modifier, o.modifier, true) && compareDeep(chain, o.chain, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestResourceSearchParamComponent)) return false; ConformanceRestResourceSearchParamComponent o = (ConformanceRestResourceSearchParamComponent) other; return compareValues(name, o.name, true) && compareValues(definition, o.definition, true) && compareValues(type, o.type, true) && compareValues(documentation, o.documentation, true) && compareValues(target, o.target, true) && compareValues(modifier, o.modifier, true) && compareValues(chain, o.chain, true); } public boolean isEmpty() { return super.isEmpty() && (name == null || name.isEmpty()) && (definition == null || definition.isEmpty()) && (type == null || type.isEmpty()) && (documentation == null || documentation.isEmpty()) && (target == null || target.isEmpty()) && (modifier == null || modifier.isEmpty()) && (chain == null || chain.isEmpty()) ; } public String fhirType() { return "Conformance.rest.resource.searchParam"; } } @Block() public static class SystemInteractionComponent extends BackboneElement implements IBaseBackboneElement { /** * A coded identifier of the operation, supported by the system. */ @Child(name = "code", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="transaction | search-system | history-system", formalDefinition="A coded identifier of the operation, supported by the system." ) protected Enumeration<SystemRestfulInteraction> code; /** * Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented. */ @Child(name = "documentation", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Anything special about operation behavior", formalDefinition="Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented." ) protected StringType documentation; private static final long serialVersionUID = 510675287L; /** * Constructor */ public SystemInteractionComponent() { super(); } /** * Constructor */ public SystemInteractionComponent(Enumeration<SystemRestfulInteraction> code) { super(); this.code = code; } /** * @return {@link #code} (A coded identifier of the operation, supported by the system.). This is the underlying object with id, value and extensions. The accessor "getCode" gives direct access to the value */ public Enumeration<SystemRestfulInteraction> getCodeElement() { if (this.code == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create SystemInteractionComponent.code"); else if (Configuration.doAutoCreate()) this.code = new Enumeration<SystemRestfulInteraction>(new SystemRestfulInteractionEnumFactory()); // bb return this.code; } public boolean hasCodeElement() { return this.code != null && !this.code.isEmpty(); } public boolean hasCode() { return this.code != null && !this.code.isEmpty(); } /** * @param value {@link #code} (A coded identifier of the operation, supported by the system.). This is the underlying object with id, value and extensions. The accessor "getCode" gives direct access to the value */ public SystemInteractionComponent setCodeElement(Enumeration<SystemRestfulInteraction> value) { this.code = value; return this; } /** * @return A coded identifier of the operation, supported by the system. */ public SystemRestfulInteraction getCode() { return this.code == null ? null : this.code.getValue(); } /** * @param value A coded identifier of the operation, supported by the system. */ public SystemInteractionComponent setCode(SystemRestfulInteraction value) { if (this.code == null) this.code = new Enumeration<SystemRestfulInteraction>(new SystemRestfulInteractionEnumFactory()); this.code.setValue(value); return this; } /** * @return {@link #documentation} (Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create SystemInteractionComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public SystemInteractionComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented. */ public SystemInteractionComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("code", "code", "A coded identifier of the operation, supported by the system.", 0, java.lang.Integer.MAX_VALUE, code)); childrenList.add(new Property("documentation", "string", "Guidance specific to the implementation of this operation, such as limitations on the kind of transactions allowed, or information about system wide search is implemented.", 0, java.lang.Integer.MAX_VALUE, documentation)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3059181: /*code*/ return this.code == null ? new Base[0] : new Base[] {this.code}; // Enumeration<SystemRestfulInteraction> case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3059181: // code this.code = new SystemRestfulInteractionEnumFactory().fromType(value); // Enumeration<SystemRestfulInteraction> break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("code")) this.code = new SystemRestfulInteractionEnumFactory().fromType(value); // Enumeration<SystemRestfulInteraction> else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3059181: throw new FHIRException("Cannot make property code as it is not a complex type"); // Enumeration<SystemRestfulInteraction> case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("code")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.code"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else return super.addChild(name); } public SystemInteractionComponent copy() { SystemInteractionComponent dst = new SystemInteractionComponent(); copyValues(dst); dst.code = code == null ? null : code.copy(); dst.documentation = documentation == null ? null : documentation.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof SystemInteractionComponent)) return false; SystemInteractionComponent o = (SystemInteractionComponent) other; return compareDeep(code, o.code, true) && compareDeep(documentation, o.documentation, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof SystemInteractionComponent)) return false; SystemInteractionComponent o = (SystemInteractionComponent) other; return compareValues(code, o.code, true) && compareValues(documentation, o.documentation, true); } public boolean isEmpty() { return super.isEmpty() && (code == null || code.isEmpty()) && (documentation == null || documentation.isEmpty()) ; } public String fhirType() { return "Conformance.rest.interaction"; } } @Block() public static class ConformanceRestOperationComponent extends BackboneElement implements IBaseBackboneElement { /** * The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called. */ @Child(name = "name", type = {StringType.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Name by which the operation/query is invoked", formalDefinition="The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called." ) protected StringType name; /** * Where the formal definition can be found. */ @Child(name = "definition", type = {OperationDefinition.class}, order=2, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="The defined operation/query", formalDefinition="Where the formal definition can be found." ) protected Reference definition; /** * The actual object that is the target of the reference (Where the formal definition can be found.) */ protected OperationDefinition definitionTarget; private static final long serialVersionUID = 122107272L; /** * Constructor */ public ConformanceRestOperationComponent() { super(); } /** * Constructor */ public ConformanceRestOperationComponent(StringType name, Reference definition) { super(); this.name = name; this.definition = definition; } /** * @return {@link #name} (The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public StringType getNameElement() { if (this.name == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestOperationComponent.name"); else if (Configuration.doAutoCreate()) this.name = new StringType(); // bb return this.name; } public boolean hasNameElement() { return this.name != null && !this.name.isEmpty(); } public boolean hasName() { return this.name != null && !this.name.isEmpty(); } /** * @param value {@link #name} (The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public ConformanceRestOperationComponent setNameElement(StringType value) { this.name = value; return this; } /** * @return The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called. */ public String getName() { return this.name == null ? null : this.name.getValue(); } /** * @param value The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called. */ public ConformanceRestOperationComponent setName(String value) { if (this.name == null) this.name = new StringType(); this.name.setValue(value); return this; } /** * @return {@link #definition} (Where the formal definition can be found.) */ public Reference getDefinition() { if (this.definition == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestOperationComponent.definition"); else if (Configuration.doAutoCreate()) this.definition = new Reference(); // cc return this.definition; } public boolean hasDefinition() { return this.definition != null && !this.definition.isEmpty(); } /** * @param value {@link #definition} (Where the formal definition can be found.) */ public ConformanceRestOperationComponent setDefinition(Reference value) { this.definition = value; return this; } /** * @return {@link #definition} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (Where the formal definition can be found.) */ public OperationDefinition getDefinitionTarget() { if (this.definitionTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceRestOperationComponent.definition"); else if (Configuration.doAutoCreate()) this.definitionTarget = new OperationDefinition(); // aa return this.definitionTarget; } /** * @param value {@link #definition} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (Where the formal definition can be found.) */ public ConformanceRestOperationComponent setDefinitionTarget(OperationDefinition value) { this.definitionTarget = value; return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("name", "string", "The name of the operation or query. For an operation, this is the name prefixed with $ and used in the url. For a query, this is the name used in the _query parameter when the query is called.", 0, java.lang.Integer.MAX_VALUE, name)); childrenList.add(new Property("definition", "Reference(OperationDefinition)", "Where the formal definition can be found.", 0, java.lang.Integer.MAX_VALUE, definition)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType case -1014418093: /*definition*/ return this.definition == null ? new Base[0] : new Base[] {this.definition}; // Reference default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3373707: // name this.name = castToString(value); // StringType break; case -1014418093: // definition this.definition = castToReference(value); // Reference break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("name")) this.name = castToString(value); // StringType else if (name.equals("definition")) this.definition = castToReference(value); // Reference else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3373707: throw new FHIRException("Cannot make property name as it is not a complex type"); // StringType case -1014418093: return getDefinition(); // Reference default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("name")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.name"); } else if (name.equals("definition")) { this.definition = new Reference(); return this.definition; } else return super.addChild(name); } public ConformanceRestOperationComponent copy() { ConformanceRestOperationComponent dst = new ConformanceRestOperationComponent(); copyValues(dst); dst.name = name == null ? null : name.copy(); dst.definition = definition == null ? null : definition.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceRestOperationComponent)) return false; ConformanceRestOperationComponent o = (ConformanceRestOperationComponent) other; return compareDeep(name, o.name, true) && compareDeep(definition, o.definition, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceRestOperationComponent)) return false; ConformanceRestOperationComponent o = (ConformanceRestOperationComponent) other; return compareValues(name, o.name, true); } public boolean isEmpty() { return super.isEmpty() && (name == null || name.isEmpty()) && (definition == null || definition.isEmpty()) ; } public String fhirType() { return "Conformance.rest.operation"; } } @Block() public static class ConformanceMessagingComponent extends BackboneElement implements IBaseBackboneElement { /** * An endpoint (network accessible address) to which messages and/or replies are to be sent. */ @Child(name = "endpoint", type = {}, order=1, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Where messages should be sent", formalDefinition="An endpoint (network accessible address) to which messages and/or replies are to be sent." ) protected List<ConformanceMessagingEndpointComponent> endpoint; /** * Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender). */ @Child(name = "reliableCache", type = {UnsignedIntType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Reliable Message Cache Length (min)", formalDefinition="Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender)." ) protected UnsignedIntType reliableCache; /** * Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner. */ @Child(name = "documentation", type = {StringType.class}, order=3, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Messaging interface behavior details", formalDefinition="Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner." ) protected StringType documentation; /** * A description of the solution's support for an event at this end-point. */ @Child(name = "event", type = {}, order=4, min=1, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Declare support for this event", formalDefinition="A description of the solution's support for an event at this end-point." ) protected List<ConformanceMessagingEventComponent> event; private static final long serialVersionUID = -712362545L; /** * Constructor */ public ConformanceMessagingComponent() { super(); } /** * @return {@link #endpoint} (An endpoint (network accessible address) to which messages and/or replies are to be sent.) */ public List<ConformanceMessagingEndpointComponent> getEndpoint() { if (this.endpoint == null) this.endpoint = new ArrayList<ConformanceMessagingEndpointComponent>(); return this.endpoint; } public boolean hasEndpoint() { if (this.endpoint == null) return false; for (ConformanceMessagingEndpointComponent item : this.endpoint) if (!item.isEmpty()) return true; return false; } /** * @return {@link #endpoint} (An endpoint (network accessible address) to which messages and/or replies are to be sent.) */ // syntactic sugar public ConformanceMessagingEndpointComponent addEndpoint() { //3 ConformanceMessagingEndpointComponent t = new ConformanceMessagingEndpointComponent(); if (this.endpoint == null) this.endpoint = new ArrayList<ConformanceMessagingEndpointComponent>(); this.endpoint.add(t); return t; } // syntactic sugar public ConformanceMessagingComponent addEndpoint(ConformanceMessagingEndpointComponent t) { //3 if (t == null) return this; if (this.endpoint == null) this.endpoint = new ArrayList<ConformanceMessagingEndpointComponent>(); this.endpoint.add(t); return this; } /** * @return {@link #reliableCache} (Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender).). This is the underlying object with id, value and extensions. The accessor "getReliableCache" gives direct access to the value */ public UnsignedIntType getReliableCacheElement() { if (this.reliableCache == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingComponent.reliableCache"); else if (Configuration.doAutoCreate()) this.reliableCache = new UnsignedIntType(); // bb return this.reliableCache; } public boolean hasReliableCacheElement() { return this.reliableCache != null && !this.reliableCache.isEmpty(); } public boolean hasReliableCache() { return this.reliableCache != null && !this.reliableCache.isEmpty(); } /** * @param value {@link #reliableCache} (Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender).). This is the underlying object with id, value and extensions. The accessor "getReliableCache" gives direct access to the value */ public ConformanceMessagingComponent setReliableCacheElement(UnsignedIntType value) { this.reliableCache = value; return this; } /** * @return Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender). */ public int getReliableCache() { return this.reliableCache == null || this.reliableCache.isEmpty() ? 0 : this.reliableCache.getValue(); } /** * @param value Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender). */ public ConformanceMessagingComponent setReliableCache(int value) { if (this.reliableCache == null) this.reliableCache = new UnsignedIntType(); this.reliableCache.setValue(value); return this; } /** * @return {@link #documentation} (Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ConformanceMessagingComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner. */ public ConformanceMessagingComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } /** * @return {@link #event} (A description of the solution's support for an event at this end-point.) */ public List<ConformanceMessagingEventComponent> getEvent() { if (this.event == null) this.event = new ArrayList<ConformanceMessagingEventComponent>(); return this.event; } public boolean hasEvent() { if (this.event == null) return false; for (ConformanceMessagingEventComponent item : this.event) if (!item.isEmpty()) return true; return false; } /** * @return {@link #event} (A description of the solution's support for an event at this end-point.) */ // syntactic sugar public ConformanceMessagingEventComponent addEvent() { //3 ConformanceMessagingEventComponent t = new ConformanceMessagingEventComponent(); if (this.event == null) this.event = new ArrayList<ConformanceMessagingEventComponent>(); this.event.add(t); return t; } // syntactic sugar public ConformanceMessagingComponent addEvent(ConformanceMessagingEventComponent t) { //3 if (t == null) return this; if (this.event == null) this.event = new ArrayList<ConformanceMessagingEventComponent>(); this.event.add(t); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("endpoint", "", "An endpoint (network accessible address) to which messages and/or replies are to be sent.", 0, java.lang.Integer.MAX_VALUE, endpoint)); childrenList.add(new Property("reliableCache", "unsignedInt", "Length if the receiver's reliable messaging cache in minutes (if a receiver) or how long the cache length on the receiver should be (if a sender).", 0, java.lang.Integer.MAX_VALUE, reliableCache)); childrenList.add(new Property("documentation", "string", "Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the conformance statement. For example, process for becoming an authorized messaging exchange partner.", 0, java.lang.Integer.MAX_VALUE, documentation)); childrenList.add(new Property("event", "", "A description of the solution's support for an event at this end-point.", 0, java.lang.Integer.MAX_VALUE, event)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 1741102485: /*endpoint*/ return this.endpoint == null ? new Base[0] : this.endpoint.toArray(new Base[this.endpoint.size()]); // ConformanceMessagingEndpointComponent case 897803608: /*reliableCache*/ return this.reliableCache == null ? new Base[0] : new Base[] {this.reliableCache}; // UnsignedIntType case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType case 96891546: /*event*/ return this.event == null ? new Base[0] : this.event.toArray(new Base[this.event.size()]); // ConformanceMessagingEventComponent default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 1741102485: // endpoint this.getEndpoint().add((ConformanceMessagingEndpointComponent) value); // ConformanceMessagingEndpointComponent break; case 897803608: // reliableCache this.reliableCache = castToUnsignedInt(value); // UnsignedIntType break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; case 96891546: // event this.getEvent().add((ConformanceMessagingEventComponent) value); // ConformanceMessagingEventComponent break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("endpoint")) this.getEndpoint().add((ConformanceMessagingEndpointComponent) value); else if (name.equals("reliableCache")) this.reliableCache = castToUnsignedInt(value); // UnsignedIntType else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else if (name.equals("event")) this.getEvent().add((ConformanceMessagingEventComponent) value); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 1741102485: return addEndpoint(); // ConformanceMessagingEndpointComponent case 897803608: throw new FHIRException("Cannot make property reliableCache as it is not a complex type"); // UnsignedIntType case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType case 96891546: return addEvent(); // ConformanceMessagingEventComponent default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("endpoint")) { return addEndpoint(); } else if (name.equals("reliableCache")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.reliableCache"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else if (name.equals("event")) { return addEvent(); } else return super.addChild(name); } public ConformanceMessagingComponent copy() { ConformanceMessagingComponent dst = new ConformanceMessagingComponent(); copyValues(dst); if (endpoint != null) { dst.endpoint = new ArrayList<ConformanceMessagingEndpointComponent>(); for (ConformanceMessagingEndpointComponent i : endpoint) dst.endpoint.add(i.copy()); }; dst.reliableCache = reliableCache == null ? null : reliableCache.copy(); dst.documentation = documentation == null ? null : documentation.copy(); if (event != null) { dst.event = new ArrayList<ConformanceMessagingEventComponent>(); for (ConformanceMessagingEventComponent i : event) dst.event.add(i.copy()); }; return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceMessagingComponent)) return false; ConformanceMessagingComponent o = (ConformanceMessagingComponent) other; return compareDeep(endpoint, o.endpoint, true) && compareDeep(reliableCache, o.reliableCache, true) && compareDeep(documentation, o.documentation, true) && compareDeep(event, o.event, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceMessagingComponent)) return false; ConformanceMessagingComponent o = (ConformanceMessagingComponent) other; return compareValues(reliableCache, o.reliableCache, true) && compareValues(documentation, o.documentation, true) ; } public boolean isEmpty() { return super.isEmpty() && (endpoint == null || endpoint.isEmpty()) && (reliableCache == null || reliableCache.isEmpty()) && (documentation == null || documentation.isEmpty()) && (event == null || event.isEmpty()) ; } public String fhirType() { return "Conformance.messaging"; } } @Block() public static class ConformanceMessagingEndpointComponent extends BackboneElement implements IBaseBackboneElement { /** * A list of the messaging transport protocol(s) identifiers, supported by this endpoint. */ @Child(name = "protocol", type = {Coding.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="http | ftp | mllp +", formalDefinition="A list of the messaging transport protocol(s) identifiers, supported by this endpoint." ) protected Coding protocol; /** * The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier. */ @Child(name = "address", type = {UriType.class}, order=2, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Address of end-point", formalDefinition="The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier." ) protected UriType address; private static final long serialVersionUID = 1294656428L; /** * Constructor */ public ConformanceMessagingEndpointComponent() { super(); } /** * Constructor */ public ConformanceMessagingEndpointComponent(Coding protocol, UriType address) { super(); this.protocol = protocol; this.address = address; } /** * @return {@link #protocol} (A list of the messaging transport protocol(s) identifiers, supported by this endpoint.) */ public Coding getProtocol() { if (this.protocol == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEndpointComponent.protocol"); else if (Configuration.doAutoCreate()) this.protocol = new Coding(); // cc return this.protocol; } public boolean hasProtocol() { return this.protocol != null && !this.protocol.isEmpty(); } /** * @param value {@link #protocol} (A list of the messaging transport protocol(s) identifiers, supported by this endpoint.) */ public ConformanceMessagingEndpointComponent setProtocol(Coding value) { this.protocol = value; return this; } /** * @return {@link #address} (The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier.). This is the underlying object with id, value and extensions. The accessor "getAddress" gives direct access to the value */ public UriType getAddressElement() { if (this.address == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEndpointComponent.address"); else if (Configuration.doAutoCreate()) this.address = new UriType(); // bb return this.address; } public boolean hasAddressElement() { return this.address != null && !this.address.isEmpty(); } public boolean hasAddress() { return this.address != null && !this.address.isEmpty(); } /** * @param value {@link #address} (The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier.). This is the underlying object with id, value and extensions. The accessor "getAddress" gives direct access to the value */ public ConformanceMessagingEndpointComponent setAddressElement(UriType value) { this.address = value; return this; } /** * @return The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier. */ public String getAddress() { return this.address == null ? null : this.address.getValue(); } /** * @param value The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier. */ public ConformanceMessagingEndpointComponent setAddress(String value) { if (this.address == null) this.address = new UriType(); this.address.setValue(value); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("protocol", "Coding", "A list of the messaging transport protocol(s) identifiers, supported by this endpoint.", 0, java.lang.Integer.MAX_VALUE, protocol)); childrenList.add(new Property("address", "uri", "The network address of the end-point. For solutions that do not use network addresses for routing, it can be just an identifier.", 0, java.lang.Integer.MAX_VALUE, address)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case -989163880: /*protocol*/ return this.protocol == null ? new Base[0] : new Base[] {this.protocol}; // Coding case -1147692044: /*address*/ return this.address == null ? new Base[0] : new Base[] {this.address}; // UriType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case -989163880: // protocol this.protocol = castToCoding(value); // Coding break; case -1147692044: // address this.address = castToUri(value); // UriType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("protocol")) this.protocol = castToCoding(value); // Coding else if (name.equals("address")) this.address = castToUri(value); // UriType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case -989163880: return getProtocol(); // Coding case -1147692044: throw new FHIRException("Cannot make property address as it is not a complex type"); // UriType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("protocol")) { this.protocol = new Coding(); return this.protocol; } else if (name.equals("address")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.address"); } else return super.addChild(name); } public ConformanceMessagingEndpointComponent copy() { ConformanceMessagingEndpointComponent dst = new ConformanceMessagingEndpointComponent(); copyValues(dst); dst.protocol = protocol == null ? null : protocol.copy(); dst.address = address == null ? null : address.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceMessagingEndpointComponent)) return false; ConformanceMessagingEndpointComponent o = (ConformanceMessagingEndpointComponent) other; return compareDeep(protocol, o.protocol, true) && compareDeep(address, o.address, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceMessagingEndpointComponent)) return false; ConformanceMessagingEndpointComponent o = (ConformanceMessagingEndpointComponent) other; return compareValues(address, o.address, true); } public boolean isEmpty() { return super.isEmpty() && (protocol == null || protocol.isEmpty()) && (address == null || address.isEmpty()) ; } public String fhirType() { return "Conformance.messaging.endpoint"; } } @Block() public static class ConformanceMessagingEventComponent extends BackboneElement implements IBaseBackboneElement { /** * A coded identifier of a supported messaging event. */ @Child(name = "code", type = {Coding.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Event type", formalDefinition="A coded identifier of a supported messaging event." ) protected Coding code; /** * The impact of the content of the message. */ @Child(name = "category", type = {CodeType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Consequence | Currency | Notification", formalDefinition="The impact of the content of the message." ) protected Enumeration<MessageSignificanceCategory> category; /** * The mode of this event declaration - whether application is sender or receiver. */ @Child(name = "mode", type = {CodeType.class}, order=3, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="sender | receiver", formalDefinition="The mode of this event declaration - whether application is sender or receiver." ) protected Enumeration<ConformanceEventMode> mode; /** * A resource associated with the event. This is the resource that defines the event. */ @Child(name = "focus", type = {CodeType.class}, order=4, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Resource that's focus of message", formalDefinition="A resource associated with the event. This is the resource that defines the event." ) protected CodeType focus; /** * Information about the request for this event. */ @Child(name = "request", type = {StructureDefinition.class}, order=5, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Profile that describes the request", formalDefinition="Information about the request for this event." ) protected Reference request; /** * The actual object that is the target of the reference (Information about the request for this event.) */ protected StructureDefinition requestTarget; /** * Information about the response for this event. */ @Child(name = "response", type = {StructureDefinition.class}, order=6, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Profile that describes the response", formalDefinition="Information about the response for this event." ) protected Reference response; /** * The actual object that is the target of the reference (Information about the response for this event.) */ protected StructureDefinition responseTarget; /** * Guidance on how this event is handled, such as internal system trigger points, business rules, etc. */ @Child(name = "documentation", type = {StringType.class}, order=7, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Endpoint-specific event documentation", formalDefinition="Guidance on how this event is handled, such as internal system trigger points, business rules, etc." ) protected StringType documentation; private static final long serialVersionUID = -47031390L; /** * Constructor */ public ConformanceMessagingEventComponent() { super(); } /** * Constructor */ public ConformanceMessagingEventComponent(Coding code, Enumeration<ConformanceEventMode> mode, CodeType focus, Reference request, Reference response) { super(); this.code = code; this.mode = mode; this.focus = focus; this.request = request; this.response = response; } /** * @return {@link #code} (A coded identifier of a supported messaging event.) */ public Coding getCode() { if (this.code == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.code"); else if (Configuration.doAutoCreate()) this.code = new Coding(); // cc return this.code; } public boolean hasCode() { return this.code != null && !this.code.isEmpty(); } /** * @param value {@link #code} (A coded identifier of a supported messaging event.) */ public ConformanceMessagingEventComponent setCode(Coding value) { this.code = value; return this; } /** * @return {@link #category} (The impact of the content of the message.). This is the underlying object with id, value and extensions. The accessor "getCategory" gives direct access to the value */ public Enumeration<MessageSignificanceCategory> getCategoryElement() { if (this.category == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.category"); else if (Configuration.doAutoCreate()) this.category = new Enumeration<MessageSignificanceCategory>(new MessageSignificanceCategoryEnumFactory()); // bb return this.category; } public boolean hasCategoryElement() { return this.category != null && !this.category.isEmpty(); } public boolean hasCategory() { return this.category != null && !this.category.isEmpty(); } /** * @param value {@link #category} (The impact of the content of the message.). This is the underlying object with id, value and extensions. The accessor "getCategory" gives direct access to the value */ public ConformanceMessagingEventComponent setCategoryElement(Enumeration<MessageSignificanceCategory> value) { this.category = value; return this; } /** * @return The impact of the content of the message. */ public MessageSignificanceCategory getCategory() { return this.category == null ? null : this.category.getValue(); } /** * @param value The impact of the content of the message. */ public ConformanceMessagingEventComponent setCategory(MessageSignificanceCategory value) { if (value == null) this.category = null; else { if (this.category == null) this.category = new Enumeration<MessageSignificanceCategory>(new MessageSignificanceCategoryEnumFactory()); this.category.setValue(value); } return this; } /** * @return {@link #mode} (The mode of this event declaration - whether application is sender or receiver.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public Enumeration<ConformanceEventMode> getModeElement() { if (this.mode == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.mode"); else if (Configuration.doAutoCreate()) this.mode = new Enumeration<ConformanceEventMode>(new ConformanceEventModeEnumFactory()); // bb return this.mode; } public boolean hasModeElement() { return this.mode != null && !this.mode.isEmpty(); } public boolean hasMode() { return this.mode != null && !this.mode.isEmpty(); } /** * @param value {@link #mode} (The mode of this event declaration - whether application is sender or receiver.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public ConformanceMessagingEventComponent setModeElement(Enumeration<ConformanceEventMode> value) { this.mode = value; return this; } /** * @return The mode of this event declaration - whether application is sender or receiver. */ public ConformanceEventMode getMode() { return this.mode == null ? null : this.mode.getValue(); } /** * @param value The mode of this event declaration - whether application is sender or receiver. */ public ConformanceMessagingEventComponent setMode(ConformanceEventMode value) { if (this.mode == null) this.mode = new Enumeration<ConformanceEventMode>(new ConformanceEventModeEnumFactory()); this.mode.setValue(value); return this; } /** * @return {@link #focus} (A resource associated with the event. This is the resource that defines the event.). This is the underlying object with id, value and extensions. The accessor "getFocus" gives direct access to the value */ public CodeType getFocusElement() { if (this.focus == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.focus"); else if (Configuration.doAutoCreate()) this.focus = new CodeType(); // bb return this.focus; } public boolean hasFocusElement() { return this.focus != null && !this.focus.isEmpty(); } public boolean hasFocus() { return this.focus != null && !this.focus.isEmpty(); } /** * @param value {@link #focus} (A resource associated with the event. This is the resource that defines the event.). This is the underlying object with id, value and extensions. The accessor "getFocus" gives direct access to the value */ public ConformanceMessagingEventComponent setFocusElement(CodeType value) { this.focus = value; return this; } /** * @return A resource associated with the event. This is the resource that defines the event. */ public String getFocus() { return this.focus == null ? null : this.focus.getValue(); } /** * @param value A resource associated with the event. This is the resource that defines the event. */ public ConformanceMessagingEventComponent setFocus(String value) { if (this.focus == null) this.focus = new CodeType(); this.focus.setValue(value); return this; } /** * @return {@link #request} (Information about the request for this event.) */ public Reference getRequest() { if (this.request == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.request"); else if (Configuration.doAutoCreate()) this.request = new Reference(); // cc return this.request; } public boolean hasRequest() { return this.request != null && !this.request.isEmpty(); } /** * @param value {@link #request} (Information about the request for this event.) */ public ConformanceMessagingEventComponent setRequest(Reference value) { this.request = value; return this; } /** * @return {@link #request} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (Information about the request for this event.) */ public StructureDefinition getRequestTarget() { if (this.requestTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.request"); else if (Configuration.doAutoCreate()) this.requestTarget = new StructureDefinition(); // aa return this.requestTarget; } /** * @param value {@link #request} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (Information about the request for this event.) */ public ConformanceMessagingEventComponent setRequestTarget(StructureDefinition value) { this.requestTarget = value; return this; } /** * @return {@link #response} (Information about the response for this event.) */ public Reference getResponse() { if (this.response == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.response"); else if (Configuration.doAutoCreate()) this.response = new Reference(); // cc return this.response; } public boolean hasResponse() { return this.response != null && !this.response.isEmpty(); } /** * @param value {@link #response} (Information about the response for this event.) */ public ConformanceMessagingEventComponent setResponse(Reference value) { this.response = value; return this; } /** * @return {@link #response} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (Information about the response for this event.) */ public StructureDefinition getResponseTarget() { if (this.responseTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.response"); else if (Configuration.doAutoCreate()) this.responseTarget = new StructureDefinition(); // aa return this.responseTarget; } /** * @param value {@link #response} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (Information about the response for this event.) */ public ConformanceMessagingEventComponent setResponseTarget(StructureDefinition value) { this.responseTarget = value; return this; } /** * @return {@link #documentation} (Guidance on how this event is handled, such as internal system trigger points, business rules, etc.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceMessagingEventComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (Guidance on how this event is handled, such as internal system trigger points, business rules, etc.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ConformanceMessagingEventComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return Guidance on how this event is handled, such as internal system trigger points, business rules, etc. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value Guidance on how this event is handled, such as internal system trigger points, business rules, etc. */ public ConformanceMessagingEventComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("code", "Coding", "A coded identifier of a supported messaging event.", 0, java.lang.Integer.MAX_VALUE, code)); childrenList.add(new Property("category", "code", "The impact of the content of the message.", 0, java.lang.Integer.MAX_VALUE, category)); childrenList.add(new Property("mode", "code", "The mode of this event declaration - whether application is sender or receiver.", 0, java.lang.Integer.MAX_VALUE, mode)); childrenList.add(new Property("focus", "code", "A resource associated with the event. This is the resource that defines the event.", 0, java.lang.Integer.MAX_VALUE, focus)); childrenList.add(new Property("request", "Reference(StructureDefinition)", "Information about the request for this event.", 0, java.lang.Integer.MAX_VALUE, request)); childrenList.add(new Property("response", "Reference(StructureDefinition)", "Information about the response for this event.", 0, java.lang.Integer.MAX_VALUE, response)); childrenList.add(new Property("documentation", "string", "Guidance on how this event is handled, such as internal system trigger points, business rules, etc.", 0, java.lang.Integer.MAX_VALUE, documentation)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3059181: /*code*/ return this.code == null ? new Base[0] : new Base[] {this.code}; // Coding case 50511102: /*category*/ return this.category == null ? new Base[0] : new Base[] {this.category}; // Enumeration<MessageSignificanceCategory> case 3357091: /*mode*/ return this.mode == null ? new Base[0] : new Base[] {this.mode}; // Enumeration<ConformanceEventMode> case 97604824: /*focus*/ return this.focus == null ? new Base[0] : new Base[] {this.focus}; // CodeType case 1095692943: /*request*/ return this.request == null ? new Base[0] : new Base[] {this.request}; // Reference case -340323263: /*response*/ return this.response == null ? new Base[0] : new Base[] {this.response}; // Reference case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3059181: // code this.code = castToCoding(value); // Coding break; case 50511102: // category this.category = new MessageSignificanceCategoryEnumFactory().fromType(value); // Enumeration<MessageSignificanceCategory> break; case 3357091: // mode this.mode = new ConformanceEventModeEnumFactory().fromType(value); // Enumeration<ConformanceEventMode> break; case 97604824: // focus this.focus = castToCode(value); // CodeType break; case 1095692943: // request this.request = castToReference(value); // Reference break; case -340323263: // response this.response = castToReference(value); // Reference break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("code")) this.code = castToCoding(value); // Coding else if (name.equals("category")) this.category = new MessageSignificanceCategoryEnumFactory().fromType(value); // Enumeration<MessageSignificanceCategory> else if (name.equals("mode")) this.mode = new ConformanceEventModeEnumFactory().fromType(value); // Enumeration<ConformanceEventMode> else if (name.equals("focus")) this.focus = castToCode(value); // CodeType else if (name.equals("request")) this.request = castToReference(value); // Reference else if (name.equals("response")) this.response = castToReference(value); // Reference else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3059181: return getCode(); // Coding case 50511102: throw new FHIRException("Cannot make property category as it is not a complex type"); // Enumeration<MessageSignificanceCategory> case 3357091: throw new FHIRException("Cannot make property mode as it is not a complex type"); // Enumeration<ConformanceEventMode> case 97604824: throw new FHIRException("Cannot make property focus as it is not a complex type"); // CodeType case 1095692943: return getRequest(); // Reference case -340323263: return getResponse(); // Reference case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("code")) { this.code = new Coding(); return this.code; } else if (name.equals("category")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.category"); } else if (name.equals("mode")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.mode"); } else if (name.equals("focus")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.focus"); } else if (name.equals("request")) { this.request = new Reference(); return this.request; } else if (name.equals("response")) { this.response = new Reference(); return this.response; } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else return super.addChild(name); } public ConformanceMessagingEventComponent copy() { ConformanceMessagingEventComponent dst = new ConformanceMessagingEventComponent(); copyValues(dst); dst.code = code == null ? null : code.copy(); dst.category = category == null ? null : category.copy(); dst.mode = mode == null ? null : mode.copy(); dst.focus = focus == null ? null : focus.copy(); dst.request = request == null ? null : request.copy(); dst.response = response == null ? null : response.copy(); dst.documentation = documentation == null ? null : documentation.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceMessagingEventComponent)) return false; ConformanceMessagingEventComponent o = (ConformanceMessagingEventComponent) other; return compareDeep(code, o.code, true) && compareDeep(category, o.category, true) && compareDeep(mode, o.mode, true) && compareDeep(focus, o.focus, true) && compareDeep(request, o.request, true) && compareDeep(response, o.response, true) && compareDeep(documentation, o.documentation, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceMessagingEventComponent)) return false; ConformanceMessagingEventComponent o = (ConformanceMessagingEventComponent) other; return compareValues(category, o.category, true) && compareValues(mode, o.mode, true) && compareValues(focus, o.focus, true) && compareValues(documentation, o.documentation, true); } public boolean isEmpty() { return super.isEmpty() && (code == null || code.isEmpty()) && (category == null || category.isEmpty()) && (mode == null || mode.isEmpty()) && (focus == null || focus.isEmpty()) && (request == null || request.isEmpty()) && (response == null || response.isEmpty()) && (documentation == null || documentation.isEmpty()) ; } public String fhirType() { return "Conformance.messaging.event"; } } @Block() public static class ConformanceDocumentComponent extends BackboneElement implements IBaseBackboneElement { /** * Mode of this document declaration - whether application is producer or consumer. */ @Child(name = "mode", type = {CodeType.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="producer | consumer", formalDefinition="Mode of this document declaration - whether application is producer or consumer." ) protected Enumeration<DocumentMode> mode; /** * A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc. */ @Child(name = "documentation", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Description of document support", formalDefinition="A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc." ) protected StringType documentation; /** * A constraint on a resource used in the document. */ @Child(name = "profile", type = {StructureDefinition.class}, order=3, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="Constraint on a resource used in the document", formalDefinition="A constraint on a resource used in the document." ) protected Reference profile; /** * The actual object that is the target of the reference (A constraint on a resource used in the document.) */ protected StructureDefinition profileTarget; private static final long serialVersionUID = -1059555053L; /** * Constructor */ public ConformanceDocumentComponent() { super(); } /** * Constructor */ public ConformanceDocumentComponent(Enumeration<DocumentMode> mode, Reference profile) { super(); this.mode = mode; this.profile = profile; } /** * @return {@link #mode} (Mode of this document declaration - whether application is producer or consumer.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public Enumeration<DocumentMode> getModeElement() { if (this.mode == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceDocumentComponent.mode"); else if (Configuration.doAutoCreate()) this.mode = new Enumeration<DocumentMode>(new DocumentModeEnumFactory()); // bb return this.mode; } public boolean hasModeElement() { return this.mode != null && !this.mode.isEmpty(); } public boolean hasMode() { return this.mode != null && !this.mode.isEmpty(); } /** * @param value {@link #mode} (Mode of this document declaration - whether application is producer or consumer.). This is the underlying object with id, value and extensions. The accessor "getMode" gives direct access to the value */ public ConformanceDocumentComponent setModeElement(Enumeration<DocumentMode> value) { this.mode = value; return this; } /** * @return Mode of this document declaration - whether application is producer or consumer. */ public DocumentMode getMode() { return this.mode == null ? null : this.mode.getValue(); } /** * @param value Mode of this document declaration - whether application is producer or consumer. */ public ConformanceDocumentComponent setMode(DocumentMode value) { if (this.mode == null) this.mode = new Enumeration<DocumentMode>(new DocumentModeEnumFactory()); this.mode.setValue(value); return this; } /** * @return {@link #documentation} (A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public StringType getDocumentationElement() { if (this.documentation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceDocumentComponent.documentation"); else if (Configuration.doAutoCreate()) this.documentation = new StringType(); // bb return this.documentation; } public boolean hasDocumentationElement() { return this.documentation != null && !this.documentation.isEmpty(); } public boolean hasDocumentation() { return this.documentation != null && !this.documentation.isEmpty(); } /** * @param value {@link #documentation} (A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc.). This is the underlying object with id, value and extensions. The accessor "getDocumentation" gives direct access to the value */ public ConformanceDocumentComponent setDocumentationElement(StringType value) { this.documentation = value; return this; } /** * @return A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc. */ public String getDocumentation() { return this.documentation == null ? null : this.documentation.getValue(); } /** * @param value A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc. */ public ConformanceDocumentComponent setDocumentation(String value) { if (Utilities.noString(value)) this.documentation = null; else { if (this.documentation == null) this.documentation = new StringType(); this.documentation.setValue(value); } return this; } /** * @return {@link #profile} (A constraint on a resource used in the document.) */ public Reference getProfile() { if (this.profile == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceDocumentComponent.profile"); else if (Configuration.doAutoCreate()) this.profile = new Reference(); // cc return this.profile; } public boolean hasProfile() { return this.profile != null && !this.profile.isEmpty(); } /** * @param value {@link #profile} (A constraint on a resource used in the document.) */ public ConformanceDocumentComponent setProfile(Reference value) { this.profile = value; return this; } /** * @return {@link #profile} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (A constraint on a resource used in the document.) */ public StructureDefinition getProfileTarget() { if (this.profileTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create ConformanceDocumentComponent.profile"); else if (Configuration.doAutoCreate()) this.profileTarget = new StructureDefinition(); // aa return this.profileTarget; } /** * @param value {@link #profile} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (A constraint on a resource used in the document.) */ public ConformanceDocumentComponent setProfileTarget(StructureDefinition value) { this.profileTarget = value; return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("mode", "code", "Mode of this document declaration - whether application is producer or consumer.", 0, java.lang.Integer.MAX_VALUE, mode)); childrenList.add(new Property("documentation", "string", "A description of how the application supports or uses the specified document profile. For example, when are documents created, what action is taken with consumed documents, etc.", 0, java.lang.Integer.MAX_VALUE, documentation)); childrenList.add(new Property("profile", "Reference(StructureDefinition)", "A constraint on a resource used in the document.", 0, java.lang.Integer.MAX_VALUE, profile)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 3357091: /*mode*/ return this.mode == null ? new Base[0] : new Base[] {this.mode}; // Enumeration<DocumentMode> case 1587405498: /*documentation*/ return this.documentation == null ? new Base[0] : new Base[] {this.documentation}; // StringType case -309425751: /*profile*/ return this.profile == null ? new Base[0] : new Base[] {this.profile}; // Reference default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 3357091: // mode this.mode = new DocumentModeEnumFactory().fromType(value); // Enumeration<DocumentMode> break; case 1587405498: // documentation this.documentation = castToString(value); // StringType break; case -309425751: // profile this.profile = castToReference(value); // Reference break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("mode")) this.mode = new DocumentModeEnumFactory().fromType(value); // Enumeration<DocumentMode> else if (name.equals("documentation")) this.documentation = castToString(value); // StringType else if (name.equals("profile")) this.profile = castToReference(value); // Reference else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 3357091: throw new FHIRException("Cannot make property mode as it is not a complex type"); // Enumeration<DocumentMode> case 1587405498: throw new FHIRException("Cannot make property documentation as it is not a complex type"); // StringType case -309425751: return getProfile(); // Reference default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("mode")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.mode"); } else if (name.equals("documentation")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.documentation"); } else if (name.equals("profile")) { this.profile = new Reference(); return this.profile; } else return super.addChild(name); } public ConformanceDocumentComponent copy() { ConformanceDocumentComponent dst = new ConformanceDocumentComponent(); copyValues(dst); dst.mode = mode == null ? null : mode.copy(); dst.documentation = documentation == null ? null : documentation.copy(); dst.profile = profile == null ? null : profile.copy(); return dst; } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof ConformanceDocumentComponent)) return false; ConformanceDocumentComponent o = (ConformanceDocumentComponent) other; return compareDeep(mode, o.mode, true) && compareDeep(documentation, o.documentation, true) && compareDeep(profile, o.profile, true) ; } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof ConformanceDocumentComponent)) return false; ConformanceDocumentComponent o = (ConformanceDocumentComponent) other; return compareValues(mode, o.mode, true) && compareValues(documentation, o.documentation, true); } public boolean isEmpty() { return super.isEmpty() && (mode == null || mode.isEmpty()) && (documentation == null || documentation.isEmpty()) && (profile == null || profile.isEmpty()); } public String fhirType() { return "Conformance.document"; } } /** * An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published. */ @Child(name = "url", type = {UriType.class}, order=0, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Logical uri to reference this statement", formalDefinition="An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published." ) protected UriType url; /** * The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp. */ @Child(name = "version", type = {StringType.class}, order=1, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Logical id for this version of the statement", formalDefinition="The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp." ) protected StringType version; /** * A free text natural language name identifying the conformance statement. */ @Child(name = "name", type = {StringType.class}, order=2, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Informal name for this conformance statement", formalDefinition="A free text natural language name identifying the conformance statement." ) protected StringType name; /** * The status of this conformance statement. */ @Child(name = "status", type = {CodeType.class}, order=3, min=1, max=1, modifier=true, summary=true) @Description(shortDefinition="draft | active | retired", formalDefinition="The status of this conformance statement." ) protected Enumeration<ConformanceResourceStatus> status; /** * A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage. */ @Child(name = "experimental", type = {BooleanType.class}, order=4, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="If for testing purposes, not real usage", formalDefinition="A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage." ) protected BooleanType experimental; /** * The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes. */ @Child(name = "date", type = {DateTimeType.class}, order=5, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="Publication Date(/time)", formalDefinition="The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes." ) protected DateTimeType date; /** * The name of the individual or organization that published the conformance. */ @Child(name = "publisher", type = {StringType.class}, order=6, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Name of the publisher (Organization or individual)", formalDefinition="The name of the individual or organization that published the conformance." ) protected StringType publisher; /** * Contacts to assist a user in finding and communicating with the publisher. */ @Child(name = "contact", type = {}, order=7, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="Contact details of the publisher", formalDefinition="Contacts to assist a user in finding and communicating with the publisher." ) protected List<ConformanceContactComponent> contact; /** * A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP. */ @Child(name = "description", type = {StringType.class}, order=8, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Human description of the conformance statement", formalDefinition="A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP." ) protected StringType description; /** * The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching of conformance statements. */ @Child(name = "useContext", type = {CodeableConcept.class}, order=9, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="Content intends to support these contexts", formalDefinition="The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching of conformance statements." ) protected List<CodeableConcept> useContext; /** * Explains why this conformance statement is needed and why it's been constrained as it has. */ @Child(name = "requirements", type = {StringType.class}, order=10, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Why this resource has been created", formalDefinition="Explains why this conformance statement is needed and why it's been constrained as it has." ) protected StringType requirements; /** * A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement. */ @Child(name = "copyright", type = {StringType.class}, order=11, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Use and/or publishing restrictions", formalDefinition="A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement." ) protected StringType copyright; /** * The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase). */ @Child(name = "kind", type = {CodeType.class}, order=12, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="instance | capability | requirements", formalDefinition="The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase)." ) protected Enumeration<ConformanceStatementKind> kind; /** * Software that is covered by this conformance statement. It is used when the conformance statement describes the capabilities of a particular software version, independent of an installation. */ @Child(name = "software", type = {}, order=13, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="Software that is covered by this conformance statement", formalDefinition="Software that is covered by this conformance statement. It is used when the conformance statement describes the capabilities of a particular software version, independent of an installation." ) protected ConformanceSoftwareComponent software; /** * Identifies a specific implementation instance that is described by the conformance statement - i.e. a particular installation, rather than the capabilities of a software program. */ @Child(name = "implementation", type = {}, order=14, min=0, max=1, modifier=false, summary=true) @Description(shortDefinition="If this describes a specific instance", formalDefinition="Identifies a specific implementation instance that is described by the conformance statement - i.e. a particular installation, rather than the capabilities of a software program." ) protected ConformanceImplementationComponent implementation; /** * The version of the FHIR specification on which this conformance statement is based. */ @Child(name = "fhirVersion", type = {IdType.class}, order=15, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="FHIR Version the system uses", formalDefinition="The version of the FHIR specification on which this conformance statement is based." ) protected IdType fhirVersion; /** * A code that indicates whether the application accepts unknown elements or extensions when reading resources. */ @Child(name = "acceptUnknown", type = {CodeType.class}, order=16, min=1, max=1, modifier=false, summary=true) @Description(shortDefinition="no | extensions | elements | both", formalDefinition="A code that indicates whether the application accepts unknown elements or extensions when reading resources." ) protected Enumeration<UnknownContentCode> acceptUnknown; /** * A list of the formats supported by this implementation using their content types. */ @Child(name = "format", type = {CodeType.class}, order=17, min=1, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="formats supported (xml | json | mime type)", formalDefinition="A list of the formats supported by this implementation using their content types." ) protected List<CodeType> format; /** * A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}. */ @Child(name = "profile", type = {StructureDefinition.class}, order=18, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Profiles for use cases supported", formalDefinition="A list of profiles that represent different use cases supported by the system. For a server, \"supported by the system\" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}." ) protected List<Reference> profile; /** * The actual objects that are the target of the reference (A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ protected List<StructureDefinition> profileTarget; /** * A definition of the restful capabilities of the solution, if any. */ @Child(name = "rest", type = {}, order=19, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=true) @Description(shortDefinition="If the endpoint is a RESTful one", formalDefinition="A definition of the restful capabilities of the solution, if any." ) protected List<ConformanceRestComponent> rest; /** * A description of the messaging capabilities of the solution. */ @Child(name = "messaging", type = {}, order=20, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="If messaging is supported", formalDefinition="A description of the messaging capabilities of the solution." ) protected List<ConformanceMessagingComponent> messaging; /** * A document definition. */ @Child(name = "document", type = {}, order=21, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Document definition", formalDefinition="A document definition." ) protected List<ConformanceDocumentComponent> document; private static final long serialVersionUID = 64276427L; /** * Constructor */ public Conformance() { super(); } /** * Constructor */ public Conformance(Enumeration<ConformanceResourceStatus> status, DateTimeType date, Enumeration<ConformanceStatementKind> kind, IdType fhirVersion, Enumeration<UnknownContentCode> acceptUnknown) { super(); this.status = status; this.date = date; this.kind = kind; this.fhirVersion = fhirVersion; this.acceptUnknown = acceptUnknown; } /** * @return {@link #url} (An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public UriType getUrlElement() { if (this.url == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.url"); else if (Configuration.doAutoCreate()) this.url = new UriType(); // bb return this.url; } public boolean hasUrlElement() { return this.url != null && !this.url.isEmpty(); } public boolean hasUrl() { return this.url != null && !this.url.isEmpty(); } /** * @param value {@link #url} (An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public Conformance setUrlElement(UriType value) { this.url = value; return this; } /** * @return An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published. */ public String getUrl() { return this.url == null ? null : this.url.getValue(); } /** * @param value An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published. */ public Conformance setUrl(String value) { if (Utilities.noString(value)) this.url = null; else { if (this.url == null) this.url = new UriType(); this.url.setValue(value); } return this; } /** * @return {@link #version} (The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public StringType getVersionElement() { if (this.version == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.version"); else if (Configuration.doAutoCreate()) this.version = new StringType(); // bb return this.version; } public boolean hasVersionElement() { return this.version != null && !this.version.isEmpty(); } public boolean hasVersion() { return this.version != null && !this.version.isEmpty(); } /** * @param value {@link #version} (The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public Conformance setVersionElement(StringType value) { this.version = value; return this; } /** * @return The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp. */ public String getVersion() { return this.version == null ? null : this.version.getValue(); } /** * @param value The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp. */ public Conformance setVersion(String value) { if (Utilities.noString(value)) this.version = null; else { if (this.version == null) this.version = new StringType(); this.version.setValue(value); } return this; } /** * @return {@link #name} (A free text natural language name identifying the conformance statement.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public StringType getNameElement() { if (this.name == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.name"); else if (Configuration.doAutoCreate()) this.name = new StringType(); // bb return this.name; } public boolean hasNameElement() { return this.name != null && !this.name.isEmpty(); } public boolean hasName() { return this.name != null && !this.name.isEmpty(); } /** * @param value {@link #name} (A free text natural language name identifying the conformance statement.). This is the underlying object with id, value and extensions. The accessor "getName" gives direct access to the value */ public Conformance setNameElement(StringType value) { this.name = value; return this; } /** * @return A free text natural language name identifying the conformance statement. */ public String getName() { return this.name == null ? null : this.name.getValue(); } /** * @param value A free text natural language name identifying the conformance statement. */ public Conformance setName(String value) { if (Utilities.noString(value)) this.name = null; else { if (this.name == null) this.name = new StringType(); this.name.setValue(value); } return this; } /** * @return {@link #status} (The status of this conformance statement.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public Enumeration<ConformanceResourceStatus> getStatusElement() { if (this.status == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.status"); else if (Configuration.doAutoCreate()) this.status = new Enumeration<ConformanceResourceStatus>(new ConformanceResourceStatusEnumFactory()); // bb return this.status; } public boolean hasStatusElement() { return this.status != null && !this.status.isEmpty(); } public boolean hasStatus() { return this.status != null && !this.status.isEmpty(); } /** * @param value {@link #status} (The status of this conformance statement.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public Conformance setStatusElement(Enumeration<ConformanceResourceStatus> value) { this.status = value; return this; } /** * @return The status of this conformance statement. */ public ConformanceResourceStatus getStatus() { return this.status == null ? null : this.status.getValue(); } /** * @param value The status of this conformance statement. */ public Conformance setStatus(ConformanceResourceStatus value) { if (this.status == null) this.status = new Enumeration<ConformanceResourceStatus>(new ConformanceResourceStatusEnumFactory()); this.status.setValue(value); return this; } /** * @return {@link #experimental} (A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage.). This is the underlying object with id, value and extensions. The accessor "getExperimental" gives direct access to the value */ public BooleanType getExperimentalElement() { if (this.experimental == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.experimental"); else if (Configuration.doAutoCreate()) this.experimental = new BooleanType(); // bb return this.experimental; } public boolean hasExperimentalElement() { return this.experimental != null && !this.experimental.isEmpty(); } public boolean hasExperimental() { return this.experimental != null && !this.experimental.isEmpty(); } /** * @param value {@link #experimental} (A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage.). This is the underlying object with id, value and extensions. The accessor "getExperimental" gives direct access to the value */ public Conformance setExperimentalElement(BooleanType value) { this.experimental = value; return this; } /** * @return A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage. */ public boolean getExperimental() { return this.experimental == null || this.experimental.isEmpty() ? false : this.experimental.getValue(); } /** * @param value A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage. */ public Conformance setExperimental(boolean value) { if (this.experimental == null) this.experimental = new BooleanType(); this.experimental.setValue(value); return this; } /** * @return {@link #date} (The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes.). This is the underlying object with id, value and extensions. The accessor "getDate" gives direct access to the value */ public DateTimeType getDateElement() { if (this.date == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.date"); else if (Configuration.doAutoCreate()) this.date = new DateTimeType(); // bb return this.date; } public boolean hasDateElement() { return this.date != null && !this.date.isEmpty(); } public boolean hasDate() { return this.date != null && !this.date.isEmpty(); } /** * @param value {@link #date} (The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes.). This is the underlying object with id, value and extensions. The accessor "getDate" gives direct access to the value */ public Conformance setDateElement(DateTimeType value) { this.date = value; return this; } /** * @return The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes. */ public Date getDate() { return this.date == null ? null : this.date.getValue(); } /** * @param value The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes. */ public Conformance setDate(Date value) { if (this.date == null) this.date = new DateTimeType(); this.date.setValue(value); return this; } /** * @return {@link #publisher} (The name of the individual or organization that published the conformance.). This is the underlying object with id, value and extensions. The accessor "getPublisher" gives direct access to the value */ public StringType getPublisherElement() { if (this.publisher == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.publisher"); else if (Configuration.doAutoCreate()) this.publisher = new StringType(); // bb return this.publisher; } public boolean hasPublisherElement() { return this.publisher != null && !this.publisher.isEmpty(); } public boolean hasPublisher() { return this.publisher != null && !this.publisher.isEmpty(); } /** * @param value {@link #publisher} (The name of the individual or organization that published the conformance.). This is the underlying object with id, value and extensions. The accessor "getPublisher" gives direct access to the value */ public Conformance setPublisherElement(StringType value) { this.publisher = value; return this; } /** * @return The name of the individual or organization that published the conformance. */ public String getPublisher() { return this.publisher == null ? null : this.publisher.getValue(); } /** * @param value The name of the individual or organization that published the conformance. */ public Conformance setPublisher(String value) { if (Utilities.noString(value)) this.publisher = null; else { if (this.publisher == null) this.publisher = new StringType(); this.publisher.setValue(value); } return this; } /** * @return {@link #contact} (Contacts to assist a user in finding and communicating with the publisher.) */ public List<ConformanceContactComponent> getContact() { if (this.contact == null) this.contact = new ArrayList<ConformanceContactComponent>(); return this.contact; } public boolean hasContact() { if (this.contact == null) return false; for (ConformanceContactComponent item : this.contact) if (!item.isEmpty()) return true; return false; } /** * @return {@link #contact} (Contacts to assist a user in finding and communicating with the publisher.) */ // syntactic sugar public ConformanceContactComponent addContact() { //3 ConformanceContactComponent t = new ConformanceContactComponent(); if (this.contact == null) this.contact = new ArrayList<ConformanceContactComponent>(); this.contact.add(t); return t; } // syntactic sugar public Conformance addContact(ConformanceContactComponent t) { //3 if (t == null) return this; if (this.contact == null) this.contact = new ArrayList<ConformanceContactComponent>(); this.contact.add(t); return this; } /** * @return {@link #description} (A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public StringType getDescriptionElement() { if (this.description == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.description"); else if (Configuration.doAutoCreate()) this.description = new StringType(); // bb return this.description; } public boolean hasDescriptionElement() { return this.description != null && !this.description.isEmpty(); } public boolean hasDescription() { return this.description != null && !this.description.isEmpty(); } /** * @param value {@link #description} (A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP.). This is the underlying object with id, value and extensions. The accessor "getDescription" gives direct access to the value */ public Conformance setDescriptionElement(StringType value) { this.description = value; return this; } /** * @return A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP. */ public String getDescription() { return this.description == null ? null : this.description.getValue(); } /** * @param value A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP. */ public Conformance setDescription(String value) { if (Utilities.noString(value)) this.description = null; else { if (this.description == null) this.description = new StringType(); this.description.setValue(value); } return this; } /** * @return {@link #useContext} (The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching of conformance statements.) */ public List<CodeableConcept> getUseContext() { if (this.useContext == null) this.useContext = new ArrayList<CodeableConcept>(); return this.useContext; } public boolean hasUseContext() { if (this.useContext == null) return false; for (CodeableConcept item : this.useContext) if (!item.isEmpty()) return true; return false; } /** * @return {@link #useContext} (The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching of conformance statements.) */ // syntactic sugar public CodeableConcept addUseContext() { //3 CodeableConcept t = new CodeableConcept(); if (this.useContext == null) this.useContext = new ArrayList<CodeableConcept>(); this.useContext.add(t); return t; } // syntactic sugar public Conformance addUseContext(CodeableConcept t) { //3 if (t == null) return this; if (this.useContext == null) this.useContext = new ArrayList<CodeableConcept>(); this.useContext.add(t); return this; } /** * @return {@link #requirements} (Explains why this conformance statement is needed and why it's been constrained as it has.). This is the underlying object with id, value and extensions. The accessor "getRequirements" gives direct access to the value */ public StringType getRequirementsElement() { if (this.requirements == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.requirements"); else if (Configuration.doAutoCreate()) this.requirements = new StringType(); // bb return this.requirements; } public boolean hasRequirementsElement() { return this.requirements != null && !this.requirements.isEmpty(); } public boolean hasRequirements() { return this.requirements != null && !this.requirements.isEmpty(); } /** * @param value {@link #requirements} (Explains why this conformance statement is needed and why it's been constrained as it has.). This is the underlying object with id, value and extensions. The accessor "getRequirements" gives direct access to the value */ public Conformance setRequirementsElement(StringType value) { this.requirements = value; return this; } /** * @return Explains why this conformance statement is needed and why it's been constrained as it has. */ public String getRequirements() { return this.requirements == null ? null : this.requirements.getValue(); } /** * @param value Explains why this conformance statement is needed and why it's been constrained as it has. */ public Conformance setRequirements(String value) { if (Utilities.noString(value)) this.requirements = null; else { if (this.requirements == null) this.requirements = new StringType(); this.requirements.setValue(value); } return this; } /** * @return {@link #copyright} (A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement.). This is the underlying object with id, value and extensions. The accessor "getCopyright" gives direct access to the value */ public StringType getCopyrightElement() { if (this.copyright == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.copyright"); else if (Configuration.doAutoCreate()) this.copyright = new StringType(); // bb return this.copyright; } public boolean hasCopyrightElement() { return this.copyright != null && !this.copyright.isEmpty(); } public boolean hasCopyright() { return this.copyright != null && !this.copyright.isEmpty(); } /** * @param value {@link #copyright} (A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement.). This is the underlying object with id, value and extensions. The accessor "getCopyright" gives direct access to the value */ public Conformance setCopyrightElement(StringType value) { this.copyright = value; return this; } /** * @return A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement. */ public String getCopyright() { return this.copyright == null ? null : this.copyright.getValue(); } /** * @param value A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement. */ public Conformance setCopyright(String value) { if (Utilities.noString(value)) this.copyright = null; else { if (this.copyright == null) this.copyright = new StringType(); this.copyright.setValue(value); } return this; } /** * @return {@link #kind} (The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase).). This is the underlying object with id, value and extensions. The accessor "getKind" gives direct access to the value */ public Enumeration<ConformanceStatementKind> getKindElement() { if (this.kind == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.kind"); else if (Configuration.doAutoCreate()) this.kind = new Enumeration<ConformanceStatementKind>(new ConformanceStatementKindEnumFactory()); // bb return this.kind; } public boolean hasKindElement() { return this.kind != null && !this.kind.isEmpty(); } public boolean hasKind() { return this.kind != null && !this.kind.isEmpty(); } /** * @param value {@link #kind} (The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase).). This is the underlying object with id, value and extensions. The accessor "getKind" gives direct access to the value */ public Conformance setKindElement(Enumeration<ConformanceStatementKind> value) { this.kind = value; return this; } /** * @return The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase). */ public ConformanceStatementKind getKind() { return this.kind == null ? null : this.kind.getValue(); } /** * @param value The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase). */ public Conformance setKind(ConformanceStatementKind value) { if (this.kind == null) this.kind = new Enumeration<ConformanceStatementKind>(new ConformanceStatementKindEnumFactory()); this.kind.setValue(value); return this; } /** * @return {@link #software} (Software that is covered by this conformance statement. It is used when the conformance statement describes the capabilities of a particular software version, independent of an installation.) */ public ConformanceSoftwareComponent getSoftware() { if (this.software == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.software"); else if (Configuration.doAutoCreate()) this.software = new ConformanceSoftwareComponent(); // cc return this.software; } public boolean hasSoftware() { return this.software != null && !this.software.isEmpty(); } /** * @param value {@link #software} (Software that is covered by this conformance statement. It is used when the conformance statement describes the capabilities of a particular software version, independent of an installation.) */ public Conformance setSoftware(ConformanceSoftwareComponent value) { this.software = value; return this; } /** * @return {@link #implementation} (Identifies a specific implementation instance that is described by the conformance statement - i.e. a particular installation, rather than the capabilities of a software program.) */ public ConformanceImplementationComponent getImplementation() { if (this.implementation == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.implementation"); else if (Configuration.doAutoCreate()) this.implementation = new ConformanceImplementationComponent(); // cc return this.implementation; } public boolean hasImplementation() { return this.implementation != null && !this.implementation.isEmpty(); } /** * @param value {@link #implementation} (Identifies a specific implementation instance that is described by the conformance statement - i.e. a particular installation, rather than the capabilities of a software program.) */ public Conformance setImplementation(ConformanceImplementationComponent value) { this.implementation = value; return this; } /** * @return {@link #fhirVersion} (The version of the FHIR specification on which this conformance statement is based.). This is the underlying object with id, value and extensions. The accessor "getFhirVersion" gives direct access to the value */ public IdType getFhirVersionElement() { if (this.fhirVersion == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.fhirVersion"); else if (Configuration.doAutoCreate()) this.fhirVersion = new IdType(); // bb return this.fhirVersion; } public boolean hasFhirVersionElement() { return this.fhirVersion != null && !this.fhirVersion.isEmpty(); } public boolean hasFhirVersion() { return this.fhirVersion != null && !this.fhirVersion.isEmpty(); } /** * @param value {@link #fhirVersion} (The version of the FHIR specification on which this conformance statement is based.). This is the underlying object with id, value and extensions. The accessor "getFhirVersion" gives direct access to the value */ public Conformance setFhirVersionElement(IdType value) { this.fhirVersion = value; return this; } /** * @return The version of the FHIR specification on which this conformance statement is based. */ public String getFhirVersion() { return this.fhirVersion == null ? null : this.fhirVersion.getValue(); } /** * @param value The version of the FHIR specification on which this conformance statement is based. */ public Conformance setFhirVersion(String value) { if (this.fhirVersion == null) this.fhirVersion = new IdType(); this.fhirVersion.setValue(value); return this; } /** * @return {@link #acceptUnknown} (A code that indicates whether the application accepts unknown elements or extensions when reading resources.). This is the underlying object with id, value and extensions. The accessor "getAcceptUnknown" gives direct access to the value */ public Enumeration<UnknownContentCode> getAcceptUnknownElement() { if (this.acceptUnknown == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Conformance.acceptUnknown"); else if (Configuration.doAutoCreate()) this.acceptUnknown = new Enumeration<UnknownContentCode>(new UnknownContentCodeEnumFactory()); // bb return this.acceptUnknown; } public boolean hasAcceptUnknownElement() { return this.acceptUnknown != null && !this.acceptUnknown.isEmpty(); } public boolean hasAcceptUnknown() { return this.acceptUnknown != null && !this.acceptUnknown.isEmpty(); } /** * @param value {@link #acceptUnknown} (A code that indicates whether the application accepts unknown elements or extensions when reading resources.). This is the underlying object with id, value and extensions. The accessor "getAcceptUnknown" gives direct access to the value */ public Conformance setAcceptUnknownElement(Enumeration<UnknownContentCode> value) { this.acceptUnknown = value; return this; } /** * @return A code that indicates whether the application accepts unknown elements or extensions when reading resources. */ public UnknownContentCode getAcceptUnknown() { return this.acceptUnknown == null ? null : this.acceptUnknown.getValue(); } /** * @param value A code that indicates whether the application accepts unknown elements or extensions when reading resources. */ public Conformance setAcceptUnknown(UnknownContentCode value) { if (this.acceptUnknown == null) this.acceptUnknown = new Enumeration<UnknownContentCode>(new UnknownContentCodeEnumFactory()); this.acceptUnknown.setValue(value); return this; } /** * @return {@link #format} (A list of the formats supported by this implementation using their content types.) */ public List<CodeType> getFormat() { if (this.format == null) this.format = new ArrayList<CodeType>(); return this.format; } public boolean hasFormat() { if (this.format == null) return false; for (CodeType item : this.format) if (!item.isEmpty()) return true; return false; } /** * @return {@link #format} (A list of the formats supported by this implementation using their content types.) */ // syntactic sugar public CodeType addFormatElement() {//2 CodeType t = new CodeType(); if (this.format == null) this.format = new ArrayList<CodeType>(); this.format.add(t); return t; } /** * @param value {@link #format} (A list of the formats supported by this implementation using their content types.) */ public Conformance addFormat(String value) { //1 CodeType t = new CodeType(); t.setValue(value); if (this.format == null) this.format = new ArrayList<CodeType>(); this.format.add(t); return this; } /** * @param value {@link #format} (A list of the formats supported by this implementation using their content types.) */ public boolean hasFormat(String value) { if (this.format == null) return false; for (CodeType v : this.format) if (v.equals(value)) // code return true; return false; } /** * @return {@link #profile} (A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public List<Reference> getProfile() { if (this.profile == null) this.profile = new ArrayList<Reference>(); return this.profile; } public boolean hasProfile() { if (this.profile == null) return false; for (Reference item : this.profile) if (!item.isEmpty()) return true; return false; } /** * @return {@link #profile} (A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ // syntactic sugar public Reference addProfile() { //3 Reference t = new Reference(); if (this.profile == null) this.profile = new ArrayList<Reference>(); this.profile.add(t); return t; } // syntactic sugar public Conformance addProfile(Reference t) { //3 if (t == null) return this; if (this.profile == null) this.profile = new ArrayList<Reference>(); this.profile.add(t); return this; } /** * @return {@link #profile} (The actual objects that are the target of the reference. The reference library doesn't populate this, but you can use this to hold the resources if you resolvethemt. A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public List<StructureDefinition> getProfileTarget() { if (this.profileTarget == null) this.profileTarget = new ArrayList<StructureDefinition>(); return this.profileTarget; } // syntactic sugar /** * @return {@link #profile} (Add an actual object that is the target of the reference. The reference library doesn't use these, but you can use this to hold the resources if you resolvethemt. A list of profiles that represent different use cases supported by the system. For a server, "supported by the system" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.) */ public StructureDefinition addProfileTarget() { StructureDefinition r = new StructureDefinition(); if (this.profileTarget == null) this.profileTarget = new ArrayList<StructureDefinition>(); this.profileTarget.add(r); return r; } /** * @return {@link #rest} (A definition of the restful capabilities of the solution, if any.) */ public List<ConformanceRestComponent> getRest() { if (this.rest == null) this.rest = new ArrayList<ConformanceRestComponent>(); return this.rest; } public boolean hasRest() { if (this.rest == null) return false; for (ConformanceRestComponent item : this.rest) if (!item.isEmpty()) return true; return false; } /** * @return {@link #rest} (A definition of the restful capabilities of the solution, if any.) */ // syntactic sugar public ConformanceRestComponent addRest() { //3 ConformanceRestComponent t = new ConformanceRestComponent(); if (this.rest == null) this.rest = new ArrayList<ConformanceRestComponent>(); this.rest.add(t); return t; } // syntactic sugar public Conformance addRest(ConformanceRestComponent t) { //3 if (t == null) return this; if (this.rest == null) this.rest = new ArrayList<ConformanceRestComponent>(); this.rest.add(t); return this; } /** * @return {@link #messaging} (A description of the messaging capabilities of the solution.) */ public List<ConformanceMessagingComponent> getMessaging() { if (this.messaging == null) this.messaging = new ArrayList<ConformanceMessagingComponent>(); return this.messaging; } public boolean hasMessaging() { if (this.messaging == null) return false; for (ConformanceMessagingComponent item : this.messaging) if (!item.isEmpty()) return true; return false; } /** * @return {@link #messaging} (A description of the messaging capabilities of the solution.) */ // syntactic sugar public ConformanceMessagingComponent addMessaging() { //3 ConformanceMessagingComponent t = new ConformanceMessagingComponent(); if (this.messaging == null) this.messaging = new ArrayList<ConformanceMessagingComponent>(); this.messaging.add(t); return t; } // syntactic sugar public Conformance addMessaging(ConformanceMessagingComponent t) { //3 if (t == null) return this; if (this.messaging == null) this.messaging = new ArrayList<ConformanceMessagingComponent>(); this.messaging.add(t); return this; } /** * @return {@link #document} (A document definition.) */ public List<ConformanceDocumentComponent> getDocument() { if (this.document == null) this.document = new ArrayList<ConformanceDocumentComponent>(); return this.document; } public boolean hasDocument() { if (this.document == null) return false; for (ConformanceDocumentComponent item : this.document) if (!item.isEmpty()) return true; return false; } /** * @return {@link #document} (A document definition.) */ // syntactic sugar public ConformanceDocumentComponent addDocument() { //3 ConformanceDocumentComponent t = new ConformanceDocumentComponent(); if (this.document == null) this.document = new ArrayList<ConformanceDocumentComponent>(); this.document.add(t); return t; } // syntactic sugar public Conformance addDocument(ConformanceDocumentComponent t) { //3 if (t == null) return this; if (this.document == null) this.document = new ArrayList<ConformanceDocumentComponent>(); this.document.add(t); return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("url", "uri", "An absolute URL that is used to identify this conformance statement when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this conformance statement is (or will be) published.", 0, java.lang.Integer.MAX_VALUE, url)); childrenList.add(new Property("version", "string", "The identifier that is used to identify this version of the conformance statement when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the profile author manually and the value should be a timestamp.", 0, java.lang.Integer.MAX_VALUE, version)); childrenList.add(new Property("name", "string", "A free text natural language name identifying the conformance statement.", 0, java.lang.Integer.MAX_VALUE, name)); childrenList.add(new Property("status", "code", "The status of this conformance statement.", 0, java.lang.Integer.MAX_VALUE, status)); childrenList.add(new Property("experimental", "boolean", "A flag to indicate that this conformance statement is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage.", 0, java.lang.Integer.MAX_VALUE, experimental)); childrenList.add(new Property("date", "dateTime", "The date (and optionally time) when the conformance statement was published. The date must change when the business version changes, if it does, and it must change if the status code changes. In addition, it should change when the substantive content of the conformance statement changes.", 0, java.lang.Integer.MAX_VALUE, date)); childrenList.add(new Property("publisher", "string", "The name of the individual or organization that published the conformance.", 0, java.lang.Integer.MAX_VALUE, publisher)); childrenList.add(new Property("contact", "", "Contacts to assist a user in finding and communicating with the publisher.", 0, java.lang.Integer.MAX_VALUE, contact)); childrenList.add(new Property("description", "string", "A free text natural language description of the conformance statement and its use. Typically, this is used when the conformance statement describes a desired rather than an actual solution, for example as a formal expression of requirements as part of an RFP.", 0, java.lang.Integer.MAX_VALUE, description)); childrenList.add(new Property("useContext", "CodeableConcept", "The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching of conformance statements.", 0, java.lang.Integer.MAX_VALUE, useContext)); childrenList.add(new Property("requirements", "string", "Explains why this conformance statement is needed and why it's been constrained as it has.", 0, java.lang.Integer.MAX_VALUE, requirements)); childrenList.add(new Property("copyright", "string", "A copyright statement relating to the conformance statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the details of the system described by the conformance statement.", 0, java.lang.Integer.MAX_VALUE, copyright)); childrenList.add(new Property("kind", "code", "The way that this statement is intended to be used, to describe an actual running instance of software, a particular product (kind not instance of software) or a class of implementation (e.g. a desired purchase).", 0, java.lang.Integer.MAX_VALUE, kind)); childrenList.add(new Property("software", "", "Software that is covered by this conformance statement. It is used when the conformance statement describes the capabilities of a particular software version, independent of an installation.", 0, java.lang.Integer.MAX_VALUE, software)); childrenList.add(new Property("implementation", "", "Identifies a specific implementation instance that is described by the conformance statement - i.e. a particular installation, rather than the capabilities of a software program.", 0, java.lang.Integer.MAX_VALUE, implementation)); childrenList.add(new Property("fhirVersion", "id", "The version of the FHIR specification on which this conformance statement is based.", 0, java.lang.Integer.MAX_VALUE, fhirVersion)); childrenList.add(new Property("acceptUnknown", "code", "A code that indicates whether the application accepts unknown elements or extensions when reading resources.", 0, java.lang.Integer.MAX_VALUE, acceptUnknown)); childrenList.add(new Property("format", "code", "A list of the formats supported by this implementation using their content types.", 0, java.lang.Integer.MAX_VALUE, format)); childrenList.add(new Property("profile", "Reference(StructureDefinition)", "A list of profiles that represent different use cases supported by the system. For a server, \"supported by the system\" means the system hosts/produces a set of resources that are conformant to a particular profile, and allows clients that use its services to search using this profile and to find appropriate data. For a client, it means the system will search by this profile and process data according to the guidance implicit in the profile. See further discussion in [Using Profiles]{profiling.html#profile-uses}.", 0, java.lang.Integer.MAX_VALUE, profile)); childrenList.add(new Property("rest", "", "A definition of the restful capabilities of the solution, if any.", 0, java.lang.Integer.MAX_VALUE, rest)); childrenList.add(new Property("messaging", "", "A description of the messaging capabilities of the solution.", 0, java.lang.Integer.MAX_VALUE, messaging)); childrenList.add(new Property("document", "", "A document definition.", 0, java.lang.Integer.MAX_VALUE, document)); } @Override public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException { switch (hash) { case 116079: /*url*/ return this.url == null ? new Base[0] : new Base[] {this.url}; // UriType case 351608024: /*version*/ return this.version == null ? new Base[0] : new Base[] {this.version}; // StringType case 3373707: /*name*/ return this.name == null ? new Base[0] : new Base[] {this.name}; // StringType case -892481550: /*status*/ return this.status == null ? new Base[0] : new Base[] {this.status}; // Enumeration<ConformanceResourceStatus> case -404562712: /*experimental*/ return this.experimental == null ? new Base[0] : new Base[] {this.experimental}; // BooleanType case 3076014: /*date*/ return this.date == null ? new Base[0] : new Base[] {this.date}; // DateTimeType case 1447404028: /*publisher*/ return this.publisher == null ? new Base[0] : new Base[] {this.publisher}; // StringType case 951526432: /*contact*/ return this.contact == null ? new Base[0] : this.contact.toArray(new Base[this.contact.size()]); // ConformanceContactComponent case -1724546052: /*description*/ return this.description == null ? new Base[0] : new Base[] {this.description}; // StringType case -669707736: /*useContext*/ return this.useContext == null ? new Base[0] : this.useContext.toArray(new Base[this.useContext.size()]); // CodeableConcept case -1619874672: /*requirements*/ return this.requirements == null ? new Base[0] : new Base[] {this.requirements}; // StringType case 1522889671: /*copyright*/ return this.copyright == null ? new Base[0] : new Base[] {this.copyright}; // StringType case 3292052: /*kind*/ return this.kind == null ? new Base[0] : new Base[] {this.kind}; // Enumeration<ConformanceStatementKind> case 1319330215: /*software*/ return this.software == null ? new Base[0] : new Base[] {this.software}; // ConformanceSoftwareComponent case 1683336114: /*implementation*/ return this.implementation == null ? new Base[0] : new Base[] {this.implementation}; // ConformanceImplementationComponent case 461006061: /*fhirVersion*/ return this.fhirVersion == null ? new Base[0] : new Base[] {this.fhirVersion}; // IdType case -1862642142: /*acceptUnknown*/ return this.acceptUnknown == null ? new Base[0] : new Base[] {this.acceptUnknown}; // Enumeration<UnknownContentCode> case -1268779017: /*format*/ return this.format == null ? new Base[0] : this.format.toArray(new Base[this.format.size()]); // CodeType case -309425751: /*profile*/ return this.profile == null ? new Base[0] : this.profile.toArray(new Base[this.profile.size()]); // Reference case 3496916: /*rest*/ return this.rest == null ? new Base[0] : this.rest.toArray(new Base[this.rest.size()]); // ConformanceRestComponent case -1440008444: /*messaging*/ return this.messaging == null ? new Base[0] : this.messaging.toArray(new Base[this.messaging.size()]); // ConformanceMessagingComponent case 861720859: /*document*/ return this.document == null ? new Base[0] : this.document.toArray(new Base[this.document.size()]); // ConformanceDocumentComponent default: return super.getProperty(hash, name, checkValid); } } @Override public void setProperty(int hash, String name, Base value) throws FHIRException { switch (hash) { case 116079: // url this.url = castToUri(value); // UriType break; case 351608024: // version this.version = castToString(value); // StringType break; case 3373707: // name this.name = castToString(value); // StringType break; case -892481550: // status this.status = new ConformanceResourceStatusEnumFactory().fromType(value); // Enumeration<ConformanceResourceStatus> break; case -404562712: // experimental this.experimental = castToBoolean(value); // BooleanType break; case 3076014: // date this.date = castToDateTime(value); // DateTimeType break; case 1447404028: // publisher this.publisher = castToString(value); // StringType break; case 951526432: // contact this.getContact().add((ConformanceContactComponent) value); // ConformanceContactComponent break; case -1724546052: // description this.description = castToString(value); // StringType break; case -669707736: // useContext this.getUseContext().add(castToCodeableConcept(value)); // CodeableConcept break; case -1619874672: // requirements this.requirements = castToString(value); // StringType break; case 1522889671: // copyright this.copyright = castToString(value); // StringType break; case 3292052: // kind this.kind = new ConformanceStatementKindEnumFactory().fromType(value); // Enumeration<ConformanceStatementKind> break; case 1319330215: // software this.software = (ConformanceSoftwareComponent) value; // ConformanceSoftwareComponent break; case 1683336114: // implementation this.implementation = (ConformanceImplementationComponent) value; // ConformanceImplementationComponent break; case 461006061: // fhirVersion this.fhirVersion = castToId(value); // IdType break; case -1862642142: // acceptUnknown this.acceptUnknown = new UnknownContentCodeEnumFactory().fromType(value); // Enumeration<UnknownContentCode> break; case -1268779017: // format this.getFormat().add(castToCode(value)); // CodeType break; case -309425751: // profile this.getProfile().add(castToReference(value)); // Reference break; case 3496916: // rest this.getRest().add((ConformanceRestComponent) value); // ConformanceRestComponent break; case -1440008444: // messaging this.getMessaging().add((ConformanceMessagingComponent) value); // ConformanceMessagingComponent break; case 861720859: // document this.getDocument().add((ConformanceDocumentComponent) value); // ConformanceDocumentComponent break; default: super.setProperty(hash, name, value); } } @Override public void setProperty(String name, Base value) throws FHIRException { if (name.equals("url")) this.url = castToUri(value); // UriType else if (name.equals("version")) this.version = castToString(value); // StringType else if (name.equals("name")) this.name = castToString(value); // StringType else if (name.equals("status")) this.status = new ConformanceResourceStatusEnumFactory().fromType(value); // Enumeration<ConformanceResourceStatus> else if (name.equals("experimental")) this.experimental = castToBoolean(value); // BooleanType else if (name.equals("date")) this.date = castToDateTime(value); // DateTimeType else if (name.equals("publisher")) this.publisher = castToString(value); // StringType else if (name.equals("contact")) this.getContact().add((ConformanceContactComponent) value); else if (name.equals("description")) this.description = castToString(value); // StringType else if (name.equals("useContext")) this.getUseContext().add(castToCodeableConcept(value)); else if (name.equals("requirements")) this.requirements = castToString(value); // StringType else if (name.equals("copyright")) this.copyright = castToString(value); // StringType else if (name.equals("kind")) this.kind = new ConformanceStatementKindEnumFactory().fromType(value); // Enumeration<ConformanceStatementKind> else if (name.equals("software")) this.software = (ConformanceSoftwareComponent) value; // ConformanceSoftwareComponent else if (name.equals("implementation")) this.implementation = (ConformanceImplementationComponent) value; // ConformanceImplementationComponent else if (name.equals("fhirVersion")) this.fhirVersion = castToId(value); // IdType else if (name.equals("acceptUnknown")) this.acceptUnknown = new UnknownContentCodeEnumFactory().fromType(value); // Enumeration<UnknownContentCode> else if (name.equals("format")) this.getFormat().add(castToCode(value)); else if (name.equals("profile")) this.getProfile().add(castToReference(value)); else if (name.equals("rest")) this.getRest().add((ConformanceRestComponent) value); else if (name.equals("messaging")) this.getMessaging().add((ConformanceMessagingComponent) value); else if (name.equals("document")) this.getDocument().add((ConformanceDocumentComponent) value); else super.setProperty(name, value); } @Override public Base makeProperty(int hash, String name) throws FHIRException { switch (hash) { case 116079: throw new FHIRException("Cannot make property url as it is not a complex type"); // UriType case 351608024: throw new FHIRException("Cannot make property version as it is not a complex type"); // StringType case 3373707: throw new FHIRException("Cannot make property name as it is not a complex type"); // StringType case -892481550: throw new FHIRException("Cannot make property status as it is not a complex type"); // Enumeration<ConformanceResourceStatus> case -404562712: throw new FHIRException("Cannot make property experimental as it is not a complex type"); // BooleanType case 3076014: throw new FHIRException("Cannot make property date as it is not a complex type"); // DateTimeType case 1447404028: throw new FHIRException("Cannot make property publisher as it is not a complex type"); // StringType case 951526432: return addContact(); // ConformanceContactComponent case -1724546052: throw new FHIRException("Cannot make property description as it is not a complex type"); // StringType case -669707736: return addUseContext(); // CodeableConcept case -1619874672: throw new FHIRException("Cannot make property requirements as it is not a complex type"); // StringType case 1522889671: throw new FHIRException("Cannot make property copyright as it is not a complex type"); // StringType case 3292052: throw new FHIRException("Cannot make property kind as it is not a complex type"); // Enumeration<ConformanceStatementKind> case 1319330215: return getSoftware(); // ConformanceSoftwareComponent case 1683336114: return getImplementation(); // ConformanceImplementationComponent case 461006061: throw new FHIRException("Cannot make property fhirVersion as it is not a complex type"); // IdType case -1862642142: throw new FHIRException("Cannot make property acceptUnknown as it is not a complex type"); // Enumeration<UnknownContentCode> case -1268779017: throw new FHIRException("Cannot make property format as it is not a complex type"); // CodeType case -309425751: return addProfile(); // Reference case 3496916: return addRest(); // ConformanceRestComponent case -1440008444: return addMessaging(); // ConformanceMessagingComponent case 861720859: return addDocument(); // ConformanceDocumentComponent default: return super.makeProperty(hash, name); } } @Override public Base addChild(String name) throws FHIRException { if (name.equals("url")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.url"); } else if (name.equals("version")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.version"); } else if (name.equals("name")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.name"); } else if (name.equals("status")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.status"); } else if (name.equals("experimental")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.experimental"); } else if (name.equals("date")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.date"); } else if (name.equals("publisher")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.publisher"); } else if (name.equals("contact")) { return addContact(); } else if (name.equals("description")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.description"); } else if (name.equals("useContext")) { return addUseContext(); } else if (name.equals("requirements")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.requirements"); } else if (name.equals("copyright")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.copyright"); } else if (name.equals("kind")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.kind"); } else if (name.equals("software")) { this.software = new ConformanceSoftwareComponent(); return this.software; } else if (name.equals("implementation")) { this.implementation = new ConformanceImplementationComponent(); return this.implementation; } else if (name.equals("fhirVersion")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.fhirVersion"); } else if (name.equals("acceptUnknown")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.acceptUnknown"); } else if (name.equals("format")) { throw new FHIRException("Cannot call addChild on a primitive type Conformance.format"); } else if (name.equals("profile")) { return addProfile(); } else if (name.equals("rest")) { return addRest(); } else if (name.equals("messaging")) { return addMessaging(); } else if (name.equals("document")) { return addDocument(); } else return super.addChild(name); } public String fhirType() { return "Conformance"; } public Conformance copy() { Conformance dst = new Conformance(); copyValues(dst); dst.url = url == null ? null : url.copy(); dst.version = version == null ? null : version.copy(); dst.name = name == null ? null : name.copy(); dst.status = status == null ? null : status.copy(); dst.experimental = experimental == null ? null : experimental.copy(); dst.date = date == null ? null : date.copy(); dst.publisher = publisher == null ? null : publisher.copy(); if (contact != null) { dst.contact = new ArrayList<ConformanceContactComponent>(); for (ConformanceContactComponent i : contact) dst.contact.add(i.copy()); }; dst.description = description == null ? null : description.copy(); if (useContext != null) { dst.useContext = new ArrayList<CodeableConcept>(); for (CodeableConcept i : useContext) dst.useContext.add(i.copy()); }; dst.requirements = requirements == null ? null : requirements.copy(); dst.copyright = copyright == null ? null : copyright.copy(); dst.kind = kind == null ? null : kind.copy(); dst.software = software == null ? null : software.copy(); dst.implementation = implementation == null ? null : implementation.copy(); dst.fhirVersion = fhirVersion == null ? null : fhirVersion.copy(); dst.acceptUnknown = acceptUnknown == null ? null : acceptUnknown.copy(); if (format != null) { dst.format = new ArrayList<CodeType>(); for (CodeType i : format) dst.format.add(i.copy()); }; if (profile != null) { dst.profile = new ArrayList<Reference>(); for (Reference i : profile) dst.profile.add(i.copy()); }; if (rest != null) { dst.rest = new ArrayList<ConformanceRestComponent>(); for (ConformanceRestComponent i : rest) dst.rest.add(i.copy()); }; if (messaging != null) { dst.messaging = new ArrayList<ConformanceMessagingComponent>(); for (ConformanceMessagingComponent i : messaging) dst.messaging.add(i.copy()); }; if (document != null) { dst.document = new ArrayList<ConformanceDocumentComponent>(); for (ConformanceDocumentComponent i : document) dst.document.add(i.copy()); }; return dst; } protected Conformance typedCopy() { return copy(); } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof Conformance)) return false; Conformance o = (Conformance) other; return compareDeep(url, o.url, true) && compareDeep(version, o.version, true) && compareDeep(name, o.name, true) && compareDeep(status, o.status, true) && compareDeep(experimental, o.experimental, true) && compareDeep(date, o.date, true) && compareDeep(publisher, o.publisher, true) && compareDeep(contact, o.contact, true) && compareDeep(description, o.description, true) && compareDeep(useContext, o.useContext, true) && compareDeep(requirements, o.requirements, true) && compareDeep(copyright, o.copyright, true) && compareDeep(kind, o.kind, true) && compareDeep(software, o.software, true) && compareDeep(implementation, o.implementation, true) && compareDeep(fhirVersion, o.fhirVersion, true) && compareDeep(acceptUnknown, o.acceptUnknown, true) && compareDeep(format, o.format, true) && compareDeep(profile, o.profile, true) && compareDeep(rest, o.rest, true) && compareDeep(messaging, o.messaging, true) && compareDeep(document, o.document, true) ; } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof Conformance)) return false; Conformance o = (Conformance) other; return compareValues(url, o.url, true) && compareValues(version, o.version, true) && compareValues(name, o.name, true) && compareValues(status, o.status, true) && compareValues(experimental, o.experimental, true) && compareValues(date, o.date, true) && compareValues(publisher, o.publisher, true) && compareValues(description, o.description, true) && compareValues(requirements, o.requirements, true) && compareValues(copyright, o.copyright, true) && compareValues(kind, o.kind, true) && compareValues(fhirVersion, o.fhirVersion, true) && compareValues(acceptUnknown, o.acceptUnknown, true) && compareValues(format, o.format, true); } public boolean isEmpty() { return super.isEmpty() && (url == null || url.isEmpty()) && (version == null || version.isEmpty()) && (name == null || name.isEmpty()) && (status == null || status.isEmpty()) && (experimental == null || experimental.isEmpty()) && (date == null || date.isEmpty()) && (publisher == null || publisher.isEmpty()) && (contact == null || contact.isEmpty()) && (description == null || description.isEmpty()) && (useContext == null || useContext.isEmpty()) && (requirements == null || requirements.isEmpty()) && (copyright == null || copyright.isEmpty()) && (kind == null || kind.isEmpty()) && (software == null || software.isEmpty()) && (implementation == null || implementation.isEmpty()) && (fhirVersion == null || fhirVersion.isEmpty()) && (acceptUnknown == null || acceptUnknown.isEmpty()) && (format == null || format.isEmpty()) && (profile == null || profile.isEmpty()) && (rest == null || rest.isEmpty()) && (messaging == null || messaging.isEmpty()) && (document == null || document.isEmpty()) ; } @Override public ResourceType getResourceType() { return ResourceType.Conformance; } /** * Search parameter: <b>securityservice</b> * <p> * Description: <b>OAuth | SMART-on-FHIR | NTLM | Basic | Kerberos | Certificates</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.security.service</b><br> * </p> */ @SearchParamDefinition(name="securityservice", path="Conformance.rest.security.service", description="OAuth | SMART-on-FHIR | NTLM | Basic | Kerberos | Certificates", type="token" ) public static final String SP_SECURITYSERVICE = "securityservice"; /** * <b>Fluent Client</b> search parameter constant for <b>securityservice</b> * <p> * Description: <b>OAuth | SMART-on-FHIR | NTLM | Basic | Kerberos | Certificates</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.security.service</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam SECURITYSERVICE = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_SECURITYSERVICE); /** * Search parameter: <b>status</b> * <p> * Description: <b>The current status of the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.status</b><br> * </p> */ @SearchParamDefinition(name="status", path="Conformance.status", description="The current status of the conformance statement", type="token" ) public static final String SP_STATUS = "status"; /** * <b>Fluent Client</b> search parameter constant for <b>status</b> * <p> * Description: <b>The current status of the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.status</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_STATUS); /** * Search parameter: <b>resource</b> * <p> * Description: <b>Name of a resource mentioned in a conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.resource.type</b><br> * </p> */ @SearchParamDefinition(name="resource", path="Conformance.rest.resource.type", description="Name of a resource mentioned in a conformance statement", type="token" ) public static final String SP_RESOURCE = "resource"; /** * <b>Fluent Client</b> search parameter constant for <b>resource</b> * <p> * Description: <b>Name of a resource mentioned in a conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.resource.type</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam RESOURCE = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_RESOURCE); /** * Search parameter: <b>format</b> * <p> * Description: <b>formats supported (xml | json | mime type)</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.format</b><br> * </p> */ @SearchParamDefinition(name="format", path="Conformance.format", description="formats supported (xml | json | mime type)", type="token" ) public static final String SP_FORMAT = "format"; /** * <b>Fluent Client</b> search parameter constant for <b>format</b> * <p> * Description: <b>formats supported (xml | json | mime type)</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.format</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam FORMAT = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_FORMAT); /** * Search parameter: <b>date</b> * <p> * Description: <b>The conformance statement publication date</b><br> * Type: <b>date</b><br> * Path: <b>Conformance.date</b><br> * </p> */ @SearchParamDefinition(name="date", path="Conformance.date", description="The conformance statement publication date", type="date" ) public static final String SP_DATE = "date"; /** * <b>Fluent Client</b> search parameter constant for <b>date</b> * <p> * Description: <b>The conformance statement publication date</b><br> * Type: <b>date</b><br> * Path: <b>Conformance.date</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.DateClientParam DATE = new ca.uhn.fhir.rest.gclient.DateClientParam(SP_DATE); /** * Search parameter: <b>url</b> * <p> * Description: <b>The uri that identifies the conformance statement</b><br> * Type: <b>uri</b><br> * Path: <b>Conformance.url</b><br> * </p> */ @SearchParamDefinition(name="url", path="Conformance.url", description="The uri that identifies the conformance statement", type="uri" ) public static final String SP_URL = "url"; /** * <b>Fluent Client</b> search parameter constant for <b>url</b> * <p> * Description: <b>The uri that identifies the conformance statement</b><br> * Type: <b>uri</b><br> * Path: <b>Conformance.url</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.UriClientParam URL = new ca.uhn.fhir.rest.gclient.UriClientParam(SP_URL); /** * Search parameter: <b>version</b> * <p> * Description: <b>The version identifier of the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.version</b><br> * </p> */ @SearchParamDefinition(name="version", path="Conformance.version", description="The version identifier of the conformance statement", type="token" ) public static final String SP_VERSION = "version"; /** * <b>Fluent Client</b> search parameter constant for <b>version</b> * <p> * Description: <b>The version identifier of the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.version</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam VERSION = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_VERSION); /** * Search parameter: <b>publisher</b> * <p> * Description: <b>Name of the publisher of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.publisher</b><br> * </p> */ @SearchParamDefinition(name="publisher", path="Conformance.publisher", description="Name of the publisher of the conformance statement", type="string" ) public static final String SP_PUBLISHER = "publisher"; /** * <b>Fluent Client</b> search parameter constant for <b>publisher</b> * <p> * Description: <b>Name of the publisher of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.publisher</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.StringClientParam PUBLISHER = new ca.uhn.fhir.rest.gclient.StringClientParam(SP_PUBLISHER); /** * Search parameter: <b>mode</b> * <p> * Description: <b>Mode - restful (server/client) or messaging (sender/receiver)</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.mode</b><br> * </p> */ @SearchParamDefinition(name="mode", path="Conformance.rest.mode", description="Mode - restful (server/client) or messaging (sender/receiver)", type="token" ) public static final String SP_MODE = "mode"; /** * <b>Fluent Client</b> search parameter constant for <b>mode</b> * <p> * Description: <b>Mode - restful (server/client) or messaging (sender/receiver)</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.rest.mode</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam MODE = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_MODE); /** * Search parameter: <b>resourceprofile</b> * <p> * Description: <b>A profile id invoked in a conformance statement</b><br> * Type: <b>reference</b><br> * Path: <b>Conformance.rest.resource.profile</b><br> * </p> */ @SearchParamDefinition(name="resourceprofile", path="Conformance.rest.resource.profile", description="A profile id invoked in a conformance statement", type="reference" ) public static final String SP_RESOURCEPROFILE = "resourceprofile"; /** * <b>Fluent Client</b> search parameter constant for <b>resourceprofile</b> * <p> * Description: <b>A profile id invoked in a conformance statement</b><br> * Type: <b>reference</b><br> * Path: <b>Conformance.rest.resource.profile</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam RESOURCEPROFILE = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_RESOURCEPROFILE); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>Conformance:resourceprofile</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_RESOURCEPROFILE = new ca.uhn.fhir.model.api.Include("Conformance:resourceprofile").toLocked(); /** * Search parameter: <b>software</b> * <p> * Description: <b>Part of a the name of a software application</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.software.name</b><br> * </p> */ @SearchParamDefinition(name="software", path="Conformance.software.name", description="Part of a the name of a software application", type="string" ) public static final String SP_SOFTWARE = "software"; /** * <b>Fluent Client</b> search parameter constant for <b>software</b> * <p> * Description: <b>Part of a the name of a software application</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.software.name</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.StringClientParam SOFTWARE = new ca.uhn.fhir.rest.gclient.StringClientParam(SP_SOFTWARE); /** * Search parameter: <b>description</b> * <p> * Description: <b>Text search in the description of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.description</b><br> * </p> */ @SearchParamDefinition(name="description", path="Conformance.description", description="Text search in the description of the conformance statement", type="string" ) public static final String SP_DESCRIPTION = "description"; /** * <b>Fluent Client</b> search parameter constant for <b>description</b> * <p> * Description: <b>Text search in the description of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.description</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.StringClientParam DESCRIPTION = new ca.uhn.fhir.rest.gclient.StringClientParam(SP_DESCRIPTION); /** * Search parameter: <b>event</b> * <p> * Description: <b>Event code in a conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.messaging.event.code</b><br> * </p> */ @SearchParamDefinition(name="event", path="Conformance.messaging.event.code", description="Event code in a conformance statement", type="token" ) public static final String SP_EVENT = "event"; /** * <b>Fluent Client</b> search parameter constant for <b>event</b> * <p> * Description: <b>Event code in a conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.messaging.event.code</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam EVENT = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_EVENT); /** * Search parameter: <b>name</b> * <p> * Description: <b>Name of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.name</b><br> * </p> */ @SearchParamDefinition(name="name", path="Conformance.name", description="Name of the conformance statement", type="string" ) public static final String SP_NAME = "name"; /** * <b>Fluent Client</b> search parameter constant for <b>name</b> * <p> * Description: <b>Name of the conformance statement</b><br> * Type: <b>string</b><br> * Path: <b>Conformance.name</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.StringClientParam NAME = new ca.uhn.fhir.rest.gclient.StringClientParam(SP_NAME); /** * Search parameter: <b>context</b> * <p> * Description: <b>A use context assigned to the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.useContext</b><br> * </p> */ @SearchParamDefinition(name="context", path="Conformance.useContext", description="A use context assigned to the conformance statement", type="token" ) public static final String SP_CONTEXT = "context"; /** * <b>Fluent Client</b> search parameter constant for <b>context</b> * <p> * Description: <b>A use context assigned to the conformance statement</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.useContext</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam CONTEXT = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_CONTEXT); /** * Search parameter: <b>supported-profile</b> * <p> * Description: <b>Profiles for use cases supported</b><br> * Type: <b>reference</b><br> * Path: <b>Conformance.profile</b><br> * </p> */ @SearchParamDefinition(name="supported-profile", path="Conformance.profile", description="Profiles for use cases supported", type="reference" ) public static final String SP_SUPPORTED_PROFILE = "supported-profile"; /** * <b>Fluent Client</b> search parameter constant for <b>supported-profile</b> * <p> * Description: <b>Profiles for use cases supported</b><br> * Type: <b>reference</b><br> * Path: <b>Conformance.profile</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam SUPPORTED_PROFILE = new ca.uhn.fhir.rest.gclient.ReferenceClientParam(SP_SUPPORTED_PROFILE); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "<b>Conformance:supported-profile</b>". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_SUPPORTED_PROFILE = new ca.uhn.fhir.model.api.Include("Conformance:supported-profile").toLocked(); /** * Search parameter: <b>fhirversion</b> * <p> * Description: <b>The version of FHIR</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.version</b><br> * </p> */ @SearchParamDefinition(name="fhirversion", path="Conformance.version", description="The version of FHIR", type="token" ) public static final String SP_FHIRVERSION = "fhirversion"; /** * <b>Fluent Client</b> search parameter constant for <b>fhirversion</b> * <p> * Description: <b>The version of FHIR</b><br> * Type: <b>token</b><br> * Path: <b>Conformance.version</b><br> * </p> */ public static final ca.uhn.fhir.rest.gclient.TokenClientParam FHIRVERSION = new ca.uhn.fhir.rest.gclient.TokenClientParam(SP_FHIRVERSION); }