001package org.hl7.fhir.r4.model;
002
003/*
004  Copyright (c) 2011+, HL7, Inc.
005  All rights reserved.
006  
007  Redistribution and use in source and binary forms, with or without modification, 
008  are permitted provided that the following conditions are met:
009  
010   * Redistributions of source code must retain the above copyright notice, this 
011     list of conditions and the following disclaimer.
012   * Redistributions in binary form must reproduce the above copyright notice, 
013     this list of conditions and the following disclaimer in the documentation 
014     and/or other materials provided with the distribution.
015   * Neither the name of HL7 nor the names of its contributors may be used to 
016     endorse or promote products derived from this software without specific 
017     prior written permission.
018  
019  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
020  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
021  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
022  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
023  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
024  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
025  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
026  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
027  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
028  POSSIBILITY OF SUCH DAMAGE.
029  
030*/
031
032// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
033import java.util.ArrayList;
034import java.util.Date;
035import java.util.List;
036
037import org.hl7.fhir.exceptions.FHIRException;
038import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
039import org.hl7.fhir.instance.model.api.IBaseConformance;
040import org.hl7.fhir.r4.model.Enumerations.FHIRVersion;
041import org.hl7.fhir.r4.model.Enumerations.FHIRVersionEnumFactory;
042import org.hl7.fhir.r4.model.Enumerations.PublicationStatus;
043import org.hl7.fhir.r4.model.Enumerations.PublicationStatusEnumFactory;
044import org.hl7.fhir.r4.model.Enumerations.SearchParamType;
045import org.hl7.fhir.r4.model.Enumerations.SearchParamTypeEnumFactory;
046import org.hl7.fhir.utilities.Utilities;
047
048import ca.uhn.fhir.model.api.annotation.Block;
049import ca.uhn.fhir.model.api.annotation.Child;
050import ca.uhn.fhir.model.api.annotation.ChildOrder;
051import ca.uhn.fhir.model.api.annotation.Description;
052import ca.uhn.fhir.model.api.annotation.ResourceDef;
053import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;
054
055/**
056 * A Capability Statement documents a set of capabilities (behaviors) of a FHIR
057 * Server for a particular version of FHIR that may be used as a statement of
058 * actual server functionality or a statement of required or desired server
059 * implementation.
060 */
061@ResourceDef(name = "CapabilityStatement", profile = "http://hl7.org/fhir/StructureDefinition/CapabilityStatement")
062@ChildOrder(names = { "url", "version", "name", "title", "status", "experimental", "date", "publisher", "contact",
063    "description", "useContext", "jurisdiction", "purpose", "copyright", "kind", "instantiates", "imports", "software",
064    "implementation", "fhirVersion", "format", "patchFormat", "implementationGuide", "rest", "messaging", "document" })
065public class CapabilityStatement extends MetadataResource implements IBaseConformance {
066
067  public enum CapabilityStatementKind {
068    /**
069     * The CapabilityStatement instance represents the present capabilities of a
070     * specific system instance. This is the kind returned by /metadata for a FHIR
071     * server end-point.
072     */
073    INSTANCE,
074    /**
075     * The CapabilityStatement instance represents the capabilities of a system or
076     * piece of software, independent of a particular installation.
077     */
078    CAPABILITY,
079    /**
080     * The CapabilityStatement instance represents a set of requirements for other
081     * systems to meet; e.g. as part of an implementation guide or 'request for
082     * proposal'.
083     */
084    REQUIREMENTS,
085    /**
086     * added to help the parsers with the generic types
087     */
088    NULL;
089
090    public static CapabilityStatementKind fromCode(String codeString) throws FHIRException {
091      if (codeString == null || "".equals(codeString))
092        return null;
093      if ("instance".equals(codeString))
094        return INSTANCE;
095      if ("capability".equals(codeString))
096        return CAPABILITY;
097      if ("requirements".equals(codeString))
098        return REQUIREMENTS;
099      if (Configuration.isAcceptInvalidEnums())
100        return null;
101      else
102        throw new FHIRException("Unknown CapabilityStatementKind code '" + codeString + "'");
103    }
104
105    public String toCode() {
106      switch (this) {
107      case INSTANCE:
108        return "instance";
109      case CAPABILITY:
110        return "capability";
111      case REQUIREMENTS:
112        return "requirements";
113      case NULL:
114        return null;
115      default:
116        return "?";
117      }
118    }
119
120    public String getSystem() {
121      switch (this) {
122      case INSTANCE:
123        return "http://hl7.org/fhir/capability-statement-kind";
124      case CAPABILITY:
125        return "http://hl7.org/fhir/capability-statement-kind";
126      case REQUIREMENTS:
127        return "http://hl7.org/fhir/capability-statement-kind";
128      case NULL:
129        return null;
130      default:
131        return "?";
132      }
133    }
134
135    public String getDefinition() {
136      switch (this) {
137      case INSTANCE:
138        return "The CapabilityStatement instance represents the present capabilities of a specific system instance.  This is the kind returned by /metadata for a FHIR server end-point.";
139      case CAPABILITY:
140        return "The CapabilityStatement instance represents the capabilities of a system or piece of software, independent of a particular installation.";
141      case REQUIREMENTS:
142        return "The CapabilityStatement instance represents a set of requirements for other systems to meet; e.g. as part of an implementation guide or 'request for proposal'.";
143      case NULL:
144        return null;
145      default:
146        return "?";
147      }
148    }
149
150    public String getDisplay() {
151      switch (this) {
152      case INSTANCE:
153        return "Instance";
154      case CAPABILITY:
155        return "Capability";
156      case REQUIREMENTS:
157        return "Requirements";
158      case NULL:
159        return null;
160      default:
161        return "?";
162      }
163    }
164  }
165
166  public static class CapabilityStatementKindEnumFactory implements EnumFactory<CapabilityStatementKind> {
167    public CapabilityStatementKind fromCode(String codeString) throws IllegalArgumentException {
168      if (codeString == null || "".equals(codeString))
169        if (codeString == null || "".equals(codeString))
170          return null;
171      if ("instance".equals(codeString))
172        return CapabilityStatementKind.INSTANCE;
173      if ("capability".equals(codeString))
174        return CapabilityStatementKind.CAPABILITY;
175      if ("requirements".equals(codeString))
176        return CapabilityStatementKind.REQUIREMENTS;
177      throw new IllegalArgumentException("Unknown CapabilityStatementKind code '" + codeString + "'");
178    }
179
180    public Enumeration<CapabilityStatementKind> fromType(PrimitiveType<?> code) throws FHIRException {
181      if (code == null)
182        return null;
183      if (code.isEmpty())
184        return new Enumeration<CapabilityStatementKind>(this, CapabilityStatementKind.NULL, code);
185      String codeString = code.asStringValue();
186      if (codeString == null || "".equals(codeString))
187        return new Enumeration<CapabilityStatementKind>(this, CapabilityStatementKind.NULL, code);
188      if ("instance".equals(codeString))
189        return new Enumeration<CapabilityStatementKind>(this, CapabilityStatementKind.INSTANCE, code);
190      if ("capability".equals(codeString))
191        return new Enumeration<CapabilityStatementKind>(this, CapabilityStatementKind.CAPABILITY, code);
192      if ("requirements".equals(codeString))
193        return new Enumeration<CapabilityStatementKind>(this, CapabilityStatementKind.REQUIREMENTS, code);
194      throw new FHIRException("Unknown CapabilityStatementKind code '" + codeString + "'");
195    }
196
197    public String toCode(CapabilityStatementKind code) {
198       if (code == CapabilityStatementKind.NULL)
199           return null;
200       if (code == CapabilityStatementKind.INSTANCE)
201        return "instance";
202      if (code == CapabilityStatementKind.CAPABILITY)
203        return "capability";
204      if (code == CapabilityStatementKind.REQUIREMENTS)
205        return "requirements";
206      return "?";
207   }
208
209    public String toSystem(CapabilityStatementKind code) {
210      return code.getSystem();
211    }
212  }
213
214  public enum RestfulCapabilityMode {
215    /**
216     * The application acts as a client for this resource.
217     */
218    CLIENT,
219    /**
220     * The application acts as a server for this resource.
221     */
222    SERVER,
223    /**
224     * added to help the parsers with the generic types
225     */
226    NULL;
227
228    public static RestfulCapabilityMode fromCode(String codeString) throws FHIRException {
229      if (codeString == null || "".equals(codeString))
230        return null;
231      if ("client".equals(codeString))
232        return CLIENT;
233      if ("server".equals(codeString))
234        return SERVER;
235      if (Configuration.isAcceptInvalidEnums())
236        return null;
237      else
238        throw new FHIRException("Unknown RestfulCapabilityMode code '" + codeString + "'");
239    }
240
241    public String toCode() {
242      switch (this) {
243      case CLIENT:
244        return "client";
245      case SERVER:
246        return "server";
247      case NULL:
248        return null;
249      default:
250        return "?";
251      }
252    }
253
254    public String getSystem() {
255      switch (this) {
256      case CLIENT:
257        return "http://hl7.org/fhir/restful-capability-mode";
258      case SERVER:
259        return "http://hl7.org/fhir/restful-capability-mode";
260      case NULL:
261        return null;
262      default:
263        return "?";
264      }
265    }
266
267    public String getDefinition() {
268      switch (this) {
269      case CLIENT:
270        return "The application acts as a client for this resource.";
271      case SERVER:
272        return "The application acts as a server for this resource.";
273      case NULL:
274        return null;
275      default:
276        return "?";
277      }
278    }
279
280    public String getDisplay() {
281      switch (this) {
282      case CLIENT:
283        return "Client";
284      case SERVER:
285        return "Server";
286      case NULL:
287        return null;
288      default:
289        return "?";
290      }
291    }
292  }
293
294  public static class RestfulCapabilityModeEnumFactory implements EnumFactory<RestfulCapabilityMode> {
295    public RestfulCapabilityMode fromCode(String codeString) throws IllegalArgumentException {
296      if (codeString == null || "".equals(codeString))
297        if (codeString == null || "".equals(codeString))
298          return null;
299      if ("client".equals(codeString))
300        return RestfulCapabilityMode.CLIENT;
301      if ("server".equals(codeString))
302        return RestfulCapabilityMode.SERVER;
303      throw new IllegalArgumentException("Unknown RestfulCapabilityMode code '" + codeString + "'");
304    }
305
306    public Enumeration<RestfulCapabilityMode> fromType(PrimitiveType<?> code) throws FHIRException {
307      if (code == null)
308        return null;
309      if (code.isEmpty())
310        return new Enumeration<RestfulCapabilityMode>(this, RestfulCapabilityMode.NULL, code);
311      String codeString = code.asStringValue();
312      if (codeString == null || "".equals(codeString))
313        return new Enumeration<RestfulCapabilityMode>(this, RestfulCapabilityMode.NULL, code);
314      if ("client".equals(codeString))
315        return new Enumeration<RestfulCapabilityMode>(this, RestfulCapabilityMode.CLIENT, code);
316      if ("server".equals(codeString))
317        return new Enumeration<RestfulCapabilityMode>(this, RestfulCapabilityMode.SERVER, code);
318      throw new FHIRException("Unknown RestfulCapabilityMode code '" + codeString + "'");
319    }
320
321    public String toCode(RestfulCapabilityMode code) {
322       if (code == RestfulCapabilityMode.NULL)
323           return null;
324       if (code == RestfulCapabilityMode.CLIENT)
325        return "client";
326      if (code == RestfulCapabilityMode.SERVER)
327        return "server";
328      return "?";
329   }
330
331    public String toSystem(RestfulCapabilityMode code) {
332      return code.getSystem();
333    }
334  }
335
336  public enum TypeRestfulInteraction {
337    /**
338     * null
339     */
340    READ,
341    /**
342     * null
343     */
344    VREAD,
345    /**
346     * null
347     */
348    UPDATE,
349    /**
350     * null
351     */
352    PATCH,
353    /**
354     * null
355     */
356    DELETE,
357    /**
358     * null
359     */
360    HISTORYINSTANCE,
361    /**
362     * null
363     */
364    HISTORYTYPE,
365    /**
366     * null
367     */
368    CREATE,
369    /**
370     * null
371     */
372    SEARCHTYPE,
373    /**
374     * added to help the parsers with the generic types
375     */
376    NULL;
377
378    public static TypeRestfulInteraction fromCode(String codeString) throws FHIRException {
379      if (codeString == null || "".equals(codeString))
380        return null;
381      if ("read".equals(codeString))
382        return READ;
383      if ("vread".equals(codeString))
384        return VREAD;
385      if ("update".equals(codeString))
386        return UPDATE;
387      if ("patch".equals(codeString))
388        return PATCH;
389      if ("delete".equals(codeString))
390        return DELETE;
391      if ("history-instance".equals(codeString))
392        return HISTORYINSTANCE;
393      if ("history-type".equals(codeString))
394        return HISTORYTYPE;
395      if ("create".equals(codeString))
396        return CREATE;
397      if ("search-type".equals(codeString))
398        return SEARCHTYPE;
399      if (Configuration.isAcceptInvalidEnums())
400        return null;
401      else
402        throw new FHIRException("Unknown TypeRestfulInteraction code '" + codeString + "'");
403    }
404
405    public String toCode() {
406      switch (this) {
407      case READ:
408        return "read";
409      case VREAD:
410        return "vread";
411      case UPDATE:
412        return "update";
413      case PATCH:
414        return "patch";
415      case DELETE:
416        return "delete";
417      case HISTORYINSTANCE:
418        return "history-instance";
419      case HISTORYTYPE:
420        return "history-type";
421      case CREATE:
422        return "create";
423      case SEARCHTYPE:
424        return "search-type";
425      case NULL:
426        return null;
427      default:
428        return "?";
429      }
430    }
431
432    public String getSystem() {
433      switch (this) {
434      case READ:
435        return "http://hl7.org/fhir/restful-interaction";
436      case VREAD:
437        return "http://hl7.org/fhir/restful-interaction";
438      case UPDATE:
439        return "http://hl7.org/fhir/restful-interaction";
440      case PATCH:
441        return "http://hl7.org/fhir/restful-interaction";
442      case DELETE:
443        return "http://hl7.org/fhir/restful-interaction";
444      case HISTORYINSTANCE:
445        return "http://hl7.org/fhir/restful-interaction";
446      case HISTORYTYPE:
447        return "http://hl7.org/fhir/restful-interaction";
448      case CREATE:
449        return "http://hl7.org/fhir/restful-interaction";
450      case SEARCHTYPE:
451        return "http://hl7.org/fhir/restful-interaction";
452      case NULL:
453        return null;
454      default:
455        return "?";
456      }
457    }
458
459    public String getDefinition() {
460      switch (this) {
461      case READ:
462        return "";
463      case VREAD:
464        return "";
465      case UPDATE:
466        return "";
467      case PATCH:
468        return "";
469      case DELETE:
470        return "";
471      case HISTORYINSTANCE:
472        return "";
473      case HISTORYTYPE:
474        return "";
475      case CREATE:
476        return "";
477      case SEARCHTYPE:
478        return "";
479      case NULL:
480        return null;
481      default:
482        return "?";
483      }
484    }
485
486    public String getDisplay() {
487      switch (this) {
488      case READ:
489        return "read";
490      case VREAD:
491        return "vread";
492      case UPDATE:
493        return "update";
494      case PATCH:
495        return "patch";
496      case DELETE:
497        return "delete";
498      case HISTORYINSTANCE:
499        return "history-instance";
500      case HISTORYTYPE:
501        return "history-type";
502      case CREATE:
503        return "create";
504      case SEARCHTYPE:
505        return "search-type";
506      case NULL:
507        return null;
508      default:
509        return "?";
510      }
511    }
512  }
513
514  public static class TypeRestfulInteractionEnumFactory implements EnumFactory<TypeRestfulInteraction> {
515    public TypeRestfulInteraction fromCode(String codeString) throws IllegalArgumentException {
516      if (codeString == null || "".equals(codeString))
517        if (codeString == null || "".equals(codeString))
518          return null;
519      if ("read".equals(codeString))
520        return TypeRestfulInteraction.READ;
521      if ("vread".equals(codeString))
522        return TypeRestfulInteraction.VREAD;
523      if ("update".equals(codeString))
524        return TypeRestfulInteraction.UPDATE;
525      if ("patch".equals(codeString))
526        return TypeRestfulInteraction.PATCH;
527      if ("delete".equals(codeString))
528        return TypeRestfulInteraction.DELETE;
529      if ("history-instance".equals(codeString))
530        return TypeRestfulInteraction.HISTORYINSTANCE;
531      if ("history-type".equals(codeString))
532        return TypeRestfulInteraction.HISTORYTYPE;
533      if ("create".equals(codeString))
534        return TypeRestfulInteraction.CREATE;
535      if ("search-type".equals(codeString))
536        return TypeRestfulInteraction.SEARCHTYPE;
537      throw new IllegalArgumentException("Unknown TypeRestfulInteraction code '" + codeString + "'");
538    }
539
540    public Enumeration<TypeRestfulInteraction> fromType(PrimitiveType<?> code) throws FHIRException {
541      if (code == null)
542        return null;
543      if (code.isEmpty())
544        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.NULL, code);
545      String codeString = code.asStringValue();
546      if (codeString == null || "".equals(codeString))
547        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.NULL, code);
548      if ("read".equals(codeString))
549        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.READ, code);
550      if ("vread".equals(codeString))
551        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.VREAD, code);
552      if ("update".equals(codeString))
553        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.UPDATE, code);
554      if ("patch".equals(codeString))
555        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.PATCH, code);
556      if ("delete".equals(codeString))
557        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.DELETE, code);
558      if ("history-instance".equals(codeString))
559        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.HISTORYINSTANCE, code);
560      if ("history-type".equals(codeString))
561        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.HISTORYTYPE, code);
562      if ("create".equals(codeString))
563        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.CREATE, code);
564      if ("search-type".equals(codeString))
565        return new Enumeration<TypeRestfulInteraction>(this, TypeRestfulInteraction.SEARCHTYPE, code);
566      throw new FHIRException("Unknown TypeRestfulInteraction code '" + codeString + "'");
567    }
568
569    public String toCode(TypeRestfulInteraction code) {
570       if (code == TypeRestfulInteraction.NULL)
571           return null;
572       if (code == TypeRestfulInteraction.READ)
573        return "read";
574      if (code == TypeRestfulInteraction.VREAD)
575        return "vread";
576      if (code == TypeRestfulInteraction.UPDATE)
577        return "update";
578      if (code == TypeRestfulInteraction.PATCH)
579        return "patch";
580      if (code == TypeRestfulInteraction.DELETE)
581        return "delete";
582      if (code == TypeRestfulInteraction.HISTORYINSTANCE)
583        return "history-instance";
584      if (code == TypeRestfulInteraction.HISTORYTYPE)
585        return "history-type";
586      if (code == TypeRestfulInteraction.CREATE)
587        return "create";
588      if (code == TypeRestfulInteraction.SEARCHTYPE)
589        return "search-type";
590      return "?";
591   }
592
593    public String toSystem(TypeRestfulInteraction code) {
594      return code.getSystem();
595    }
596  }
597
598  public enum ResourceVersionPolicy {
599    /**
600     * VersionId meta-property is not supported (server) or used (client).
601     */
602    NOVERSION,
603    /**
604     * VersionId meta-property is supported (server) or used (client).
605     */
606    VERSIONED,
607    /**
608     * VersionId must be correct for updates (server) or will be specified (If-match
609     * header) for updates (client).
610     */
611    VERSIONEDUPDATE,
612    /**
613     * added to help the parsers with the generic types
614     */
615    NULL;
616
617    public static ResourceVersionPolicy fromCode(String codeString) throws FHIRException {
618      if (codeString == null || "".equals(codeString))
619        return null;
620      if ("no-version".equals(codeString))
621        return NOVERSION;
622      if ("versioned".equals(codeString))
623        return VERSIONED;
624      if ("versioned-update".equals(codeString))
625        return VERSIONEDUPDATE;
626      if (Configuration.isAcceptInvalidEnums())
627        return null;
628      else
629        throw new FHIRException("Unknown ResourceVersionPolicy code '" + codeString + "'");
630    }
631
632    public String toCode() {
633      switch (this) {
634      case NOVERSION:
635        return "no-version";
636      case VERSIONED:
637        return "versioned";
638      case VERSIONEDUPDATE:
639        return "versioned-update";
640      case NULL:
641        return null;
642      default:
643        return "?";
644      }
645    }
646
647    public String getSystem() {
648      switch (this) {
649      case NOVERSION:
650        return "http://hl7.org/fhir/versioning-policy";
651      case VERSIONED:
652        return "http://hl7.org/fhir/versioning-policy";
653      case VERSIONEDUPDATE:
654        return "http://hl7.org/fhir/versioning-policy";
655      case NULL:
656        return null;
657      default:
658        return "?";
659      }
660    }
661
662    public String getDefinition() {
663      switch (this) {
664      case NOVERSION:
665        return "VersionId meta-property is not supported (server) or used (client).";
666      case VERSIONED:
667        return "VersionId meta-property is supported (server) or used (client).";
668      case VERSIONEDUPDATE:
669        return "VersionId must be correct for updates (server) or will be specified (If-match header) for updates (client).";
670      case NULL:
671        return null;
672      default:
673        return "?";
674      }
675    }
676
677    public String getDisplay() {
678      switch (this) {
679      case NOVERSION:
680        return "No VersionId Support";
681      case VERSIONED:
682        return "Versioned";
683      case VERSIONEDUPDATE:
684        return "VersionId tracked fully";
685      case NULL:
686        return null;
687      default:
688        return "?";
689      }
690    }
691  }
692
693  public static class ResourceVersionPolicyEnumFactory implements EnumFactory<ResourceVersionPolicy> {
694    public ResourceVersionPolicy fromCode(String codeString) throws IllegalArgumentException {
695      if (codeString == null || "".equals(codeString))
696        if (codeString == null || "".equals(codeString))
697          return null;
698      if ("no-version".equals(codeString))
699        return ResourceVersionPolicy.NOVERSION;
700      if ("versioned".equals(codeString))
701        return ResourceVersionPolicy.VERSIONED;
702      if ("versioned-update".equals(codeString))
703        return ResourceVersionPolicy.VERSIONEDUPDATE;
704      throw new IllegalArgumentException("Unknown ResourceVersionPolicy code '" + codeString + "'");
705    }
706
707    public Enumeration<ResourceVersionPolicy> fromType(PrimitiveType<?> code) throws FHIRException {
708      if (code == null)
709        return null;
710      if (code.isEmpty())
711        return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.NULL, code);
712      String codeString = code.asStringValue();
713      if (codeString == null || "".equals(codeString))
714        return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.NULL, code);
715      if ("no-version".equals(codeString))
716        return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.NOVERSION, code);
717      if ("versioned".equals(codeString))
718        return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.VERSIONED, code);
719      if ("versioned-update".equals(codeString))
720        return new Enumeration<ResourceVersionPolicy>(this, ResourceVersionPolicy.VERSIONEDUPDATE, code);
721      throw new FHIRException("Unknown ResourceVersionPolicy code '" + codeString + "'");
722    }
723
724    public String toCode(ResourceVersionPolicy code) {
725       if (code == ResourceVersionPolicy.NULL)
726           return null;
727       if (code == ResourceVersionPolicy.NOVERSION)
728        return "no-version";
729      if (code == ResourceVersionPolicy.VERSIONED)
730        return "versioned";
731      if (code == ResourceVersionPolicy.VERSIONEDUPDATE)
732        return "versioned-update";
733      return "?";
734   }
735
736    public String toSystem(ResourceVersionPolicy code) {
737      return code.getSystem();
738    }
739  }
740
741  public enum ConditionalReadStatus {
742    /**
743     * No support for conditional reads.
744     */
745    NOTSUPPORTED,
746    /**
747     * Conditional reads are supported, but only with the If-Modified-Since HTTP
748     * Header.
749     */
750    MODIFIEDSINCE,
751    /**
752     * Conditional reads are supported, but only with the If-None-Match HTTP Header.
753     */
754    NOTMATCH,
755    /**
756     * Conditional reads are supported, with both If-Modified-Since and
757     * If-None-Match HTTP Headers.
758     */
759    FULLSUPPORT,
760    /**
761     * added to help the parsers with the generic types
762     */
763    NULL;
764
765    public static ConditionalReadStatus fromCode(String codeString) throws FHIRException {
766      if (codeString == null || "".equals(codeString))
767        return null;
768      if ("not-supported".equals(codeString))
769        return NOTSUPPORTED;
770      if ("modified-since".equals(codeString))
771        return MODIFIEDSINCE;
772      if ("not-match".equals(codeString))
773        return NOTMATCH;
774      if ("full-support".equals(codeString))
775        return FULLSUPPORT;
776      if (Configuration.isAcceptInvalidEnums())
777        return null;
778      else
779        throw new FHIRException("Unknown ConditionalReadStatus code '" + codeString + "'");
780    }
781
782    public String toCode() {
783      switch (this) {
784      case NOTSUPPORTED:
785        return "not-supported";
786      case MODIFIEDSINCE:
787        return "modified-since";
788      case NOTMATCH:
789        return "not-match";
790      case FULLSUPPORT:
791        return "full-support";
792      case NULL:
793        return null;
794      default:
795        return "?";
796      }
797    }
798
799    public String getSystem() {
800      switch (this) {
801      case NOTSUPPORTED:
802        return "http://hl7.org/fhir/conditional-read-status";
803      case MODIFIEDSINCE:
804        return "http://hl7.org/fhir/conditional-read-status";
805      case NOTMATCH:
806        return "http://hl7.org/fhir/conditional-read-status";
807      case FULLSUPPORT:
808        return "http://hl7.org/fhir/conditional-read-status";
809      case NULL:
810        return null;
811      default:
812        return "?";
813      }
814    }
815
816    public String getDefinition() {
817      switch (this) {
818      case NOTSUPPORTED:
819        return "No support for conditional reads.";
820      case MODIFIEDSINCE:
821        return "Conditional reads are supported, but only with the If-Modified-Since HTTP Header.";
822      case NOTMATCH:
823        return "Conditional reads are supported, but only with the If-None-Match HTTP Header.";
824      case FULLSUPPORT:
825        return "Conditional reads are supported, with both If-Modified-Since and If-None-Match HTTP Headers.";
826      case NULL:
827        return null;
828      default:
829        return "?";
830      }
831    }
832
833    public String getDisplay() {
834      switch (this) {
835      case NOTSUPPORTED:
836        return "Not Supported";
837      case MODIFIEDSINCE:
838        return "If-Modified-Since";
839      case NOTMATCH:
840        return "If-None-Match";
841      case FULLSUPPORT:
842        return "Full Support";
843      case NULL:
844        return null;
845      default:
846        return "?";
847      }
848    }
849  }
850
851  public static class ConditionalReadStatusEnumFactory implements EnumFactory<ConditionalReadStatus> {
852    public ConditionalReadStatus fromCode(String codeString) throws IllegalArgumentException {
853      if (codeString == null || "".equals(codeString))
854        if (codeString == null || "".equals(codeString))
855          return null;
856      if ("not-supported".equals(codeString))
857        return ConditionalReadStatus.NOTSUPPORTED;
858      if ("modified-since".equals(codeString))
859        return ConditionalReadStatus.MODIFIEDSINCE;
860      if ("not-match".equals(codeString))
861        return ConditionalReadStatus.NOTMATCH;
862      if ("full-support".equals(codeString))
863        return ConditionalReadStatus.FULLSUPPORT;
864      throw new IllegalArgumentException("Unknown ConditionalReadStatus code '" + codeString + "'");
865    }
866
867    public Enumeration<ConditionalReadStatus> fromType(PrimitiveType<?> code) throws FHIRException {
868      if (code == null)
869        return null;
870      if (code.isEmpty())
871        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.NULL, code);
872      String codeString = code.asStringValue();
873      if (codeString == null || "".equals(codeString))
874        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.NULL, code);
875      if ("not-supported".equals(codeString))
876        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.NOTSUPPORTED, code);
877      if ("modified-since".equals(codeString))
878        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.MODIFIEDSINCE, code);
879      if ("not-match".equals(codeString))
880        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.NOTMATCH, code);
881      if ("full-support".equals(codeString))
882        return new Enumeration<ConditionalReadStatus>(this, ConditionalReadStatus.FULLSUPPORT, code);
883      throw new FHIRException("Unknown ConditionalReadStatus code '" + codeString + "'");
884    }
885
886    public String toCode(ConditionalReadStatus code) {
887       if (code == ConditionalReadStatus.NULL)
888           return null;
889       if (code == ConditionalReadStatus.NOTSUPPORTED)
890        return "not-supported";
891      if (code == ConditionalReadStatus.MODIFIEDSINCE)
892        return "modified-since";
893      if (code == ConditionalReadStatus.NOTMATCH)
894        return "not-match";
895      if (code == ConditionalReadStatus.FULLSUPPORT)
896        return "full-support";
897      return "?";
898   }
899
900    public String toSystem(ConditionalReadStatus code) {
901      return code.getSystem();
902    }
903  }
904
905  public enum ConditionalDeleteStatus {
906    /**
907     * No support for conditional deletes.
908     */
909    NOTSUPPORTED,
910    /**
911     * Conditional deletes are supported, but only single resources at a time.
912     */
913    SINGLE,
914    /**
915     * Conditional deletes are supported, and multiple resources can be deleted in a
916     * single interaction.
917     */
918    MULTIPLE,
919    /**
920     * added to help the parsers with the generic types
921     */
922    NULL;
923
924    public static ConditionalDeleteStatus fromCode(String codeString) throws FHIRException {
925      if (codeString == null || "".equals(codeString))
926        return null;
927      if ("not-supported".equals(codeString))
928        return NOTSUPPORTED;
929      if ("single".equals(codeString))
930        return SINGLE;
931      if ("multiple".equals(codeString))
932        return MULTIPLE;
933      if (Configuration.isAcceptInvalidEnums())
934        return null;
935      else
936        throw new FHIRException("Unknown ConditionalDeleteStatus code '" + codeString + "'");
937    }
938
939    public String toCode() {
940      switch (this) {
941      case NOTSUPPORTED:
942        return "not-supported";
943      case SINGLE:
944        return "single";
945      case MULTIPLE:
946        return "multiple";
947      case NULL:
948        return null;
949      default:
950        return "?";
951      }
952    }
953
954    public String getSystem() {
955      switch (this) {
956      case NOTSUPPORTED:
957        return "http://hl7.org/fhir/conditional-delete-status";
958      case SINGLE:
959        return "http://hl7.org/fhir/conditional-delete-status";
960      case MULTIPLE:
961        return "http://hl7.org/fhir/conditional-delete-status";
962      case NULL:
963        return null;
964      default:
965        return "?";
966      }
967    }
968
969    public String getDefinition() {
970      switch (this) {
971      case NOTSUPPORTED:
972        return "No support for conditional deletes.";
973      case SINGLE:
974        return "Conditional deletes are supported, but only single resources at a time.";
975      case MULTIPLE:
976        return "Conditional deletes are supported, and multiple resources can be deleted in a single interaction.";
977      case NULL:
978        return null;
979      default:
980        return "?";
981      }
982    }
983
984    public String getDisplay() {
985      switch (this) {
986      case NOTSUPPORTED:
987        return "Not Supported";
988      case SINGLE:
989        return "Single Deletes Supported";
990      case MULTIPLE:
991        return "Multiple Deletes Supported";
992      case NULL:
993        return null;
994      default:
995        return "?";
996      }
997    }
998  }
999
1000  public static class ConditionalDeleteStatusEnumFactory implements EnumFactory<ConditionalDeleteStatus> {
1001    public ConditionalDeleteStatus fromCode(String codeString) throws IllegalArgumentException {
1002      if (codeString == null || "".equals(codeString))
1003        if (codeString == null || "".equals(codeString))
1004          return null;
1005      if ("not-supported".equals(codeString))
1006        return ConditionalDeleteStatus.NOTSUPPORTED;
1007      if ("single".equals(codeString))
1008        return ConditionalDeleteStatus.SINGLE;
1009      if ("multiple".equals(codeString))
1010        return ConditionalDeleteStatus.MULTIPLE;
1011      throw new IllegalArgumentException("Unknown ConditionalDeleteStatus code '" + codeString + "'");
1012    }
1013
1014    public Enumeration<ConditionalDeleteStatus> fromType(PrimitiveType<?> code) throws FHIRException {
1015      if (code == null)
1016        return null;
1017      if (code.isEmpty())
1018        return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.NULL, code);
1019      String codeString = code.asStringValue();
1020      if (codeString == null || "".equals(codeString))
1021        return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.NULL, code);
1022      if ("not-supported".equals(codeString))
1023        return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.NOTSUPPORTED, code);
1024      if ("single".equals(codeString))
1025        return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.SINGLE, code);
1026      if ("multiple".equals(codeString))
1027        return new Enumeration<ConditionalDeleteStatus>(this, ConditionalDeleteStatus.MULTIPLE, code);
1028      throw new FHIRException("Unknown ConditionalDeleteStatus code '" + codeString + "'");
1029    }
1030
1031    public String toCode(ConditionalDeleteStatus code) {
1032       if (code == ConditionalDeleteStatus.NULL)
1033           return null;
1034       if (code == ConditionalDeleteStatus.NOTSUPPORTED)
1035        return "not-supported";
1036      if (code == ConditionalDeleteStatus.SINGLE)
1037        return "single";
1038      if (code == ConditionalDeleteStatus.MULTIPLE)
1039        return "multiple";
1040      return "?";
1041   }
1042
1043    public String toSystem(ConditionalDeleteStatus code) {
1044      return code.getSystem();
1045    }
1046  }
1047
1048  public enum ReferenceHandlingPolicy {
1049    /**
1050     * The server supports and populates Literal references (i.e. using
1051     * Reference.reference) where they are known (this code does not guarantee that
1052     * all references are literal; see 'enforced').
1053     */
1054    LITERAL,
1055    /**
1056     * The server allows logical references (i.e. using Reference.identifier).
1057     */
1058    LOGICAL,
1059    /**
1060     * The server will attempt to resolve logical references to literal references -
1061     * i.e. converting Reference.identifier to Reference.reference (if resolution
1062     * fails, the server may still accept resources; see logical).
1063     */
1064    RESOLVES,
1065    /**
1066     * The server enforces that references have integrity - e.g. it ensures that
1067     * references can always be resolved. This is typically the case for clinical
1068     * record systems, but often not the case for middleware/proxy systems.
1069     */
1070    ENFORCED,
1071    /**
1072     * The server does not support references that point to other servers.
1073     */
1074    LOCAL,
1075    /**
1076     * added to help the parsers with the generic types
1077     */
1078    NULL;
1079
1080    public static ReferenceHandlingPolicy fromCode(String codeString) throws FHIRException {
1081      if (codeString == null || "".equals(codeString))
1082        return null;
1083      if ("literal".equals(codeString))
1084        return LITERAL;
1085      if ("logical".equals(codeString))
1086        return LOGICAL;
1087      if ("resolves".equals(codeString))
1088        return RESOLVES;
1089      if ("enforced".equals(codeString))
1090        return ENFORCED;
1091      if ("local".equals(codeString))
1092        return LOCAL;
1093      if (Configuration.isAcceptInvalidEnums())
1094        return null;
1095      else
1096        throw new FHIRException("Unknown ReferenceHandlingPolicy code '" + codeString + "'");
1097    }
1098
1099    public String toCode() {
1100      switch (this) {
1101      case LITERAL:
1102        return "literal";
1103      case LOGICAL:
1104        return "logical";
1105      case RESOLVES:
1106        return "resolves";
1107      case ENFORCED:
1108        return "enforced";
1109      case LOCAL:
1110        return "local";
1111      case NULL:
1112        return null;
1113      default:
1114        return "?";
1115      }
1116    }
1117
1118    public String getSystem() {
1119      switch (this) {
1120      case LITERAL:
1121        return "http://hl7.org/fhir/reference-handling-policy";
1122      case LOGICAL:
1123        return "http://hl7.org/fhir/reference-handling-policy";
1124      case RESOLVES:
1125        return "http://hl7.org/fhir/reference-handling-policy";
1126      case ENFORCED:
1127        return "http://hl7.org/fhir/reference-handling-policy";
1128      case LOCAL:
1129        return "http://hl7.org/fhir/reference-handling-policy";
1130      case NULL:
1131        return null;
1132      default:
1133        return "?";
1134      }
1135    }
1136
1137    public String getDefinition() {
1138      switch (this) {
1139      case LITERAL:
1140        return "The server supports and populates Literal references (i.e. using Reference.reference) where they are known (this code does not guarantee that all references are literal; see 'enforced').";
1141      case LOGICAL:
1142        return "The server allows logical references (i.e. using Reference.identifier).";
1143      case RESOLVES:
1144        return "The server will attempt to resolve logical references to literal references - i.e. converting Reference.identifier to Reference.reference (if resolution fails, the server may still accept resources; see logical).";
1145      case ENFORCED:
1146        return "The server enforces that references have integrity - e.g. it ensures that references can always be resolved. This is typically the case for clinical record systems, but often not the case for middleware/proxy systems.";
1147      case LOCAL:
1148        return "The server does not support references that point to other servers.";
1149      case NULL:
1150        return null;
1151      default:
1152        return "?";
1153      }
1154    }
1155
1156    public String getDisplay() {
1157      switch (this) {
1158      case LITERAL:
1159        return "Literal References";
1160      case LOGICAL:
1161        return "Logical References";
1162      case RESOLVES:
1163        return "Resolves References";
1164      case ENFORCED:
1165        return "Reference Integrity Enforced";
1166      case LOCAL:
1167        return "Local References Only";
1168      case NULL:
1169        return null;
1170      default:
1171        return "?";
1172      }
1173    }
1174  }
1175
1176  public static class ReferenceHandlingPolicyEnumFactory implements EnumFactory<ReferenceHandlingPolicy> {
1177    public ReferenceHandlingPolicy fromCode(String codeString) throws IllegalArgumentException {
1178      if (codeString == null || "".equals(codeString))
1179        if (codeString == null || "".equals(codeString))
1180          return null;
1181      if ("literal".equals(codeString))
1182        return ReferenceHandlingPolicy.LITERAL;
1183      if ("logical".equals(codeString))
1184        return ReferenceHandlingPolicy.LOGICAL;
1185      if ("resolves".equals(codeString))
1186        return ReferenceHandlingPolicy.RESOLVES;
1187      if ("enforced".equals(codeString))
1188        return ReferenceHandlingPolicy.ENFORCED;
1189      if ("local".equals(codeString))
1190        return ReferenceHandlingPolicy.LOCAL;
1191      throw new IllegalArgumentException("Unknown ReferenceHandlingPolicy code '" + codeString + "'");
1192    }
1193
1194    public Enumeration<ReferenceHandlingPolicy> fromType(PrimitiveType<?> code) throws FHIRException {
1195      if (code == null)
1196        return null;
1197      if (code.isEmpty())
1198        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.NULL, code);
1199      String codeString = code.asStringValue();
1200      if (codeString == null || "".equals(codeString))
1201        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.NULL, code);
1202      if ("literal".equals(codeString))
1203        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.LITERAL, code);
1204      if ("logical".equals(codeString))
1205        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.LOGICAL, code);
1206      if ("resolves".equals(codeString))
1207        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.RESOLVES, code);
1208      if ("enforced".equals(codeString))
1209        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.ENFORCED, code);
1210      if ("local".equals(codeString))
1211        return new Enumeration<ReferenceHandlingPolicy>(this, ReferenceHandlingPolicy.LOCAL, code);
1212      throw new FHIRException("Unknown ReferenceHandlingPolicy code '" + codeString + "'");
1213    }
1214
1215    public String toCode(ReferenceHandlingPolicy code) {
1216       if (code == ReferenceHandlingPolicy.NULL)
1217           return null;
1218       if (code == ReferenceHandlingPolicy.LITERAL)
1219        return "literal";
1220      if (code == ReferenceHandlingPolicy.LOGICAL)
1221        return "logical";
1222      if (code == ReferenceHandlingPolicy.RESOLVES)
1223        return "resolves";
1224      if (code == ReferenceHandlingPolicy.ENFORCED)
1225        return "enforced";
1226      if (code == ReferenceHandlingPolicy.LOCAL)
1227        return "local";
1228      return "?";
1229   }
1230
1231    public String toSystem(ReferenceHandlingPolicy code) {
1232      return code.getSystem();
1233    }
1234  }
1235
1236  public enum SystemRestfulInteraction {
1237    /**
1238     * null
1239     */
1240    TRANSACTION,
1241    /**
1242     * null
1243     */
1244    BATCH,
1245    /**
1246     * null
1247     */
1248    SEARCHSYSTEM,
1249    /**
1250     * null
1251     */
1252    HISTORYSYSTEM,
1253    /**
1254     * added to help the parsers with the generic types
1255     */
1256    NULL;
1257
1258    public static SystemRestfulInteraction fromCode(String codeString) throws FHIRException {
1259      if (codeString == null || "".equals(codeString))
1260        return null;
1261      if ("transaction".equals(codeString))
1262        return TRANSACTION;
1263      if ("batch".equals(codeString))
1264        return BATCH;
1265      if ("search-system".equals(codeString))
1266        return SEARCHSYSTEM;
1267      if ("history-system".equals(codeString))
1268        return HISTORYSYSTEM;
1269      if (Configuration.isAcceptInvalidEnums())
1270        return null;
1271      else
1272        throw new FHIRException("Unknown SystemRestfulInteraction code '" + codeString + "'");
1273    }
1274
1275    public String toCode() {
1276      switch (this) {
1277      case TRANSACTION:
1278        return "transaction";
1279      case BATCH:
1280        return "batch";
1281      case SEARCHSYSTEM:
1282        return "search-system";
1283      case HISTORYSYSTEM:
1284        return "history-system";
1285      case NULL:
1286        return null;
1287      default:
1288        return "?";
1289      }
1290    }
1291
1292    public String getSystem() {
1293      switch (this) {
1294      case TRANSACTION:
1295        return "http://hl7.org/fhir/restful-interaction";
1296      case BATCH:
1297        return "http://hl7.org/fhir/restful-interaction";
1298      case SEARCHSYSTEM:
1299        return "http://hl7.org/fhir/restful-interaction";
1300      case HISTORYSYSTEM:
1301        return "http://hl7.org/fhir/restful-interaction";
1302      case NULL:
1303        return null;
1304      default:
1305        return "?";
1306      }
1307    }
1308
1309    public String getDefinition() {
1310      switch (this) {
1311      case TRANSACTION:
1312        return "";
1313      case BATCH:
1314        return "";
1315      case SEARCHSYSTEM:
1316        return "";
1317      case HISTORYSYSTEM:
1318        return "";
1319      case NULL:
1320        return null;
1321      default:
1322        return "?";
1323      }
1324    }
1325
1326    public String getDisplay() {
1327      switch (this) {
1328      case TRANSACTION:
1329        return "transaction";
1330      case BATCH:
1331        return "batch";
1332      case SEARCHSYSTEM:
1333        return "search-system";
1334      case HISTORYSYSTEM:
1335        return "history-system";
1336      case NULL:
1337        return null;
1338      default:
1339        return "?";
1340      }
1341    }
1342  }
1343
1344  public static class SystemRestfulInteractionEnumFactory implements EnumFactory<SystemRestfulInteraction> {
1345    public SystemRestfulInteraction fromCode(String codeString) throws IllegalArgumentException {
1346      if (codeString == null || "".equals(codeString))
1347        if (codeString == null || "".equals(codeString))
1348          return null;
1349      if ("transaction".equals(codeString))
1350        return SystemRestfulInteraction.TRANSACTION;
1351      if ("batch".equals(codeString))
1352        return SystemRestfulInteraction.BATCH;
1353      if ("search-system".equals(codeString))
1354        return SystemRestfulInteraction.SEARCHSYSTEM;
1355      if ("history-system".equals(codeString))
1356        return SystemRestfulInteraction.HISTORYSYSTEM;
1357      throw new IllegalArgumentException("Unknown SystemRestfulInteraction code '" + codeString + "'");
1358    }
1359
1360    public Enumeration<SystemRestfulInteraction> fromType(PrimitiveType<?> code) throws FHIRException {
1361      if (code == null)
1362        return null;
1363      if (code.isEmpty())
1364        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.NULL, code);
1365      String codeString = code.asStringValue();
1366      if (codeString == null || "".equals(codeString))
1367        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.NULL, code);
1368      if ("transaction".equals(codeString))
1369        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.TRANSACTION, code);
1370      if ("batch".equals(codeString))
1371        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.BATCH, code);
1372      if ("search-system".equals(codeString))
1373        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.SEARCHSYSTEM, code);
1374      if ("history-system".equals(codeString))
1375        return new Enumeration<SystemRestfulInteraction>(this, SystemRestfulInteraction.HISTORYSYSTEM, code);
1376      throw new FHIRException("Unknown SystemRestfulInteraction code '" + codeString + "'");
1377    }
1378
1379    public String toCode(SystemRestfulInteraction code) {
1380       if (code == SystemRestfulInteraction.NULL)
1381           return null;
1382       if (code == SystemRestfulInteraction.TRANSACTION)
1383        return "transaction";
1384      if (code == SystemRestfulInteraction.BATCH)
1385        return "batch";
1386      if (code == SystemRestfulInteraction.SEARCHSYSTEM)
1387        return "search-system";
1388      if (code == SystemRestfulInteraction.HISTORYSYSTEM)
1389        return "history-system";
1390      return "?";
1391   }
1392
1393    public String toSystem(SystemRestfulInteraction code) {
1394      return code.getSystem();
1395    }
1396  }
1397
1398  public enum EventCapabilityMode {
1399    /**
1400     * The application sends requests and receives responses.
1401     */
1402    SENDER,
1403    /**
1404     * The application receives requests and sends responses.
1405     */
1406    RECEIVER,
1407    /**
1408     * added to help the parsers with the generic types
1409     */
1410    NULL;
1411
1412    public static EventCapabilityMode fromCode(String codeString) throws FHIRException {
1413      if (codeString == null || "".equals(codeString))
1414        return null;
1415      if ("sender".equals(codeString))
1416        return SENDER;
1417      if ("receiver".equals(codeString))
1418        return RECEIVER;
1419      if (Configuration.isAcceptInvalidEnums())
1420        return null;
1421      else
1422        throw new FHIRException("Unknown EventCapabilityMode code '" + codeString + "'");
1423    }
1424
1425    public String toCode() {
1426      switch (this) {
1427      case SENDER:
1428        return "sender";
1429      case RECEIVER:
1430        return "receiver";
1431      case NULL:
1432        return null;
1433      default:
1434        return "?";
1435      }
1436    }
1437
1438    public String getSystem() {
1439      switch (this) {
1440      case SENDER:
1441        return "http://hl7.org/fhir/event-capability-mode";
1442      case RECEIVER:
1443        return "http://hl7.org/fhir/event-capability-mode";
1444      case NULL:
1445        return null;
1446      default:
1447        return "?";
1448      }
1449    }
1450
1451    public String getDefinition() {
1452      switch (this) {
1453      case SENDER:
1454        return "The application sends requests and receives responses.";
1455      case RECEIVER:
1456        return "The application receives requests and sends responses.";
1457      case NULL:
1458        return null;
1459      default:
1460        return "?";
1461      }
1462    }
1463
1464    public String getDisplay() {
1465      switch (this) {
1466      case SENDER:
1467        return "Sender";
1468      case RECEIVER:
1469        return "Receiver";
1470      case NULL:
1471        return null;
1472      default:
1473        return "?";
1474      }
1475    }
1476  }
1477
1478  public static class EventCapabilityModeEnumFactory implements EnumFactory<EventCapabilityMode> {
1479    public EventCapabilityMode fromCode(String codeString) throws IllegalArgumentException {
1480      if (codeString == null || "".equals(codeString))
1481        if (codeString == null || "".equals(codeString))
1482          return null;
1483      if ("sender".equals(codeString))
1484        return EventCapabilityMode.SENDER;
1485      if ("receiver".equals(codeString))
1486        return EventCapabilityMode.RECEIVER;
1487      throw new IllegalArgumentException("Unknown EventCapabilityMode code '" + codeString + "'");
1488    }
1489
1490    public Enumeration<EventCapabilityMode> fromType(PrimitiveType<?> code) throws FHIRException {
1491      if (code == null)
1492        return null;
1493      if (code.isEmpty())
1494        return new Enumeration<EventCapabilityMode>(this, EventCapabilityMode.NULL, code);
1495      String codeString = code.asStringValue();
1496      if (codeString == null || "".equals(codeString))
1497        return new Enumeration<EventCapabilityMode>(this, EventCapabilityMode.NULL, code);
1498      if ("sender".equals(codeString))
1499        return new Enumeration<EventCapabilityMode>(this, EventCapabilityMode.SENDER, code);
1500      if ("receiver".equals(codeString))
1501        return new Enumeration<EventCapabilityMode>(this, EventCapabilityMode.RECEIVER, code);
1502      throw new FHIRException("Unknown EventCapabilityMode code '" + codeString + "'");
1503    }
1504
1505    public String toCode(EventCapabilityMode code) {
1506       if (code == EventCapabilityMode.NULL)
1507           return null;
1508       if (code == EventCapabilityMode.SENDER)
1509        return "sender";
1510      if (code == EventCapabilityMode.RECEIVER)
1511        return "receiver";
1512      return "?";
1513   }
1514
1515    public String toSystem(EventCapabilityMode code) {
1516      return code.getSystem();
1517    }
1518  }
1519
1520  public enum DocumentMode {
1521    /**
1522     * The application produces documents of the specified type.
1523     */
1524    PRODUCER,
1525    /**
1526     * The application consumes documents of the specified type.
1527     */
1528    CONSUMER,
1529    /**
1530     * added to help the parsers with the generic types
1531     */
1532    NULL;
1533
1534    public static DocumentMode fromCode(String codeString) throws FHIRException {
1535      if (codeString == null || "".equals(codeString))
1536        return null;
1537      if ("producer".equals(codeString))
1538        return PRODUCER;
1539      if ("consumer".equals(codeString))
1540        return CONSUMER;
1541      if (Configuration.isAcceptInvalidEnums())
1542        return null;
1543      else
1544        throw new FHIRException("Unknown DocumentMode code '" + codeString + "'");
1545    }
1546
1547    public String toCode() {
1548      switch (this) {
1549      case PRODUCER:
1550        return "producer";
1551      case CONSUMER:
1552        return "consumer";
1553      case NULL:
1554        return null;
1555      default:
1556        return "?";
1557      }
1558    }
1559
1560    public String getSystem() {
1561      switch (this) {
1562      case PRODUCER:
1563        return "http://hl7.org/fhir/document-mode";
1564      case CONSUMER:
1565        return "http://hl7.org/fhir/document-mode";
1566      case NULL:
1567        return null;
1568      default:
1569        return "?";
1570      }
1571    }
1572
1573    public String getDefinition() {
1574      switch (this) {
1575      case PRODUCER:
1576        return "The application produces documents of the specified type.";
1577      case CONSUMER:
1578        return "The application consumes documents of the specified type.";
1579      case NULL:
1580        return null;
1581      default:
1582        return "?";
1583      }
1584    }
1585
1586    public String getDisplay() {
1587      switch (this) {
1588      case PRODUCER:
1589        return "Producer";
1590      case CONSUMER:
1591        return "Consumer";
1592      case NULL:
1593        return null;
1594      default:
1595        return "?";
1596      }
1597    }
1598  }
1599
1600  public static class DocumentModeEnumFactory implements EnumFactory<DocumentMode> {
1601    public DocumentMode fromCode(String codeString) throws IllegalArgumentException {
1602      if (codeString == null || "".equals(codeString))
1603        if (codeString == null || "".equals(codeString))
1604          return null;
1605      if ("producer".equals(codeString))
1606        return DocumentMode.PRODUCER;
1607      if ("consumer".equals(codeString))
1608        return DocumentMode.CONSUMER;
1609      throw new IllegalArgumentException("Unknown DocumentMode code '" + codeString + "'");
1610    }
1611
1612    public Enumeration<DocumentMode> fromType(PrimitiveType<?> code) throws FHIRException {
1613      if (code == null)
1614        return null;
1615      if (code.isEmpty())
1616        return new Enumeration<DocumentMode>(this, DocumentMode.NULL, code);
1617      String codeString = code.asStringValue();
1618      if (codeString == null || "".equals(codeString))
1619        return new Enumeration<DocumentMode>(this, DocumentMode.NULL, code);
1620      if ("producer".equals(codeString))
1621        return new Enumeration<DocumentMode>(this, DocumentMode.PRODUCER, code);
1622      if ("consumer".equals(codeString))
1623        return new Enumeration<DocumentMode>(this, DocumentMode.CONSUMER, code);
1624      throw new FHIRException("Unknown DocumentMode code '" + codeString + "'");
1625    }
1626
1627    public String toCode(DocumentMode code) {
1628       if (code == DocumentMode.NULL)
1629           return null;
1630       if (code == DocumentMode.PRODUCER)
1631        return "producer";
1632      if (code == DocumentMode.CONSUMER)
1633        return "consumer";
1634      return "?";
1635   }
1636
1637    public String toSystem(DocumentMode code) {
1638      return code.getSystem();
1639    }
1640  }
1641
1642  @Block()
1643  public static class CapabilityStatementSoftwareComponent extends BackboneElement implements IBaseBackboneElement {
1644    /**
1645     * Name the software is known by.
1646     */
1647    @Child(name = "name", type = { StringType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
1648    @Description(shortDefinition = "A name the software is known by", formalDefinition = "Name the software is known by.")
1649    protected StringType name;
1650
1651    /**
1652     * The version identifier for the software covered by this statement.
1653     */
1654    @Child(name = "version", type = { StringType.class }, order = 2, min = 0, max = 1, modifier = false, summary = true)
1655    @Description(shortDefinition = "Version covered by this statement", formalDefinition = "The version identifier for the software covered by this statement.")
1656    protected StringType version;
1657
1658    /**
1659     * Date this version of the software was released.
1660     */
1661    @Child(name = "releaseDate", type = {
1662        DateTimeType.class }, order = 3, min = 0, max = 1, modifier = false, summary = true)
1663    @Description(shortDefinition = "Date this version was released", formalDefinition = "Date this version of the software was released.")
1664    protected DateTimeType releaseDate;
1665
1666    private static final long serialVersionUID = 1819769027L;
1667
1668    /**
1669     * Constructor
1670     */
1671    public CapabilityStatementSoftwareComponent() {
1672      super();
1673    }
1674
1675    /**
1676     * Constructor
1677     */
1678    public CapabilityStatementSoftwareComponent(StringType name) {
1679      super();
1680      this.name = name;
1681    }
1682
1683    /**
1684     * @return {@link #name} (Name the software is known by.). This is the
1685     *         underlying object with id, value and extensions. The accessor
1686     *         "getName" gives direct access to the value
1687     */
1688    public StringType getNameElement() {
1689      if (this.name == null)
1690        if (Configuration.errorOnAutoCreate())
1691          throw new Error("Attempt to auto-create CapabilityStatementSoftwareComponent.name");
1692        else if (Configuration.doAutoCreate())
1693          this.name = new StringType(); // bb
1694      return this.name;
1695    }
1696
1697    public boolean hasNameElement() {
1698      return this.name != null && !this.name.isEmpty();
1699    }
1700
1701    public boolean hasName() {
1702      return this.name != null && !this.name.isEmpty();
1703    }
1704
1705    /**
1706     * @param value {@link #name} (Name the software is known by.). This is the
1707     *              underlying object with id, value and extensions. The accessor
1708     *              "getName" gives direct access to the value
1709     */
1710    public CapabilityStatementSoftwareComponent setNameElement(StringType value) {
1711      this.name = value;
1712      return this;
1713    }
1714
1715    /**
1716     * @return Name the software is known by.
1717     */
1718    public String getName() {
1719      return this.name == null ? null : this.name.getValue();
1720    }
1721
1722    /**
1723     * @param value Name the software is known by.
1724     */
1725    public CapabilityStatementSoftwareComponent setName(String value) {
1726      if (this.name == null)
1727        this.name = new StringType();
1728      this.name.setValue(value);
1729      return this;
1730    }
1731
1732    /**
1733     * @return {@link #version} (The version identifier for the software covered by
1734     *         this statement.). This is the underlying object with id, value and
1735     *         extensions. The accessor "getVersion" gives direct access to the
1736     *         value
1737     */
1738    public StringType getVersionElement() {
1739      if (this.version == null)
1740        if (Configuration.errorOnAutoCreate())
1741          throw new Error("Attempt to auto-create CapabilityStatementSoftwareComponent.version");
1742        else if (Configuration.doAutoCreate())
1743          this.version = new StringType(); // bb
1744      return this.version;
1745    }
1746
1747    public boolean hasVersionElement() {
1748      return this.version != null && !this.version.isEmpty();
1749    }
1750
1751    public boolean hasVersion() {
1752      return this.version != null && !this.version.isEmpty();
1753    }
1754
1755    /**
1756     * @param value {@link #version} (The version identifier for the software
1757     *              covered by this statement.). This is the underlying object with
1758     *              id, value and extensions. The accessor "getVersion" gives direct
1759     *              access to the value
1760     */
1761    public CapabilityStatementSoftwareComponent setVersionElement(StringType value) {
1762      this.version = value;
1763      return this;
1764    }
1765
1766    /**
1767     * @return The version identifier for the software covered by this statement.
1768     */
1769    public String getVersion() {
1770      return this.version == null ? null : this.version.getValue();
1771    }
1772
1773    /**
1774     * @param value The version identifier for the software covered by this
1775     *              statement.
1776     */
1777    public CapabilityStatementSoftwareComponent setVersion(String value) {
1778      if (Utilities.noString(value))
1779        this.version = null;
1780      else {
1781        if (this.version == null)
1782          this.version = new StringType();
1783        this.version.setValue(value);
1784      }
1785      return this;
1786    }
1787
1788    /**
1789     * @return {@link #releaseDate} (Date this version of the software was
1790     *         released.). This is the underlying object with id, value and
1791     *         extensions. The accessor "getReleaseDate" gives direct access to the
1792     *         value
1793     */
1794    public DateTimeType getReleaseDateElement() {
1795      if (this.releaseDate == null)
1796        if (Configuration.errorOnAutoCreate())
1797          throw new Error("Attempt to auto-create CapabilityStatementSoftwareComponent.releaseDate");
1798        else if (Configuration.doAutoCreate())
1799          this.releaseDate = new DateTimeType(); // bb
1800      return this.releaseDate;
1801    }
1802
1803    public boolean hasReleaseDateElement() {
1804      return this.releaseDate != null && !this.releaseDate.isEmpty();
1805    }
1806
1807    public boolean hasReleaseDate() {
1808      return this.releaseDate != null && !this.releaseDate.isEmpty();
1809    }
1810
1811    /**
1812     * @param value {@link #releaseDate} (Date this version of the software was
1813     *              released.). This is the underlying object with id, value and
1814     *              extensions. The accessor "getReleaseDate" gives direct access to
1815     *              the value
1816     */
1817    public CapabilityStatementSoftwareComponent setReleaseDateElement(DateTimeType value) {
1818      this.releaseDate = value;
1819      return this;
1820    }
1821
1822    /**
1823     * @return Date this version of the software was released.
1824     */
1825    public Date getReleaseDate() {
1826      return this.releaseDate == null ? null : this.releaseDate.getValue();
1827    }
1828
1829    /**
1830     * @param value Date this version of the software was released.
1831     */
1832    public CapabilityStatementSoftwareComponent setReleaseDate(Date value) {
1833      if (value == null)
1834        this.releaseDate = null;
1835      else {
1836        if (this.releaseDate == null)
1837          this.releaseDate = new DateTimeType();
1838        this.releaseDate.setValue(value);
1839      }
1840      return this;
1841    }
1842
1843    protected void listChildren(List<Property> children) {
1844      super.listChildren(children);
1845      children.add(new Property("name", "string", "Name the software is known by.", 0, 1, name));
1846      children.add(new Property("version", "string",
1847          "The version identifier for the software covered by this statement.", 0, 1, version));
1848      children.add(new Property("releaseDate", "dateTime", "Date this version of the software was released.", 0, 1,
1849          releaseDate));
1850    }
1851
1852    @Override
1853    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
1854      switch (_hash) {
1855      case 3373707:
1856        /* name */ return new Property("name", "string", "Name the software is known by.", 0, 1, name);
1857      case 351608024:
1858        /* version */ return new Property("version", "string",
1859            "The version identifier for the software covered by this statement.", 0, 1, version);
1860      case 212873301:
1861        /* releaseDate */ return new Property("releaseDate", "dateTime",
1862            "Date this version of the software was released.", 0, 1, releaseDate);
1863      default:
1864        return super.getNamedProperty(_hash, _name, _checkValid);
1865      }
1866
1867    }
1868
1869    @Override
1870    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
1871      switch (hash) {
1872      case 3373707:
1873        /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
1874      case 351608024:
1875        /* version */ return this.version == null ? new Base[0] : new Base[] { this.version }; // StringType
1876      case 212873301:
1877        /* releaseDate */ return this.releaseDate == null ? new Base[0] : new Base[] { this.releaseDate }; // DateTimeType
1878      default:
1879        return super.getProperty(hash, name, checkValid);
1880      }
1881
1882    }
1883
1884    @Override
1885    public Base setProperty(int hash, String name, Base value) throws FHIRException {
1886      switch (hash) {
1887      case 3373707: // name
1888        this.name = castToString(value); // StringType
1889        return value;
1890      case 351608024: // version
1891        this.version = castToString(value); // StringType
1892        return value;
1893      case 212873301: // releaseDate
1894        this.releaseDate = castToDateTime(value); // DateTimeType
1895        return value;
1896      default:
1897        return super.setProperty(hash, name, value);
1898      }
1899
1900    }
1901
1902    @Override
1903    public Base setProperty(String name, Base value) throws FHIRException {
1904      if (name.equals("name")) {
1905        this.name = castToString(value); // StringType
1906      } else if (name.equals("version")) {
1907        this.version = castToString(value); // StringType
1908      } else if (name.equals("releaseDate")) {
1909        this.releaseDate = castToDateTime(value); // DateTimeType
1910      } else
1911        return super.setProperty(name, value);
1912      return value;
1913    }
1914
1915  @Override
1916  public void removeChild(String name, Base value) throws FHIRException {
1917      if (name.equals("name")) {
1918        this.name = null;
1919      } else if (name.equals("version")) {
1920        this.version = null;
1921      } else if (name.equals("releaseDate")) {
1922        this.releaseDate = null;
1923      } else
1924        super.removeChild(name, value);
1925      
1926    }
1927
1928    @Override
1929    public Base makeProperty(int hash, String name) throws FHIRException {
1930      switch (hash) {
1931      case 3373707:
1932        return getNameElement();
1933      case 351608024:
1934        return getVersionElement();
1935      case 212873301:
1936        return getReleaseDateElement();
1937      default:
1938        return super.makeProperty(hash, name);
1939      }
1940
1941    }
1942
1943    @Override
1944    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
1945      switch (hash) {
1946      case 3373707:
1947        /* name */ return new String[] { "string" };
1948      case 351608024:
1949        /* version */ return new String[] { "string" };
1950      case 212873301:
1951        /* releaseDate */ return new String[] { "dateTime" };
1952      default:
1953        return super.getTypesForProperty(hash, name);
1954      }
1955
1956    }
1957
1958    @Override
1959    public Base addChild(String name) throws FHIRException {
1960      if (name.equals("name")) {
1961        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.name");
1962      } else if (name.equals("version")) {
1963        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.version");
1964      } else if (name.equals("releaseDate")) {
1965        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.releaseDate");
1966      } else
1967        return super.addChild(name);
1968    }
1969
1970    public CapabilityStatementSoftwareComponent copy() {
1971      CapabilityStatementSoftwareComponent dst = new CapabilityStatementSoftwareComponent();
1972      copyValues(dst);
1973      return dst;
1974    }
1975
1976    public void copyValues(CapabilityStatementSoftwareComponent dst) {
1977      super.copyValues(dst);
1978      dst.name = name == null ? null : name.copy();
1979      dst.version = version == null ? null : version.copy();
1980      dst.releaseDate = releaseDate == null ? null : releaseDate.copy();
1981    }
1982
1983    @Override
1984    public boolean equalsDeep(Base other_) {
1985      if (!super.equalsDeep(other_))
1986        return false;
1987      if (!(other_ instanceof CapabilityStatementSoftwareComponent))
1988        return false;
1989      CapabilityStatementSoftwareComponent o = (CapabilityStatementSoftwareComponent) other_;
1990      return compareDeep(name, o.name, true) && compareDeep(version, o.version, true)
1991          && compareDeep(releaseDate, o.releaseDate, true);
1992    }
1993
1994    @Override
1995    public boolean equalsShallow(Base other_) {
1996      if (!super.equalsShallow(other_))
1997        return false;
1998      if (!(other_ instanceof CapabilityStatementSoftwareComponent))
1999        return false;
2000      CapabilityStatementSoftwareComponent o = (CapabilityStatementSoftwareComponent) other_;
2001      return compareValues(name, o.name, true) && compareValues(version, o.version, true)
2002          && compareValues(releaseDate, o.releaseDate, true);
2003    }
2004
2005    public boolean isEmpty() {
2006      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(name, version, releaseDate);
2007    }
2008
2009    public String fhirType() {
2010      return "CapabilityStatement.software";
2011
2012    }
2013
2014  }
2015
2016  @Block()
2017  public static class CapabilityStatementImplementationComponent extends BackboneElement
2018      implements IBaseBackboneElement {
2019    /**
2020     * Information about the specific installation that this capability statement
2021     * relates to.
2022     */
2023    @Child(name = "description", type = {
2024        StringType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
2025    @Description(shortDefinition = "Describes this specific instance", formalDefinition = "Information about the specific installation that this capability statement relates to.")
2026    protected StringType description;
2027
2028    /**
2029     * An absolute base URL for the implementation. This forms the base for REST
2030     * interfaces as well as the mailbox and document interfaces.
2031     */
2032    @Child(name = "url", type = { UrlType.class }, order = 2, min = 0, max = 1, modifier = false, summary = true)
2033    @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.")
2034    protected UrlType url;
2035
2036    /**
2037     * The organization responsible for the management of the instance and oversight
2038     * of the data on the server at the specified URL.
2039     */
2040    @Child(name = "custodian", type = {
2041        Organization.class }, order = 3, min = 0, max = 1, modifier = false, summary = true)
2042    @Description(shortDefinition = "Organization that manages the data", formalDefinition = "The organization responsible for the management of the instance and oversight of the data on the server at the specified URL.")
2043    protected Reference custodian;
2044
2045    /**
2046     * The actual object that is the target of the reference (The organization
2047     * responsible for the management of the instance and oversight of the data on
2048     * the server at the specified URL.)
2049     */
2050    protected Organization custodianTarget;
2051
2052    private static final long serialVersionUID = -1705695694L;
2053
2054    /**
2055     * Constructor
2056     */
2057    public CapabilityStatementImplementationComponent() {
2058      super();
2059    }
2060
2061    /**
2062     * Constructor
2063     */
2064    public CapabilityStatementImplementationComponent(StringType description) {
2065      super();
2066      this.description = description;
2067    }
2068
2069    /**
2070     * @return {@link #description} (Information about the specific installation
2071     *         that this capability statement relates to.). This is the underlying
2072     *         object with id, value and extensions. The accessor "getDescription"
2073     *         gives direct access to the value
2074     */
2075    public StringType getDescriptionElement() {
2076      if (this.description == null)
2077        if (Configuration.errorOnAutoCreate())
2078          throw new Error("Attempt to auto-create CapabilityStatementImplementationComponent.description");
2079        else if (Configuration.doAutoCreate())
2080          this.description = new StringType(); // bb
2081      return this.description;
2082    }
2083
2084    public boolean hasDescriptionElement() {
2085      return this.description != null && !this.description.isEmpty();
2086    }
2087
2088    public boolean hasDescription() {
2089      return this.description != null && !this.description.isEmpty();
2090    }
2091
2092    /**
2093     * @param value {@link #description} (Information about the specific
2094     *              installation that this capability statement relates to.). This
2095     *              is the underlying object with id, value and extensions. The
2096     *              accessor "getDescription" gives direct access to the value
2097     */
2098    public CapabilityStatementImplementationComponent setDescriptionElement(StringType value) {
2099      this.description = value;
2100      return this;
2101    }
2102
2103    /**
2104     * @return Information about the specific installation that this capability
2105     *         statement relates to.
2106     */
2107    public String getDescription() {
2108      return this.description == null ? null : this.description.getValue();
2109    }
2110
2111    /**
2112     * @param value Information about the specific installation that this capability
2113     *              statement relates to.
2114     */
2115    public CapabilityStatementImplementationComponent setDescription(String value) {
2116      if (this.description == null)
2117        this.description = new StringType();
2118      this.description.setValue(value);
2119      return this;
2120    }
2121
2122    /**
2123     * @return {@link #url} (An absolute base URL for the implementation. This forms
2124     *         the base for REST interfaces as well as the mailbox and document
2125     *         interfaces.). This is the underlying object with id, value and
2126     *         extensions. The accessor "getUrl" gives direct access to the value
2127     */
2128    public UrlType getUrlElement() {
2129      if (this.url == null)
2130        if (Configuration.errorOnAutoCreate())
2131          throw new Error("Attempt to auto-create CapabilityStatementImplementationComponent.url");
2132        else if (Configuration.doAutoCreate())
2133          this.url = new UrlType(); // bb
2134      return this.url;
2135    }
2136
2137    public boolean hasUrlElement() {
2138      return this.url != null && !this.url.isEmpty();
2139    }
2140
2141    public boolean hasUrl() {
2142      return this.url != null && !this.url.isEmpty();
2143    }
2144
2145    /**
2146     * @param value {@link #url} (An absolute base URL for the implementation. This
2147     *              forms the base for REST interfaces as well as the mailbox and
2148     *              document interfaces.). This is the underlying object with id,
2149     *              value and extensions. The accessor "getUrl" gives direct access
2150     *              to the value
2151     */
2152    public CapabilityStatementImplementationComponent setUrlElement(UrlType value) {
2153      this.url = value;
2154      return this;
2155    }
2156
2157    /**
2158     * @return An absolute base URL for the implementation. This forms the base for
2159     *         REST interfaces as well as the mailbox and document interfaces.
2160     */
2161    public String getUrl() {
2162      return this.url == null ? null : this.url.getValue();
2163    }
2164
2165    /**
2166     * @param value An absolute base URL for the implementation. This forms the base
2167     *              for REST interfaces as well as the mailbox and document
2168     *              interfaces.
2169     */
2170    public CapabilityStatementImplementationComponent setUrl(String value) {
2171      if (Utilities.noString(value))
2172        this.url = null;
2173      else {
2174        if (this.url == null)
2175          this.url = new UrlType();
2176        this.url.setValue(value);
2177      }
2178      return this;
2179    }
2180
2181    /**
2182     * @return {@link #custodian} (The organization responsible for the management
2183     *         of the instance and oversight of the data on the server at the
2184     *         specified URL.)
2185     */
2186    public Reference getCustodian() {
2187      if (this.custodian == null)
2188        if (Configuration.errorOnAutoCreate())
2189          throw new Error("Attempt to auto-create CapabilityStatementImplementationComponent.custodian");
2190        else if (Configuration.doAutoCreate())
2191          this.custodian = new Reference(); // cc
2192      return this.custodian;
2193    }
2194
2195    public boolean hasCustodian() {
2196      return this.custodian != null && !this.custodian.isEmpty();
2197    }
2198
2199    /**
2200     * @param value {@link #custodian} (The organization responsible for the
2201     *              management of the instance and oversight of the data on the
2202     *              server at the specified URL.)
2203     */
2204    public CapabilityStatementImplementationComponent setCustodian(Reference value) {
2205      this.custodian = value;
2206      return this;
2207    }
2208
2209    /**
2210     * @return {@link #custodian} The actual object that is the target of the
2211     *         reference. The reference library doesn't populate this, but you can
2212     *         use it to hold the resource if you resolve it. (The organization
2213     *         responsible for the management of the instance and oversight of the
2214     *         data on the server at the specified URL.)
2215     */
2216    public Organization getCustodianTarget() {
2217      if (this.custodianTarget == null)
2218        if (Configuration.errorOnAutoCreate())
2219          throw new Error("Attempt to auto-create CapabilityStatementImplementationComponent.custodian");
2220        else if (Configuration.doAutoCreate())
2221          this.custodianTarget = new Organization(); // aa
2222      return this.custodianTarget;
2223    }
2224
2225    /**
2226     * @param value {@link #custodian} The actual object that is the target of the
2227     *              reference. The reference library doesn't use these, but you can
2228     *              use it to hold the resource if you resolve it. (The organization
2229     *              responsible for the management of the instance and oversight of
2230     *              the data on the server at the specified URL.)
2231     */
2232    public CapabilityStatementImplementationComponent setCustodianTarget(Organization value) {
2233      this.custodianTarget = value;
2234      return this;
2235    }
2236
2237    protected void listChildren(List<Property> children) {
2238      super.listChildren(children);
2239      children.add(new Property("description", "string",
2240          "Information about the specific installation that this capability statement relates to.", 0, 1, description));
2241      children.add(new Property("url", "url",
2242          "An absolute base URL for the implementation.  This forms the base for REST interfaces as well as the mailbox and document interfaces.",
2243          0, 1, url));
2244      children.add(new Property("custodian", "Reference(Organization)",
2245          "The organization responsible for the management of the instance and oversight of the data on the server at the specified URL.",
2246          0, 1, custodian));
2247    }
2248
2249    @Override
2250    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
2251      switch (_hash) {
2252      case -1724546052:
2253        /* description */ return new Property("description", "string",
2254            "Information about the specific installation that this capability statement relates to.", 0, 1,
2255            description);
2256      case 116079:
2257        /* url */ return new Property("url", "url",
2258            "An absolute base URL for the implementation.  This forms the base for REST interfaces as well as the mailbox and document interfaces.",
2259            0, 1, url);
2260      case 1611297262:
2261        /* custodian */ return new Property("custodian", "Reference(Organization)",
2262            "The organization responsible for the management of the instance and oversight of the data on the server at the specified URL.",
2263            0, 1, custodian);
2264      default:
2265        return super.getNamedProperty(_hash, _name, _checkValid);
2266      }
2267
2268    }
2269
2270    @Override
2271    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
2272      switch (hash) {
2273      case -1724546052:
2274        /* description */ return this.description == null ? new Base[0] : new Base[] { this.description }; // StringType
2275      case 116079:
2276        /* url */ return this.url == null ? new Base[0] : new Base[] { this.url }; // UrlType
2277      case 1611297262:
2278        /* custodian */ return this.custodian == null ? new Base[0] : new Base[] { this.custodian }; // Reference
2279      default:
2280        return super.getProperty(hash, name, checkValid);
2281      }
2282
2283    }
2284
2285    @Override
2286    public Base setProperty(int hash, String name, Base value) throws FHIRException {
2287      switch (hash) {
2288      case -1724546052: // description
2289        this.description = castToString(value); // StringType
2290        return value;
2291      case 116079: // url
2292        this.url = castToUrl(value); // UrlType
2293        return value;
2294      case 1611297262: // custodian
2295        this.custodian = castToReference(value); // Reference
2296        return value;
2297      default:
2298        return super.setProperty(hash, name, value);
2299      }
2300
2301    }
2302
2303    @Override
2304    public Base setProperty(String name, Base value) throws FHIRException {
2305      if (name.equals("description")) {
2306        this.description = castToString(value); // StringType
2307      } else if (name.equals("url")) {
2308        this.url = castToUrl(value); // UrlType
2309      } else if (name.equals("custodian")) {
2310        this.custodian = castToReference(value); // Reference
2311      } else
2312        return super.setProperty(name, value);
2313      return value;
2314    }
2315
2316  @Override
2317  public void removeChild(String name, Base value) throws FHIRException {
2318      if (name.equals("description")) {
2319        this.description = null;
2320      } else if (name.equals("url")) {
2321        this.url = null;
2322      } else if (name.equals("custodian")) {
2323        this.custodian = null;
2324      } else
2325        super.removeChild(name, value);
2326      
2327    }
2328
2329    @Override
2330    public Base makeProperty(int hash, String name) throws FHIRException {
2331      switch (hash) {
2332      case -1724546052:
2333        return getDescriptionElement();
2334      case 116079:
2335        return getUrlElement();
2336      case 1611297262:
2337        return getCustodian();
2338      default:
2339        return super.makeProperty(hash, name);
2340      }
2341
2342    }
2343
2344    @Override
2345    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
2346      switch (hash) {
2347      case -1724546052:
2348        /* description */ return new String[] { "string" };
2349      case 116079:
2350        /* url */ return new String[] { "url" };
2351      case 1611297262:
2352        /* custodian */ return new String[] { "Reference" };
2353      default:
2354        return super.getTypesForProperty(hash, name);
2355      }
2356
2357    }
2358
2359    @Override
2360    public Base addChild(String name) throws FHIRException {
2361      if (name.equals("description")) {
2362        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.description");
2363      } else if (name.equals("url")) {
2364        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.url");
2365      } else if (name.equals("custodian")) {
2366        this.custodian = new Reference();
2367        return this.custodian;
2368      } else
2369        return super.addChild(name);
2370    }
2371
2372    public CapabilityStatementImplementationComponent copy() {
2373      CapabilityStatementImplementationComponent dst = new CapabilityStatementImplementationComponent();
2374      copyValues(dst);
2375      return dst;
2376    }
2377
2378    public void copyValues(CapabilityStatementImplementationComponent dst) {
2379      super.copyValues(dst);
2380      dst.description = description == null ? null : description.copy();
2381      dst.url = url == null ? null : url.copy();
2382      dst.custodian = custodian == null ? null : custodian.copy();
2383    }
2384
2385    @Override
2386    public boolean equalsDeep(Base other_) {
2387      if (!super.equalsDeep(other_))
2388        return false;
2389      if (!(other_ instanceof CapabilityStatementImplementationComponent))
2390        return false;
2391      CapabilityStatementImplementationComponent o = (CapabilityStatementImplementationComponent) other_;
2392      return compareDeep(description, o.description, true) && compareDeep(url, o.url, true)
2393          && compareDeep(custodian, o.custodian, true);
2394    }
2395
2396    @Override
2397    public boolean equalsShallow(Base other_) {
2398      if (!super.equalsShallow(other_))
2399        return false;
2400      if (!(other_ instanceof CapabilityStatementImplementationComponent))
2401        return false;
2402      CapabilityStatementImplementationComponent o = (CapabilityStatementImplementationComponent) other_;
2403      return compareValues(description, o.description, true) && compareValues(url, o.url, true);
2404    }
2405
2406    public boolean isEmpty() {
2407      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(description, url, custodian);
2408    }
2409
2410    public String fhirType() {
2411      return "CapabilityStatement.implementation";
2412
2413    }
2414
2415  }
2416
2417  @Block()
2418  public static class CapabilityStatementRestComponent extends BackboneElement implements IBaseBackboneElement {
2419    /**
2420     * Identifies whether this portion of the statement is describing the ability to
2421     * initiate or receive restful operations.
2422     */
2423    @Child(name = "mode", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
2424    @Description(shortDefinition = "client | server", formalDefinition = "Identifies whether this portion of the statement is describing the ability to initiate or receive restful operations.")
2425    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/restful-capability-mode")
2426    protected Enumeration<RestfulCapabilityMode> mode;
2427
2428    /**
2429     * Information about the system's restful capabilities that apply across all
2430     * applications, such as security.
2431     */
2432    @Child(name = "documentation", type = {
2433        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
2434    @Description(shortDefinition = "General description of implementation", formalDefinition = "Information about the system's restful capabilities that apply across all applications, such as security.")
2435    protected MarkdownType documentation;
2436
2437    /**
2438     * Information about security implementation from an interface perspective -
2439     * what a client needs to know.
2440     */
2441    @Child(name = "security", type = {}, order = 3, min = 0, max = 1, modifier = false, summary = true)
2442    @Description(shortDefinition = "Information about security of implementation", formalDefinition = "Information about security implementation from an interface perspective - what a client needs to know.")
2443    protected CapabilityStatementRestSecurityComponent security;
2444
2445    /**
2446     * A specification of the restful capabilities of the solution for a specific
2447     * resource type.
2448     */
2449    @Child(name = "resource", type = {}, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
2450    @Description(shortDefinition = "Resource served on the REST interface", formalDefinition = "A specification of the restful capabilities of the solution for a specific resource type.")
2451    protected List<CapabilityStatementRestResourceComponent> resource;
2452
2453    /**
2454     * A specification of restful operations supported by the system.
2455     */
2456    @Child(name = "interaction", type = {}, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2457    @Description(shortDefinition = "What operations are supported?", formalDefinition = "A specification of restful operations supported by the system.")
2458    protected List<SystemInteractionComponent> interaction;
2459
2460    /**
2461     * Search parameters that are supported for searching all resources for
2462     * implementations to support and/or make use of - either references to ones
2463     * defined in the specification, or additional ones defined for/by the
2464     * implementation.
2465     */
2466    @Child(name = "searchParam", type = {
2467        CapabilityStatementRestResourceSearchParamComponent.class }, order = 6, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2468    @Description(shortDefinition = "Search parameters 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.")
2469    protected List<CapabilityStatementRestResourceSearchParamComponent> searchParam;
2470
2471    /**
2472     * Definition of an operation or a named query together with its parameters and
2473     * their meaning and type.
2474     */
2475    @Child(name = "operation", type = {
2476        CapabilityStatementRestResourceOperationComponent.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
2477    @Description(shortDefinition = "Definition of a system level operation", formalDefinition = "Definition of an operation or a named query together with its parameters and their meaning and type.")
2478    protected List<CapabilityStatementRestResourceOperationComponent> operation;
2479
2480    /**
2481     * An absolute URI which is a reference to the definition of a compartment that
2482     * the system supports. The reference is to a CompartmentDefinition resource by
2483     * its canonical URL .
2484     */
2485    @Child(name = "compartment", type = {
2486        CanonicalType.class }, order = 8, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
2487    @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 its canonical URL .")
2488    protected List<CanonicalType> compartment;
2489
2490    private static final long serialVersionUID = -1442029817L;
2491
2492    /**
2493     * Constructor
2494     */
2495    public CapabilityStatementRestComponent() {
2496      super();
2497    }
2498
2499    /**
2500     * Constructor
2501     */
2502    public CapabilityStatementRestComponent(Enumeration<RestfulCapabilityMode> mode) {
2503      super();
2504      this.mode = mode;
2505    }
2506
2507    /**
2508     * @return {@link #mode} (Identifies whether this portion of the statement is
2509     *         describing the ability to initiate or receive restful operations.).
2510     *         This is the underlying object with id, value and extensions. The
2511     *         accessor "getMode" gives direct access to the value
2512     */
2513    public Enumeration<RestfulCapabilityMode> getModeElement() {
2514      if (this.mode == null)
2515        if (Configuration.errorOnAutoCreate())
2516          throw new Error("Attempt to auto-create CapabilityStatementRestComponent.mode");
2517        else if (Configuration.doAutoCreate())
2518          this.mode = new Enumeration<RestfulCapabilityMode>(new RestfulCapabilityModeEnumFactory()); // bb
2519      return this.mode;
2520    }
2521
2522    public boolean hasModeElement() {
2523      return this.mode != null && !this.mode.isEmpty();
2524    }
2525
2526    public boolean hasMode() {
2527      return this.mode != null && !this.mode.isEmpty();
2528    }
2529
2530    /**
2531     * @param value {@link #mode} (Identifies whether this portion of the statement
2532     *              is describing the ability to initiate or receive restful
2533     *              operations.). This is the underlying object with id, value and
2534     *              extensions. The accessor "getMode" gives direct access to the
2535     *              value
2536     */
2537    public CapabilityStatementRestComponent setModeElement(Enumeration<RestfulCapabilityMode> value) {
2538      this.mode = value;
2539      return this;
2540    }
2541
2542    /**
2543     * @return Identifies whether this portion of the statement is describing the
2544     *         ability to initiate or receive restful operations.
2545     */
2546    public RestfulCapabilityMode getMode() {
2547      return this.mode == null ? null : this.mode.getValue();
2548    }
2549
2550    /**
2551     * @param value Identifies whether this portion of the statement is describing
2552     *              the ability to initiate or receive restful operations.
2553     */
2554    public CapabilityStatementRestComponent setMode(RestfulCapabilityMode value) {
2555      if (this.mode == null)
2556        this.mode = new Enumeration<RestfulCapabilityMode>(new RestfulCapabilityModeEnumFactory());
2557      this.mode.setValue(value);
2558      return this;
2559    }
2560
2561    /**
2562     * @return {@link #documentation} (Information about the system's restful
2563     *         capabilities that apply across all applications, such as security.).
2564     *         This is the underlying object with id, value and extensions. The
2565     *         accessor "getDocumentation" gives direct access to the value
2566     */
2567    public MarkdownType getDocumentationElement() {
2568      if (this.documentation == null)
2569        if (Configuration.errorOnAutoCreate())
2570          throw new Error("Attempt to auto-create CapabilityStatementRestComponent.documentation");
2571        else if (Configuration.doAutoCreate())
2572          this.documentation = new MarkdownType(); // bb
2573      return this.documentation;
2574    }
2575
2576    public boolean hasDocumentationElement() {
2577      return this.documentation != null && !this.documentation.isEmpty();
2578    }
2579
2580    public boolean hasDocumentation() {
2581      return this.documentation != null && !this.documentation.isEmpty();
2582    }
2583
2584    /**
2585     * @param value {@link #documentation} (Information about the system's restful
2586     *              capabilities that apply across all applications, such as
2587     *              security.). This is the underlying object with id, value and
2588     *              extensions. The accessor "getDocumentation" gives direct access
2589     *              to the value
2590     */
2591    public CapabilityStatementRestComponent setDocumentationElement(MarkdownType value) {
2592      this.documentation = value;
2593      return this;
2594    }
2595
2596    /**
2597     * @return Information about the system's restful capabilities that apply across
2598     *         all applications, such as security.
2599     */
2600    public String getDocumentation() {
2601      return this.documentation == null ? null : this.documentation.getValue();
2602    }
2603
2604    /**
2605     * @param value Information about the system's restful capabilities that apply
2606     *              across all applications, such as security.
2607     */
2608    public CapabilityStatementRestComponent setDocumentation(String value) {
2609      if (value == null)
2610        this.documentation = null;
2611      else {
2612        if (this.documentation == null)
2613          this.documentation = new MarkdownType();
2614        this.documentation.setValue(value);
2615      }
2616      return this;
2617    }
2618
2619    /**
2620     * @return {@link #security} (Information about security implementation from an
2621     *         interface perspective - what a client needs to know.)
2622     */
2623    public CapabilityStatementRestSecurityComponent getSecurity() {
2624      if (this.security == null)
2625        if (Configuration.errorOnAutoCreate())
2626          throw new Error("Attempt to auto-create CapabilityStatementRestComponent.security");
2627        else if (Configuration.doAutoCreate())
2628          this.security = new CapabilityStatementRestSecurityComponent(); // cc
2629      return this.security;
2630    }
2631
2632    public boolean hasSecurity() {
2633      return this.security != null && !this.security.isEmpty();
2634    }
2635
2636    /**
2637     * @param value {@link #security} (Information about security implementation
2638     *              from an interface perspective - what a client needs to know.)
2639     */
2640    public CapabilityStatementRestComponent setSecurity(CapabilityStatementRestSecurityComponent value) {
2641      this.security = value;
2642      return this;
2643    }
2644
2645    /**
2646     * @return {@link #resource} (A specification of the restful capabilities of the
2647     *         solution for a specific resource type.)
2648     */
2649    public List<CapabilityStatementRestResourceComponent> getResource() {
2650      if (this.resource == null)
2651        this.resource = new ArrayList<CapabilityStatementRestResourceComponent>();
2652      return this.resource;
2653    }
2654
2655    /**
2656     * @return Returns a reference to <code>this</code> for easy method chaining
2657     */
2658    public CapabilityStatementRestComponent setResource(List<CapabilityStatementRestResourceComponent> theResource) {
2659      this.resource = theResource;
2660      return this;
2661    }
2662
2663    public boolean hasResource() {
2664      if (this.resource == null)
2665        return false;
2666      for (CapabilityStatementRestResourceComponent item : this.resource)
2667        if (!item.isEmpty())
2668          return true;
2669      return false;
2670    }
2671
2672    public CapabilityStatementRestResourceComponent addResource() { // 3
2673      CapabilityStatementRestResourceComponent t = new CapabilityStatementRestResourceComponent();
2674      if (this.resource == null)
2675        this.resource = new ArrayList<CapabilityStatementRestResourceComponent>();
2676      this.resource.add(t);
2677      return t;
2678    }
2679
2680    public CapabilityStatementRestComponent addResource(CapabilityStatementRestResourceComponent t) { // 3
2681      if (t == null)
2682        return this;
2683      if (this.resource == null)
2684        this.resource = new ArrayList<CapabilityStatementRestResourceComponent>();
2685      this.resource.add(t);
2686      return this;
2687    }
2688
2689    /**
2690     * @return The first repetition of repeating field {@link #resource}, creating
2691     *         it if it does not already exist
2692     */
2693    public CapabilityStatementRestResourceComponent getResourceFirstRep() {
2694      if (getResource().isEmpty()) {
2695        addResource();
2696      }
2697      return getResource().get(0);
2698    }
2699
2700    /**
2701     * @return {@link #interaction} (A specification of restful operations supported
2702     *         by the system.)
2703     */
2704    public List<SystemInteractionComponent> getInteraction() {
2705      if (this.interaction == null)
2706        this.interaction = new ArrayList<SystemInteractionComponent>();
2707      return this.interaction;
2708    }
2709
2710    /**
2711     * @return Returns a reference to <code>this</code> for easy method chaining
2712     */
2713    public CapabilityStatementRestComponent setInteraction(List<SystemInteractionComponent> theInteraction) {
2714      this.interaction = theInteraction;
2715      return this;
2716    }
2717
2718    public boolean hasInteraction() {
2719      if (this.interaction == null)
2720        return false;
2721      for (SystemInteractionComponent item : this.interaction)
2722        if (!item.isEmpty())
2723          return true;
2724      return false;
2725    }
2726
2727    public SystemInteractionComponent addInteraction() { // 3
2728      SystemInteractionComponent t = new SystemInteractionComponent();
2729      if (this.interaction == null)
2730        this.interaction = new ArrayList<SystemInteractionComponent>();
2731      this.interaction.add(t);
2732      return t;
2733    }
2734
2735    public CapabilityStatementRestComponent addInteraction(SystemInteractionComponent t) { // 3
2736      if (t == null)
2737        return this;
2738      if (this.interaction == null)
2739        this.interaction = new ArrayList<SystemInteractionComponent>();
2740      this.interaction.add(t);
2741      return this;
2742    }
2743
2744    /**
2745     * @return The first repetition of repeating field {@link #interaction},
2746     *         creating it if it does not already exist
2747     */
2748    public SystemInteractionComponent getInteractionFirstRep() {
2749      if (getInteraction().isEmpty()) {
2750        addInteraction();
2751      }
2752      return getInteraction().get(0);
2753    }
2754
2755    /**
2756     * @return {@link #searchParam} (Search parameters that are supported for
2757     *         searching all resources for implementations to support and/or make
2758     *         use of - either references to ones defined in the specification, or
2759     *         additional ones defined for/by the implementation.)
2760     */
2761    public List<CapabilityStatementRestResourceSearchParamComponent> getSearchParam() {
2762      if (this.searchParam == null)
2763        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
2764      return this.searchParam;
2765    }
2766
2767    /**
2768     * @return Returns a reference to <code>this</code> for easy method chaining
2769     */
2770    public CapabilityStatementRestComponent setSearchParam(
2771        List<CapabilityStatementRestResourceSearchParamComponent> theSearchParam) {
2772      this.searchParam = theSearchParam;
2773      return this;
2774    }
2775
2776    public boolean hasSearchParam() {
2777      if (this.searchParam == null)
2778        return false;
2779      for (CapabilityStatementRestResourceSearchParamComponent item : this.searchParam)
2780        if (!item.isEmpty())
2781          return true;
2782      return false;
2783    }
2784
2785    public CapabilityStatementRestResourceSearchParamComponent addSearchParam() { // 3
2786      CapabilityStatementRestResourceSearchParamComponent t = new CapabilityStatementRestResourceSearchParamComponent();
2787      if (this.searchParam == null)
2788        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
2789      this.searchParam.add(t);
2790      return t;
2791    }
2792
2793    public CapabilityStatementRestComponent addSearchParam(CapabilityStatementRestResourceSearchParamComponent t) { // 3
2794      if (t == null)
2795        return this;
2796      if (this.searchParam == null)
2797        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
2798      this.searchParam.add(t);
2799      return this;
2800    }
2801
2802    /**
2803     * @return The first repetition of repeating field {@link #searchParam},
2804     *         creating it if it does not already exist
2805     */
2806    public CapabilityStatementRestResourceSearchParamComponent getSearchParamFirstRep() {
2807      if (getSearchParam().isEmpty()) {
2808        addSearchParam();
2809      }
2810      return getSearchParam().get(0);
2811    }
2812
2813    /**
2814     * @return {@link #operation} (Definition of an operation or a named query
2815     *         together with its parameters and their meaning and type.)
2816     */
2817    public List<CapabilityStatementRestResourceOperationComponent> getOperation() {
2818      if (this.operation == null)
2819        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
2820      return this.operation;
2821    }
2822
2823    /**
2824     * @return Returns a reference to <code>this</code> for easy method chaining
2825     */
2826    public CapabilityStatementRestComponent setOperation(
2827        List<CapabilityStatementRestResourceOperationComponent> theOperation) {
2828      this.operation = theOperation;
2829      return this;
2830    }
2831
2832    public boolean hasOperation() {
2833      if (this.operation == null)
2834        return false;
2835      for (CapabilityStatementRestResourceOperationComponent item : this.operation)
2836        if (!item.isEmpty())
2837          return true;
2838      return false;
2839    }
2840
2841    public CapabilityStatementRestResourceOperationComponent addOperation() { // 3
2842      CapabilityStatementRestResourceOperationComponent t = new CapabilityStatementRestResourceOperationComponent();
2843      if (this.operation == null)
2844        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
2845      this.operation.add(t);
2846      return t;
2847    }
2848
2849    public CapabilityStatementRestComponent addOperation(CapabilityStatementRestResourceOperationComponent t) { // 3
2850      if (t == null)
2851        return this;
2852      if (this.operation == null)
2853        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
2854      this.operation.add(t);
2855      return this;
2856    }
2857
2858    /**
2859     * @return The first repetition of repeating field {@link #operation}, creating
2860     *         it if it does not already exist
2861     */
2862    public CapabilityStatementRestResourceOperationComponent getOperationFirstRep() {
2863      if (getOperation().isEmpty()) {
2864        addOperation();
2865      }
2866      return getOperation().get(0);
2867    }
2868
2869    /**
2870     * @return {@link #compartment} (An absolute URI which is a reference to the
2871     *         definition of a compartment that the system supports. The reference
2872     *         is to a CompartmentDefinition resource by its canonical URL .)
2873     */
2874    public List<CanonicalType> getCompartment() {
2875      if (this.compartment == null)
2876        this.compartment = new ArrayList<CanonicalType>();
2877      return this.compartment;
2878    }
2879
2880    /**
2881     * @return Returns a reference to <code>this</code> for easy method chaining
2882     */
2883    public CapabilityStatementRestComponent setCompartment(List<CanonicalType> theCompartment) {
2884      this.compartment = theCompartment;
2885      return this;
2886    }
2887
2888    public boolean hasCompartment() {
2889      if (this.compartment == null)
2890        return false;
2891      for (CanonicalType item : this.compartment)
2892        if (!item.isEmpty())
2893          return true;
2894      return false;
2895    }
2896
2897    /**
2898     * @return {@link #compartment} (An absolute URI which is a reference to the
2899     *         definition of a compartment that the system supports. The reference
2900     *         is to a CompartmentDefinition resource by its canonical URL .)
2901     */
2902    public CanonicalType addCompartmentElement() {// 2
2903      CanonicalType t = new CanonicalType();
2904      if (this.compartment == null)
2905        this.compartment = new ArrayList<CanonicalType>();
2906      this.compartment.add(t);
2907      return t;
2908    }
2909
2910    /**
2911     * @param value {@link #compartment} (An absolute URI which is a reference to
2912     *              the definition of a compartment that the system supports. The
2913     *              reference is to a CompartmentDefinition resource by its
2914     *              canonical URL .)
2915     */
2916    public CapabilityStatementRestComponent addCompartment(String value) { // 1
2917      CanonicalType t = new CanonicalType();
2918      t.setValue(value);
2919      if (this.compartment == null)
2920        this.compartment = new ArrayList<CanonicalType>();
2921      this.compartment.add(t);
2922      return this;
2923    }
2924
2925    /**
2926     * @param value {@link #compartment} (An absolute URI which is a reference to
2927     *              the definition of a compartment that the system supports. The
2928     *              reference is to a CompartmentDefinition resource by its
2929     *              canonical URL .)
2930     */
2931    public boolean hasCompartment(String value) {
2932      if (this.compartment == null)
2933        return false;
2934      for (CanonicalType v : this.compartment)
2935        if (v.getValue().equals(value)) // canonical(CompartmentDefinition)
2936          return true;
2937      return false;
2938    }
2939
2940    protected void listChildren(List<Property> children) {
2941      super.listChildren(children);
2942      children.add(new Property("mode", "code",
2943          "Identifies whether this portion of the statement is describing the ability to initiate or receive restful operations.",
2944          0, 1, mode));
2945      children.add(new Property("documentation", "markdown",
2946          "Information about the system's restful capabilities that apply across all applications, such as security.",
2947          0, 1, documentation));
2948      children.add(new Property("security", "",
2949          "Information about security implementation from an interface perspective - what a client needs to know.", 0,
2950          1, security));
2951      children.add(new Property("resource", "",
2952          "A specification of the restful capabilities of the solution for a specific resource type.", 0,
2953          java.lang.Integer.MAX_VALUE, resource));
2954      children.add(new Property("interaction", "", "A specification of restful operations supported by the system.", 0,
2955          java.lang.Integer.MAX_VALUE, interaction));
2956      children.add(new Property("searchParam", "@CapabilityStatement.rest.resource.searchParam",
2957          "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.",
2958          0, java.lang.Integer.MAX_VALUE, searchParam));
2959      children.add(new Property("operation", "@CapabilityStatement.rest.resource.operation",
2960          "Definition of an operation or a named query together with its parameters and their meaning and type.", 0,
2961          java.lang.Integer.MAX_VALUE, operation));
2962      children.add(new Property("compartment", "canonical(CompartmentDefinition)",
2963          "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 its canonical URL .",
2964          0, java.lang.Integer.MAX_VALUE, compartment));
2965    }
2966
2967    @Override
2968    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
2969      switch (_hash) {
2970      case 3357091:
2971        /* mode */ return new Property("mode", "code",
2972            "Identifies whether this portion of the statement is describing the ability to initiate or receive restful operations.",
2973            0, 1, mode);
2974      case 1587405498:
2975        /* documentation */ return new Property("documentation", "markdown",
2976            "Information about the system's restful capabilities that apply across all applications, such as security.",
2977            0, 1, documentation);
2978      case 949122880:
2979        /* security */ return new Property("security", "",
2980            "Information about security implementation from an interface perspective - what a client needs to know.", 0,
2981            1, security);
2982      case -341064690:
2983        /* resource */ return new Property("resource", "",
2984            "A specification of the restful capabilities of the solution for a specific resource type.", 0,
2985            java.lang.Integer.MAX_VALUE, resource);
2986      case 1844104722:
2987        /* interaction */ return new Property("interaction", "",
2988            "A specification of restful operations supported by the system.", 0, java.lang.Integer.MAX_VALUE,
2989            interaction);
2990      case -553645115:
2991        /* searchParam */ return new Property("searchParam", "@CapabilityStatement.rest.resource.searchParam",
2992            "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.",
2993            0, java.lang.Integer.MAX_VALUE, searchParam);
2994      case 1662702951:
2995        /* operation */ return new Property("operation", "@CapabilityStatement.rest.resource.operation",
2996            "Definition of an operation or a named query together with its parameters and their meaning and type.", 0,
2997            java.lang.Integer.MAX_VALUE, operation);
2998      case -397756334:
2999        /* compartment */ return new Property("compartment", "canonical(CompartmentDefinition)",
3000            "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 its canonical URL .",
3001            0, java.lang.Integer.MAX_VALUE, compartment);
3002      default:
3003        return super.getNamedProperty(_hash, _name, _checkValid);
3004      }
3005
3006    }
3007
3008    @Override
3009    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
3010      switch (hash) {
3011      case 3357091:
3012        /* mode */ return this.mode == null ? new Base[0] : new Base[] { this.mode }; // Enumeration<RestfulCapabilityMode>
3013      case 1587405498:
3014        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
3015      case 949122880:
3016        /* security */ return this.security == null ? new Base[0] : new Base[] { this.security }; // CapabilityStatementRestSecurityComponent
3017      case -341064690:
3018        /* resource */ return this.resource == null ? new Base[0]
3019            : this.resource.toArray(new Base[this.resource.size()]); // CapabilityStatementRestResourceComponent
3020      case 1844104722:
3021        /* interaction */ return this.interaction == null ? new Base[0]
3022            : this.interaction.toArray(new Base[this.interaction.size()]); // SystemInteractionComponent
3023      case -553645115:
3024        /* searchParam */ return this.searchParam == null ? new Base[0]
3025            : this.searchParam.toArray(new Base[this.searchParam.size()]); // CapabilityStatementRestResourceSearchParamComponent
3026      case 1662702951:
3027        /* operation */ return this.operation == null ? new Base[0]
3028            : this.operation.toArray(new Base[this.operation.size()]); // CapabilityStatementRestResourceOperationComponent
3029      case -397756334:
3030        /* compartment */ return this.compartment == null ? new Base[0]
3031            : this.compartment.toArray(new Base[this.compartment.size()]); // CanonicalType
3032      default:
3033        return super.getProperty(hash, name, checkValid);
3034      }
3035
3036    }
3037
3038    @Override
3039    public Base setProperty(int hash, String name, Base value) throws FHIRException {
3040      switch (hash) {
3041      case 3357091: // mode
3042        value = new RestfulCapabilityModeEnumFactory().fromType(castToCode(value));
3043        this.mode = (Enumeration) value; // Enumeration<RestfulCapabilityMode>
3044        return value;
3045      case 1587405498: // documentation
3046        this.documentation = castToMarkdown(value); // MarkdownType
3047        return value;
3048      case 949122880: // security
3049        this.security = (CapabilityStatementRestSecurityComponent) value; // CapabilityStatementRestSecurityComponent
3050        return value;
3051      case -341064690: // resource
3052        this.getResource().add((CapabilityStatementRestResourceComponent) value); // CapabilityStatementRestResourceComponent
3053        return value;
3054      case 1844104722: // interaction
3055        this.getInteraction().add((SystemInteractionComponent) value); // SystemInteractionComponent
3056        return value;
3057      case -553645115: // searchParam
3058        this.getSearchParam().add((CapabilityStatementRestResourceSearchParamComponent) value); // CapabilityStatementRestResourceSearchParamComponent
3059        return value;
3060      case 1662702951: // operation
3061        this.getOperation().add((CapabilityStatementRestResourceOperationComponent) value); // CapabilityStatementRestResourceOperationComponent
3062        return value;
3063      case -397756334: // compartment
3064        this.getCompartment().add(castToCanonical(value)); // CanonicalType
3065        return value;
3066      default:
3067        return super.setProperty(hash, name, value);
3068      }
3069
3070    }
3071
3072    @Override
3073    public Base setProperty(String name, Base value) throws FHIRException {
3074      if (name.equals("mode")) {
3075        value = new RestfulCapabilityModeEnumFactory().fromType(castToCode(value));
3076        this.mode = (Enumeration) value; // Enumeration<RestfulCapabilityMode>
3077      } else if (name.equals("documentation")) {
3078        this.documentation = castToMarkdown(value); // MarkdownType
3079      } else if (name.equals("security")) {
3080        this.security = (CapabilityStatementRestSecurityComponent) value; // CapabilityStatementRestSecurityComponent
3081      } else if (name.equals("resource")) {
3082        this.getResource().add((CapabilityStatementRestResourceComponent) value);
3083      } else if (name.equals("interaction")) {
3084        this.getInteraction().add((SystemInteractionComponent) value);
3085      } else if (name.equals("searchParam")) {
3086        this.getSearchParam().add((CapabilityStatementRestResourceSearchParamComponent) value);
3087      } else if (name.equals("operation")) {
3088        this.getOperation().add((CapabilityStatementRestResourceOperationComponent) value);
3089      } else if (name.equals("compartment")) {
3090        this.getCompartment().add(castToCanonical(value));
3091      } else
3092        return super.setProperty(name, value);
3093      return value;
3094    }
3095
3096  @Override
3097  public void removeChild(String name, Base value) throws FHIRException {
3098      if (name.equals("mode")) {
3099        this.mode = null;
3100      } else if (name.equals("documentation")) {
3101        this.documentation = null;
3102      } else if (name.equals("security")) {
3103        this.security = (CapabilityStatementRestSecurityComponent) value; // CapabilityStatementRestSecurityComponent
3104      } else if (name.equals("resource")) {
3105        this.getResource().remove((CapabilityStatementRestResourceComponent) value);
3106      } else if (name.equals("interaction")) {
3107        this.getInteraction().remove((SystemInteractionComponent) value);
3108      } else if (name.equals("searchParam")) {
3109        this.getSearchParam().remove((CapabilityStatementRestResourceSearchParamComponent) value);
3110      } else if (name.equals("operation")) {
3111        this.getOperation().remove((CapabilityStatementRestResourceOperationComponent) value);
3112      } else if (name.equals("compartment")) {
3113        this.getCompartment().remove(castToCanonical(value));
3114      } else
3115        super.removeChild(name, value);
3116      
3117    }
3118
3119    @Override
3120    public Base makeProperty(int hash, String name) throws FHIRException {
3121      switch (hash) {
3122      case 3357091:
3123        return getModeElement();
3124      case 1587405498:
3125        return getDocumentationElement();
3126      case 949122880:
3127        return getSecurity();
3128      case -341064690:
3129        return addResource();
3130      case 1844104722:
3131        return addInteraction();
3132      case -553645115:
3133        return addSearchParam();
3134      case 1662702951:
3135        return addOperation();
3136      case -397756334:
3137        return addCompartmentElement();
3138      default:
3139        return super.makeProperty(hash, name);
3140      }
3141
3142    }
3143
3144    @Override
3145    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
3146      switch (hash) {
3147      case 3357091:
3148        /* mode */ return new String[] { "code" };
3149      case 1587405498:
3150        /* documentation */ return new String[] { "markdown" };
3151      case 949122880:
3152        /* security */ return new String[] {};
3153      case -341064690:
3154        /* resource */ return new String[] {};
3155      case 1844104722:
3156        /* interaction */ return new String[] {};
3157      case -553645115:
3158        /* searchParam */ return new String[] { "@CapabilityStatement.rest.resource.searchParam" };
3159      case 1662702951:
3160        /* operation */ return new String[] { "@CapabilityStatement.rest.resource.operation" };
3161      case -397756334:
3162        /* compartment */ return new String[] { "canonical" };
3163      default:
3164        return super.getTypesForProperty(hash, name);
3165      }
3166
3167    }
3168
3169    @Override
3170    public Base addChild(String name) throws FHIRException {
3171      if (name.equals("mode")) {
3172        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.mode");
3173      } else if (name.equals("documentation")) {
3174        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
3175      } else if (name.equals("security")) {
3176        this.security = new CapabilityStatementRestSecurityComponent();
3177        return this.security;
3178      } else if (name.equals("resource")) {
3179        return addResource();
3180      } else if (name.equals("interaction")) {
3181        return addInteraction();
3182      } else if (name.equals("searchParam")) {
3183        return addSearchParam();
3184      } else if (name.equals("operation")) {
3185        return addOperation();
3186      } else if (name.equals("compartment")) {
3187        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.compartment");
3188      } else
3189        return super.addChild(name);
3190    }
3191
3192    public CapabilityStatementRestComponent copy() {
3193      CapabilityStatementRestComponent dst = new CapabilityStatementRestComponent();
3194      copyValues(dst);
3195      return dst;
3196    }
3197
3198    public void copyValues(CapabilityStatementRestComponent dst) {
3199      super.copyValues(dst);
3200      dst.mode = mode == null ? null : mode.copy();
3201      dst.documentation = documentation == null ? null : documentation.copy();
3202      dst.security = security == null ? null : security.copy();
3203      if (resource != null) {
3204        dst.resource = new ArrayList<CapabilityStatementRestResourceComponent>();
3205        for (CapabilityStatementRestResourceComponent i : resource)
3206          dst.resource.add(i.copy());
3207      }
3208      ;
3209      if (interaction != null) {
3210        dst.interaction = new ArrayList<SystemInteractionComponent>();
3211        for (SystemInteractionComponent i : interaction)
3212          dst.interaction.add(i.copy());
3213      }
3214      ;
3215      if (searchParam != null) {
3216        dst.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
3217        for (CapabilityStatementRestResourceSearchParamComponent i : searchParam)
3218          dst.searchParam.add(i.copy());
3219      }
3220      ;
3221      if (operation != null) {
3222        dst.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
3223        for (CapabilityStatementRestResourceOperationComponent i : operation)
3224          dst.operation.add(i.copy());
3225      }
3226      ;
3227      if (compartment != null) {
3228        dst.compartment = new ArrayList<CanonicalType>();
3229        for (CanonicalType i : compartment)
3230          dst.compartment.add(i.copy());
3231      }
3232      ;
3233    }
3234
3235    @Override
3236    public boolean equalsDeep(Base other_) {
3237      if (!super.equalsDeep(other_))
3238        return false;
3239      if (!(other_ instanceof CapabilityStatementRestComponent))
3240        return false;
3241      CapabilityStatementRestComponent o = (CapabilityStatementRestComponent) other_;
3242      return compareDeep(mode, o.mode, true) && compareDeep(documentation, o.documentation, true)
3243          && compareDeep(security, o.security, true) && compareDeep(resource, o.resource, true)
3244          && compareDeep(interaction, o.interaction, true) && compareDeep(searchParam, o.searchParam, true)
3245          && compareDeep(operation, o.operation, true) && compareDeep(compartment, o.compartment, true);
3246    }
3247
3248    @Override
3249    public boolean equalsShallow(Base other_) {
3250      if (!super.equalsShallow(other_))
3251        return false;
3252      if (!(other_ instanceof CapabilityStatementRestComponent))
3253        return false;
3254      CapabilityStatementRestComponent o = (CapabilityStatementRestComponent) other_;
3255      return compareValues(mode, o.mode, true) && compareValues(documentation, o.documentation, true);
3256    }
3257
3258    public boolean isEmpty() {
3259      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(mode, documentation, security, resource,
3260          interaction, searchParam, operation, compartment);
3261    }
3262
3263    public String fhirType() {
3264      return "CapabilityStatement.rest";
3265
3266    }
3267
3268  }
3269
3270  @Block()
3271  public static class CapabilityStatementRestSecurityComponent extends BackboneElement implements IBaseBackboneElement {
3272    /**
3273     * Server adds CORS headers when responding to requests - this enables
3274     * Javascript applications to use the server.
3275     */
3276    @Child(name = "cors", type = { BooleanType.class }, order = 1, min = 0, max = 1, modifier = false, summary = true)
3277    @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.")
3278    protected BooleanType cors;
3279
3280    /**
3281     * Types of security services that are supported/required by the system.
3282     */
3283    @Child(name = "service", type = {
3284        CodeableConcept.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
3285    @Description(shortDefinition = "OAuth | SMART-on-FHIR | NTLM | Basic | Kerberos | Certificates", formalDefinition = "Types of security services that are supported/required by the system.")
3286    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/restful-security-service")
3287    protected List<CodeableConcept> service;
3288
3289    /**
3290     * General description of how security works.
3291     */
3292    @Child(name = "description", type = {
3293        MarkdownType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
3294    @Description(shortDefinition = "General description of how security works", formalDefinition = "General description of how security works.")
3295    protected MarkdownType description;
3296
3297    private static final long serialVersionUID = -1348900500L;
3298
3299    /**
3300     * Constructor
3301     */
3302    public CapabilityStatementRestSecurityComponent() {
3303      super();
3304    }
3305
3306    /**
3307     * @return {@link #cors} (Server adds CORS headers when responding to requests -
3308     *         this enables Javascript applications to use the server.). This is the
3309     *         underlying object with id, value and extensions. The accessor
3310     *         "getCors" gives direct access to the value
3311     */
3312    public BooleanType getCorsElement() {
3313      if (this.cors == null)
3314        if (Configuration.errorOnAutoCreate())
3315          throw new Error("Attempt to auto-create CapabilityStatementRestSecurityComponent.cors");
3316        else if (Configuration.doAutoCreate())
3317          this.cors = new BooleanType(); // bb
3318      return this.cors;
3319    }
3320
3321    public boolean hasCorsElement() {
3322      return this.cors != null && !this.cors.isEmpty();
3323    }
3324
3325    public boolean hasCors() {
3326      return this.cors != null && !this.cors.isEmpty();
3327    }
3328
3329    /**
3330     * @param value {@link #cors} (Server adds CORS headers when responding to
3331     *              requests - this enables Javascript applications to use the
3332     *              server.). This is the underlying object with id, value and
3333     *              extensions. The accessor "getCors" gives direct access to the
3334     *              value
3335     */
3336    public CapabilityStatementRestSecurityComponent setCorsElement(BooleanType value) {
3337      this.cors = value;
3338      return this;
3339    }
3340
3341    /**
3342     * @return Server adds CORS headers when responding to requests - this enables
3343     *         Javascript applications to use the server.
3344     */
3345    public boolean getCors() {
3346      return this.cors == null || this.cors.isEmpty() ? false : this.cors.getValue();
3347    }
3348
3349    /**
3350     * @param value Server adds CORS headers when responding to requests - this
3351     *              enables Javascript applications to use the server.
3352     */
3353    public CapabilityStatementRestSecurityComponent setCors(boolean value) {
3354      if (this.cors == null)
3355        this.cors = new BooleanType();
3356      this.cors.setValue(value);
3357      return this;
3358    }
3359
3360    /**
3361     * @return {@link #service} (Types of security services that are
3362     *         supported/required by the system.)
3363     */
3364    public List<CodeableConcept> getService() {
3365      if (this.service == null)
3366        this.service = new ArrayList<CodeableConcept>();
3367      return this.service;
3368    }
3369
3370    /**
3371     * @return Returns a reference to <code>this</code> for easy method chaining
3372     */
3373    public CapabilityStatementRestSecurityComponent setService(List<CodeableConcept> theService) {
3374      this.service = theService;
3375      return this;
3376    }
3377
3378    public boolean hasService() {
3379      if (this.service == null)
3380        return false;
3381      for (CodeableConcept item : this.service)
3382        if (!item.isEmpty())
3383          return true;
3384      return false;
3385    }
3386
3387    public CodeableConcept addService() { // 3
3388      CodeableConcept t = new CodeableConcept();
3389      if (this.service == null)
3390        this.service = new ArrayList<CodeableConcept>();
3391      this.service.add(t);
3392      return t;
3393    }
3394
3395    public CapabilityStatementRestSecurityComponent addService(CodeableConcept t) { // 3
3396      if (t == null)
3397        return this;
3398      if (this.service == null)
3399        this.service = new ArrayList<CodeableConcept>();
3400      this.service.add(t);
3401      return this;
3402    }
3403
3404    /**
3405     * @return The first repetition of repeating field {@link #service}, creating it
3406     *         if it does not already exist
3407     */
3408    public CodeableConcept getServiceFirstRep() {
3409      if (getService().isEmpty()) {
3410        addService();
3411      }
3412      return getService().get(0);
3413    }
3414
3415    /**
3416     * @return {@link #description} (General description of how security works.).
3417     *         This is the underlying object with id, value and extensions. The
3418     *         accessor "getDescription" gives direct access to the value
3419     */
3420    public MarkdownType getDescriptionElement() {
3421      if (this.description == null)
3422        if (Configuration.errorOnAutoCreate())
3423          throw new Error("Attempt to auto-create CapabilityStatementRestSecurityComponent.description");
3424        else if (Configuration.doAutoCreate())
3425          this.description = new MarkdownType(); // bb
3426      return this.description;
3427    }
3428
3429    public boolean hasDescriptionElement() {
3430      return this.description != null && !this.description.isEmpty();
3431    }
3432
3433    public boolean hasDescription() {
3434      return this.description != null && !this.description.isEmpty();
3435    }
3436
3437    /**
3438     * @param value {@link #description} (General description of how security
3439     *              works.). This is the underlying object with id, value and
3440     *              extensions. The accessor "getDescription" gives direct access to
3441     *              the value
3442     */
3443    public CapabilityStatementRestSecurityComponent setDescriptionElement(MarkdownType value) {
3444      this.description = value;
3445      return this;
3446    }
3447
3448    /**
3449     * @return General description of how security works.
3450     */
3451    public String getDescription() {
3452      return this.description == null ? null : this.description.getValue();
3453    }
3454
3455    /**
3456     * @param value General description of how security works.
3457     */
3458    public CapabilityStatementRestSecurityComponent setDescription(String value) {
3459      if (value == null)
3460        this.description = null;
3461      else {
3462        if (this.description == null)
3463          this.description = new MarkdownType();
3464        this.description.setValue(value);
3465      }
3466      return this;
3467    }
3468
3469    protected void listChildren(List<Property> children) {
3470      super.listChildren(children);
3471      children.add(new Property("cors", "boolean",
3472          "Server adds CORS headers when responding to requests - this enables Javascript applications to use the server.",
3473          0, 1, cors));
3474      children.add(new Property("service", "CodeableConcept",
3475          "Types of security services that are supported/required by the system.", 0, java.lang.Integer.MAX_VALUE,
3476          service));
3477      children.add(
3478          new Property("description", "markdown", "General description of how security works.", 0, 1, description));
3479    }
3480
3481    @Override
3482    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
3483      switch (_hash) {
3484      case 3059629:
3485        /* cors */ return new Property("cors", "boolean",
3486            "Server adds CORS headers when responding to requests - this enables Javascript applications to use the server.",
3487            0, 1, cors);
3488      case 1984153269:
3489        /* service */ return new Property("service", "CodeableConcept",
3490            "Types of security services that are supported/required by the system.", 0, java.lang.Integer.MAX_VALUE,
3491            service);
3492      case -1724546052:
3493        /* description */ return new Property("description", "markdown", "General description of how security works.",
3494            0, 1, description);
3495      default:
3496        return super.getNamedProperty(_hash, _name, _checkValid);
3497      }
3498
3499    }
3500
3501    @Override
3502    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
3503      switch (hash) {
3504      case 3059629:
3505        /* cors */ return this.cors == null ? new Base[0] : new Base[] { this.cors }; // BooleanType
3506      case 1984153269:
3507        /* service */ return this.service == null ? new Base[0] : this.service.toArray(new Base[this.service.size()]); // CodeableConcept
3508      case -1724546052:
3509        /* description */ return this.description == null ? new Base[0] : new Base[] { this.description }; // MarkdownType
3510      default:
3511        return super.getProperty(hash, name, checkValid);
3512      }
3513
3514    }
3515
3516    @Override
3517    public Base setProperty(int hash, String name, Base value) throws FHIRException {
3518      switch (hash) {
3519      case 3059629: // cors
3520        this.cors = castToBoolean(value); // BooleanType
3521        return value;
3522      case 1984153269: // service
3523        this.getService().add(castToCodeableConcept(value)); // CodeableConcept
3524        return value;
3525      case -1724546052: // description
3526        this.description = castToMarkdown(value); // MarkdownType
3527        return value;
3528      default:
3529        return super.setProperty(hash, name, value);
3530      }
3531
3532    }
3533
3534    @Override
3535    public Base setProperty(String name, Base value) throws FHIRException {
3536      if (name.equals("cors")) {
3537        this.cors = castToBoolean(value); // BooleanType
3538      } else if (name.equals("service")) {
3539        this.getService().add(castToCodeableConcept(value));
3540      } else if (name.equals("description")) {
3541        this.description = castToMarkdown(value); // MarkdownType
3542      } else
3543        return super.setProperty(name, value);
3544      return value;
3545    }
3546
3547  @Override
3548  public void removeChild(String name, Base value) throws FHIRException {
3549      if (name.equals("cors")) {
3550        this.cors = null;
3551      } else if (name.equals("service")) {
3552        this.getService().remove(castToCodeableConcept(value));
3553      } else if (name.equals("description")) {
3554        this.description = null;
3555      } else
3556        super.removeChild(name, value);
3557      
3558    }
3559
3560    @Override
3561    public Base makeProperty(int hash, String name) throws FHIRException {
3562      switch (hash) {
3563      case 3059629:
3564        return getCorsElement();
3565      case 1984153269:
3566        return addService();
3567      case -1724546052:
3568        return getDescriptionElement();
3569      default:
3570        return super.makeProperty(hash, name);
3571      }
3572
3573    }
3574
3575    @Override
3576    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
3577      switch (hash) {
3578      case 3059629:
3579        /* cors */ return new String[] { "boolean" };
3580      case 1984153269:
3581        /* service */ return new String[] { "CodeableConcept" };
3582      case -1724546052:
3583        /* description */ return new String[] { "markdown" };
3584      default:
3585        return super.getTypesForProperty(hash, name);
3586      }
3587
3588    }
3589
3590    @Override
3591    public Base addChild(String name) throws FHIRException {
3592      if (name.equals("cors")) {
3593        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.cors");
3594      } else if (name.equals("service")) {
3595        return addService();
3596      } else if (name.equals("description")) {
3597        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.description");
3598      } else
3599        return super.addChild(name);
3600    }
3601
3602    public CapabilityStatementRestSecurityComponent copy() {
3603      CapabilityStatementRestSecurityComponent dst = new CapabilityStatementRestSecurityComponent();
3604      copyValues(dst);
3605      return dst;
3606    }
3607
3608    public void copyValues(CapabilityStatementRestSecurityComponent dst) {
3609      super.copyValues(dst);
3610      dst.cors = cors == null ? null : cors.copy();
3611      if (service != null) {
3612        dst.service = new ArrayList<CodeableConcept>();
3613        for (CodeableConcept i : service)
3614          dst.service.add(i.copy());
3615      }
3616      ;
3617      dst.description = description == null ? null : description.copy();
3618    }
3619
3620    @Override
3621    public boolean equalsDeep(Base other_) {
3622      if (!super.equalsDeep(other_))
3623        return false;
3624      if (!(other_ instanceof CapabilityStatementRestSecurityComponent))
3625        return false;
3626      CapabilityStatementRestSecurityComponent o = (CapabilityStatementRestSecurityComponent) other_;
3627      return compareDeep(cors, o.cors, true) && compareDeep(service, o.service, true)
3628          && compareDeep(description, o.description, true);
3629    }
3630
3631    @Override
3632    public boolean equalsShallow(Base other_) {
3633      if (!super.equalsShallow(other_))
3634        return false;
3635      if (!(other_ instanceof CapabilityStatementRestSecurityComponent))
3636        return false;
3637      CapabilityStatementRestSecurityComponent o = (CapabilityStatementRestSecurityComponent) other_;
3638      return compareValues(cors, o.cors, true) && compareValues(description, o.description, true);
3639    }
3640
3641    public boolean isEmpty() {
3642      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(cors, service, description);
3643    }
3644
3645    public String fhirType() {
3646      return "CapabilityStatement.rest.security";
3647
3648    }
3649
3650  }
3651
3652  @Block()
3653  public static class CapabilityStatementRestResourceComponent extends BackboneElement implements IBaseBackboneElement {
3654    /**
3655     * A type of resource exposed via the restful interface.
3656     */
3657    @Child(name = "type", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
3658    @Description(shortDefinition = "A resource type that is supported", formalDefinition = "A type of resource exposed via the restful interface.")
3659    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/resource-types")
3660    protected CodeType type;
3661
3662    /**
3663     * A specification of the profile that describes the solution's overall support
3664     * for the resource, including any constraints on cardinality, bindings, lengths
3665     * or other limitations. See further discussion in [Using
3666     * Profiles](profiling.html#profile-uses).
3667     */
3668    @Child(name = "profile", type = {
3669        CanonicalType.class }, order = 2, min = 0, max = 1, modifier = false, summary = true)
3670    @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).")
3671    protected CanonicalType profile;
3672
3673    /**
3674     * A list of profiles that represent different use cases supported by the
3675     * system. For a server, "supported by the system" means the system
3676     * hosts/produces a set of resources that are conformant to a particular
3677     * profile, and allows clients that use its services to search using this
3678     * profile and to find appropriate data. For a client, it means the system will
3679     * search by this profile and process data according to the guidance implicit in
3680     * the profile. See further discussion in [Using
3681     * Profiles](profiling.html#profile-uses).
3682     */
3683    @Child(name = "supportedProfile", type = {
3684        CanonicalType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
3685    @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).")
3686    protected List<CanonicalType> supportedProfile;
3687
3688    /**
3689     * Additional information about the resource type used by the system.
3690     */
3691    @Child(name = "documentation", type = {
3692        MarkdownType.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
3693    @Description(shortDefinition = "Additional information about the use of the resource type", formalDefinition = "Additional information about the resource type used by the system.")
3694    protected MarkdownType documentation;
3695
3696    /**
3697     * Identifies a restful operation supported by the solution.
3698     */
3699    @Child(name = "interaction", type = {}, order = 5, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3700    @Description(shortDefinition = "What operations are supported?", formalDefinition = "Identifies a restful operation supported by the solution.")
3701    protected List<ResourceInteractionComponent> interaction;
3702
3703    /**
3704     * This field is set to no-version to specify that the system does not support
3705     * (server) or use (client) versioning for this resource type. If this has some
3706     * other value, the server must at least correctly track and populate the
3707     * versionId meta-property on resources. If the value is 'versioned-update',
3708     * then the server supports all the versioning features, including using e-tags
3709     * for version integrity in the API.
3710     */
3711    @Child(name = "versioning", type = {
3712        CodeType.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
3713    @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.")
3714    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/versioning-policy")
3715    protected Enumeration<ResourceVersionPolicy> versioning;
3716
3717    /**
3718     * A flag for whether the server is able to return past versions as part of the
3719     * vRead operation.
3720     */
3721    @Child(name = "readHistory", type = {
3722        BooleanType.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
3723    @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.")
3724    protected BooleanType readHistory;
3725
3726    /**
3727     * A flag to indicate that the server allows or needs to allow the client to
3728     * create new identities on the server (that is, the client PUTs to a location
3729     * where there is no existing resource). Allowing this operation means that the
3730     * server allows the client to create new identities on the server.
3731     */
3732    @Child(name = "updateCreate", type = {
3733        BooleanType.class }, order = 8, min = 0, max = 1, modifier = false, summary = false)
3734    @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 (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.")
3735    protected BooleanType updateCreate;
3736
3737    /**
3738     * A flag that indicates that the server supports conditional create.
3739     */
3740    @Child(name = "conditionalCreate", type = {
3741        BooleanType.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
3742    @Description(shortDefinition = "If allows/uses conditional create", formalDefinition = "A flag that indicates that the server supports conditional create.")
3743    protected BooleanType conditionalCreate;
3744
3745    /**
3746     * A code that indicates how the server supports conditional read.
3747     */
3748    @Child(name = "conditionalRead", type = {
3749        CodeType.class }, order = 10, min = 0, max = 1, modifier = false, summary = false)
3750    @Description(shortDefinition = "not-supported | modified-since | not-match | full-support", formalDefinition = "A code that indicates how the server supports conditional read.")
3751    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/conditional-read-status")
3752    protected Enumeration<ConditionalReadStatus> conditionalRead;
3753
3754    /**
3755     * A flag that indicates that the server supports conditional update.
3756     */
3757    @Child(name = "conditionalUpdate", type = {
3758        BooleanType.class }, order = 11, min = 0, max = 1, modifier = false, summary = false)
3759    @Description(shortDefinition = "If allows/uses conditional update", formalDefinition = "A flag that indicates that the server supports conditional update.")
3760    protected BooleanType conditionalUpdate;
3761
3762    /**
3763     * A code that indicates how the server supports conditional delete.
3764     */
3765    @Child(name = "conditionalDelete", type = {
3766        CodeType.class }, order = 12, min = 0, max = 1, modifier = false, summary = false)
3767    @Description(shortDefinition = "not-supported | single | multiple - how conditional delete is supported", formalDefinition = "A code that indicates how the server supports conditional delete.")
3768    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/conditional-delete-status")
3769    protected Enumeration<ConditionalDeleteStatus> conditionalDelete;
3770
3771    /**
3772     * A set of flags that defines how references are supported.
3773     */
3774    @Child(name = "referencePolicy", type = {
3775        CodeType.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3776    @Description(shortDefinition = "literal | logical | resolves | enforced | local", formalDefinition = "A set of flags that defines how references are supported.")
3777    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/reference-handling-policy")
3778    protected List<Enumeration<ReferenceHandlingPolicy>> referencePolicy;
3779
3780    /**
3781     * A list of _include values supported by the server.
3782     */
3783    @Child(name = "searchInclude", type = {
3784        StringType.class }, order = 14, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3785    @Description(shortDefinition = "_include values supported by the server", formalDefinition = "A list of _include values supported by the server.")
3786    protected List<StringType> searchInclude;
3787
3788    /**
3789     * A list of _revinclude (reverse include) values supported by the server.
3790     */
3791    @Child(name = "searchRevInclude", type = {
3792        StringType.class }, order = 15, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3793    @Description(shortDefinition = "_revinclude values supported by the server", formalDefinition = "A list of _revinclude (reverse include) values supported by the server.")
3794    protected List<StringType> searchRevInclude;
3795
3796    /**
3797     * Search parameters for implementations to support and/or make use of - either
3798     * references to ones defined in the specification, or additional ones defined
3799     * for/by the implementation.
3800     */
3801    @Child(name = "searchParam", type = {}, order = 16, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
3802    @Description(shortDefinition = "Search parameters 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.")
3803    protected List<CapabilityStatementRestResourceSearchParamComponent> searchParam;
3804
3805    /**
3806     * Definition of an operation or a named query together with its parameters and
3807     * their meaning and type. Consult the definition of the operation for details
3808     * about how to invoke the operation, and the parameters.
3809     */
3810    @Child(name = "operation", type = {}, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
3811    @Description(shortDefinition = "Definition of a resource operation", formalDefinition = "Definition of an operation or a named query together with its parameters and their meaning and type. Consult the definition of the operation for details about how to invoke the operation, and the parameters.")
3812    protected List<CapabilityStatementRestResourceOperationComponent> operation;
3813
3814    private static final long serialVersionUID = -1843372337L;
3815
3816    /**
3817     * Constructor
3818     */
3819    public CapabilityStatementRestResourceComponent() {
3820      super();
3821    }
3822
3823    /**
3824     * Constructor
3825     */
3826    public CapabilityStatementRestResourceComponent(CodeType type) {
3827      super();
3828      this.type = type;
3829    }
3830
3831    /**
3832     * @return {@link #type} (A type of resource exposed via the restful
3833     *         interface.). This is the underlying object with id, value and
3834     *         extensions. The accessor "getType" gives direct access to the value
3835     */
3836    public CodeType getTypeElement() {
3837      if (this.type == null)
3838        if (Configuration.errorOnAutoCreate())
3839          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.type");
3840        else if (Configuration.doAutoCreate())
3841          this.type = new CodeType(); // bb
3842      return this.type;
3843    }
3844
3845    public boolean hasTypeElement() {
3846      return this.type != null && !this.type.isEmpty();
3847    }
3848
3849    public boolean hasType() {
3850      return this.type != null && !this.type.isEmpty();
3851    }
3852
3853    /**
3854     * @param value {@link #type} (A type of resource exposed via the restful
3855     *              interface.). This is the underlying object with id, value and
3856     *              extensions. The accessor "getType" gives direct access to the
3857     *              value
3858     */
3859    public CapabilityStatementRestResourceComponent setTypeElement(CodeType value) {
3860      this.type = value;
3861      return this;
3862    }
3863
3864    /**
3865     * @return A type of resource exposed via the restful interface.
3866     */
3867    public String getType() {
3868      return this.type == null ? null : this.type.getValue();
3869    }
3870
3871    /**
3872     * @param value A type of resource exposed via the restful interface.
3873     */
3874    public CapabilityStatementRestResourceComponent setType(String value) {
3875      if (this.type == null)
3876        this.type = new CodeType();
3877      this.type.setValue(value);
3878      return this;
3879    }
3880
3881    /**
3882     * @return {@link #profile} (A specification of the profile that describes the
3883     *         solution's overall support for the resource, including any
3884     *         constraints on cardinality, bindings, lengths or other limitations.
3885     *         See further discussion in [Using
3886     *         Profiles](profiling.html#profile-uses).). This is the underlying
3887     *         object with id, value and extensions. The accessor "getProfile" gives
3888     *         direct access to the value
3889     */
3890    public CanonicalType getProfileElement() {
3891      if (this.profile == null)
3892        if (Configuration.errorOnAutoCreate())
3893          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.profile");
3894        else if (Configuration.doAutoCreate())
3895          this.profile = new CanonicalType(); // bb
3896      return this.profile;
3897    }
3898
3899    public boolean hasProfileElement() {
3900      return this.profile != null && !this.profile.isEmpty();
3901    }
3902
3903    public boolean hasProfile() {
3904      return this.profile != null && !this.profile.isEmpty();
3905    }
3906
3907    /**
3908     * @param value {@link #profile} (A specification of the profile that describes
3909     *              the solution's overall support for the resource, including any
3910     *              constraints on cardinality, bindings, lengths or other
3911     *              limitations. See further discussion in [Using
3912     *              Profiles](profiling.html#profile-uses).). This is the underlying
3913     *              object with id, value and extensions. The accessor "getProfile"
3914     *              gives direct access to the value
3915     */
3916    public CapabilityStatementRestResourceComponent setProfileElement(CanonicalType value) {
3917      this.profile = value;
3918      return this;
3919    }
3920
3921    /**
3922     * @return A specification of the profile that describes the solution's overall
3923     *         support for the resource, including any constraints on cardinality,
3924     *         bindings, lengths or other limitations. See further discussion in
3925     *         [Using Profiles](profiling.html#profile-uses).
3926     */
3927    public String getProfile() {
3928      return this.profile == null ? null : this.profile.getValue();
3929    }
3930
3931    /**
3932     * @param value A specification of the profile that describes the solution's
3933     *              overall support for the resource, including any constraints on
3934     *              cardinality, bindings, lengths or other limitations. See further
3935     *              discussion in [Using Profiles](profiling.html#profile-uses).
3936     */
3937    public CapabilityStatementRestResourceComponent setProfile(String value) {
3938      if (Utilities.noString(value))
3939        this.profile = null;
3940      else {
3941        if (this.profile == null)
3942          this.profile = new CanonicalType();
3943        this.profile.setValue(value);
3944      }
3945      return this;
3946    }
3947
3948    /**
3949     * @return {@link #supportedProfile} (A list of profiles that represent
3950     *         different use cases supported by the system. For a server, "supported
3951     *         by the system" means the system hosts/produces a set of resources
3952     *         that are conformant to a particular profile, and allows clients that
3953     *         use its services to search using this profile and to find appropriate
3954     *         data. For a client, it means the system will search by this profile
3955     *         and process data according to the guidance implicit in the profile.
3956     *         See further discussion in [Using
3957     *         Profiles](profiling.html#profile-uses).)
3958     */
3959    public List<CanonicalType> getSupportedProfile() {
3960      if (this.supportedProfile == null)
3961        this.supportedProfile = new ArrayList<CanonicalType>();
3962      return this.supportedProfile;
3963    }
3964
3965    /**
3966     * @return Returns a reference to <code>this</code> for easy method chaining
3967     */
3968    public CapabilityStatementRestResourceComponent setSupportedProfile(List<CanonicalType> theSupportedProfile) {
3969      this.supportedProfile = theSupportedProfile;
3970      return this;
3971    }
3972
3973    public boolean hasSupportedProfile() {
3974      if (this.supportedProfile == null)
3975        return false;
3976      for (CanonicalType item : this.supportedProfile)
3977        if (!item.isEmpty())
3978          return true;
3979      return false;
3980    }
3981
3982    /**
3983     * @return {@link #supportedProfile} (A list of profiles that represent
3984     *         different use cases supported by the system. For a server, "supported
3985     *         by the system" means the system hosts/produces a set of resources
3986     *         that are conformant to a particular profile, and allows clients that
3987     *         use its services to search using this profile and to find appropriate
3988     *         data. For a client, it means the system will search by this profile
3989     *         and process data according to the guidance implicit in the profile.
3990     *         See further discussion in [Using
3991     *         Profiles](profiling.html#profile-uses).)
3992     */
3993    public CanonicalType addSupportedProfileElement() {// 2
3994      CanonicalType t = new CanonicalType();
3995      if (this.supportedProfile == null)
3996        this.supportedProfile = new ArrayList<CanonicalType>();
3997      this.supportedProfile.add(t);
3998      return t;
3999    }
4000
4001    /**
4002     * @param value {@link #supportedProfile} (A list of profiles that represent
4003     *              different use cases supported by the system. For a server,
4004     *              "supported by the system" means the system hosts/produces a set
4005     *              of resources that are conformant to a particular profile, and
4006     *              allows clients that use its services to search using this
4007     *              profile and to find appropriate data. For a client, it means the
4008     *              system will search by this profile and process data according to
4009     *              the guidance implicit in the profile. See further discussion in
4010     *              [Using Profiles](profiling.html#profile-uses).)
4011     */
4012    public CapabilityStatementRestResourceComponent addSupportedProfile(String value) { // 1
4013      CanonicalType t = new CanonicalType();
4014      t.setValue(value);
4015      if (this.supportedProfile == null)
4016        this.supportedProfile = new ArrayList<CanonicalType>();
4017      this.supportedProfile.add(t);
4018      return this;
4019    }
4020
4021    /**
4022     * @param value {@link #supportedProfile} (A list of profiles that represent
4023     *              different use cases supported by the system. For a server,
4024     *              "supported by the system" means the system hosts/produces a set
4025     *              of resources that are conformant to a particular profile, and
4026     *              allows clients that use its services to search using this
4027     *              profile and to find appropriate data. For a client, it means the
4028     *              system will search by this profile and process data according to
4029     *              the guidance implicit in the profile. See further discussion in
4030     *              [Using Profiles](profiling.html#profile-uses).)
4031     */
4032    public boolean hasSupportedProfile(String value) {
4033      if (this.supportedProfile == null)
4034        return false;
4035      for (CanonicalType v : this.supportedProfile)
4036        if (v.getValue().equals(value)) // canonical(StructureDefinition)
4037          return true;
4038      return false;
4039    }
4040
4041    /**
4042     * @return {@link #documentation} (Additional information about the resource
4043     *         type used by the system.). This is the underlying object with id,
4044     *         value and extensions. The accessor "getDocumentation" gives direct
4045     *         access to the value
4046     */
4047    public MarkdownType getDocumentationElement() {
4048      if (this.documentation == null)
4049        if (Configuration.errorOnAutoCreate())
4050          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.documentation");
4051        else if (Configuration.doAutoCreate())
4052          this.documentation = new MarkdownType(); // bb
4053      return this.documentation;
4054    }
4055
4056    public boolean hasDocumentationElement() {
4057      return this.documentation != null && !this.documentation.isEmpty();
4058    }
4059
4060    public boolean hasDocumentation() {
4061      return this.documentation != null && !this.documentation.isEmpty();
4062    }
4063
4064    /**
4065     * @param value {@link #documentation} (Additional information about the
4066     *              resource type used by the system.). This is the underlying
4067     *              object with id, value and extensions. The accessor
4068     *              "getDocumentation" gives direct access to the value
4069     */
4070    public CapabilityStatementRestResourceComponent setDocumentationElement(MarkdownType value) {
4071      this.documentation = value;
4072      return this;
4073    }
4074
4075    /**
4076     * @return Additional information about the resource type used by the system.
4077     */
4078    public String getDocumentation() {
4079      return this.documentation == null ? null : this.documentation.getValue();
4080    }
4081
4082    /**
4083     * @param value Additional information about the resource type used by the
4084     *              system.
4085     */
4086    public CapabilityStatementRestResourceComponent setDocumentation(String value) {
4087      if (value == null)
4088        this.documentation = null;
4089      else {
4090        if (this.documentation == null)
4091          this.documentation = new MarkdownType();
4092        this.documentation.setValue(value);
4093      }
4094      return this;
4095    }
4096
4097    /**
4098     * @return {@link #interaction} (Identifies a restful operation supported by the
4099     *         solution.)
4100     */
4101    public List<ResourceInteractionComponent> getInteraction() {
4102      if (this.interaction == null)
4103        this.interaction = new ArrayList<ResourceInteractionComponent>();
4104      return this.interaction;
4105    }
4106
4107    /**
4108     * @return Returns a reference to <code>this</code> for easy method chaining
4109     */
4110    public CapabilityStatementRestResourceComponent setInteraction(List<ResourceInteractionComponent> theInteraction) {
4111      this.interaction = theInteraction;
4112      return this;
4113    }
4114
4115    public boolean hasInteraction() {
4116      if (this.interaction == null)
4117        return false;
4118      for (ResourceInteractionComponent item : this.interaction)
4119        if (!item.isEmpty())
4120          return true;
4121      return false;
4122    }
4123
4124    public ResourceInteractionComponent addInteraction() { // 3
4125      ResourceInteractionComponent t = new ResourceInteractionComponent();
4126      if (this.interaction == null)
4127        this.interaction = new ArrayList<ResourceInteractionComponent>();
4128      this.interaction.add(t);
4129      return t;
4130    }
4131
4132    public CapabilityStatementRestResourceComponent addInteraction(ResourceInteractionComponent t) { // 3
4133      if (t == null)
4134        return this;
4135      if (this.interaction == null)
4136        this.interaction = new ArrayList<ResourceInteractionComponent>();
4137      this.interaction.add(t);
4138      return this;
4139    }
4140
4141    /**
4142     * @return The first repetition of repeating field {@link #interaction},
4143     *         creating it if it does not already exist
4144     */
4145    public ResourceInteractionComponent getInteractionFirstRep() {
4146      if (getInteraction().isEmpty()) {
4147        addInteraction();
4148      }
4149      return getInteraction().get(0);
4150    }
4151
4152    /**
4153     * @return {@link #versioning} (This field is set to no-version to specify that
4154     *         the system does not support (server) or use (client) versioning for
4155     *         this resource type. If this has some other value, the server must at
4156     *         least correctly track and populate the versionId meta-property on
4157     *         resources. If the value is 'versioned-update', then the server
4158     *         supports all the versioning features, including using e-tags for
4159     *         version integrity in the API.). This is the underlying object with
4160     *         id, value and extensions. The accessor "getVersioning" gives direct
4161     *         access to the value
4162     */
4163    public Enumeration<ResourceVersionPolicy> getVersioningElement() {
4164      if (this.versioning == null)
4165        if (Configuration.errorOnAutoCreate())
4166          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.versioning");
4167        else if (Configuration.doAutoCreate())
4168          this.versioning = new Enumeration<ResourceVersionPolicy>(new ResourceVersionPolicyEnumFactory()); // bb
4169      return this.versioning;
4170    }
4171
4172    public boolean hasVersioningElement() {
4173      return this.versioning != null && !this.versioning.isEmpty();
4174    }
4175
4176    public boolean hasVersioning() {
4177      return this.versioning != null && !this.versioning.isEmpty();
4178    }
4179
4180    /**
4181     * @param value {@link #versioning} (This field is set to no-version to specify
4182     *              that the system does not support (server) or use (client)
4183     *              versioning for this resource type. If this has some other value,
4184     *              the server must at least correctly track and populate the
4185     *              versionId meta-property on resources. If the value is
4186     *              'versioned-update', then the server supports all the versioning
4187     *              features, including using e-tags for version integrity in the
4188     *              API.). This is the underlying object with id, value and
4189     *              extensions. The accessor "getVersioning" gives direct access to
4190     *              the value
4191     */
4192    public CapabilityStatementRestResourceComponent setVersioningElement(Enumeration<ResourceVersionPolicy> value) {
4193      this.versioning = value;
4194      return this;
4195    }
4196
4197    /**
4198     * @return This field is set to no-version to specify that the system does not
4199     *         support (server) or use (client) versioning for this resource type.
4200     *         If this has some other value, the server must at least correctly
4201     *         track and populate the versionId meta-property on resources. If the
4202     *         value is 'versioned-update', then the server supports all the
4203     *         versioning features, including using e-tags for version integrity in
4204     *         the API.
4205     */
4206    public ResourceVersionPolicy getVersioning() {
4207      return this.versioning == null ? null : this.versioning.getValue();
4208    }
4209
4210    /**
4211     * @param value This field is set to no-version to specify that the system does
4212     *              not support (server) or use (client) versioning for this
4213     *              resource type. If this has some other value, the server must at
4214     *              least correctly track and populate the versionId meta-property
4215     *              on resources. If the value is 'versioned-update', then the
4216     *              server supports all the versioning features, including using
4217     *              e-tags for version integrity in the API.
4218     */
4219    public CapabilityStatementRestResourceComponent setVersioning(ResourceVersionPolicy value) {
4220      if (value == null)
4221        this.versioning = null;
4222      else {
4223        if (this.versioning == null)
4224          this.versioning = new Enumeration<ResourceVersionPolicy>(new ResourceVersionPolicyEnumFactory());
4225        this.versioning.setValue(value);
4226      }
4227      return this;
4228    }
4229
4230    /**
4231     * @return {@link #readHistory} (A flag for whether the server is able to return
4232     *         past versions as part of the vRead operation.). This is the
4233     *         underlying object with id, value and extensions. The accessor
4234     *         "getReadHistory" gives direct access to the value
4235     */
4236    public BooleanType getReadHistoryElement() {
4237      if (this.readHistory == null)
4238        if (Configuration.errorOnAutoCreate())
4239          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.readHistory");
4240        else if (Configuration.doAutoCreate())
4241          this.readHistory = new BooleanType(); // bb
4242      return this.readHistory;
4243    }
4244
4245    public boolean hasReadHistoryElement() {
4246      return this.readHistory != null && !this.readHistory.isEmpty();
4247    }
4248
4249    public boolean hasReadHistory() {
4250      return this.readHistory != null && !this.readHistory.isEmpty();
4251    }
4252
4253    /**
4254     * @param value {@link #readHistory} (A flag for whether the server is able to
4255     *              return past versions as part of the vRead operation.). This is
4256     *              the underlying object with id, value and extensions. The
4257     *              accessor "getReadHistory" gives direct access to the value
4258     */
4259    public CapabilityStatementRestResourceComponent setReadHistoryElement(BooleanType value) {
4260      this.readHistory = value;
4261      return this;
4262    }
4263
4264    /**
4265     * @return A flag for whether the server is able to return past versions as part
4266     *         of the vRead operation.
4267     */
4268    public boolean getReadHistory() {
4269      return this.readHistory == null || this.readHistory.isEmpty() ? false : this.readHistory.getValue();
4270    }
4271
4272    /**
4273     * @param value A flag for whether the server is able to return past versions as
4274     *              part of the vRead operation.
4275     */
4276    public CapabilityStatementRestResourceComponent setReadHistory(boolean value) {
4277      if (this.readHistory == null)
4278        this.readHistory = new BooleanType();
4279      this.readHistory.setValue(value);
4280      return this;
4281    }
4282
4283    /**
4284     * @return {@link #updateCreate} (A flag to indicate that the server allows or
4285     *         needs to allow the client to create new identities on the server
4286     *         (that is, the client PUTs to a location where there is no existing
4287     *         resource). Allowing this operation means that the server allows the
4288     *         client to create new identities on the server.). This is the
4289     *         underlying object with id, value and extensions. The accessor
4290     *         "getUpdateCreate" gives direct access to the value
4291     */
4292    public BooleanType getUpdateCreateElement() {
4293      if (this.updateCreate == null)
4294        if (Configuration.errorOnAutoCreate())
4295          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.updateCreate");
4296        else if (Configuration.doAutoCreate())
4297          this.updateCreate = new BooleanType(); // bb
4298      return this.updateCreate;
4299    }
4300
4301    public boolean hasUpdateCreateElement() {
4302      return this.updateCreate != null && !this.updateCreate.isEmpty();
4303    }
4304
4305    public boolean hasUpdateCreate() {
4306      return this.updateCreate != null && !this.updateCreate.isEmpty();
4307    }
4308
4309    /**
4310     * @param value {@link #updateCreate} (A flag to indicate that the server allows
4311     *              or needs to allow the client to create new identities on the
4312     *              server (that is, the client PUTs to a location where there is no
4313     *              existing resource). Allowing this operation means that the
4314     *              server allows the client to create new identities on the
4315     *              server.). This is the underlying object with id, value and
4316     *              extensions. The accessor "getUpdateCreate" gives direct access
4317     *              to the value
4318     */
4319    public CapabilityStatementRestResourceComponent setUpdateCreateElement(BooleanType value) {
4320      this.updateCreate = value;
4321      return this;
4322    }
4323
4324    /**
4325     * @return A flag to indicate that the server allows or needs to allow the
4326     *         client to create new identities on the server (that is, the client
4327     *         PUTs to a location where there is no existing resource). Allowing
4328     *         this operation means that the server allows the client to create new
4329     *         identities on the server.
4330     */
4331    public boolean getUpdateCreate() {
4332      return this.updateCreate == null || this.updateCreate.isEmpty() ? false : this.updateCreate.getValue();
4333    }
4334
4335    /**
4336     * @param value A flag to indicate that the server allows or needs to allow the
4337     *              client to create new identities on the server (that is, the
4338     *              client PUTs to a location where there is no existing resource).
4339     *              Allowing this operation means that the server allows the client
4340     *              to create new identities on the server.
4341     */
4342    public CapabilityStatementRestResourceComponent setUpdateCreate(boolean value) {
4343      if (this.updateCreate == null)
4344        this.updateCreate = new BooleanType();
4345      this.updateCreate.setValue(value);
4346      return this;
4347    }
4348
4349    /**
4350     * @return {@link #conditionalCreate} (A flag that indicates that the server
4351     *         supports conditional create.). This is the underlying object with id,
4352     *         value and extensions. The accessor "getConditionalCreate" gives
4353     *         direct access to the value
4354     */
4355    public BooleanType getConditionalCreateElement() {
4356      if (this.conditionalCreate == null)
4357        if (Configuration.errorOnAutoCreate())
4358          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.conditionalCreate");
4359        else if (Configuration.doAutoCreate())
4360          this.conditionalCreate = new BooleanType(); // bb
4361      return this.conditionalCreate;
4362    }
4363
4364    public boolean hasConditionalCreateElement() {
4365      return this.conditionalCreate != null && !this.conditionalCreate.isEmpty();
4366    }
4367
4368    public boolean hasConditionalCreate() {
4369      return this.conditionalCreate != null && !this.conditionalCreate.isEmpty();
4370    }
4371
4372    /**
4373     * @param value {@link #conditionalCreate} (A flag that indicates that the
4374     *              server supports conditional create.). This is the underlying
4375     *              object with id, value and extensions. The accessor
4376     *              "getConditionalCreate" gives direct access to the value
4377     */
4378    public CapabilityStatementRestResourceComponent setConditionalCreateElement(BooleanType value) {
4379      this.conditionalCreate = value;
4380      return this;
4381    }
4382
4383    /**
4384     * @return A flag that indicates that the server supports conditional create.
4385     */
4386    public boolean getConditionalCreate() {
4387      return this.conditionalCreate == null || this.conditionalCreate.isEmpty() ? false
4388          : this.conditionalCreate.getValue();
4389    }
4390
4391    /**
4392     * @param value A flag that indicates that the server supports conditional
4393     *              create.
4394     */
4395    public CapabilityStatementRestResourceComponent setConditionalCreate(boolean value) {
4396      if (this.conditionalCreate == null)
4397        this.conditionalCreate = new BooleanType();
4398      this.conditionalCreate.setValue(value);
4399      return this;
4400    }
4401
4402    /**
4403     * @return {@link #conditionalRead} (A code that indicates how the server
4404     *         supports conditional read.). This is the underlying object with id,
4405     *         value and extensions. The accessor "getConditionalRead" gives direct
4406     *         access to the value
4407     */
4408    public Enumeration<ConditionalReadStatus> getConditionalReadElement() {
4409      if (this.conditionalRead == null)
4410        if (Configuration.errorOnAutoCreate())
4411          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.conditionalRead");
4412        else if (Configuration.doAutoCreate())
4413          this.conditionalRead = new Enumeration<ConditionalReadStatus>(new ConditionalReadStatusEnumFactory()); // bb
4414      return this.conditionalRead;
4415    }
4416
4417    public boolean hasConditionalReadElement() {
4418      return this.conditionalRead != null && !this.conditionalRead.isEmpty();
4419    }
4420
4421    public boolean hasConditionalRead() {
4422      return this.conditionalRead != null && !this.conditionalRead.isEmpty();
4423    }
4424
4425    /**
4426     * @param value {@link #conditionalRead} (A code that indicates how the server
4427     *              supports conditional read.). This is the underlying object with
4428     *              id, value and extensions. The accessor "getConditionalRead"
4429     *              gives direct access to the value
4430     */
4431    public CapabilityStatementRestResourceComponent setConditionalReadElement(
4432        Enumeration<ConditionalReadStatus> value) {
4433      this.conditionalRead = value;
4434      return this;
4435    }
4436
4437    /**
4438     * @return A code that indicates how the server supports conditional read.
4439     */
4440    public ConditionalReadStatus getConditionalRead() {
4441      return this.conditionalRead == null ? null : this.conditionalRead.getValue();
4442    }
4443
4444    /**
4445     * @param value A code that indicates how the server supports conditional read.
4446     */
4447    public CapabilityStatementRestResourceComponent setConditionalRead(ConditionalReadStatus value) {
4448      if (value == null)
4449        this.conditionalRead = null;
4450      else {
4451        if (this.conditionalRead == null)
4452          this.conditionalRead = new Enumeration<ConditionalReadStatus>(new ConditionalReadStatusEnumFactory());
4453        this.conditionalRead.setValue(value);
4454      }
4455      return this;
4456    }
4457
4458    /**
4459     * @return {@link #conditionalUpdate} (A flag that indicates that the server
4460     *         supports conditional update.). This is the underlying object with id,
4461     *         value and extensions. The accessor "getConditionalUpdate" gives
4462     *         direct access to the value
4463     */
4464    public BooleanType getConditionalUpdateElement() {
4465      if (this.conditionalUpdate == null)
4466        if (Configuration.errorOnAutoCreate())
4467          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.conditionalUpdate");
4468        else if (Configuration.doAutoCreate())
4469          this.conditionalUpdate = new BooleanType(); // bb
4470      return this.conditionalUpdate;
4471    }
4472
4473    public boolean hasConditionalUpdateElement() {
4474      return this.conditionalUpdate != null && !this.conditionalUpdate.isEmpty();
4475    }
4476
4477    public boolean hasConditionalUpdate() {
4478      return this.conditionalUpdate != null && !this.conditionalUpdate.isEmpty();
4479    }
4480
4481    /**
4482     * @param value {@link #conditionalUpdate} (A flag that indicates that the
4483     *              server supports conditional update.). This is the underlying
4484     *              object with id, value and extensions. The accessor
4485     *              "getConditionalUpdate" gives direct access to the value
4486     */
4487    public CapabilityStatementRestResourceComponent setConditionalUpdateElement(BooleanType value) {
4488      this.conditionalUpdate = value;
4489      return this;
4490    }
4491
4492    /**
4493     * @return A flag that indicates that the server supports conditional update.
4494     */
4495    public boolean getConditionalUpdate() {
4496      return this.conditionalUpdate == null || this.conditionalUpdate.isEmpty() ? false
4497          : this.conditionalUpdate.getValue();
4498    }
4499
4500    /**
4501     * @param value A flag that indicates that the server supports conditional
4502     *              update.
4503     */
4504    public CapabilityStatementRestResourceComponent setConditionalUpdate(boolean value) {
4505      if (this.conditionalUpdate == null)
4506        this.conditionalUpdate = new BooleanType();
4507      this.conditionalUpdate.setValue(value);
4508      return this;
4509    }
4510
4511    /**
4512     * @return {@link #conditionalDelete} (A code that indicates how the server
4513     *         supports conditional delete.). This is the underlying object with id,
4514     *         value and extensions. The accessor "getConditionalDelete" gives
4515     *         direct access to the value
4516     */
4517    public Enumeration<ConditionalDeleteStatus> getConditionalDeleteElement() {
4518      if (this.conditionalDelete == null)
4519        if (Configuration.errorOnAutoCreate())
4520          throw new Error("Attempt to auto-create CapabilityStatementRestResourceComponent.conditionalDelete");
4521        else if (Configuration.doAutoCreate())
4522          this.conditionalDelete = new Enumeration<ConditionalDeleteStatus>(new ConditionalDeleteStatusEnumFactory()); // bb
4523      return this.conditionalDelete;
4524    }
4525
4526    public boolean hasConditionalDeleteElement() {
4527      return this.conditionalDelete != null && !this.conditionalDelete.isEmpty();
4528    }
4529
4530    public boolean hasConditionalDelete() {
4531      return this.conditionalDelete != null && !this.conditionalDelete.isEmpty();
4532    }
4533
4534    /**
4535     * @param value {@link #conditionalDelete} (A code that indicates how the server
4536     *              supports conditional delete.). This is the underlying object
4537     *              with id, value and extensions. The accessor
4538     *              "getConditionalDelete" gives direct access to the value
4539     */
4540    public CapabilityStatementRestResourceComponent setConditionalDeleteElement(
4541        Enumeration<ConditionalDeleteStatus> value) {
4542      this.conditionalDelete = value;
4543      return this;
4544    }
4545
4546    /**
4547     * @return A code that indicates how the server supports conditional delete.
4548     */
4549    public ConditionalDeleteStatus getConditionalDelete() {
4550      return this.conditionalDelete == null ? null : this.conditionalDelete.getValue();
4551    }
4552
4553    /**
4554     * @param value A code that indicates how the server supports conditional
4555     *              delete.
4556     */
4557    public CapabilityStatementRestResourceComponent setConditionalDelete(ConditionalDeleteStatus value) {
4558      if (value == null)
4559        this.conditionalDelete = null;
4560      else {
4561        if (this.conditionalDelete == null)
4562          this.conditionalDelete = new Enumeration<ConditionalDeleteStatus>(new ConditionalDeleteStatusEnumFactory());
4563        this.conditionalDelete.setValue(value);
4564      }
4565      return this;
4566    }
4567
4568    /**
4569     * @return {@link #referencePolicy} (A set of flags that defines how references
4570     *         are supported.)
4571     */
4572    public List<Enumeration<ReferenceHandlingPolicy>> getReferencePolicy() {
4573      if (this.referencePolicy == null)
4574        this.referencePolicy = new ArrayList<Enumeration<ReferenceHandlingPolicy>>();
4575      return this.referencePolicy;
4576    }
4577
4578    /**
4579     * @return Returns a reference to <code>this</code> for easy method chaining
4580     */
4581    public CapabilityStatementRestResourceComponent setReferencePolicy(
4582        List<Enumeration<ReferenceHandlingPolicy>> theReferencePolicy) {
4583      this.referencePolicy = theReferencePolicy;
4584      return this;
4585    }
4586
4587    public boolean hasReferencePolicy() {
4588      if (this.referencePolicy == null)
4589        return false;
4590      for (Enumeration<ReferenceHandlingPolicy> item : this.referencePolicy)
4591        if (!item.isEmpty())
4592          return true;
4593      return false;
4594    }
4595
4596    /**
4597     * @return {@link #referencePolicy} (A set of flags that defines how references
4598     *         are supported.)
4599     */
4600    public Enumeration<ReferenceHandlingPolicy> addReferencePolicyElement() {// 2
4601      Enumeration<ReferenceHandlingPolicy> t = new Enumeration<ReferenceHandlingPolicy>(
4602          new ReferenceHandlingPolicyEnumFactory());
4603      if (this.referencePolicy == null)
4604        this.referencePolicy = new ArrayList<Enumeration<ReferenceHandlingPolicy>>();
4605      this.referencePolicy.add(t);
4606      return t;
4607    }
4608
4609    /**
4610     * @param value {@link #referencePolicy} (A set of flags that defines how
4611     *              references are supported.)
4612     */
4613    public CapabilityStatementRestResourceComponent addReferencePolicy(ReferenceHandlingPolicy value) { // 1
4614      Enumeration<ReferenceHandlingPolicy> t = new Enumeration<ReferenceHandlingPolicy>(
4615          new ReferenceHandlingPolicyEnumFactory());
4616      t.setValue(value);
4617      if (this.referencePolicy == null)
4618        this.referencePolicy = new ArrayList<Enumeration<ReferenceHandlingPolicy>>();
4619      this.referencePolicy.add(t);
4620      return this;
4621    }
4622
4623    /**
4624     * @param value {@link #referencePolicy} (A set of flags that defines how
4625     *              references are supported.)
4626     */
4627    public boolean hasReferencePolicy(ReferenceHandlingPolicy value) {
4628      if (this.referencePolicy == null)
4629        return false;
4630      for (Enumeration<ReferenceHandlingPolicy> v : this.referencePolicy)
4631        if (v.getValue().equals(value)) // code
4632          return true;
4633      return false;
4634    }
4635
4636    /**
4637     * @return {@link #searchInclude} (A list of _include values supported by the
4638     *         server.)
4639     */
4640    public List<StringType> getSearchInclude() {
4641      if (this.searchInclude == null)
4642        this.searchInclude = new ArrayList<StringType>();
4643      return this.searchInclude;
4644    }
4645
4646    /**
4647     * @return Returns a reference to <code>this</code> for easy method chaining
4648     */
4649    public CapabilityStatementRestResourceComponent setSearchInclude(List<StringType> theSearchInclude) {
4650      this.searchInclude = theSearchInclude;
4651      return this;
4652    }
4653
4654    public boolean hasSearchInclude() {
4655      if (this.searchInclude == null)
4656        return false;
4657      for (StringType item : this.searchInclude)
4658        if (!item.isEmpty())
4659          return true;
4660      return false;
4661    }
4662
4663    /**
4664     * @return {@link #searchInclude} (A list of _include values supported by the
4665     *         server.)
4666     */
4667    public StringType addSearchIncludeElement() {// 2
4668      StringType t = new StringType();
4669      if (this.searchInclude == null)
4670        this.searchInclude = new ArrayList<StringType>();
4671      this.searchInclude.add(t);
4672      return t;
4673    }
4674
4675    /**
4676     * @param value {@link #searchInclude} (A list of _include values supported by
4677     *              the server.)
4678     */
4679    public CapabilityStatementRestResourceComponent addSearchInclude(String value) { // 1
4680      StringType t = new StringType();
4681      t.setValue(value);
4682      if (this.searchInclude == null)
4683        this.searchInclude = new ArrayList<StringType>();
4684      this.searchInclude.add(t);
4685      return this;
4686    }
4687
4688    /**
4689     * @param value {@link #searchInclude} (A list of _include values supported by
4690     *              the server.)
4691     */
4692    public boolean hasSearchInclude(String value) {
4693      if (this.searchInclude == null)
4694        return false;
4695      for (StringType v : this.searchInclude)
4696        if (v.getValue().equals(value)) // string
4697          return true;
4698      return false;
4699    }
4700
4701    /**
4702     * @return {@link #searchRevInclude} (A list of _revinclude (reverse include)
4703     *         values supported by the server.)
4704     */
4705    public List<StringType> getSearchRevInclude() {
4706      if (this.searchRevInclude == null)
4707        this.searchRevInclude = new ArrayList<StringType>();
4708      return this.searchRevInclude;
4709    }
4710
4711    /**
4712     * @return Returns a reference to <code>this</code> for easy method chaining
4713     */
4714    public CapabilityStatementRestResourceComponent setSearchRevInclude(List<StringType> theSearchRevInclude) {
4715      this.searchRevInclude = theSearchRevInclude;
4716      return this;
4717    }
4718
4719    public boolean hasSearchRevInclude() {
4720      if (this.searchRevInclude == null)
4721        return false;
4722      for (StringType item : this.searchRevInclude)
4723        if (!item.isEmpty())
4724          return true;
4725      return false;
4726    }
4727
4728    /**
4729     * @return {@link #searchRevInclude} (A list of _revinclude (reverse include)
4730     *         values supported by the server.)
4731     */
4732    public StringType addSearchRevIncludeElement() {// 2
4733      StringType t = new StringType();
4734      if (this.searchRevInclude == null)
4735        this.searchRevInclude = new ArrayList<StringType>();
4736      this.searchRevInclude.add(t);
4737      return t;
4738    }
4739
4740    /**
4741     * @param value {@link #searchRevInclude} (A list of _revinclude (reverse
4742     *              include) values supported by the server.)
4743     */
4744    public CapabilityStatementRestResourceComponent addSearchRevInclude(String value) { // 1
4745      StringType t = new StringType();
4746      t.setValue(value);
4747      if (this.searchRevInclude == null)
4748        this.searchRevInclude = new ArrayList<StringType>();
4749      this.searchRevInclude.add(t);
4750      return this;
4751    }
4752
4753    /**
4754     * @param value {@link #searchRevInclude} (A list of _revinclude (reverse
4755     *              include) values supported by the server.)
4756     */
4757    public boolean hasSearchRevInclude(String value) {
4758      if (this.searchRevInclude == null)
4759        return false;
4760      for (StringType v : this.searchRevInclude)
4761        if (v.getValue().equals(value)) // string
4762          return true;
4763      return false;
4764    }
4765
4766    /**
4767     * @return {@link #searchParam} (Search parameters for implementations to
4768     *         support and/or make use of - either references to ones defined in the
4769     *         specification, or additional ones defined for/by the implementation.)
4770     */
4771    public List<CapabilityStatementRestResourceSearchParamComponent> getSearchParam() {
4772      if (this.searchParam == null)
4773        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
4774      return this.searchParam;
4775    }
4776
4777    /**
4778     * @return Returns a reference to <code>this</code> for easy method chaining
4779     */
4780    public CapabilityStatementRestResourceComponent setSearchParam(
4781        List<CapabilityStatementRestResourceSearchParamComponent> theSearchParam) {
4782      this.searchParam = theSearchParam;
4783      return this;
4784    }
4785
4786    public boolean hasSearchParam() {
4787      if (this.searchParam == null)
4788        return false;
4789      for (CapabilityStatementRestResourceSearchParamComponent item : this.searchParam)
4790        if (!item.isEmpty())
4791          return true;
4792      return false;
4793    }
4794
4795    public CapabilityStatementRestResourceSearchParamComponent addSearchParam() { // 3
4796      CapabilityStatementRestResourceSearchParamComponent t = new CapabilityStatementRestResourceSearchParamComponent();
4797      if (this.searchParam == null)
4798        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
4799      this.searchParam.add(t);
4800      return t;
4801    }
4802
4803    public CapabilityStatementRestResourceComponent addSearchParam(
4804        CapabilityStatementRestResourceSearchParamComponent t) { // 3
4805      if (t == null)
4806        return this;
4807      if (this.searchParam == null)
4808        this.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
4809      this.searchParam.add(t);
4810      return this;
4811    }
4812
4813    /**
4814     * @return The first repetition of repeating field {@link #searchParam},
4815     *         creating it if it does not already exist
4816     */
4817    public CapabilityStatementRestResourceSearchParamComponent getSearchParamFirstRep() {
4818      if (getSearchParam().isEmpty()) {
4819        addSearchParam();
4820      }
4821      return getSearchParam().get(0);
4822    }
4823
4824    /**
4825     * @return {@link #operation} (Definition of an operation or a named query
4826     *         together with its parameters and their meaning and type. Consult the
4827     *         definition of the operation for details about how to invoke the
4828     *         operation, and the parameters.)
4829     */
4830    public List<CapabilityStatementRestResourceOperationComponent> getOperation() {
4831      if (this.operation == null)
4832        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
4833      return this.operation;
4834    }
4835
4836    /**
4837     * @return Returns a reference to <code>this</code> for easy method chaining
4838     */
4839    public CapabilityStatementRestResourceComponent setOperation(
4840        List<CapabilityStatementRestResourceOperationComponent> theOperation) {
4841      this.operation = theOperation;
4842      return this;
4843    }
4844
4845    public boolean hasOperation() {
4846      if (this.operation == null)
4847        return false;
4848      for (CapabilityStatementRestResourceOperationComponent item : this.operation)
4849        if (!item.isEmpty())
4850          return true;
4851      return false;
4852    }
4853
4854    public CapabilityStatementRestResourceOperationComponent addOperation() { // 3
4855      CapabilityStatementRestResourceOperationComponent t = new CapabilityStatementRestResourceOperationComponent();
4856      if (this.operation == null)
4857        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
4858      this.operation.add(t);
4859      return t;
4860    }
4861
4862    public CapabilityStatementRestResourceComponent addOperation(CapabilityStatementRestResourceOperationComponent t) { // 3
4863      if (t == null)
4864        return this;
4865      if (this.operation == null)
4866        this.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
4867      this.operation.add(t);
4868      return this;
4869    }
4870
4871    /**
4872     * @return The first repetition of repeating field {@link #operation}, creating
4873     *         it if it does not already exist
4874     */
4875    public CapabilityStatementRestResourceOperationComponent getOperationFirstRep() {
4876      if (getOperation().isEmpty()) {
4877        addOperation();
4878      }
4879      return getOperation().get(0);
4880    }
4881
4882    protected void listChildren(List<Property> children) {
4883      super.listChildren(children);
4884      children.add(new Property("type", "code", "A type of resource exposed via the restful interface.", 0, 1, type));
4885      children.add(new Property("profile", "canonical(StructureDefinition)",
4886          "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).",
4887          0, 1, profile));
4888      children.add(new Property("supportedProfile", "canonical(StructureDefinition)",
4889          "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).",
4890          0, java.lang.Integer.MAX_VALUE, supportedProfile));
4891      children.add(new Property("documentation", "markdown",
4892          "Additional information about the resource type used by the system.", 0, 1, documentation));
4893      children.add(new Property("interaction", "", "Identifies a restful operation supported by the solution.", 0,
4894          java.lang.Integer.MAX_VALUE, interaction));
4895      children.add(new Property("versioning", "code",
4896          "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.",
4897          0, 1, versioning));
4898      children.add(new Property("readHistory", "boolean",
4899          "A flag for whether the server is able to return past versions as part of the vRead operation.", 0, 1,
4900          readHistory));
4901      children.add(new Property("updateCreate", "boolean",
4902          "A flag to indicate that the server allows or needs to allow the client to create new identities on the server (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.",
4903          0, 1, updateCreate));
4904      children.add(new Property("conditionalCreate", "boolean",
4905          "A flag that indicates that the server supports conditional create.", 0, 1, conditionalCreate));
4906      children.add(new Property("conditionalRead", "code",
4907          "A code that indicates how the server supports conditional read.", 0, 1, conditionalRead));
4908      children.add(new Property("conditionalUpdate", "boolean",
4909          "A flag that indicates that the server supports conditional update.", 0, 1, conditionalUpdate));
4910      children.add(new Property("conditionalDelete", "code",
4911          "A code that indicates how the server supports conditional delete.", 0, 1, conditionalDelete));
4912      children.add(new Property("referencePolicy", "code", "A set of flags that defines how references are supported.",
4913          0, java.lang.Integer.MAX_VALUE, referencePolicy));
4914      children.add(new Property("searchInclude", "string", "A list of _include values supported by the server.", 0,
4915          java.lang.Integer.MAX_VALUE, searchInclude));
4916      children.add(new Property("searchRevInclude", "string",
4917          "A list of _revinclude (reverse include) values supported by the server.", 0, java.lang.Integer.MAX_VALUE,
4918          searchRevInclude));
4919      children.add(new Property("searchParam", "",
4920          "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.",
4921          0, java.lang.Integer.MAX_VALUE, searchParam));
4922      children.add(new Property("operation", "",
4923          "Definition of an operation or a named query together with its parameters and their meaning and type. Consult the definition of the operation for details about how to invoke the operation, and the parameters.",
4924          0, java.lang.Integer.MAX_VALUE, operation));
4925    }
4926
4927    @Override
4928    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
4929      switch (_hash) {
4930      case 3575610:
4931        /* type */ return new Property("type", "code", "A type of resource exposed via the restful interface.", 0, 1,
4932            type);
4933      case -309425751:
4934        /* profile */ return new Property("profile", "canonical(StructureDefinition)",
4935            "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).",
4936            0, 1, profile);
4937      case 1225477403:
4938        /* supportedProfile */ return new Property("supportedProfile", "canonical(StructureDefinition)",
4939            "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).",
4940            0, java.lang.Integer.MAX_VALUE, supportedProfile);
4941      case 1587405498:
4942        /* documentation */ return new Property("documentation", "markdown",
4943            "Additional information about the resource type used by the system.", 0, 1, documentation);
4944      case 1844104722:
4945        /* interaction */ return new Property("interaction", "",
4946            "Identifies a restful operation supported by the solution.", 0, java.lang.Integer.MAX_VALUE, interaction);
4947      case -670487542:
4948        /* versioning */ return new Property("versioning", "code",
4949            "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.",
4950            0, 1, versioning);
4951      case 187518494:
4952        /* readHistory */ return new Property("readHistory", "boolean",
4953            "A flag for whether the server is able to return past versions as part of the vRead operation.", 0, 1,
4954            readHistory);
4955      case -1400550619:
4956        /* updateCreate */ return new Property("updateCreate", "boolean",
4957            "A flag to indicate that the server allows or needs to allow the client to create new identities on the server (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.",
4958            0, 1, updateCreate);
4959      case 6401826:
4960        /* conditionalCreate */ return new Property("conditionalCreate", "boolean",
4961            "A flag that indicates that the server supports conditional create.", 0, 1, conditionalCreate);
4962      case 822786364:
4963        /* conditionalRead */ return new Property("conditionalRead", "code",
4964            "A code that indicates how the server supports conditional read.", 0, 1, conditionalRead);
4965      case 519849711:
4966        /* conditionalUpdate */ return new Property("conditionalUpdate", "boolean",
4967            "A flag that indicates that the server supports conditional update.", 0, 1, conditionalUpdate);
4968      case 23237585:
4969        /* conditionalDelete */ return new Property("conditionalDelete", "code",
4970            "A code that indicates how the server supports conditional delete.", 0, 1, conditionalDelete);
4971      case 796257373:
4972        /* referencePolicy */ return new Property("referencePolicy", "code",
4973            "A set of flags that defines how references are supported.", 0, java.lang.Integer.MAX_VALUE,
4974            referencePolicy);
4975      case -1035904544:
4976        /* searchInclude */ return new Property("searchInclude", "string",
4977            "A list of _include values supported by the server.", 0, java.lang.Integer.MAX_VALUE, searchInclude);
4978      case -2123884979:
4979        /* searchRevInclude */ return new Property("searchRevInclude", "string",
4980            "A list of _revinclude (reverse include) values supported by the server.", 0, java.lang.Integer.MAX_VALUE,
4981            searchRevInclude);
4982      case -553645115:
4983        /* searchParam */ return new Property("searchParam", "",
4984            "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.",
4985            0, java.lang.Integer.MAX_VALUE, searchParam);
4986      case 1662702951:
4987        /* operation */ return new Property("operation", "",
4988            "Definition of an operation or a named query together with its parameters and their meaning and type. Consult the definition of the operation for details about how to invoke the operation, and the parameters.",
4989            0, java.lang.Integer.MAX_VALUE, operation);
4990      default:
4991        return super.getNamedProperty(_hash, _name, _checkValid);
4992      }
4993
4994    }
4995
4996    @Override
4997    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
4998      switch (hash) {
4999      case 3575610:
5000        /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeType
5001      case -309425751:
5002        /* profile */ return this.profile == null ? new Base[0] : new Base[] { this.profile }; // CanonicalType
5003      case 1225477403:
5004        /* supportedProfile */ return this.supportedProfile == null ? new Base[0]
5005            : this.supportedProfile.toArray(new Base[this.supportedProfile.size()]); // CanonicalType
5006      case 1587405498:
5007        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
5008      case 1844104722:
5009        /* interaction */ return this.interaction == null ? new Base[0]
5010            : this.interaction.toArray(new Base[this.interaction.size()]); // ResourceInteractionComponent
5011      case -670487542:
5012        /* versioning */ return this.versioning == null ? new Base[0] : new Base[] { this.versioning }; // Enumeration<ResourceVersionPolicy>
5013      case 187518494:
5014        /* readHistory */ return this.readHistory == null ? new Base[0] : new Base[] { this.readHistory }; // BooleanType
5015      case -1400550619:
5016        /* updateCreate */ return this.updateCreate == null ? new Base[0] : new Base[] { this.updateCreate }; // BooleanType
5017      case 6401826:
5018        /* conditionalCreate */ return this.conditionalCreate == null ? new Base[0]
5019            : new Base[] { this.conditionalCreate }; // BooleanType
5020      case 822786364:
5021        /* conditionalRead */ return this.conditionalRead == null ? new Base[0] : new Base[] { this.conditionalRead }; // Enumeration<ConditionalReadStatus>
5022      case 519849711:
5023        /* conditionalUpdate */ return this.conditionalUpdate == null ? new Base[0]
5024            : new Base[] { this.conditionalUpdate }; // BooleanType
5025      case 23237585:
5026        /* conditionalDelete */ return this.conditionalDelete == null ? new Base[0]
5027            : new Base[] { this.conditionalDelete }; // Enumeration<ConditionalDeleteStatus>
5028      case 796257373:
5029        /* referencePolicy */ return this.referencePolicy == null ? new Base[0]
5030            : this.referencePolicy.toArray(new Base[this.referencePolicy.size()]); // Enumeration<ReferenceHandlingPolicy>
5031      case -1035904544:
5032        /* searchInclude */ return this.searchInclude == null ? new Base[0]
5033            : this.searchInclude.toArray(new Base[this.searchInclude.size()]); // StringType
5034      case -2123884979:
5035        /* searchRevInclude */ return this.searchRevInclude == null ? new Base[0]
5036            : this.searchRevInclude.toArray(new Base[this.searchRevInclude.size()]); // StringType
5037      case -553645115:
5038        /* searchParam */ return this.searchParam == null ? new Base[0]
5039            : this.searchParam.toArray(new Base[this.searchParam.size()]); // CapabilityStatementRestResourceSearchParamComponent
5040      case 1662702951:
5041        /* operation */ return this.operation == null ? new Base[0]
5042            : this.operation.toArray(new Base[this.operation.size()]); // CapabilityStatementRestResourceOperationComponent
5043      default:
5044        return super.getProperty(hash, name, checkValid);
5045      }
5046
5047    }
5048
5049    @Override
5050    public Base setProperty(int hash, String name, Base value) throws FHIRException {
5051      switch (hash) {
5052      case 3575610: // type
5053        this.type = castToCode(value); // CodeType
5054        return value;
5055      case -309425751: // profile
5056        this.profile = castToCanonical(value); // CanonicalType
5057        return value;
5058      case 1225477403: // supportedProfile
5059        this.getSupportedProfile().add(castToCanonical(value)); // CanonicalType
5060        return value;
5061      case 1587405498: // documentation
5062        this.documentation = castToMarkdown(value); // MarkdownType
5063        return value;
5064      case 1844104722: // interaction
5065        this.getInteraction().add((ResourceInteractionComponent) value); // ResourceInteractionComponent
5066        return value;
5067      case -670487542: // versioning
5068        value = new ResourceVersionPolicyEnumFactory().fromType(castToCode(value));
5069        this.versioning = (Enumeration) value; // Enumeration<ResourceVersionPolicy>
5070        return value;
5071      case 187518494: // readHistory
5072        this.readHistory = castToBoolean(value); // BooleanType
5073        return value;
5074      case -1400550619: // updateCreate
5075        this.updateCreate = castToBoolean(value); // BooleanType
5076        return value;
5077      case 6401826: // conditionalCreate
5078        this.conditionalCreate = castToBoolean(value); // BooleanType
5079        return value;
5080      case 822786364: // conditionalRead
5081        value = new ConditionalReadStatusEnumFactory().fromType(castToCode(value));
5082        this.conditionalRead = (Enumeration) value; // Enumeration<ConditionalReadStatus>
5083        return value;
5084      case 519849711: // conditionalUpdate
5085        this.conditionalUpdate = castToBoolean(value); // BooleanType
5086        return value;
5087      case 23237585: // conditionalDelete
5088        value = new ConditionalDeleteStatusEnumFactory().fromType(castToCode(value));
5089        this.conditionalDelete = (Enumeration) value; // Enumeration<ConditionalDeleteStatus>
5090        return value;
5091      case 796257373: // referencePolicy
5092        value = new ReferenceHandlingPolicyEnumFactory().fromType(castToCode(value));
5093        this.getReferencePolicy().add((Enumeration) value); // Enumeration<ReferenceHandlingPolicy>
5094        return value;
5095      case -1035904544: // searchInclude
5096        this.getSearchInclude().add(castToString(value)); // StringType
5097        return value;
5098      case -2123884979: // searchRevInclude
5099        this.getSearchRevInclude().add(castToString(value)); // StringType
5100        return value;
5101      case -553645115: // searchParam
5102        this.getSearchParam().add((CapabilityStatementRestResourceSearchParamComponent) value); // CapabilityStatementRestResourceSearchParamComponent
5103        return value;
5104      case 1662702951: // operation
5105        this.getOperation().add((CapabilityStatementRestResourceOperationComponent) value); // CapabilityStatementRestResourceOperationComponent
5106        return value;
5107      default:
5108        return super.setProperty(hash, name, value);
5109      }
5110
5111    }
5112
5113    @Override
5114    public Base setProperty(String name, Base value) throws FHIRException {
5115      if (name.equals("type")) {
5116        this.type = castToCode(value); // CodeType
5117      } else if (name.equals("profile")) {
5118        this.profile = castToCanonical(value); // CanonicalType
5119      } else if (name.equals("supportedProfile")) {
5120        this.getSupportedProfile().add(castToCanonical(value));
5121      } else if (name.equals("documentation")) {
5122        this.documentation = castToMarkdown(value); // MarkdownType
5123      } else if (name.equals("interaction")) {
5124        this.getInteraction().add((ResourceInteractionComponent) value);
5125      } else if (name.equals("versioning")) {
5126        value = new ResourceVersionPolicyEnumFactory().fromType(castToCode(value));
5127        this.versioning = (Enumeration) value; // Enumeration<ResourceVersionPolicy>
5128      } else if (name.equals("readHistory")) {
5129        this.readHistory = castToBoolean(value); // BooleanType
5130      } else if (name.equals("updateCreate")) {
5131        this.updateCreate = castToBoolean(value); // BooleanType
5132      } else if (name.equals("conditionalCreate")) {
5133        this.conditionalCreate = castToBoolean(value); // BooleanType
5134      } else if (name.equals("conditionalRead")) {
5135        value = new ConditionalReadStatusEnumFactory().fromType(castToCode(value));
5136        this.conditionalRead = (Enumeration) value; // Enumeration<ConditionalReadStatus>
5137      } else if (name.equals("conditionalUpdate")) {
5138        this.conditionalUpdate = castToBoolean(value); // BooleanType
5139      } else if (name.equals("conditionalDelete")) {
5140        value = new ConditionalDeleteStatusEnumFactory().fromType(castToCode(value));
5141        this.conditionalDelete = (Enumeration) value; // Enumeration<ConditionalDeleteStatus>
5142      } else if (name.equals("referencePolicy")) {
5143        value = new ReferenceHandlingPolicyEnumFactory().fromType(castToCode(value));
5144        this.getReferencePolicy().add((Enumeration) value);
5145      } else if (name.equals("searchInclude")) {
5146        this.getSearchInclude().add(castToString(value));
5147      } else if (name.equals("searchRevInclude")) {
5148        this.getSearchRevInclude().add(castToString(value));
5149      } else if (name.equals("searchParam")) {
5150        this.getSearchParam().add((CapabilityStatementRestResourceSearchParamComponent) value);
5151      } else if (name.equals("operation")) {
5152        this.getOperation().add((CapabilityStatementRestResourceOperationComponent) value);
5153      } else
5154        return super.setProperty(name, value);
5155      return value;
5156    }
5157
5158  @Override
5159  public void removeChild(String name, Base value) throws FHIRException {
5160      if (name.equals("type")) {
5161        this.type = null;
5162      } else if (name.equals("profile")) {
5163        this.profile = null;
5164      } else if (name.equals("supportedProfile")) {
5165        this.getSupportedProfile().remove(castToCanonical(value));
5166      } else if (name.equals("documentation")) {
5167        this.documentation = null;
5168      } else if (name.equals("interaction")) {
5169        this.getInteraction().remove((ResourceInteractionComponent) value);
5170      } else if (name.equals("versioning")) {
5171        this.versioning = null;
5172      } else if (name.equals("readHistory")) {
5173        this.readHistory = null;
5174      } else if (name.equals("updateCreate")) {
5175        this.updateCreate = null;
5176      } else if (name.equals("conditionalCreate")) {
5177        this.conditionalCreate = null;
5178      } else if (name.equals("conditionalRead")) {
5179        this.conditionalRead = null;
5180      } else if (name.equals("conditionalUpdate")) {
5181        this.conditionalUpdate = null;
5182      } else if (name.equals("conditionalDelete")) {
5183        this.conditionalDelete = null;
5184      } else if (name.equals("referencePolicy")) {
5185        this.getReferencePolicy().remove((Enumeration) value);
5186      } else if (name.equals("searchInclude")) {
5187        this.getSearchInclude().remove(castToString(value));
5188      } else if (name.equals("searchRevInclude")) {
5189        this.getSearchRevInclude().remove(castToString(value));
5190      } else if (name.equals("searchParam")) {
5191        this.getSearchParam().remove((CapabilityStatementRestResourceSearchParamComponent) value);
5192      } else if (name.equals("operation")) {
5193        this.getOperation().remove((CapabilityStatementRestResourceOperationComponent) value);
5194      } else
5195        super.removeChild(name, value);
5196      
5197    }
5198
5199    @Override
5200    public Base makeProperty(int hash, String name) throws FHIRException {
5201      switch (hash) {
5202      case 3575610:
5203        return getTypeElement();
5204      case -309425751:
5205        return getProfileElement();
5206      case 1225477403:
5207        return addSupportedProfileElement();
5208      case 1587405498:
5209        return getDocumentationElement();
5210      case 1844104722:
5211        return addInteraction();
5212      case -670487542:
5213        return getVersioningElement();
5214      case 187518494:
5215        return getReadHistoryElement();
5216      case -1400550619:
5217        return getUpdateCreateElement();
5218      case 6401826:
5219        return getConditionalCreateElement();
5220      case 822786364:
5221        return getConditionalReadElement();
5222      case 519849711:
5223        return getConditionalUpdateElement();
5224      case 23237585:
5225        return getConditionalDeleteElement();
5226      case 796257373:
5227        return addReferencePolicyElement();
5228      case -1035904544:
5229        return addSearchIncludeElement();
5230      case -2123884979:
5231        return addSearchRevIncludeElement();
5232      case -553645115:
5233        return addSearchParam();
5234      case 1662702951:
5235        return addOperation();
5236      default:
5237        return super.makeProperty(hash, name);
5238      }
5239
5240    }
5241
5242    @Override
5243    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
5244      switch (hash) {
5245      case 3575610:
5246        /* type */ return new String[] { "code" };
5247      case -309425751:
5248        /* profile */ return new String[] { "canonical" };
5249      case 1225477403:
5250        /* supportedProfile */ return new String[] { "canonical" };
5251      case 1587405498:
5252        /* documentation */ return new String[] { "markdown" };
5253      case 1844104722:
5254        /* interaction */ return new String[] {};
5255      case -670487542:
5256        /* versioning */ return new String[] { "code" };
5257      case 187518494:
5258        /* readHistory */ return new String[] { "boolean" };
5259      case -1400550619:
5260        /* updateCreate */ return new String[] { "boolean" };
5261      case 6401826:
5262        /* conditionalCreate */ return new String[] { "boolean" };
5263      case 822786364:
5264        /* conditionalRead */ return new String[] { "code" };
5265      case 519849711:
5266        /* conditionalUpdate */ return new String[] { "boolean" };
5267      case 23237585:
5268        /* conditionalDelete */ return new String[] { "code" };
5269      case 796257373:
5270        /* referencePolicy */ return new String[] { "code" };
5271      case -1035904544:
5272        /* searchInclude */ return new String[] { "string" };
5273      case -2123884979:
5274        /* searchRevInclude */ return new String[] { "string" };
5275      case -553645115:
5276        /* searchParam */ return new String[] {};
5277      case 1662702951:
5278        /* operation */ return new String[] {};
5279      default:
5280        return super.getTypesForProperty(hash, name);
5281      }
5282
5283    }
5284
5285    @Override
5286    public Base addChild(String name) throws FHIRException {
5287      if (name.equals("type")) {
5288        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.type");
5289      } else if (name.equals("profile")) {
5290        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.profile");
5291      } else if (name.equals("supportedProfile")) {
5292        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.supportedProfile");
5293      } else if (name.equals("documentation")) {
5294        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
5295      } else if (name.equals("interaction")) {
5296        return addInteraction();
5297      } else if (name.equals("versioning")) {
5298        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.versioning");
5299      } else if (name.equals("readHistory")) {
5300        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.readHistory");
5301      } else if (name.equals("updateCreate")) {
5302        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.updateCreate");
5303      } else if (name.equals("conditionalCreate")) {
5304        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.conditionalCreate");
5305      } else if (name.equals("conditionalRead")) {
5306        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.conditionalRead");
5307      } else if (name.equals("conditionalUpdate")) {
5308        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.conditionalUpdate");
5309      } else if (name.equals("conditionalDelete")) {
5310        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.conditionalDelete");
5311      } else if (name.equals("referencePolicy")) {
5312        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.referencePolicy");
5313      } else if (name.equals("searchInclude")) {
5314        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.searchInclude");
5315      } else if (name.equals("searchRevInclude")) {
5316        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.searchRevInclude");
5317      } else if (name.equals("searchParam")) {
5318        return addSearchParam();
5319      } else if (name.equals("operation")) {
5320        return addOperation();
5321      } else
5322        return super.addChild(name);
5323    }
5324
5325    public CapabilityStatementRestResourceComponent copy() {
5326      CapabilityStatementRestResourceComponent dst = new CapabilityStatementRestResourceComponent();
5327      copyValues(dst);
5328      return dst;
5329    }
5330
5331    public void copyValues(CapabilityStatementRestResourceComponent dst) {
5332      super.copyValues(dst);
5333      dst.type = type == null ? null : type.copy();
5334      dst.profile = profile == null ? null : profile.copy();
5335      if (supportedProfile != null) {
5336        dst.supportedProfile = new ArrayList<CanonicalType>();
5337        for (CanonicalType i : supportedProfile)
5338          dst.supportedProfile.add(i.copy());
5339      }
5340      ;
5341      dst.documentation = documentation == null ? null : documentation.copy();
5342      if (interaction != null) {
5343        dst.interaction = new ArrayList<ResourceInteractionComponent>();
5344        for (ResourceInteractionComponent i : interaction)
5345          dst.interaction.add(i.copy());
5346      }
5347      ;
5348      dst.versioning = versioning == null ? null : versioning.copy();
5349      dst.readHistory = readHistory == null ? null : readHistory.copy();
5350      dst.updateCreate = updateCreate == null ? null : updateCreate.copy();
5351      dst.conditionalCreate = conditionalCreate == null ? null : conditionalCreate.copy();
5352      dst.conditionalRead = conditionalRead == null ? null : conditionalRead.copy();
5353      dst.conditionalUpdate = conditionalUpdate == null ? null : conditionalUpdate.copy();
5354      dst.conditionalDelete = conditionalDelete == null ? null : conditionalDelete.copy();
5355      if (referencePolicy != null) {
5356        dst.referencePolicy = new ArrayList<Enumeration<ReferenceHandlingPolicy>>();
5357        for (Enumeration<ReferenceHandlingPolicy> i : referencePolicy)
5358          dst.referencePolicy.add(i.copy());
5359      }
5360      ;
5361      if (searchInclude != null) {
5362        dst.searchInclude = new ArrayList<StringType>();
5363        for (StringType i : searchInclude)
5364          dst.searchInclude.add(i.copy());
5365      }
5366      ;
5367      if (searchRevInclude != null) {
5368        dst.searchRevInclude = new ArrayList<StringType>();
5369        for (StringType i : searchRevInclude)
5370          dst.searchRevInclude.add(i.copy());
5371      }
5372      ;
5373      if (searchParam != null) {
5374        dst.searchParam = new ArrayList<CapabilityStatementRestResourceSearchParamComponent>();
5375        for (CapabilityStatementRestResourceSearchParamComponent i : searchParam)
5376          dst.searchParam.add(i.copy());
5377      }
5378      ;
5379      if (operation != null) {
5380        dst.operation = new ArrayList<CapabilityStatementRestResourceOperationComponent>();
5381        for (CapabilityStatementRestResourceOperationComponent i : operation)
5382          dst.operation.add(i.copy());
5383      }
5384      ;
5385    }
5386
5387    @Override
5388    public boolean equalsDeep(Base other_) {
5389      if (!super.equalsDeep(other_))
5390        return false;
5391      if (!(other_ instanceof CapabilityStatementRestResourceComponent))
5392        return false;
5393      CapabilityStatementRestResourceComponent o = (CapabilityStatementRestResourceComponent) other_;
5394      return compareDeep(type, o.type, true) && compareDeep(profile, o.profile, true)
5395          && compareDeep(supportedProfile, o.supportedProfile, true)
5396          && compareDeep(documentation, o.documentation, true) && compareDeep(interaction, o.interaction, true)
5397          && compareDeep(versioning, o.versioning, true) && compareDeep(readHistory, o.readHistory, true)
5398          && compareDeep(updateCreate, o.updateCreate, true)
5399          && compareDeep(conditionalCreate, o.conditionalCreate, true)
5400          && compareDeep(conditionalRead, o.conditionalRead, true)
5401          && compareDeep(conditionalUpdate, o.conditionalUpdate, true)
5402          && compareDeep(conditionalDelete, o.conditionalDelete, true)
5403          && compareDeep(referencePolicy, o.referencePolicy, true) && compareDeep(searchInclude, o.searchInclude, true)
5404          && compareDeep(searchRevInclude, o.searchRevInclude, true) && compareDeep(searchParam, o.searchParam, true)
5405          && compareDeep(operation, o.operation, true);
5406    }
5407
5408    @Override
5409    public boolean equalsShallow(Base other_) {
5410      if (!super.equalsShallow(other_))
5411        return false;
5412      if (!(other_ instanceof CapabilityStatementRestResourceComponent))
5413        return false;
5414      CapabilityStatementRestResourceComponent o = (CapabilityStatementRestResourceComponent) other_;
5415      return compareValues(type, o.type, true) && compareValues(documentation, o.documentation, true)
5416          && compareValues(versioning, o.versioning, true) && compareValues(readHistory, o.readHistory, true)
5417          && compareValues(updateCreate, o.updateCreate, true)
5418          && compareValues(conditionalCreate, o.conditionalCreate, true)
5419          && compareValues(conditionalRead, o.conditionalRead, true)
5420          && compareValues(conditionalUpdate, o.conditionalUpdate, true)
5421          && compareValues(conditionalDelete, o.conditionalDelete, true)
5422          && compareValues(referencePolicy, o.referencePolicy, true)
5423          && compareValues(searchInclude, o.searchInclude, true)
5424          && compareValues(searchRevInclude, o.searchRevInclude, true);
5425    }
5426
5427    public boolean isEmpty() {
5428      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(type, profile, supportedProfile, documentation,
5429          interaction, versioning, readHistory, updateCreate, conditionalCreate, conditionalRead, conditionalUpdate,
5430          conditionalDelete, referencePolicy, searchInclude, searchRevInclude, searchParam, operation);
5431    }
5432
5433    public String fhirType() {
5434      return "CapabilityStatement.rest.resource";
5435
5436    }
5437
5438  }
5439
5440  @Block()
5441  public static class ResourceInteractionComponent extends BackboneElement implements IBaseBackboneElement {
5442    /**
5443     * Coded identifier of the operation, supported by the system resource.
5444     */
5445    @Child(name = "code", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
5446    @Description(shortDefinition = "read | vread | update | patch | delete | history-instance | history-type | create | search-type", formalDefinition = "Coded identifier of the operation, supported by the system resource.")
5447    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/type-restful-interaction")
5448    protected Enumeration<TypeRestfulInteraction> code;
5449
5450    /**
5451     * Guidance specific to the implementation of this operation, such as 'delete is
5452     * a logical delete' or 'updates are only allowed with version id' or 'creates
5453     * permitted from pre-authorized certificates only'.
5454     */
5455    @Child(name = "documentation", type = {
5456        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
5457    @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'.")
5458    protected MarkdownType documentation;
5459
5460    private static final long serialVersionUID = 2128937796L;
5461
5462    /**
5463     * Constructor
5464     */
5465    public ResourceInteractionComponent() {
5466      super();
5467    }
5468
5469    /**
5470     * Constructor
5471     */
5472    public ResourceInteractionComponent(Enumeration<TypeRestfulInteraction> code) {
5473      super();
5474      this.code = code;
5475    }
5476
5477    /**
5478     * @return {@link #code} (Coded identifier of the operation, supported by the
5479     *         system resource.). This is the underlying object with id, value and
5480     *         extensions. The accessor "getCode" gives direct access to the value
5481     */
5482    public Enumeration<TypeRestfulInteraction> getCodeElement() {
5483      if (this.code == null)
5484        if (Configuration.errorOnAutoCreate())
5485          throw new Error("Attempt to auto-create ResourceInteractionComponent.code");
5486        else if (Configuration.doAutoCreate())
5487          this.code = new Enumeration<TypeRestfulInteraction>(new TypeRestfulInteractionEnumFactory()); // bb
5488      return this.code;
5489    }
5490
5491    public boolean hasCodeElement() {
5492      return this.code != null && !this.code.isEmpty();
5493    }
5494
5495    public boolean hasCode() {
5496      return this.code != null && !this.code.isEmpty();
5497    }
5498
5499    /**
5500     * @param value {@link #code} (Coded identifier of the operation, supported by
5501     *              the system resource.). This is the underlying object with id,
5502     *              value and extensions. The accessor "getCode" gives direct access
5503     *              to the value
5504     */
5505    public ResourceInteractionComponent setCodeElement(Enumeration<TypeRestfulInteraction> value) {
5506      this.code = value;
5507      return this;
5508    }
5509
5510    /**
5511     * @return Coded identifier of the operation, supported by the system resource.
5512     */
5513    public TypeRestfulInteraction getCode() {
5514      return this.code == null ? null : this.code.getValue();
5515    }
5516
5517    /**
5518     * @param value Coded identifier of the operation, supported by the system
5519     *              resource.
5520     */
5521    public ResourceInteractionComponent setCode(TypeRestfulInteraction value) {
5522      if (this.code == null)
5523        this.code = new Enumeration<TypeRestfulInteraction>(new TypeRestfulInteractionEnumFactory());
5524      this.code.setValue(value);
5525      return this;
5526    }
5527
5528    /**
5529     * @return {@link #documentation} (Guidance specific to the implementation of
5530     *         this operation, such as 'delete is a logical delete' or 'updates are
5531     *         only allowed with version id' or 'creates permitted from
5532     *         pre-authorized certificates only'.). This is the underlying object
5533     *         with id, value and extensions. The accessor "getDocumentation" gives
5534     *         direct access to the value
5535     */
5536    public MarkdownType getDocumentationElement() {
5537      if (this.documentation == null)
5538        if (Configuration.errorOnAutoCreate())
5539          throw new Error("Attempt to auto-create ResourceInteractionComponent.documentation");
5540        else if (Configuration.doAutoCreate())
5541          this.documentation = new MarkdownType(); // bb
5542      return this.documentation;
5543    }
5544
5545    public boolean hasDocumentationElement() {
5546      return this.documentation != null && !this.documentation.isEmpty();
5547    }
5548
5549    public boolean hasDocumentation() {
5550      return this.documentation != null && !this.documentation.isEmpty();
5551    }
5552
5553    /**
5554     * @param value {@link #documentation} (Guidance specific to the implementation
5555     *              of this operation, such as 'delete is a logical delete' or
5556     *              'updates are only allowed with version id' or 'creates permitted
5557     *              from pre-authorized certificates only'.). This is the underlying
5558     *              object with id, value and extensions. The accessor
5559     *              "getDocumentation" gives direct access to the value
5560     */
5561    public ResourceInteractionComponent setDocumentationElement(MarkdownType value) {
5562      this.documentation = value;
5563      return this;
5564    }
5565
5566    /**
5567     * @return Guidance specific to the implementation of this operation, such as
5568     *         'delete is a logical delete' or 'updates are only allowed with
5569     *         version id' or 'creates permitted from pre-authorized certificates
5570     *         only'.
5571     */
5572    public String getDocumentation() {
5573      return this.documentation == null ? null : this.documentation.getValue();
5574    }
5575
5576    /**
5577     * @param value Guidance specific to the implementation of this operation, such
5578     *              as 'delete is a logical delete' or 'updates are only allowed
5579     *              with version id' or 'creates permitted from pre-authorized
5580     *              certificates only'.
5581     */
5582    public ResourceInteractionComponent setDocumentation(String value) {
5583      if (value == null)
5584        this.documentation = null;
5585      else {
5586        if (this.documentation == null)
5587          this.documentation = new MarkdownType();
5588        this.documentation.setValue(value);
5589      }
5590      return this;
5591    }
5592
5593    protected void listChildren(List<Property> children) {
5594      super.listChildren(children);
5595      children.add(new Property("code", "code", "Coded identifier of the operation, supported by the system resource.",
5596          0, 1, code));
5597      children.add(new Property("documentation", "markdown",
5598          "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'.",
5599          0, 1, documentation));
5600    }
5601
5602    @Override
5603    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
5604      switch (_hash) {
5605      case 3059181:
5606        /* code */ return new Property("code", "code",
5607            "Coded identifier of the operation, supported by the system resource.", 0, 1, code);
5608      case 1587405498:
5609        /* documentation */ return new Property("documentation", "markdown",
5610            "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'.",
5611            0, 1, documentation);
5612      default:
5613        return super.getNamedProperty(_hash, _name, _checkValid);
5614      }
5615
5616    }
5617
5618    @Override
5619    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
5620      switch (hash) {
5621      case 3059181:
5622        /* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // Enumeration<TypeRestfulInteraction>
5623      case 1587405498:
5624        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
5625      default:
5626        return super.getProperty(hash, name, checkValid);
5627      }
5628
5629    }
5630
5631    @Override
5632    public Base setProperty(int hash, String name, Base value) throws FHIRException {
5633      switch (hash) {
5634      case 3059181: // code
5635        value = new TypeRestfulInteractionEnumFactory().fromType(castToCode(value));
5636        this.code = (Enumeration) value; // Enumeration<TypeRestfulInteraction>
5637        return value;
5638      case 1587405498: // documentation
5639        this.documentation = castToMarkdown(value); // MarkdownType
5640        return value;
5641      default:
5642        return super.setProperty(hash, name, value);
5643      }
5644
5645    }
5646
5647    @Override
5648    public Base setProperty(String name, Base value) throws FHIRException {
5649      if (name.equals("code")) {
5650        value = new TypeRestfulInteractionEnumFactory().fromType(castToCode(value));
5651        this.code = (Enumeration) value; // Enumeration<TypeRestfulInteraction>
5652      } else if (name.equals("documentation")) {
5653        this.documentation = castToMarkdown(value); // MarkdownType
5654      } else
5655        return super.setProperty(name, value);
5656      return value;
5657    }
5658
5659  @Override
5660  public void removeChild(String name, Base value) throws FHIRException {
5661      if (name.equals("code")) {
5662        this.code = null;
5663      } else if (name.equals("documentation")) {
5664        this.documentation = null;
5665      } else
5666        super.removeChild(name, value);
5667      
5668    }
5669
5670    @Override
5671    public Base makeProperty(int hash, String name) throws FHIRException {
5672      switch (hash) {
5673      case 3059181:
5674        return getCodeElement();
5675      case 1587405498:
5676        return getDocumentationElement();
5677      default:
5678        return super.makeProperty(hash, name);
5679      }
5680
5681    }
5682
5683    @Override
5684    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
5685      switch (hash) {
5686      case 3059181:
5687        /* code */ return new String[] { "code" };
5688      case 1587405498:
5689        /* documentation */ return new String[] { "markdown" };
5690      default:
5691        return super.getTypesForProperty(hash, name);
5692      }
5693
5694    }
5695
5696    @Override
5697    public Base addChild(String name) throws FHIRException {
5698      if (name.equals("code")) {
5699        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.code");
5700      } else if (name.equals("documentation")) {
5701        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
5702      } else
5703        return super.addChild(name);
5704    }
5705
5706    public ResourceInteractionComponent copy() {
5707      ResourceInteractionComponent dst = new ResourceInteractionComponent();
5708      copyValues(dst);
5709      return dst;
5710    }
5711
5712    public void copyValues(ResourceInteractionComponent dst) {
5713      super.copyValues(dst);
5714      dst.code = code == null ? null : code.copy();
5715      dst.documentation = documentation == null ? null : documentation.copy();
5716    }
5717
5718    @Override
5719    public boolean equalsDeep(Base other_) {
5720      if (!super.equalsDeep(other_))
5721        return false;
5722      if (!(other_ instanceof ResourceInteractionComponent))
5723        return false;
5724      ResourceInteractionComponent o = (ResourceInteractionComponent) other_;
5725      return compareDeep(code, o.code, true) && compareDeep(documentation, o.documentation, true);
5726    }
5727
5728    @Override
5729    public boolean equalsShallow(Base other_) {
5730      if (!super.equalsShallow(other_))
5731        return false;
5732      if (!(other_ instanceof ResourceInteractionComponent))
5733        return false;
5734      ResourceInteractionComponent o = (ResourceInteractionComponent) other_;
5735      return compareValues(code, o.code, true) && compareValues(documentation, o.documentation, true);
5736    }
5737
5738    public boolean isEmpty() {
5739      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(code, documentation);
5740    }
5741
5742    public String fhirType() {
5743      return "CapabilityStatement.rest.resource.interaction";
5744
5745    }
5746
5747  }
5748
5749  @Block()
5750  public static class CapabilityStatementRestResourceSearchParamComponent extends BackboneElement
5751      implements IBaseBackboneElement {
5752    /**
5753     * The name of the search parameter used in the interface.
5754     */
5755    @Child(name = "name", type = { StringType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
5756    @Description(shortDefinition = "Name of search parameter", formalDefinition = "The name of the search parameter used in the interface.")
5757    protected StringType name;
5758
5759    /**
5760     * An absolute URI that is a formal reference to where this parameter was first
5761     * defined, so that a client can be confident of the meaning of the search
5762     * parameter (a reference to [[[SearchParameter.url]]]). This element SHALL be
5763     * populated if the search parameter refers to a SearchParameter defined by the
5764     * FHIR core specification or externally defined IGs.
5765     */
5766    @Child(name = "definition", type = {
5767        CanonicalType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
5768    @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]]]). This element SHALL be populated if the search parameter refers to a SearchParameter defined by the FHIR core specification or externally defined IGs.")
5769    protected CanonicalType definition;
5770
5771    /**
5772     * The type of value a search parameter refers to, and how the content is
5773     * interpreted.
5774     */
5775    @Child(name = "type", type = { CodeType.class }, order = 3, min = 1, max = 1, modifier = false, summary = false)
5776    @Description(shortDefinition = "number | date | string | token | reference | composite | quantity | uri | special", formalDefinition = "The type of value a search parameter refers to, and how the content is interpreted.")
5777    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/search-param-type")
5778    protected Enumeration<SearchParamType> type;
5779
5780    /**
5781     * This allows documentation of any distinct behaviors about how the search
5782     * parameter is used. For example, text matching algorithms.
5783     */
5784    @Child(name = "documentation", type = {
5785        MarkdownType.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
5786    @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.")
5787    protected MarkdownType documentation;
5788
5789    private static final long serialVersionUID = -171123928L;
5790
5791    /**
5792     * Constructor
5793     */
5794    public CapabilityStatementRestResourceSearchParamComponent() {
5795      super();
5796    }
5797
5798    /**
5799     * Constructor
5800     */
5801    public CapabilityStatementRestResourceSearchParamComponent(StringType name, Enumeration<SearchParamType> type) {
5802      super();
5803      this.name = name;
5804      this.type = type;
5805    }
5806
5807    /**
5808     * @return {@link #name} (The name of the search parameter used in the
5809     *         interface.). This is the underlying object with id, value and
5810     *         extensions. The accessor "getName" gives direct access to the value
5811     */
5812    public StringType getNameElement() {
5813      if (this.name == null)
5814        if (Configuration.errorOnAutoCreate())
5815          throw new Error("Attempt to auto-create CapabilityStatementRestResourceSearchParamComponent.name");
5816        else if (Configuration.doAutoCreate())
5817          this.name = new StringType(); // bb
5818      return this.name;
5819    }
5820
5821    public boolean hasNameElement() {
5822      return this.name != null && !this.name.isEmpty();
5823    }
5824
5825    public boolean hasName() {
5826      return this.name != null && !this.name.isEmpty();
5827    }
5828
5829    /**
5830     * @param value {@link #name} (The name of the search parameter used in the
5831     *              interface.). This is the underlying object with id, value and
5832     *              extensions. The accessor "getName" gives direct access to the
5833     *              value
5834     */
5835    public CapabilityStatementRestResourceSearchParamComponent setNameElement(StringType value) {
5836      this.name = value;
5837      return this;
5838    }
5839
5840    /**
5841     * @return The name of the search parameter used in the interface.
5842     */
5843    public String getName() {
5844      return this.name == null ? null : this.name.getValue();
5845    }
5846
5847    /**
5848     * @param value The name of the search parameter used in the interface.
5849     */
5850    public CapabilityStatementRestResourceSearchParamComponent setName(String value) {
5851      if (this.name == null)
5852        this.name = new StringType();
5853      this.name.setValue(value);
5854      return this;
5855    }
5856
5857    /**
5858     * @return {@link #definition} (An absolute URI that is a formal reference to
5859     *         where this parameter was first defined, so that a client can be
5860     *         confident of the meaning of the search parameter (a reference to
5861     *         [[[SearchParameter.url]]]). This element SHALL be populated if the
5862     *         search parameter refers to a SearchParameter defined by the FHIR core
5863     *         specification or externally defined IGs.). This is the underlying
5864     *         object with id, value and extensions. The accessor "getDefinition"
5865     *         gives direct access to the value
5866     */
5867    public CanonicalType getDefinitionElement() {
5868      if (this.definition == null)
5869        if (Configuration.errorOnAutoCreate())
5870          throw new Error("Attempt to auto-create CapabilityStatementRestResourceSearchParamComponent.definition");
5871        else if (Configuration.doAutoCreate())
5872          this.definition = new CanonicalType(); // bb
5873      return this.definition;
5874    }
5875
5876    public boolean hasDefinitionElement() {
5877      return this.definition != null && !this.definition.isEmpty();
5878    }
5879
5880    public boolean hasDefinition() {
5881      return this.definition != null && !this.definition.isEmpty();
5882    }
5883
5884    /**
5885     * @param value {@link #definition} (An absolute URI that is a formal reference
5886     *              to where this parameter was first defined, so that a client can
5887     *              be confident of the meaning of the search parameter (a reference
5888     *              to [[[SearchParameter.url]]]). This element SHALL be populated
5889     *              if the search parameter refers to a SearchParameter defined by
5890     *              the FHIR core specification or externally defined IGs.). This is
5891     *              the underlying object with id, value and extensions. The
5892     *              accessor "getDefinition" gives direct access to the value
5893     */
5894    public CapabilityStatementRestResourceSearchParamComponent setDefinitionElement(CanonicalType value) {
5895      this.definition = value;
5896      return this;
5897    }
5898
5899    /**
5900     * @return An absolute URI that is a formal reference to where this parameter
5901     *         was first defined, so that a client can be confident of the meaning
5902     *         of the search parameter (a reference to [[[SearchParameter.url]]]).
5903     *         This element SHALL be populated if the search parameter refers to a
5904     *         SearchParameter defined by the FHIR core specification or externally
5905     *         defined IGs.
5906     */
5907    public String getDefinition() {
5908      return this.definition == null ? null : this.definition.getValue();
5909    }
5910
5911    /**
5912     * @param value An absolute URI that is a formal reference to where this
5913     *              parameter was first defined, so that a client can be confident
5914     *              of the meaning of the search parameter (a reference to
5915     *              [[[SearchParameter.url]]]). This element SHALL be populated if
5916     *              the search parameter refers to a SearchParameter defined by the
5917     *              FHIR core specification or externally defined IGs.
5918     */
5919    public CapabilityStatementRestResourceSearchParamComponent setDefinition(String value) {
5920      if (Utilities.noString(value))
5921        this.definition = null;
5922      else {
5923        if (this.definition == null)
5924          this.definition = new CanonicalType();
5925        this.definition.setValue(value);
5926      }
5927      return this;
5928    }
5929
5930    /**
5931     * @return {@link #type} (The type of value a search parameter refers to, and
5932     *         how the content is interpreted.). This is the underlying object with
5933     *         id, value and extensions. The accessor "getType" gives direct access
5934     *         to the value
5935     */
5936    public Enumeration<SearchParamType> getTypeElement() {
5937      if (this.type == null)
5938        if (Configuration.errorOnAutoCreate())
5939          throw new Error("Attempt to auto-create CapabilityStatementRestResourceSearchParamComponent.type");
5940        else if (Configuration.doAutoCreate())
5941          this.type = new Enumeration<SearchParamType>(new SearchParamTypeEnumFactory()); // bb
5942      return this.type;
5943    }
5944
5945    public boolean hasTypeElement() {
5946      return this.type != null && !this.type.isEmpty();
5947    }
5948
5949    public boolean hasType() {
5950      return this.type != null && !this.type.isEmpty();
5951    }
5952
5953    /**
5954     * @param value {@link #type} (The type of value a search parameter refers to,
5955     *              and how the content is interpreted.). This is the underlying
5956     *              object with id, value and extensions. The accessor "getType"
5957     *              gives direct access to the value
5958     */
5959    public CapabilityStatementRestResourceSearchParamComponent setTypeElement(Enumeration<SearchParamType> value) {
5960      this.type = value;
5961      return this;
5962    }
5963
5964    /**
5965     * @return The type of value a search parameter refers to, and how the content
5966     *         is interpreted.
5967     */
5968    public SearchParamType getType() {
5969      return this.type == null ? null : this.type.getValue();
5970    }
5971
5972    /**
5973     * @param value The type of value a search parameter refers to, and how the
5974     *              content is interpreted.
5975     */
5976    public CapabilityStatementRestResourceSearchParamComponent setType(SearchParamType value) {
5977      if (this.type == null)
5978        this.type = new Enumeration<SearchParamType>(new SearchParamTypeEnumFactory());
5979      this.type.setValue(value);
5980      return this;
5981    }
5982
5983    /**
5984     * @return {@link #documentation} (This allows documentation of any distinct
5985     *         behaviors about how the search parameter is used. For example, text
5986     *         matching algorithms.). This is the underlying object with id, value
5987     *         and extensions. The accessor "getDocumentation" gives direct access
5988     *         to the value
5989     */
5990    public MarkdownType getDocumentationElement() {
5991      if (this.documentation == null)
5992        if (Configuration.errorOnAutoCreate())
5993          throw new Error("Attempt to auto-create CapabilityStatementRestResourceSearchParamComponent.documentation");
5994        else if (Configuration.doAutoCreate())
5995          this.documentation = new MarkdownType(); // bb
5996      return this.documentation;
5997    }
5998
5999    public boolean hasDocumentationElement() {
6000      return this.documentation != null && !this.documentation.isEmpty();
6001    }
6002
6003    public boolean hasDocumentation() {
6004      return this.documentation != null && !this.documentation.isEmpty();
6005    }
6006
6007    /**
6008     * @param value {@link #documentation} (This allows documentation of any
6009     *              distinct behaviors about how the search parameter is used. For
6010     *              example, text matching algorithms.). This is the underlying
6011     *              object with id, value and extensions. The accessor
6012     *              "getDocumentation" gives direct access to the value
6013     */
6014    public CapabilityStatementRestResourceSearchParamComponent setDocumentationElement(MarkdownType value) {
6015      this.documentation = value;
6016      return this;
6017    }
6018
6019    /**
6020     * @return This allows documentation of any distinct behaviors about how the
6021     *         search parameter is used. For example, text matching algorithms.
6022     */
6023    public String getDocumentation() {
6024      return this.documentation == null ? null : this.documentation.getValue();
6025    }
6026
6027    /**
6028     * @param value This allows documentation of any distinct behaviors about how
6029     *              the search parameter is used. For example, text matching
6030     *              algorithms.
6031     */
6032    public CapabilityStatementRestResourceSearchParamComponent setDocumentation(String value) {
6033      if (value == null)
6034        this.documentation = null;
6035      else {
6036        if (this.documentation == null)
6037          this.documentation = new MarkdownType();
6038        this.documentation.setValue(value);
6039      }
6040      return this;
6041    }
6042
6043    protected void listChildren(List<Property> children) {
6044      super.listChildren(children);
6045      children
6046          .add(new Property("name", "string", "The name of the search parameter used in the interface.", 0, 1, name));
6047      children.add(new Property("definition", "canonical(SearchParameter)",
6048          "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 element SHALL be populated if the search parameter refers to a SearchParameter defined by the FHIR core specification or externally defined IGs.",
6049          0, 1, definition));
6050      children.add(new Property("type", "code",
6051          "The type of value a search parameter refers to, and how the content is interpreted.", 0, 1, type));
6052      children.add(new Property("documentation", "markdown",
6053          "This allows documentation of any distinct behaviors about how the search parameter is used.  For example, text matching algorithms.",
6054          0, 1, documentation));
6055    }
6056
6057    @Override
6058    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
6059      switch (_hash) {
6060      case 3373707:
6061        /* name */ return new Property("name", "string", "The name of the search parameter used in the interface.", 0,
6062            1, name);
6063      case -1014418093:
6064        /* definition */ return new Property("definition", "canonical(SearchParameter)",
6065            "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 element SHALL be populated if the search parameter refers to a SearchParameter defined by the FHIR core specification or externally defined IGs.",
6066            0, 1, definition);
6067      case 3575610:
6068        /* type */ return new Property("type", "code",
6069            "The type of value a search parameter refers to, and how the content is interpreted.", 0, 1, type);
6070      case 1587405498:
6071        /* documentation */ return new Property("documentation", "markdown",
6072            "This allows documentation of any distinct behaviors about how the search parameter is used.  For example, text matching algorithms.",
6073            0, 1, documentation);
6074      default:
6075        return super.getNamedProperty(_hash, _name, _checkValid);
6076      }
6077
6078    }
6079
6080    @Override
6081    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
6082      switch (hash) {
6083      case 3373707:
6084        /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
6085      case -1014418093:
6086        /* definition */ return this.definition == null ? new Base[0] : new Base[] { this.definition }; // CanonicalType
6087      case 3575610:
6088        /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // Enumeration<SearchParamType>
6089      case 1587405498:
6090        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
6091      default:
6092        return super.getProperty(hash, name, checkValid);
6093      }
6094
6095    }
6096
6097    @Override
6098    public Base setProperty(int hash, String name, Base value) throws FHIRException {
6099      switch (hash) {
6100      case 3373707: // name
6101        this.name = castToString(value); // StringType
6102        return value;
6103      case -1014418093: // definition
6104        this.definition = castToCanonical(value); // CanonicalType
6105        return value;
6106      case 3575610: // type
6107        value = new SearchParamTypeEnumFactory().fromType(castToCode(value));
6108        this.type = (Enumeration) value; // Enumeration<SearchParamType>
6109        return value;
6110      case 1587405498: // documentation
6111        this.documentation = castToMarkdown(value); // MarkdownType
6112        return value;
6113      default:
6114        return super.setProperty(hash, name, value);
6115      }
6116
6117    }
6118
6119    @Override
6120    public Base setProperty(String name, Base value) throws FHIRException {
6121      if (name.equals("name")) {
6122        this.name = castToString(value); // StringType
6123      } else if (name.equals("definition")) {
6124        this.definition = castToCanonical(value); // CanonicalType
6125      } else if (name.equals("type")) {
6126        value = new SearchParamTypeEnumFactory().fromType(castToCode(value));
6127        this.type = (Enumeration) value; // Enumeration<SearchParamType>
6128      } else if (name.equals("documentation")) {
6129        this.documentation = castToMarkdown(value); // MarkdownType
6130      } else
6131        return super.setProperty(name, value);
6132      return value;
6133    }
6134
6135  @Override
6136  public void removeChild(String name, Base value) throws FHIRException {
6137      if (name.equals("name")) {
6138        this.name = null;
6139      } else if (name.equals("definition")) {
6140        this.definition = null;
6141      } else if (name.equals("type")) {
6142        this.type = null;
6143      } else if (name.equals("documentation")) {
6144        this.documentation = null;
6145      } else
6146        super.removeChild(name, value);
6147      
6148    }
6149
6150    @Override
6151    public Base makeProperty(int hash, String name) throws FHIRException {
6152      switch (hash) {
6153      case 3373707:
6154        return getNameElement();
6155      case -1014418093:
6156        return getDefinitionElement();
6157      case 3575610:
6158        return getTypeElement();
6159      case 1587405498:
6160        return getDocumentationElement();
6161      default:
6162        return super.makeProperty(hash, name);
6163      }
6164
6165    }
6166
6167    @Override
6168    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
6169      switch (hash) {
6170      case 3373707:
6171        /* name */ return new String[] { "string" };
6172      case -1014418093:
6173        /* definition */ return new String[] { "canonical" };
6174      case 3575610:
6175        /* type */ return new String[] { "code" };
6176      case 1587405498:
6177        /* documentation */ return new String[] { "markdown" };
6178      default:
6179        return super.getTypesForProperty(hash, name);
6180      }
6181
6182    }
6183
6184    @Override
6185    public Base addChild(String name) throws FHIRException {
6186      if (name.equals("name")) {
6187        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.name");
6188      } else if (name.equals("definition")) {
6189        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.definition");
6190      } else if (name.equals("type")) {
6191        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.type");
6192      } else if (name.equals("documentation")) {
6193        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
6194      } else
6195        return super.addChild(name);
6196    }
6197
6198    public CapabilityStatementRestResourceSearchParamComponent copy() {
6199      CapabilityStatementRestResourceSearchParamComponent dst = new CapabilityStatementRestResourceSearchParamComponent();
6200      copyValues(dst);
6201      return dst;
6202    }
6203
6204    public void copyValues(CapabilityStatementRestResourceSearchParamComponent dst) {
6205      super.copyValues(dst);
6206      dst.name = name == null ? null : name.copy();
6207      dst.definition = definition == null ? null : definition.copy();
6208      dst.type = type == null ? null : type.copy();
6209      dst.documentation = documentation == null ? null : documentation.copy();
6210    }
6211
6212    @Override
6213    public boolean equalsDeep(Base other_) {
6214      if (!super.equalsDeep(other_))
6215        return false;
6216      if (!(other_ instanceof CapabilityStatementRestResourceSearchParamComponent))
6217        return false;
6218      CapabilityStatementRestResourceSearchParamComponent o = (CapabilityStatementRestResourceSearchParamComponent) other_;
6219      return compareDeep(name, o.name, true) && compareDeep(definition, o.definition, true)
6220          && compareDeep(type, o.type, true) && compareDeep(documentation, o.documentation, true);
6221    }
6222
6223    @Override
6224    public boolean equalsShallow(Base other_) {
6225      if (!super.equalsShallow(other_))
6226        return false;
6227      if (!(other_ instanceof CapabilityStatementRestResourceSearchParamComponent))
6228        return false;
6229      CapabilityStatementRestResourceSearchParamComponent o = (CapabilityStatementRestResourceSearchParamComponent) other_;
6230      return compareValues(name, o.name, true) && compareValues(type, o.type, true)
6231          && compareValues(documentation, o.documentation, true);
6232    }
6233
6234    public boolean isEmpty() {
6235      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(name, definition, type, documentation);
6236    }
6237
6238    public String fhirType() {
6239      return "CapabilityStatement.rest.resource.searchParam";
6240
6241    }
6242
6243  }
6244
6245  @Block()
6246  public static class CapabilityStatementRestResourceOperationComponent extends BackboneElement
6247      implements IBaseBackboneElement {
6248    /**
6249     * The name of the operation or query. For an operation, this is the name
6250     * prefixed with $ and used in the URL. For a query, this is the name used in
6251     * the _query parameter when the query is called.
6252     */
6253    @Child(name = "name", type = { StringType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
6254    @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.")
6255    protected StringType name;
6256
6257    /**
6258     * Where the formal definition can be found. If a server references the base
6259     * definition of an Operation (i.e. from the specification itself such as
6260     * ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that means it
6261     * supports the full capabilities of the operation - e.g. both GET and POST
6262     * invocation. If it only supports a subset, it must define its own custom
6263     * [[[OperationDefinition]]] with a 'base' of the original OperationDefinition.
6264     * The custom definition would describe the specific subset of functionality
6265     * supported.
6266     */
6267    @Child(name = "definition", type = {
6268        CanonicalType.class }, order = 2, min = 1, max = 1, modifier = false, summary = true)
6269    @Description(shortDefinition = "The defined operation/query", formalDefinition = "Where the formal definition can be found. If a server references the base definition of an Operation (i.e. from the specification itself such as ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that means it supports the full capabilities of the operation - e.g. both GET and POST invocation.  If it only supports a subset, it must define its own custom [[[OperationDefinition]]] with a 'base' of the original OperationDefinition.  The custom definition would describe the specific subset of functionality supported.")
6270    protected CanonicalType definition;
6271
6272    /**
6273     * Documentation that describes anything special about the operation behavior,
6274     * possibly detailing different behavior for system, type and instance-level
6275     * invocation of the operation.
6276     */
6277    @Child(name = "documentation", type = {
6278        MarkdownType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
6279    @Description(shortDefinition = "Specific details about operation behavior", formalDefinition = "Documentation that describes anything special about the operation behavior, possibly detailing different behavior for system, type and instance-level invocation of the operation.")
6280    protected MarkdownType documentation;
6281
6282    private static final long serialVersionUID = -388608084L;
6283
6284    /**
6285     * Constructor
6286     */
6287    public CapabilityStatementRestResourceOperationComponent() {
6288      super();
6289    }
6290
6291    /**
6292     * Constructor
6293     */
6294    public CapabilityStatementRestResourceOperationComponent(StringType name, CanonicalType definition) {
6295      super();
6296      this.name = name;
6297      this.definition = definition;
6298    }
6299
6300    /**
6301     * @return {@link #name} (The name of the operation or query. For an operation,
6302     *         this is the name prefixed with $ and used in the URL. For a query,
6303     *         this is the name used in the _query parameter when the query is
6304     *         called.). This is the underlying object with id, value and
6305     *         extensions. The accessor "getName" gives direct access to the value
6306     */
6307    public StringType getNameElement() {
6308      if (this.name == null)
6309        if (Configuration.errorOnAutoCreate())
6310          throw new Error("Attempt to auto-create CapabilityStatementRestResourceOperationComponent.name");
6311        else if (Configuration.doAutoCreate())
6312          this.name = new StringType(); // bb
6313      return this.name;
6314    }
6315
6316    public boolean hasNameElement() {
6317      return this.name != null && !this.name.isEmpty();
6318    }
6319
6320    public boolean hasName() {
6321      return this.name != null && !this.name.isEmpty();
6322    }
6323
6324    /**
6325     * @param value {@link #name} (The name of the operation or query. For an
6326     *              operation, this is the name prefixed with $ and used in the URL.
6327     *              For a query, this is the name used in the _query parameter when
6328     *              the query is called.). This is the underlying object with id,
6329     *              value and extensions. The accessor "getName" gives direct access
6330     *              to the value
6331     */
6332    public CapabilityStatementRestResourceOperationComponent setNameElement(StringType value) {
6333      this.name = value;
6334      return this;
6335    }
6336
6337    /**
6338     * @return The name of the operation or query. For an operation, this is the
6339     *         name prefixed with $ and used in the URL. For a query, this is the
6340     *         name used in the _query parameter when the query is called.
6341     */
6342    public String getName() {
6343      return this.name == null ? null : this.name.getValue();
6344    }
6345
6346    /**
6347     * @param value The name of the operation or query. For an operation, this is
6348     *              the name prefixed with $ and used in the URL. For a query, this
6349     *              is the name used in the _query parameter when the query is
6350     *              called.
6351     */
6352    public CapabilityStatementRestResourceOperationComponent setName(String value) {
6353      if (this.name == null)
6354        this.name = new StringType();
6355      this.name.setValue(value);
6356      return this;
6357    }
6358
6359    /**
6360     * @return {@link #definition} (Where the formal definition can be found. If a
6361     *         server references the base definition of an Operation (i.e. from the
6362     *         specification itself such as
6363     *         ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that
6364     *         means it supports the full capabilities of the operation - e.g. both
6365     *         GET and POST invocation. If it only supports a subset, it must define
6366     *         its own custom [[[OperationDefinition]]] with a 'base' of the
6367     *         original OperationDefinition. The custom definition would describe
6368     *         the specific subset of functionality supported.). This is the
6369     *         underlying object with id, value and extensions. The accessor
6370     *         "getDefinition" gives direct access to the value
6371     */
6372    public CanonicalType getDefinitionElement() {
6373      if (this.definition == null)
6374        if (Configuration.errorOnAutoCreate())
6375          throw new Error("Attempt to auto-create CapabilityStatementRestResourceOperationComponent.definition");
6376        else if (Configuration.doAutoCreate())
6377          this.definition = new CanonicalType(); // bb
6378      return this.definition;
6379    }
6380
6381    public boolean hasDefinitionElement() {
6382      return this.definition != null && !this.definition.isEmpty();
6383    }
6384
6385    public boolean hasDefinition() {
6386      return this.definition != null && !this.definition.isEmpty();
6387    }
6388
6389    /**
6390     * @param value {@link #definition} (Where the formal definition can be found.
6391     *              If a server references the base definition of an Operation (i.e.
6392     *              from the specification itself such as
6393     *              ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```),
6394     *              that means it supports the full capabilities of the operation -
6395     *              e.g. both GET and POST invocation. If it only supports a subset,
6396     *              it must define its own custom [[[OperationDefinition]]] with a
6397     *              'base' of the original OperationDefinition. The custom
6398     *              definition would describe the specific subset of functionality
6399     *              supported.). This is the underlying object with id, value and
6400     *              extensions. The accessor "getDefinition" gives direct access to
6401     *              the value
6402     */
6403    public CapabilityStatementRestResourceOperationComponent setDefinitionElement(CanonicalType value) {
6404      this.definition = value;
6405      return this;
6406    }
6407
6408    /**
6409     * @return Where the formal definition can be found. If a server references the
6410     *         base definition of an Operation (i.e. from the specification itself
6411     *         such as
6412     *         ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that
6413     *         means it supports the full capabilities of the operation - e.g. both
6414     *         GET and POST invocation. If it only supports a subset, it must define
6415     *         its own custom [[[OperationDefinition]]] with a 'base' of the
6416     *         original OperationDefinition. The custom definition would describe
6417     *         the specific subset of functionality supported.
6418     */
6419    public String getDefinition() {
6420      return this.definition == null ? null : this.definition.getValue();
6421    }
6422
6423    /**
6424     * @param value Where the formal definition can be found. If a server references
6425     *              the base definition of an Operation (i.e. from the specification
6426     *              itself such as
6427     *              ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```),
6428     *              that means it supports the full capabilities of the operation -
6429     *              e.g. both GET and POST invocation. If it only supports a subset,
6430     *              it must define its own custom [[[OperationDefinition]]] with a
6431     *              'base' of the original OperationDefinition. The custom
6432     *              definition would describe the specific subset of functionality
6433     *              supported.
6434     */
6435    public CapabilityStatementRestResourceOperationComponent setDefinition(String value) {
6436      if (this.definition == null)
6437        this.definition = new CanonicalType();
6438      this.definition.setValue(value);
6439      return this;
6440    }
6441
6442    /**
6443     * @return {@link #documentation} (Documentation that describes anything special
6444     *         about the operation behavior, possibly detailing different behavior
6445     *         for system, type and instance-level invocation of the operation.).
6446     *         This is the underlying object with id, value and extensions. The
6447     *         accessor "getDocumentation" gives direct access to the value
6448     */
6449    public MarkdownType getDocumentationElement() {
6450      if (this.documentation == null)
6451        if (Configuration.errorOnAutoCreate())
6452          throw new Error("Attempt to auto-create CapabilityStatementRestResourceOperationComponent.documentation");
6453        else if (Configuration.doAutoCreate())
6454          this.documentation = new MarkdownType(); // bb
6455      return this.documentation;
6456    }
6457
6458    public boolean hasDocumentationElement() {
6459      return this.documentation != null && !this.documentation.isEmpty();
6460    }
6461
6462    public boolean hasDocumentation() {
6463      return this.documentation != null && !this.documentation.isEmpty();
6464    }
6465
6466    /**
6467     * @param value {@link #documentation} (Documentation that describes anything
6468     *              special about the operation behavior, possibly detailing
6469     *              different behavior for system, type and instance-level
6470     *              invocation of the operation.). This is the underlying object
6471     *              with id, value and extensions. The accessor "getDocumentation"
6472     *              gives direct access to the value
6473     */
6474    public CapabilityStatementRestResourceOperationComponent setDocumentationElement(MarkdownType value) {
6475      this.documentation = value;
6476      return this;
6477    }
6478
6479    /**
6480     * @return Documentation that describes anything special about the operation
6481     *         behavior, possibly detailing different behavior for system, type and
6482     *         instance-level invocation of the operation.
6483     */
6484    public String getDocumentation() {
6485      return this.documentation == null ? null : this.documentation.getValue();
6486    }
6487
6488    /**
6489     * @param value Documentation that describes anything special about the
6490     *              operation behavior, possibly detailing different behavior for
6491     *              system, type and instance-level invocation of the operation.
6492     */
6493    public CapabilityStatementRestResourceOperationComponent setDocumentation(String value) {
6494      if (value == null)
6495        this.documentation = null;
6496      else {
6497        if (this.documentation == null)
6498          this.documentation = new MarkdownType();
6499        this.documentation.setValue(value);
6500      }
6501      return this;
6502    }
6503
6504    protected void listChildren(List<Property> children) {
6505      super.listChildren(children);
6506      children.add(new Property("name", "string",
6507          "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.",
6508          0, 1, name));
6509      children.add(new Property("definition", "canonical(OperationDefinition)",
6510          "Where the formal definition can be found. If a server references the base definition of an Operation (i.e. from the specification itself such as ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that means it supports the full capabilities of the operation - e.g. both GET and POST invocation.  If it only supports a subset, it must define its own custom [[[OperationDefinition]]] with a 'base' of the original OperationDefinition.  The custom definition would describe the specific subset of functionality supported.",
6511          0, 1, definition));
6512      children.add(new Property("documentation", "markdown",
6513          "Documentation that describes anything special about the operation behavior, possibly detailing different behavior for system, type and instance-level invocation of the operation.",
6514          0, 1, documentation));
6515    }
6516
6517    @Override
6518    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
6519      switch (_hash) {
6520      case 3373707:
6521        /* name */ return new Property("name", "string",
6522            "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.",
6523            0, 1, name);
6524      case -1014418093:
6525        /* definition */ return new Property("definition", "canonical(OperationDefinition)",
6526            "Where the formal definition can be found. If a server references the base definition of an Operation (i.e. from the specification itself such as ```http://hl7.org/fhir/OperationDefinition/ValueSet-expand```), that means it supports the full capabilities of the operation - e.g. both GET and POST invocation.  If it only supports a subset, it must define its own custom [[[OperationDefinition]]] with a 'base' of the original OperationDefinition.  The custom definition would describe the specific subset of functionality supported.",
6527            0, 1, definition);
6528      case 1587405498:
6529        /* documentation */ return new Property("documentation", "markdown",
6530            "Documentation that describes anything special about the operation behavior, possibly detailing different behavior for system, type and instance-level invocation of the operation.",
6531            0, 1, documentation);
6532      default:
6533        return super.getNamedProperty(_hash, _name, _checkValid);
6534      }
6535
6536    }
6537
6538    @Override
6539    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
6540      switch (hash) {
6541      case 3373707:
6542        /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
6543      case -1014418093:
6544        /* definition */ return this.definition == null ? new Base[0] : new Base[] { this.definition }; // CanonicalType
6545      case 1587405498:
6546        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
6547      default:
6548        return super.getProperty(hash, name, checkValid);
6549      }
6550
6551    }
6552
6553    @Override
6554    public Base setProperty(int hash, String name, Base value) throws FHIRException {
6555      switch (hash) {
6556      case 3373707: // name
6557        this.name = castToString(value); // StringType
6558        return value;
6559      case -1014418093: // definition
6560        this.definition = castToCanonical(value); // CanonicalType
6561        return value;
6562      case 1587405498: // documentation
6563        this.documentation = castToMarkdown(value); // MarkdownType
6564        return value;
6565      default:
6566        return super.setProperty(hash, name, value);
6567      }
6568
6569    }
6570
6571    @Override
6572    public Base setProperty(String name, Base value) throws FHIRException {
6573      if (name.equals("name")) {
6574        this.name = castToString(value); // StringType
6575      } else if (name.equals("definition")) {
6576        this.definition = castToCanonical(value); // CanonicalType
6577      } else if (name.equals("documentation")) {
6578        this.documentation = castToMarkdown(value); // MarkdownType
6579      } else
6580        return super.setProperty(name, value);
6581      return value;
6582    }
6583
6584  @Override
6585  public void removeChild(String name, Base value) throws FHIRException {
6586      if (name.equals("name")) {
6587        this.name = null;
6588      } else if (name.equals("definition")) {
6589        this.definition = null;
6590      } else if (name.equals("documentation")) {
6591        this.documentation = null;
6592      } else
6593        super.removeChild(name, value);
6594      
6595    }
6596
6597    @Override
6598    public Base makeProperty(int hash, String name) throws FHIRException {
6599      switch (hash) {
6600      case 3373707:
6601        return getNameElement();
6602      case -1014418093:
6603        return getDefinitionElement();
6604      case 1587405498:
6605        return getDocumentationElement();
6606      default:
6607        return super.makeProperty(hash, name);
6608      }
6609
6610    }
6611
6612    @Override
6613    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
6614      switch (hash) {
6615      case 3373707:
6616        /* name */ return new String[] { "string" };
6617      case -1014418093:
6618        /* definition */ return new String[] { "canonical" };
6619      case 1587405498:
6620        /* documentation */ return new String[] { "markdown" };
6621      default:
6622        return super.getTypesForProperty(hash, name);
6623      }
6624
6625    }
6626
6627    @Override
6628    public Base addChild(String name) throws FHIRException {
6629      if (name.equals("name")) {
6630        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.name");
6631      } else if (name.equals("definition")) {
6632        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.definition");
6633      } else if (name.equals("documentation")) {
6634        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
6635      } else
6636        return super.addChild(name);
6637    }
6638
6639    public CapabilityStatementRestResourceOperationComponent copy() {
6640      CapabilityStatementRestResourceOperationComponent dst = new CapabilityStatementRestResourceOperationComponent();
6641      copyValues(dst);
6642      return dst;
6643    }
6644
6645    public void copyValues(CapabilityStatementRestResourceOperationComponent dst) {
6646      super.copyValues(dst);
6647      dst.name = name == null ? null : name.copy();
6648      dst.definition = definition == null ? null : definition.copy();
6649      dst.documentation = documentation == null ? null : documentation.copy();
6650    }
6651
6652    @Override
6653    public boolean equalsDeep(Base other_) {
6654      if (!super.equalsDeep(other_))
6655        return false;
6656      if (!(other_ instanceof CapabilityStatementRestResourceOperationComponent))
6657        return false;
6658      CapabilityStatementRestResourceOperationComponent o = (CapabilityStatementRestResourceOperationComponent) other_;
6659      return compareDeep(name, o.name, true) && compareDeep(definition, o.definition, true)
6660          && compareDeep(documentation, o.documentation, true);
6661    }
6662
6663    @Override
6664    public boolean equalsShallow(Base other_) {
6665      if (!super.equalsShallow(other_))
6666        return false;
6667      if (!(other_ instanceof CapabilityStatementRestResourceOperationComponent))
6668        return false;
6669      CapabilityStatementRestResourceOperationComponent o = (CapabilityStatementRestResourceOperationComponent) other_;
6670      return compareValues(name, o.name, true) && compareValues(documentation, o.documentation, true);
6671    }
6672
6673    public boolean isEmpty() {
6674      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(name, definition, documentation);
6675    }
6676
6677    public String fhirType() {
6678      return "CapabilityStatement.rest.resource.operation";
6679
6680    }
6681
6682  }
6683
6684  @Block()
6685  public static class SystemInteractionComponent extends BackboneElement implements IBaseBackboneElement {
6686    /**
6687     * A coded identifier of the operation, supported by the system.
6688     */
6689    @Child(name = "code", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
6690    @Description(shortDefinition = "transaction | batch | search-system | history-system", formalDefinition = "A coded identifier of the operation, supported by the system.")
6691    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/system-restful-interaction")
6692    protected Enumeration<SystemRestfulInteraction> code;
6693
6694    /**
6695     * Guidance specific to the implementation of this operation, such as
6696     * limitations on the kind of transactions allowed, or information about system
6697     * wide search is implemented.
6698     */
6699    @Child(name = "documentation", type = {
6700        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
6701    @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.")
6702    protected MarkdownType documentation;
6703
6704    private static final long serialVersionUID = -1495143879L;
6705
6706    /**
6707     * Constructor
6708     */
6709    public SystemInteractionComponent() {
6710      super();
6711    }
6712
6713    /**
6714     * Constructor
6715     */
6716    public SystemInteractionComponent(Enumeration<SystemRestfulInteraction> code) {
6717      super();
6718      this.code = code;
6719    }
6720
6721    /**
6722     * @return {@link #code} (A coded identifier of the operation, supported by the
6723     *         system.). This is the underlying object with id, value and
6724     *         extensions. The accessor "getCode" gives direct access to the value
6725     */
6726    public Enumeration<SystemRestfulInteraction> getCodeElement() {
6727      if (this.code == null)
6728        if (Configuration.errorOnAutoCreate())
6729          throw new Error("Attempt to auto-create SystemInteractionComponent.code");
6730        else if (Configuration.doAutoCreate())
6731          this.code = new Enumeration<SystemRestfulInteraction>(new SystemRestfulInteractionEnumFactory()); // bb
6732      return this.code;
6733    }
6734
6735    public boolean hasCodeElement() {
6736      return this.code != null && !this.code.isEmpty();
6737    }
6738
6739    public boolean hasCode() {
6740      return this.code != null && !this.code.isEmpty();
6741    }
6742
6743    /**
6744     * @param value {@link #code} (A coded identifier of the operation, supported by
6745     *              the system.). This is the underlying object with id, value and
6746     *              extensions. The accessor "getCode" gives direct access to the
6747     *              value
6748     */
6749    public SystemInteractionComponent setCodeElement(Enumeration<SystemRestfulInteraction> value) {
6750      this.code = value;
6751      return this;
6752    }
6753
6754    /**
6755     * @return A coded identifier of the operation, supported by the system.
6756     */
6757    public SystemRestfulInteraction getCode() {
6758      return this.code == null ? null : this.code.getValue();
6759    }
6760
6761    /**
6762     * @param value A coded identifier of the operation, supported by the system.
6763     */
6764    public SystemInteractionComponent setCode(SystemRestfulInteraction value) {
6765      if (this.code == null)
6766        this.code = new Enumeration<SystemRestfulInteraction>(new SystemRestfulInteractionEnumFactory());
6767      this.code.setValue(value);
6768      return this;
6769    }
6770
6771    /**
6772     * @return {@link #documentation} (Guidance specific to the implementation of
6773     *         this operation, such as limitations on the kind of transactions
6774     *         allowed, or information about system wide search is implemented.).
6775     *         This is the underlying object with id, value and extensions. The
6776     *         accessor "getDocumentation" gives direct access to the value
6777     */
6778    public MarkdownType getDocumentationElement() {
6779      if (this.documentation == null)
6780        if (Configuration.errorOnAutoCreate())
6781          throw new Error("Attempt to auto-create SystemInteractionComponent.documentation");
6782        else if (Configuration.doAutoCreate())
6783          this.documentation = new MarkdownType(); // bb
6784      return this.documentation;
6785    }
6786
6787    public boolean hasDocumentationElement() {
6788      return this.documentation != null && !this.documentation.isEmpty();
6789    }
6790
6791    public boolean hasDocumentation() {
6792      return this.documentation != null && !this.documentation.isEmpty();
6793    }
6794
6795    /**
6796     * @param value {@link #documentation} (Guidance specific to the implementation
6797     *              of this operation, such as limitations on the kind of
6798     *              transactions allowed, or information about system wide search is
6799     *              implemented.). This is the underlying object with id, value and
6800     *              extensions. The accessor "getDocumentation" gives direct access
6801     *              to the value
6802     */
6803    public SystemInteractionComponent setDocumentationElement(MarkdownType value) {
6804      this.documentation = value;
6805      return this;
6806    }
6807
6808    /**
6809     * @return Guidance specific to the implementation of this operation, such as
6810     *         limitations on the kind of transactions allowed, or information about
6811     *         system wide search is implemented.
6812     */
6813    public String getDocumentation() {
6814      return this.documentation == null ? null : this.documentation.getValue();
6815    }
6816
6817    /**
6818     * @param value Guidance specific to the implementation of this operation, such
6819     *              as limitations on the kind of transactions allowed, or
6820     *              information about system wide search is implemented.
6821     */
6822    public SystemInteractionComponent setDocumentation(String value) {
6823      if (value == null)
6824        this.documentation = null;
6825      else {
6826        if (this.documentation == null)
6827          this.documentation = new MarkdownType();
6828        this.documentation.setValue(value);
6829      }
6830      return this;
6831    }
6832
6833    protected void listChildren(List<Property> children) {
6834      super.listChildren(children);
6835      children.add(
6836          new Property("code", "code", "A coded identifier of the operation, supported by the system.", 0, 1, code));
6837      children.add(new Property("documentation", "markdown",
6838          "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.",
6839          0, 1, documentation));
6840    }
6841
6842    @Override
6843    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
6844      switch (_hash) {
6845      case 3059181:
6846        /* code */ return new Property("code", "code", "A coded identifier of the operation, supported by the system.",
6847            0, 1, code);
6848      case 1587405498:
6849        /* documentation */ return new Property("documentation", "markdown",
6850            "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.",
6851            0, 1, documentation);
6852      default:
6853        return super.getNamedProperty(_hash, _name, _checkValid);
6854      }
6855
6856    }
6857
6858    @Override
6859    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
6860      switch (hash) {
6861      case 3059181:
6862        /* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // Enumeration<SystemRestfulInteraction>
6863      case 1587405498:
6864        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
6865      default:
6866        return super.getProperty(hash, name, checkValid);
6867      }
6868
6869    }
6870
6871    @Override
6872    public Base setProperty(int hash, String name, Base value) throws FHIRException {
6873      switch (hash) {
6874      case 3059181: // code
6875        value = new SystemRestfulInteractionEnumFactory().fromType(castToCode(value));
6876        this.code = (Enumeration) value; // Enumeration<SystemRestfulInteraction>
6877        return value;
6878      case 1587405498: // documentation
6879        this.documentation = castToMarkdown(value); // MarkdownType
6880        return value;
6881      default:
6882        return super.setProperty(hash, name, value);
6883      }
6884
6885    }
6886
6887    @Override
6888    public Base setProperty(String name, Base value) throws FHIRException {
6889      if (name.equals("code")) {
6890        value = new SystemRestfulInteractionEnumFactory().fromType(castToCode(value));
6891        this.code = (Enumeration) value; // Enumeration<SystemRestfulInteraction>
6892      } else if (name.equals("documentation")) {
6893        this.documentation = castToMarkdown(value); // MarkdownType
6894      } else
6895        return super.setProperty(name, value);
6896      return value;
6897    }
6898
6899  @Override
6900  public void removeChild(String name, Base value) throws FHIRException {
6901      if (name.equals("code")) {
6902        this.code = null;
6903      } else if (name.equals("documentation")) {
6904        this.documentation = null;
6905      } else
6906        super.removeChild(name, value);
6907      
6908    }
6909
6910    @Override
6911    public Base makeProperty(int hash, String name) throws FHIRException {
6912      switch (hash) {
6913      case 3059181:
6914        return getCodeElement();
6915      case 1587405498:
6916        return getDocumentationElement();
6917      default:
6918        return super.makeProperty(hash, name);
6919      }
6920
6921    }
6922
6923    @Override
6924    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
6925      switch (hash) {
6926      case 3059181:
6927        /* code */ return new String[] { "code" };
6928      case 1587405498:
6929        /* documentation */ return new String[] { "markdown" };
6930      default:
6931        return super.getTypesForProperty(hash, name);
6932      }
6933
6934    }
6935
6936    @Override
6937    public Base addChild(String name) throws FHIRException {
6938      if (name.equals("code")) {
6939        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.code");
6940      } else if (name.equals("documentation")) {
6941        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
6942      } else
6943        return super.addChild(name);
6944    }
6945
6946    public SystemInteractionComponent copy() {
6947      SystemInteractionComponent dst = new SystemInteractionComponent();
6948      copyValues(dst);
6949      return dst;
6950    }
6951
6952    public void copyValues(SystemInteractionComponent dst) {
6953      super.copyValues(dst);
6954      dst.code = code == null ? null : code.copy();
6955      dst.documentation = documentation == null ? null : documentation.copy();
6956    }
6957
6958    @Override
6959    public boolean equalsDeep(Base other_) {
6960      if (!super.equalsDeep(other_))
6961        return false;
6962      if (!(other_ instanceof SystemInteractionComponent))
6963        return false;
6964      SystemInteractionComponent o = (SystemInteractionComponent) other_;
6965      return compareDeep(code, o.code, true) && compareDeep(documentation, o.documentation, true);
6966    }
6967
6968    @Override
6969    public boolean equalsShallow(Base other_) {
6970      if (!super.equalsShallow(other_))
6971        return false;
6972      if (!(other_ instanceof SystemInteractionComponent))
6973        return false;
6974      SystemInteractionComponent o = (SystemInteractionComponent) other_;
6975      return compareValues(code, o.code, true) && compareValues(documentation, o.documentation, true);
6976    }
6977
6978    public boolean isEmpty() {
6979      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(code, documentation);
6980    }
6981
6982    public String fhirType() {
6983      return "CapabilityStatement.rest.interaction";
6984
6985    }
6986
6987  }
6988
6989  @Block()
6990  public static class CapabilityStatementMessagingComponent extends BackboneElement implements IBaseBackboneElement {
6991    /**
6992     * An endpoint (network accessible address) to which messages and/or replies are
6993     * to be sent.
6994     */
6995    @Child(name = "endpoint", type = {}, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
6996    @Description(shortDefinition = "Where messages should be sent", formalDefinition = "An endpoint (network accessible address) to which messages and/or replies are to be sent.")
6997    protected List<CapabilityStatementMessagingEndpointComponent> endpoint;
6998
6999    /**
7000     * Length if the receiver's reliable messaging cache in minutes (if a receiver)
7001     * or how long the cache length on the receiver should be (if a sender).
7002     */
7003    @Child(name = "reliableCache", type = {
7004        UnsignedIntType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
7005    @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).")
7006    protected UnsignedIntType reliableCache;
7007
7008    /**
7009     * Documentation about the system's messaging capabilities for this endpoint not
7010     * otherwise documented by the capability statement. For example, the process
7011     * for becoming an authorized messaging exchange partner.
7012     */
7013    @Child(name = "documentation", type = {
7014        MarkdownType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
7015    @Description(shortDefinition = "Messaging interface behavior details", formalDefinition = "Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the capability statement.  For example, the process for becoming an authorized messaging exchange partner.")
7016    protected MarkdownType documentation;
7017
7018    /**
7019     * References to message definitions for messages this system can send or
7020     * receive.
7021     */
7022    @Child(name = "supportedMessage", type = {}, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
7023    @Description(shortDefinition = "Messages supported by this system", formalDefinition = "References to message definitions for messages this system can send or receive.")
7024    protected List<CapabilityStatementMessagingSupportedMessageComponent> supportedMessage;
7025
7026    private static final long serialVersionUID = 300411231L;
7027
7028    /**
7029     * Constructor
7030     */
7031    public CapabilityStatementMessagingComponent() {
7032      super();
7033    }
7034
7035    /**
7036     * @return {@link #endpoint} (An endpoint (network accessible address) to which
7037     *         messages and/or replies are to be sent.)
7038     */
7039    public List<CapabilityStatementMessagingEndpointComponent> getEndpoint() {
7040      if (this.endpoint == null)
7041        this.endpoint = new ArrayList<CapabilityStatementMessagingEndpointComponent>();
7042      return this.endpoint;
7043    }
7044
7045    /**
7046     * @return Returns a reference to <code>this</code> for easy method chaining
7047     */
7048    public CapabilityStatementMessagingComponent setEndpoint(
7049        List<CapabilityStatementMessagingEndpointComponent> theEndpoint) {
7050      this.endpoint = theEndpoint;
7051      return this;
7052    }
7053
7054    public boolean hasEndpoint() {
7055      if (this.endpoint == null)
7056        return false;
7057      for (CapabilityStatementMessagingEndpointComponent item : this.endpoint)
7058        if (!item.isEmpty())
7059          return true;
7060      return false;
7061    }
7062
7063    public CapabilityStatementMessagingEndpointComponent addEndpoint() { // 3
7064      CapabilityStatementMessagingEndpointComponent t = new CapabilityStatementMessagingEndpointComponent();
7065      if (this.endpoint == null)
7066        this.endpoint = new ArrayList<CapabilityStatementMessagingEndpointComponent>();
7067      this.endpoint.add(t);
7068      return t;
7069    }
7070
7071    public CapabilityStatementMessagingComponent addEndpoint(CapabilityStatementMessagingEndpointComponent t) { // 3
7072      if (t == null)
7073        return this;
7074      if (this.endpoint == null)
7075        this.endpoint = new ArrayList<CapabilityStatementMessagingEndpointComponent>();
7076      this.endpoint.add(t);
7077      return this;
7078    }
7079
7080    /**
7081     * @return The first repetition of repeating field {@link #endpoint}, creating
7082     *         it if it does not already exist
7083     */
7084    public CapabilityStatementMessagingEndpointComponent getEndpointFirstRep() {
7085      if (getEndpoint().isEmpty()) {
7086        addEndpoint();
7087      }
7088      return getEndpoint().get(0);
7089    }
7090
7091    /**
7092     * @return {@link #reliableCache} (Length if the receiver's reliable messaging
7093     *         cache in minutes (if a receiver) or how long the cache length on the
7094     *         receiver should be (if a sender).). This is the underlying object
7095     *         with id, value and extensions. The accessor "getReliableCache" gives
7096     *         direct access to the value
7097     */
7098    public UnsignedIntType getReliableCacheElement() {
7099      if (this.reliableCache == null)
7100        if (Configuration.errorOnAutoCreate())
7101          throw new Error("Attempt to auto-create CapabilityStatementMessagingComponent.reliableCache");
7102        else if (Configuration.doAutoCreate())
7103          this.reliableCache = new UnsignedIntType(); // bb
7104      return this.reliableCache;
7105    }
7106
7107    public boolean hasReliableCacheElement() {
7108      return this.reliableCache != null && !this.reliableCache.isEmpty();
7109    }
7110
7111    public boolean hasReliableCache() {
7112      return this.reliableCache != null && !this.reliableCache.isEmpty();
7113    }
7114
7115    /**
7116     * @param value {@link #reliableCache} (Length if the receiver's reliable
7117     *              messaging cache in minutes (if a receiver) or how long the cache
7118     *              length on the receiver should be (if a sender).). This is the
7119     *              underlying object with id, value and extensions. The accessor
7120     *              "getReliableCache" gives direct access to the value
7121     */
7122    public CapabilityStatementMessagingComponent setReliableCacheElement(UnsignedIntType value) {
7123      this.reliableCache = value;
7124      return this;
7125    }
7126
7127    /**
7128     * @return Length if the receiver's reliable messaging cache in minutes (if a
7129     *         receiver) or how long the cache length on the receiver should be (if
7130     *         a sender).
7131     */
7132    public int getReliableCache() {
7133      return this.reliableCache == null || this.reliableCache.isEmpty() ? 0 : this.reliableCache.getValue();
7134    }
7135
7136    /**
7137     * @param value Length if the receiver's reliable messaging cache in minutes (if
7138     *              a receiver) or how long the cache length on the receiver should
7139     *              be (if a sender).
7140     */
7141    public CapabilityStatementMessagingComponent setReliableCache(int value) {
7142      if (this.reliableCache == null)
7143        this.reliableCache = new UnsignedIntType();
7144      this.reliableCache.setValue(value);
7145      return this;
7146    }
7147
7148    /**
7149     * @return {@link #documentation} (Documentation about the system's messaging
7150     *         capabilities for this endpoint not otherwise documented by the
7151     *         capability statement. For example, the process for becoming an
7152     *         authorized messaging exchange partner.). This is the underlying
7153     *         object with id, value and extensions. The accessor "getDocumentation"
7154     *         gives direct access to the value
7155     */
7156    public MarkdownType getDocumentationElement() {
7157      if (this.documentation == null)
7158        if (Configuration.errorOnAutoCreate())
7159          throw new Error("Attempt to auto-create CapabilityStatementMessagingComponent.documentation");
7160        else if (Configuration.doAutoCreate())
7161          this.documentation = new MarkdownType(); // bb
7162      return this.documentation;
7163    }
7164
7165    public boolean hasDocumentationElement() {
7166      return this.documentation != null && !this.documentation.isEmpty();
7167    }
7168
7169    public boolean hasDocumentation() {
7170      return this.documentation != null && !this.documentation.isEmpty();
7171    }
7172
7173    /**
7174     * @param value {@link #documentation} (Documentation about the system's
7175     *              messaging capabilities for this endpoint not otherwise
7176     *              documented by the capability statement. For example, the process
7177     *              for becoming an authorized messaging exchange partner.). This is
7178     *              the underlying object with id, value and extensions. The
7179     *              accessor "getDocumentation" gives direct access to the value
7180     */
7181    public CapabilityStatementMessagingComponent setDocumentationElement(MarkdownType value) {
7182      this.documentation = value;
7183      return this;
7184    }
7185
7186    /**
7187     * @return Documentation about the system's messaging capabilities for this
7188     *         endpoint not otherwise documented by the capability statement. For
7189     *         example, the process for becoming an authorized messaging exchange
7190     *         partner.
7191     */
7192    public String getDocumentation() {
7193      return this.documentation == null ? null : this.documentation.getValue();
7194    }
7195
7196    /**
7197     * @param value Documentation about the system's messaging capabilities for this
7198     *              endpoint not otherwise documented by the capability statement.
7199     *              For example, the process for becoming an authorized messaging
7200     *              exchange partner.
7201     */
7202    public CapabilityStatementMessagingComponent setDocumentation(String value) {
7203      if (value == null)
7204        this.documentation = null;
7205      else {
7206        if (this.documentation == null)
7207          this.documentation = new MarkdownType();
7208        this.documentation.setValue(value);
7209      }
7210      return this;
7211    }
7212
7213    /**
7214     * @return {@link #supportedMessage} (References to message definitions for
7215     *         messages this system can send or receive.)
7216     */
7217    public List<CapabilityStatementMessagingSupportedMessageComponent> getSupportedMessage() {
7218      if (this.supportedMessage == null)
7219        this.supportedMessage = new ArrayList<CapabilityStatementMessagingSupportedMessageComponent>();
7220      return this.supportedMessage;
7221    }
7222
7223    /**
7224     * @return Returns a reference to <code>this</code> for easy method chaining
7225     */
7226    public CapabilityStatementMessagingComponent setSupportedMessage(
7227        List<CapabilityStatementMessagingSupportedMessageComponent> theSupportedMessage) {
7228      this.supportedMessage = theSupportedMessage;
7229      return this;
7230    }
7231
7232    public boolean hasSupportedMessage() {
7233      if (this.supportedMessage == null)
7234        return false;
7235      for (CapabilityStatementMessagingSupportedMessageComponent item : this.supportedMessage)
7236        if (!item.isEmpty())
7237          return true;
7238      return false;
7239    }
7240
7241    public CapabilityStatementMessagingSupportedMessageComponent addSupportedMessage() { // 3
7242      CapabilityStatementMessagingSupportedMessageComponent t = new CapabilityStatementMessagingSupportedMessageComponent();
7243      if (this.supportedMessage == null)
7244        this.supportedMessage = new ArrayList<CapabilityStatementMessagingSupportedMessageComponent>();
7245      this.supportedMessage.add(t);
7246      return t;
7247    }
7248
7249    public CapabilityStatementMessagingComponent addSupportedMessage(
7250        CapabilityStatementMessagingSupportedMessageComponent t) { // 3
7251      if (t == null)
7252        return this;
7253      if (this.supportedMessage == null)
7254        this.supportedMessage = new ArrayList<CapabilityStatementMessagingSupportedMessageComponent>();
7255      this.supportedMessage.add(t);
7256      return this;
7257    }
7258
7259    /**
7260     * @return The first repetition of repeating field {@link #supportedMessage},
7261     *         creating it if it does not already exist
7262     */
7263    public CapabilityStatementMessagingSupportedMessageComponent getSupportedMessageFirstRep() {
7264      if (getSupportedMessage().isEmpty()) {
7265        addSupportedMessage();
7266      }
7267      return getSupportedMessage().get(0);
7268    }
7269
7270    protected void listChildren(List<Property> children) {
7271      super.listChildren(children);
7272      children.add(new Property("endpoint", "",
7273          "An endpoint (network accessible address) to which messages and/or replies are to be sent.", 0,
7274          java.lang.Integer.MAX_VALUE, endpoint));
7275      children.add(new Property("reliableCache", "unsignedInt",
7276          "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).",
7277          0, 1, reliableCache));
7278      children.add(new Property("documentation", "markdown",
7279          "Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the capability statement.  For example, the process for becoming an authorized messaging exchange partner.",
7280          0, 1, documentation));
7281      children.add(new Property("supportedMessage", "",
7282          "References to message definitions for messages this system can send or receive.", 0,
7283          java.lang.Integer.MAX_VALUE, supportedMessage));
7284    }
7285
7286    @Override
7287    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
7288      switch (_hash) {
7289      case 1741102485:
7290        /* endpoint */ return new Property("endpoint", "",
7291            "An endpoint (network accessible address) to which messages and/or replies are to be sent.", 0,
7292            java.lang.Integer.MAX_VALUE, endpoint);
7293      case 897803608:
7294        /* reliableCache */ return new Property("reliableCache", "unsignedInt",
7295            "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).",
7296            0, 1, reliableCache);
7297      case 1587405498:
7298        /* documentation */ return new Property("documentation", "markdown",
7299            "Documentation about the system's messaging capabilities for this endpoint not otherwise documented by the capability statement.  For example, the process for becoming an authorized messaging exchange partner.",
7300            0, 1, documentation);
7301      case -1805139079:
7302        /* supportedMessage */ return new Property("supportedMessage", "",
7303            "References to message definitions for messages this system can send or receive.", 0,
7304            java.lang.Integer.MAX_VALUE, supportedMessage);
7305      default:
7306        return super.getNamedProperty(_hash, _name, _checkValid);
7307      }
7308
7309    }
7310
7311    @Override
7312    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
7313      switch (hash) {
7314      case 1741102485:
7315        /* endpoint */ return this.endpoint == null ? new Base[0]
7316            : this.endpoint.toArray(new Base[this.endpoint.size()]); // CapabilityStatementMessagingEndpointComponent
7317      case 897803608:
7318        /* reliableCache */ return this.reliableCache == null ? new Base[0] : new Base[] { this.reliableCache }; // UnsignedIntType
7319      case 1587405498:
7320        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
7321      case -1805139079:
7322        /* supportedMessage */ return this.supportedMessage == null ? new Base[0]
7323            : this.supportedMessage.toArray(new Base[this.supportedMessage.size()]); // CapabilityStatementMessagingSupportedMessageComponent
7324      default:
7325        return super.getProperty(hash, name, checkValid);
7326      }
7327
7328    }
7329
7330    @Override
7331    public Base setProperty(int hash, String name, Base value) throws FHIRException {
7332      switch (hash) {
7333      case 1741102485: // endpoint
7334        this.getEndpoint().add((CapabilityStatementMessagingEndpointComponent) value); // CapabilityStatementMessagingEndpointComponent
7335        return value;
7336      case 897803608: // reliableCache
7337        this.reliableCache = castToUnsignedInt(value); // UnsignedIntType
7338        return value;
7339      case 1587405498: // documentation
7340        this.documentation = castToMarkdown(value); // MarkdownType
7341        return value;
7342      case -1805139079: // supportedMessage
7343        this.getSupportedMessage().add((CapabilityStatementMessagingSupportedMessageComponent) value); // CapabilityStatementMessagingSupportedMessageComponent
7344        return value;
7345      default:
7346        return super.setProperty(hash, name, value);
7347      }
7348
7349    }
7350
7351    @Override
7352    public Base setProperty(String name, Base value) throws FHIRException {
7353      if (name.equals("endpoint")) {
7354        this.getEndpoint().add((CapabilityStatementMessagingEndpointComponent) value);
7355      } else if (name.equals("reliableCache")) {
7356        this.reliableCache = castToUnsignedInt(value); // UnsignedIntType
7357      } else if (name.equals("documentation")) {
7358        this.documentation = castToMarkdown(value); // MarkdownType
7359      } else if (name.equals("supportedMessage")) {
7360        this.getSupportedMessage().add((CapabilityStatementMessagingSupportedMessageComponent) value);
7361      } else
7362        return super.setProperty(name, value);
7363      return value;
7364    }
7365
7366  @Override
7367  public void removeChild(String name, Base value) throws FHIRException {
7368      if (name.equals("endpoint")) {
7369        this.getEndpoint().remove((CapabilityStatementMessagingEndpointComponent) value);
7370      } else if (name.equals("reliableCache")) {
7371        this.reliableCache = null;
7372      } else if (name.equals("documentation")) {
7373        this.documentation = null;
7374      } else if (name.equals("supportedMessage")) {
7375        this.getSupportedMessage().remove((CapabilityStatementMessagingSupportedMessageComponent) value);
7376      } else
7377        super.removeChild(name, value);
7378      
7379    }
7380
7381    @Override
7382    public Base makeProperty(int hash, String name) throws FHIRException {
7383      switch (hash) {
7384      case 1741102485:
7385        return addEndpoint();
7386      case 897803608:
7387        return getReliableCacheElement();
7388      case 1587405498:
7389        return getDocumentationElement();
7390      case -1805139079:
7391        return addSupportedMessage();
7392      default:
7393        return super.makeProperty(hash, name);
7394      }
7395
7396    }
7397
7398    @Override
7399    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
7400      switch (hash) {
7401      case 1741102485:
7402        /* endpoint */ return new String[] {};
7403      case 897803608:
7404        /* reliableCache */ return new String[] { "unsignedInt" };
7405      case 1587405498:
7406        /* documentation */ return new String[] { "markdown" };
7407      case -1805139079:
7408        /* supportedMessage */ return new String[] {};
7409      default:
7410        return super.getTypesForProperty(hash, name);
7411      }
7412
7413    }
7414
7415    @Override
7416    public Base addChild(String name) throws FHIRException {
7417      if (name.equals("endpoint")) {
7418        return addEndpoint();
7419      } else if (name.equals("reliableCache")) {
7420        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.reliableCache");
7421      } else if (name.equals("documentation")) {
7422        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
7423      } else if (name.equals("supportedMessage")) {
7424        return addSupportedMessage();
7425      } else
7426        return super.addChild(name);
7427    }
7428
7429    public CapabilityStatementMessagingComponent copy() {
7430      CapabilityStatementMessagingComponent dst = new CapabilityStatementMessagingComponent();
7431      copyValues(dst);
7432      return dst;
7433    }
7434
7435    public void copyValues(CapabilityStatementMessagingComponent dst) {
7436      super.copyValues(dst);
7437      if (endpoint != null) {
7438        dst.endpoint = new ArrayList<CapabilityStatementMessagingEndpointComponent>();
7439        for (CapabilityStatementMessagingEndpointComponent i : endpoint)
7440          dst.endpoint.add(i.copy());
7441      }
7442      ;
7443      dst.reliableCache = reliableCache == null ? null : reliableCache.copy();
7444      dst.documentation = documentation == null ? null : documentation.copy();
7445      if (supportedMessage != null) {
7446        dst.supportedMessage = new ArrayList<CapabilityStatementMessagingSupportedMessageComponent>();
7447        for (CapabilityStatementMessagingSupportedMessageComponent i : supportedMessage)
7448          dst.supportedMessage.add(i.copy());
7449      }
7450      ;
7451    }
7452
7453    @Override
7454    public boolean equalsDeep(Base other_) {
7455      if (!super.equalsDeep(other_))
7456        return false;
7457      if (!(other_ instanceof CapabilityStatementMessagingComponent))
7458        return false;
7459      CapabilityStatementMessagingComponent o = (CapabilityStatementMessagingComponent) other_;
7460      return compareDeep(endpoint, o.endpoint, true) && compareDeep(reliableCache, o.reliableCache, true)
7461          && compareDeep(documentation, o.documentation, true)
7462          && compareDeep(supportedMessage, o.supportedMessage, true);
7463    }
7464
7465    @Override
7466    public boolean equalsShallow(Base other_) {
7467      if (!super.equalsShallow(other_))
7468        return false;
7469      if (!(other_ instanceof CapabilityStatementMessagingComponent))
7470        return false;
7471      CapabilityStatementMessagingComponent o = (CapabilityStatementMessagingComponent) other_;
7472      return compareValues(reliableCache, o.reliableCache, true) && compareValues(documentation, o.documentation, true);
7473    }
7474
7475    public boolean isEmpty() {
7476      return super.isEmpty()
7477          && ca.uhn.fhir.util.ElementUtil.isEmpty(endpoint, reliableCache, documentation, supportedMessage);
7478    }
7479
7480    public String fhirType() {
7481      return "CapabilityStatement.messaging";
7482
7483    }
7484
7485  }
7486
7487  @Block()
7488  public static class CapabilityStatementMessagingEndpointComponent extends BackboneElement
7489      implements IBaseBackboneElement {
7490    /**
7491     * A list of the messaging transport protocol(s) identifiers, supported by this
7492     * endpoint.
7493     */
7494    @Child(name = "protocol", type = { Coding.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
7495    @Description(shortDefinition = "http | ftp | mllp +", formalDefinition = "A list of the messaging transport protocol(s) identifiers, supported by this endpoint.")
7496    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/message-transport")
7497    protected Coding protocol;
7498
7499    /**
7500     * The network address of the endpoint. For solutions that do not use network
7501     * addresses for routing, it can be just an identifier.
7502     */
7503    @Child(name = "address", type = { UrlType.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
7504    @Description(shortDefinition = "Network address or identifier of the end-point", formalDefinition = "The network address of the endpoint. For solutions that do not use network addresses for routing, it can be just an identifier.")
7505    protected UrlType address;
7506
7507    private static final long serialVersionUID = -236946103L;
7508
7509    /**
7510     * Constructor
7511     */
7512    public CapabilityStatementMessagingEndpointComponent() {
7513      super();
7514    }
7515
7516    /**
7517     * Constructor
7518     */
7519    public CapabilityStatementMessagingEndpointComponent(Coding protocol, UrlType address) {
7520      super();
7521      this.protocol = protocol;
7522      this.address = address;
7523    }
7524
7525    /**
7526     * @return {@link #protocol} (A list of the messaging transport protocol(s)
7527     *         identifiers, supported by this endpoint.)
7528     */
7529    public Coding getProtocol() {
7530      if (this.protocol == null)
7531        if (Configuration.errorOnAutoCreate())
7532          throw new Error("Attempt to auto-create CapabilityStatementMessagingEndpointComponent.protocol");
7533        else if (Configuration.doAutoCreate())
7534          this.protocol = new Coding(); // cc
7535      return this.protocol;
7536    }
7537
7538    public boolean hasProtocol() {
7539      return this.protocol != null && !this.protocol.isEmpty();
7540    }
7541
7542    /**
7543     * @param value {@link #protocol} (A list of the messaging transport protocol(s)
7544     *              identifiers, supported by this endpoint.)
7545     */
7546    public CapabilityStatementMessagingEndpointComponent setProtocol(Coding value) {
7547      this.protocol = value;
7548      return this;
7549    }
7550
7551    /**
7552     * @return {@link #address} (The network address of the endpoint. For solutions
7553     *         that do not use network addresses for routing, it can be just an
7554     *         identifier.). This is the underlying object with id, value and
7555     *         extensions. The accessor "getAddress" gives direct access to the
7556     *         value
7557     */
7558    public UrlType getAddressElement() {
7559      if (this.address == null)
7560        if (Configuration.errorOnAutoCreate())
7561          throw new Error("Attempt to auto-create CapabilityStatementMessagingEndpointComponent.address");
7562        else if (Configuration.doAutoCreate())
7563          this.address = new UrlType(); // bb
7564      return this.address;
7565    }
7566
7567    public boolean hasAddressElement() {
7568      return this.address != null && !this.address.isEmpty();
7569    }
7570
7571    public boolean hasAddress() {
7572      return this.address != null && !this.address.isEmpty();
7573    }
7574
7575    /**
7576     * @param value {@link #address} (The network address of the endpoint. For
7577     *              solutions that do not use network addresses for routing, it can
7578     *              be just an identifier.). This is the underlying object with id,
7579     *              value and extensions. The accessor "getAddress" gives direct
7580     *              access to the value
7581     */
7582    public CapabilityStatementMessagingEndpointComponent setAddressElement(UrlType value) {
7583      this.address = value;
7584      return this;
7585    }
7586
7587    /**
7588     * @return The network address of the endpoint. For solutions that do not use
7589     *         network addresses for routing, it can be just an identifier.
7590     */
7591    public String getAddress() {
7592      return this.address == null ? null : this.address.getValue();
7593    }
7594
7595    /**
7596     * @param value The network address of the endpoint. For solutions that do not
7597     *              use network addresses for routing, it can be just an identifier.
7598     */
7599    public CapabilityStatementMessagingEndpointComponent setAddress(String value) {
7600      if (this.address == null)
7601        this.address = new UrlType();
7602      this.address.setValue(value);
7603      return this;
7604    }
7605
7606    protected void listChildren(List<Property> children) {
7607      super.listChildren(children);
7608      children.add(new Property("protocol", "Coding",
7609          "A list of the messaging transport protocol(s) identifiers, supported by this endpoint.", 0, 1, protocol));
7610      children.add(new Property("address", "url",
7611          "The network address of the endpoint. For solutions that do not use network addresses for routing, it can be just an identifier.",
7612          0, 1, address));
7613    }
7614
7615    @Override
7616    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
7617      switch (_hash) {
7618      case -989163880:
7619        /* protocol */ return new Property("protocol", "Coding",
7620            "A list of the messaging transport protocol(s) identifiers, supported by this endpoint.", 0, 1, protocol);
7621      case -1147692044:
7622        /* address */ return new Property("address", "url",
7623            "The network address of the endpoint. For solutions that do not use network addresses for routing, it can be just an identifier.",
7624            0, 1, address);
7625      default:
7626        return super.getNamedProperty(_hash, _name, _checkValid);
7627      }
7628
7629    }
7630
7631    @Override
7632    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
7633      switch (hash) {
7634      case -989163880:
7635        /* protocol */ return this.protocol == null ? new Base[0] : new Base[] { this.protocol }; // Coding
7636      case -1147692044:
7637        /* address */ return this.address == null ? new Base[0] : new Base[] { this.address }; // UrlType
7638      default:
7639        return super.getProperty(hash, name, checkValid);
7640      }
7641
7642    }
7643
7644    @Override
7645    public Base setProperty(int hash, String name, Base value) throws FHIRException {
7646      switch (hash) {
7647      case -989163880: // protocol
7648        this.protocol = castToCoding(value); // Coding
7649        return value;
7650      case -1147692044: // address
7651        this.address = castToUrl(value); // UrlType
7652        return value;
7653      default:
7654        return super.setProperty(hash, name, value);
7655      }
7656
7657    }
7658
7659    @Override
7660    public Base setProperty(String name, Base value) throws FHIRException {
7661      if (name.equals("protocol")) {
7662        this.protocol = castToCoding(value); // Coding
7663      } else if (name.equals("address")) {
7664        this.address = castToUrl(value); // UrlType
7665      } else
7666        return super.setProperty(name, value);
7667      return value;
7668    }
7669
7670  @Override
7671  public void removeChild(String name, Base value) throws FHIRException {
7672      if (name.equals("protocol")) {
7673        this.protocol = null;
7674      } else if (name.equals("address")) {
7675        this.address = null;
7676      } else
7677        super.removeChild(name, value);
7678      
7679    }
7680
7681    @Override
7682    public Base makeProperty(int hash, String name) throws FHIRException {
7683      switch (hash) {
7684      case -989163880:
7685        return getProtocol();
7686      case -1147692044:
7687        return getAddressElement();
7688      default:
7689        return super.makeProperty(hash, name);
7690      }
7691
7692    }
7693
7694    @Override
7695    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
7696      switch (hash) {
7697      case -989163880:
7698        /* protocol */ return new String[] { "Coding" };
7699      case -1147692044:
7700        /* address */ return new String[] { "url" };
7701      default:
7702        return super.getTypesForProperty(hash, name);
7703      }
7704
7705    }
7706
7707    @Override
7708    public Base addChild(String name) throws FHIRException {
7709      if (name.equals("protocol")) {
7710        this.protocol = new Coding();
7711        return this.protocol;
7712      } else if (name.equals("address")) {
7713        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.address");
7714      } else
7715        return super.addChild(name);
7716    }
7717
7718    public CapabilityStatementMessagingEndpointComponent copy() {
7719      CapabilityStatementMessagingEndpointComponent dst = new CapabilityStatementMessagingEndpointComponent();
7720      copyValues(dst);
7721      return dst;
7722    }
7723
7724    public void copyValues(CapabilityStatementMessagingEndpointComponent dst) {
7725      super.copyValues(dst);
7726      dst.protocol = protocol == null ? null : protocol.copy();
7727      dst.address = address == null ? null : address.copy();
7728    }
7729
7730    @Override
7731    public boolean equalsDeep(Base other_) {
7732      if (!super.equalsDeep(other_))
7733        return false;
7734      if (!(other_ instanceof CapabilityStatementMessagingEndpointComponent))
7735        return false;
7736      CapabilityStatementMessagingEndpointComponent o = (CapabilityStatementMessagingEndpointComponent) other_;
7737      return compareDeep(protocol, o.protocol, true) && compareDeep(address, o.address, true);
7738    }
7739
7740    @Override
7741    public boolean equalsShallow(Base other_) {
7742      if (!super.equalsShallow(other_))
7743        return false;
7744      if (!(other_ instanceof CapabilityStatementMessagingEndpointComponent))
7745        return false;
7746      CapabilityStatementMessagingEndpointComponent o = (CapabilityStatementMessagingEndpointComponent) other_;
7747      return compareValues(address, o.address, true);
7748    }
7749
7750    public boolean isEmpty() {
7751      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(protocol, address);
7752    }
7753
7754    public String fhirType() {
7755      return "CapabilityStatement.messaging.endpoint";
7756
7757    }
7758
7759  }
7760
7761  @Block()
7762  public static class CapabilityStatementMessagingSupportedMessageComponent extends BackboneElement
7763      implements IBaseBackboneElement {
7764    /**
7765     * The mode of this event declaration - whether application is sender or
7766     * receiver.
7767     */
7768    @Child(name = "mode", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
7769    @Description(shortDefinition = "sender | receiver", formalDefinition = "The mode of this event declaration - whether application is sender or receiver.")
7770    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/event-capability-mode")
7771    protected Enumeration<EventCapabilityMode> mode;
7772
7773    /**
7774     * Points to a message definition that identifies the messaging event, message
7775     * structure, allowed responses, etc.
7776     */
7777    @Child(name = "definition", type = {
7778        CanonicalType.class }, order = 2, min = 1, max = 1, modifier = false, summary = true)
7779    @Description(shortDefinition = "Message supported by this system", formalDefinition = "Points to a message definition that identifies the messaging event, message structure, allowed responses, etc.")
7780    protected CanonicalType definition;
7781
7782    private static final long serialVersionUID = -1172840676L;
7783
7784    /**
7785     * Constructor
7786     */
7787    public CapabilityStatementMessagingSupportedMessageComponent() {
7788      super();
7789    }
7790
7791    /**
7792     * Constructor
7793     */
7794    public CapabilityStatementMessagingSupportedMessageComponent(Enumeration<EventCapabilityMode> mode,
7795        CanonicalType definition) {
7796      super();
7797      this.mode = mode;
7798      this.definition = definition;
7799    }
7800
7801    /**
7802     * @return {@link #mode} (The mode of this event declaration - whether
7803     *         application is sender or receiver.). This is the underlying object
7804     *         with id, value and extensions. The accessor "getMode" gives direct
7805     *         access to the value
7806     */
7807    public Enumeration<EventCapabilityMode> getModeElement() {
7808      if (this.mode == null)
7809        if (Configuration.errorOnAutoCreate())
7810          throw new Error("Attempt to auto-create CapabilityStatementMessagingSupportedMessageComponent.mode");
7811        else if (Configuration.doAutoCreate())
7812          this.mode = new Enumeration<EventCapabilityMode>(new EventCapabilityModeEnumFactory()); // bb
7813      return this.mode;
7814    }
7815
7816    public boolean hasModeElement() {
7817      return this.mode != null && !this.mode.isEmpty();
7818    }
7819
7820    public boolean hasMode() {
7821      return this.mode != null && !this.mode.isEmpty();
7822    }
7823
7824    /**
7825     * @param value {@link #mode} (The mode of this event declaration - whether
7826     *              application is sender or receiver.). This is the underlying
7827     *              object with id, value and extensions. The accessor "getMode"
7828     *              gives direct access to the value
7829     */
7830    public CapabilityStatementMessagingSupportedMessageComponent setModeElement(
7831        Enumeration<EventCapabilityMode> value) {
7832      this.mode = value;
7833      return this;
7834    }
7835
7836    /**
7837     * @return The mode of this event declaration - whether application is sender or
7838     *         receiver.
7839     */
7840    public EventCapabilityMode getMode() {
7841      return this.mode == null ? null : this.mode.getValue();
7842    }
7843
7844    /**
7845     * @param value The mode of this event declaration - whether application is
7846     *              sender or receiver.
7847     */
7848    public CapabilityStatementMessagingSupportedMessageComponent setMode(EventCapabilityMode value) {
7849      if (this.mode == null)
7850        this.mode = new Enumeration<EventCapabilityMode>(new EventCapabilityModeEnumFactory());
7851      this.mode.setValue(value);
7852      return this;
7853    }
7854
7855    /**
7856     * @return {@link #definition} (Points to a message definition that identifies
7857     *         the messaging event, message structure, allowed responses, etc.).
7858     *         This is the underlying object with id, value and extensions. The
7859     *         accessor "getDefinition" gives direct access to the value
7860     */
7861    public CanonicalType getDefinitionElement() {
7862      if (this.definition == null)
7863        if (Configuration.errorOnAutoCreate())
7864          throw new Error("Attempt to auto-create CapabilityStatementMessagingSupportedMessageComponent.definition");
7865        else if (Configuration.doAutoCreate())
7866          this.definition = new CanonicalType(); // bb
7867      return this.definition;
7868    }
7869
7870    public boolean hasDefinitionElement() {
7871      return this.definition != null && !this.definition.isEmpty();
7872    }
7873
7874    public boolean hasDefinition() {
7875      return this.definition != null && !this.definition.isEmpty();
7876    }
7877
7878    /**
7879     * @param value {@link #definition} (Points to a message definition that
7880     *              identifies the messaging event, message structure, allowed
7881     *              responses, etc.). This is the underlying object with id, value
7882     *              and extensions. The accessor "getDefinition" gives direct access
7883     *              to the value
7884     */
7885    public CapabilityStatementMessagingSupportedMessageComponent setDefinitionElement(CanonicalType value) {
7886      this.definition = value;
7887      return this;
7888    }
7889
7890    /**
7891     * @return Points to a message definition that identifies the messaging event,
7892     *         message structure, allowed responses, etc.
7893     */
7894    public String getDefinition() {
7895      return this.definition == null ? null : this.definition.getValue();
7896    }
7897
7898    /**
7899     * @param value Points to a message definition that identifies the messaging
7900     *              event, message structure, allowed responses, etc.
7901     */
7902    public CapabilityStatementMessagingSupportedMessageComponent setDefinition(String value) {
7903      if (this.definition == null)
7904        this.definition = new CanonicalType();
7905      this.definition.setValue(value);
7906      return this;
7907    }
7908
7909    protected void listChildren(List<Property> children) {
7910      super.listChildren(children);
7911      children.add(new Property("mode", "code",
7912          "The mode of this event declaration - whether application is sender or receiver.", 0, 1, mode));
7913      children.add(new Property("definition", "canonical(MessageDefinition)",
7914          "Points to a message definition that identifies the messaging event, message structure, allowed responses, etc.",
7915          0, 1, definition));
7916    }
7917
7918    @Override
7919    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
7920      switch (_hash) {
7921      case 3357091:
7922        /* mode */ return new Property("mode", "code",
7923            "The mode of this event declaration - whether application is sender or receiver.", 0, 1, mode);
7924      case -1014418093:
7925        /* definition */ return new Property("definition", "canonical(MessageDefinition)",
7926            "Points to a message definition that identifies the messaging event, message structure, allowed responses, etc.",
7927            0, 1, definition);
7928      default:
7929        return super.getNamedProperty(_hash, _name, _checkValid);
7930      }
7931
7932    }
7933
7934    @Override
7935    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
7936      switch (hash) {
7937      case 3357091:
7938        /* mode */ return this.mode == null ? new Base[0] : new Base[] { this.mode }; // Enumeration<EventCapabilityMode>
7939      case -1014418093:
7940        /* definition */ return this.definition == null ? new Base[0] : new Base[] { this.definition }; // CanonicalType
7941      default:
7942        return super.getProperty(hash, name, checkValid);
7943      }
7944
7945    }
7946
7947    @Override
7948    public Base setProperty(int hash, String name, Base value) throws FHIRException {
7949      switch (hash) {
7950      case 3357091: // mode
7951        value = new EventCapabilityModeEnumFactory().fromType(castToCode(value));
7952        this.mode = (Enumeration) value; // Enumeration<EventCapabilityMode>
7953        return value;
7954      case -1014418093: // definition
7955        this.definition = castToCanonical(value); // CanonicalType
7956        return value;
7957      default:
7958        return super.setProperty(hash, name, value);
7959      }
7960
7961    }
7962
7963    @Override
7964    public Base setProperty(String name, Base value) throws FHIRException {
7965      if (name.equals("mode")) {
7966        value = new EventCapabilityModeEnumFactory().fromType(castToCode(value));
7967        this.mode = (Enumeration) value; // Enumeration<EventCapabilityMode>
7968      } else if (name.equals("definition")) {
7969        this.definition = castToCanonical(value); // CanonicalType
7970      } else
7971        return super.setProperty(name, value);
7972      return value;
7973    }
7974
7975  @Override
7976  public void removeChild(String name, Base value) throws FHIRException {
7977      if (name.equals("mode")) {
7978        this.mode = null;
7979      } else if (name.equals("definition")) {
7980        this.definition = null;
7981      } else
7982        super.removeChild(name, value);
7983      
7984    }
7985
7986    @Override
7987    public Base makeProperty(int hash, String name) throws FHIRException {
7988      switch (hash) {
7989      case 3357091:
7990        return getModeElement();
7991      case -1014418093:
7992        return getDefinitionElement();
7993      default:
7994        return super.makeProperty(hash, name);
7995      }
7996
7997    }
7998
7999    @Override
8000    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
8001      switch (hash) {
8002      case 3357091:
8003        /* mode */ return new String[] { "code" };
8004      case -1014418093:
8005        /* definition */ return new String[] { "canonical" };
8006      default:
8007        return super.getTypesForProperty(hash, name);
8008      }
8009
8010    }
8011
8012    @Override
8013    public Base addChild(String name) throws FHIRException {
8014      if (name.equals("mode")) {
8015        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.mode");
8016      } else if (name.equals("definition")) {
8017        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.definition");
8018      } else
8019        return super.addChild(name);
8020    }
8021
8022    public CapabilityStatementMessagingSupportedMessageComponent copy() {
8023      CapabilityStatementMessagingSupportedMessageComponent dst = new CapabilityStatementMessagingSupportedMessageComponent();
8024      copyValues(dst);
8025      return dst;
8026    }
8027
8028    public void copyValues(CapabilityStatementMessagingSupportedMessageComponent dst) {
8029      super.copyValues(dst);
8030      dst.mode = mode == null ? null : mode.copy();
8031      dst.definition = definition == null ? null : definition.copy();
8032    }
8033
8034    @Override
8035    public boolean equalsDeep(Base other_) {
8036      if (!super.equalsDeep(other_))
8037        return false;
8038      if (!(other_ instanceof CapabilityStatementMessagingSupportedMessageComponent))
8039        return false;
8040      CapabilityStatementMessagingSupportedMessageComponent o = (CapabilityStatementMessagingSupportedMessageComponent) other_;
8041      return compareDeep(mode, o.mode, true) && compareDeep(definition, o.definition, true);
8042    }
8043
8044    @Override
8045    public boolean equalsShallow(Base other_) {
8046      if (!super.equalsShallow(other_))
8047        return false;
8048      if (!(other_ instanceof CapabilityStatementMessagingSupportedMessageComponent))
8049        return false;
8050      CapabilityStatementMessagingSupportedMessageComponent o = (CapabilityStatementMessagingSupportedMessageComponent) other_;
8051      return compareValues(mode, o.mode, true);
8052    }
8053
8054    public boolean isEmpty() {
8055      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(mode, definition);
8056    }
8057
8058    public String fhirType() {
8059      return "CapabilityStatement.messaging.supportedMessage";
8060
8061    }
8062
8063  }
8064
8065  @Block()
8066  public static class CapabilityStatementDocumentComponent extends BackboneElement implements IBaseBackboneElement {
8067    /**
8068     * Mode of this document declaration - whether an application is a producer or
8069     * consumer.
8070     */
8071    @Child(name = "mode", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = true)
8072    @Description(shortDefinition = "producer | consumer", formalDefinition = "Mode of this document declaration - whether an application is a producer or consumer.")
8073    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/document-mode")
8074    protected Enumeration<DocumentMode> mode;
8075
8076    /**
8077     * A description of how the application supports or uses the specified document
8078     * profile. For example, when documents are created, what action is taken with
8079     * consumed documents, etc.
8080     */
8081    @Child(name = "documentation", type = {
8082        MarkdownType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
8083    @Description(shortDefinition = "Description of document support", formalDefinition = "A description of how the application supports or uses the specified document profile.  For example, when documents are created, what action is taken with consumed documents, etc.")
8084    protected MarkdownType documentation;
8085
8086    /**
8087     * A profile on the document Bundle that constrains which resources are present,
8088     * and their contents.
8089     */
8090    @Child(name = "profile", type = {
8091        CanonicalType.class }, order = 3, min = 1, max = 1, modifier = false, summary = true)
8092    @Description(shortDefinition = "Constraint on the resources used in the document", formalDefinition = "A profile on the document Bundle that constrains which resources are present, and their contents.")
8093    protected CanonicalType profile;
8094
8095    private static final long serialVersionUID = 18026632L;
8096
8097    /**
8098     * Constructor
8099     */
8100    public CapabilityStatementDocumentComponent() {
8101      super();
8102    }
8103
8104    /**
8105     * Constructor
8106     */
8107    public CapabilityStatementDocumentComponent(Enumeration<DocumentMode> mode, CanonicalType profile) {
8108      super();
8109      this.mode = mode;
8110      this.profile = profile;
8111    }
8112
8113    /**
8114     * @return {@link #mode} (Mode of this document declaration - whether an
8115     *         application is a producer or consumer.). This is the underlying
8116     *         object with id, value and extensions. The accessor "getMode" gives
8117     *         direct access to the value
8118     */
8119    public Enumeration<DocumentMode> getModeElement() {
8120      if (this.mode == null)
8121        if (Configuration.errorOnAutoCreate())
8122          throw new Error("Attempt to auto-create CapabilityStatementDocumentComponent.mode");
8123        else if (Configuration.doAutoCreate())
8124          this.mode = new Enumeration<DocumentMode>(new DocumentModeEnumFactory()); // bb
8125      return this.mode;
8126    }
8127
8128    public boolean hasModeElement() {
8129      return this.mode != null && !this.mode.isEmpty();
8130    }
8131
8132    public boolean hasMode() {
8133      return this.mode != null && !this.mode.isEmpty();
8134    }
8135
8136    /**
8137     * @param value {@link #mode} (Mode of this document declaration - whether an
8138     *              application is a producer or consumer.). This is the underlying
8139     *              object with id, value and extensions. The accessor "getMode"
8140     *              gives direct access to the value
8141     */
8142    public CapabilityStatementDocumentComponent setModeElement(Enumeration<DocumentMode> value) {
8143      this.mode = value;
8144      return this;
8145    }
8146
8147    /**
8148     * @return Mode of this document declaration - whether an application is a
8149     *         producer or consumer.
8150     */
8151    public DocumentMode getMode() {
8152      return this.mode == null ? null : this.mode.getValue();
8153    }
8154
8155    /**
8156     * @param value Mode of this document declaration - whether an application is a
8157     *              producer or consumer.
8158     */
8159    public CapabilityStatementDocumentComponent setMode(DocumentMode value) {
8160      if (this.mode == null)
8161        this.mode = new Enumeration<DocumentMode>(new DocumentModeEnumFactory());
8162      this.mode.setValue(value);
8163      return this;
8164    }
8165
8166    /**
8167     * @return {@link #documentation} (A description of how the application supports
8168     *         or uses the specified document profile. For example, when documents
8169     *         are created, what action is taken with consumed documents, etc.).
8170     *         This is the underlying object with id, value and extensions. The
8171     *         accessor "getDocumentation" gives direct access to the value
8172     */
8173    public MarkdownType getDocumentationElement() {
8174      if (this.documentation == null)
8175        if (Configuration.errorOnAutoCreate())
8176          throw new Error("Attempt to auto-create CapabilityStatementDocumentComponent.documentation");
8177        else if (Configuration.doAutoCreate())
8178          this.documentation = new MarkdownType(); // bb
8179      return this.documentation;
8180    }
8181
8182    public boolean hasDocumentationElement() {
8183      return this.documentation != null && !this.documentation.isEmpty();
8184    }
8185
8186    public boolean hasDocumentation() {
8187      return this.documentation != null && !this.documentation.isEmpty();
8188    }
8189
8190    /**
8191     * @param value {@link #documentation} (A description of how the application
8192     *              supports or uses the specified document profile. For example,
8193     *              when documents are created, what action is taken with consumed
8194     *              documents, etc.). This is the underlying object with id, value
8195     *              and extensions. The accessor "getDocumentation" gives direct
8196     *              access to the value
8197     */
8198    public CapabilityStatementDocumentComponent setDocumentationElement(MarkdownType value) {
8199      this.documentation = value;
8200      return this;
8201    }
8202
8203    /**
8204     * @return A description of how the application supports or uses the specified
8205     *         document profile. For example, when documents are created, what
8206     *         action is taken with consumed documents, etc.
8207     */
8208    public String getDocumentation() {
8209      return this.documentation == null ? null : this.documentation.getValue();
8210    }
8211
8212    /**
8213     * @param value A description of how the application supports or uses the
8214     *              specified document profile. For example, when documents are
8215     *              created, what action is taken with consumed documents, etc.
8216     */
8217    public CapabilityStatementDocumentComponent setDocumentation(String value) {
8218      if (value == null)
8219        this.documentation = null;
8220      else {
8221        if (this.documentation == null)
8222          this.documentation = new MarkdownType();
8223        this.documentation.setValue(value);
8224      }
8225      return this;
8226    }
8227
8228    /**
8229     * @return {@link #profile} (A profile on the document Bundle that constrains
8230     *         which resources are present, and their contents.). This is the
8231     *         underlying object with id, value and extensions. The accessor
8232     *         "getProfile" gives direct access to the value
8233     */
8234    public CanonicalType getProfileElement() {
8235      if (this.profile == null)
8236        if (Configuration.errorOnAutoCreate())
8237          throw new Error("Attempt to auto-create CapabilityStatementDocumentComponent.profile");
8238        else if (Configuration.doAutoCreate())
8239          this.profile = new CanonicalType(); // bb
8240      return this.profile;
8241    }
8242
8243    public boolean hasProfileElement() {
8244      return this.profile != null && !this.profile.isEmpty();
8245    }
8246
8247    public boolean hasProfile() {
8248      return this.profile != null && !this.profile.isEmpty();
8249    }
8250
8251    /**
8252     * @param value {@link #profile} (A profile on the document Bundle that
8253     *              constrains which resources are present, and their contents.).
8254     *              This is the underlying object with id, value and extensions. The
8255     *              accessor "getProfile" gives direct access to the value
8256     */
8257    public CapabilityStatementDocumentComponent setProfileElement(CanonicalType value) {
8258      this.profile = value;
8259      return this;
8260    }
8261
8262    /**
8263     * @return A profile on the document Bundle that constrains which resources are
8264     *         present, and their contents.
8265     */
8266    public String getProfile() {
8267      return this.profile == null ? null : this.profile.getValue();
8268    }
8269
8270    /**
8271     * @param value A profile on the document Bundle that constrains which resources
8272     *              are present, and their contents.
8273     */
8274    public CapabilityStatementDocumentComponent setProfile(String value) {
8275      if (this.profile == null)
8276        this.profile = new CanonicalType();
8277      this.profile.setValue(value);
8278      return this;
8279    }
8280
8281    protected void listChildren(List<Property> children) {
8282      super.listChildren(children);
8283      children.add(new Property("mode", "code",
8284          "Mode of this document declaration - whether an application is a producer or consumer.", 0, 1, mode));
8285      children.add(new Property("documentation", "markdown",
8286          "A description of how the application supports or uses the specified document profile.  For example, when documents are created, what action is taken with consumed documents, etc.",
8287          0, 1, documentation));
8288      children.add(new Property("profile", "canonical(StructureDefinition)",
8289          "A profile on the document Bundle that constrains which resources are present, and their contents.", 0, 1,
8290          profile));
8291    }
8292
8293    @Override
8294    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
8295      switch (_hash) {
8296      case 3357091:
8297        /* mode */ return new Property("mode", "code",
8298            "Mode of this document declaration - whether an application is a producer or consumer.", 0, 1, mode);
8299      case 1587405498:
8300        /* documentation */ return new Property("documentation", "markdown",
8301            "A description of how the application supports or uses the specified document profile.  For example, when documents are created, what action is taken with consumed documents, etc.",
8302            0, 1, documentation);
8303      case -309425751:
8304        /* profile */ return new Property("profile", "canonical(StructureDefinition)",
8305            "A profile on the document Bundle that constrains which resources are present, and their contents.", 0, 1,
8306            profile);
8307      default:
8308        return super.getNamedProperty(_hash, _name, _checkValid);
8309      }
8310
8311    }
8312
8313    @Override
8314    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
8315      switch (hash) {
8316      case 3357091:
8317        /* mode */ return this.mode == null ? new Base[0] : new Base[] { this.mode }; // Enumeration<DocumentMode>
8318      case 1587405498:
8319        /* documentation */ return this.documentation == null ? new Base[0] : new Base[] { this.documentation }; // MarkdownType
8320      case -309425751:
8321        /* profile */ return this.profile == null ? new Base[0] : new Base[] { this.profile }; // CanonicalType
8322      default:
8323        return super.getProperty(hash, name, checkValid);
8324      }
8325
8326    }
8327
8328    @Override
8329    public Base setProperty(int hash, String name, Base value) throws FHIRException {
8330      switch (hash) {
8331      case 3357091: // mode
8332        value = new DocumentModeEnumFactory().fromType(castToCode(value));
8333        this.mode = (Enumeration) value; // Enumeration<DocumentMode>
8334        return value;
8335      case 1587405498: // documentation
8336        this.documentation = castToMarkdown(value); // MarkdownType
8337        return value;
8338      case -309425751: // profile
8339        this.profile = castToCanonical(value); // CanonicalType
8340        return value;
8341      default:
8342        return super.setProperty(hash, name, value);
8343      }
8344
8345    }
8346
8347    @Override
8348    public Base setProperty(String name, Base value) throws FHIRException {
8349      if (name.equals("mode")) {
8350        value = new DocumentModeEnumFactory().fromType(castToCode(value));
8351        this.mode = (Enumeration) value; // Enumeration<DocumentMode>
8352      } else if (name.equals("documentation")) {
8353        this.documentation = castToMarkdown(value); // MarkdownType
8354      } else if (name.equals("profile")) {
8355        this.profile = castToCanonical(value); // CanonicalType
8356      } else
8357        return super.setProperty(name, value);
8358      return value;
8359    }
8360
8361  @Override
8362  public void removeChild(String name, Base value) throws FHIRException {
8363      if (name.equals("mode")) {
8364        this.mode = null;
8365      } else if (name.equals("documentation")) {
8366        this.documentation = null;
8367      } else if (name.equals("profile")) {
8368        this.profile = null;
8369      } else
8370        super.removeChild(name, value);
8371      
8372    }
8373
8374    @Override
8375    public Base makeProperty(int hash, String name) throws FHIRException {
8376      switch (hash) {
8377      case 3357091:
8378        return getModeElement();
8379      case 1587405498:
8380        return getDocumentationElement();
8381      case -309425751:
8382        return getProfileElement();
8383      default:
8384        return super.makeProperty(hash, name);
8385      }
8386
8387    }
8388
8389    @Override
8390    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
8391      switch (hash) {
8392      case 3357091:
8393        /* mode */ return new String[] { "code" };
8394      case 1587405498:
8395        /* documentation */ return new String[] { "markdown" };
8396      case -309425751:
8397        /* profile */ return new String[] { "canonical" };
8398      default:
8399        return super.getTypesForProperty(hash, name);
8400      }
8401
8402    }
8403
8404    @Override
8405    public Base addChild(String name) throws FHIRException {
8406      if (name.equals("mode")) {
8407        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.mode");
8408      } else if (name.equals("documentation")) {
8409        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.documentation");
8410      } else if (name.equals("profile")) {
8411        throw new FHIRException("Cannot call addChild on a singleton property CapabilityStatement.profile");
8412      } else
8413        return super.addChild(name);
8414    }
8415
8416    public CapabilityStatementDocumentComponent copy() {
8417      CapabilityStatementDocumentComponent dst = new CapabilityStatementDocumentComponent();
8418      copyValues(dst);
8419      return dst;
8420    }
8421
8422    public void copyValues(CapabilityStatementDocumentComponent dst) {
8423      super.copyValues(dst);
8424      dst.mode = mode == null ? null : mode.copy();
8425      dst.documentation = documentation == null ? null : documentation.copy();
8426      dst.profile = profile == null ? null : profile.copy();
8427    }
8428
8429    @Override
8430    public boolean equalsDeep(Base other_) {
8431      if (!super.equalsDeep(other_))
8432        return false;
8433      if (!(other_ instanceof CapabilityStatementDocumentComponent))
8434        return false;
8435      CapabilityStatementDocumentComponent o = (CapabilityStatementDocumentComponent) other_;
8436      return compareDeep(mode, o.mode, true) && compareDeep(documentation, o.documentation, true)
8437          && compareDeep(profile, o.profile, true);
8438    }
8439
8440    @Override
8441    public boolean equalsShallow(Base other_) {
8442      if (!super.equalsShallow(other_))
8443        return false;
8444      if (!(other_ instanceof CapabilityStatementDocumentComponent))
8445        return false;
8446      CapabilityStatementDocumentComponent o = (CapabilityStatementDocumentComponent) other_;
8447      return compareValues(mode, o.mode, true) && compareValues(documentation, o.documentation, true);
8448    }
8449
8450    public boolean isEmpty() {
8451      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(mode, documentation, profile);
8452    }
8453
8454    public String fhirType() {
8455      return "CapabilityStatement.document";
8456
8457    }
8458
8459  }
8460
8461  /**
8462   * Explanation of why this capability statement is needed and why it has been
8463   * designed as it has.
8464   */
8465  @Child(name = "purpose", type = {
8466      MarkdownType.class }, order = 0, min = 0, max = 1, modifier = false, summary = false)
8467  @Description(shortDefinition = "Why this capability statement is defined", formalDefinition = "Explanation of why this capability statement is needed and why it has been designed as it has.")
8468  protected MarkdownType purpose;
8469
8470  /**
8471   * A copyright statement relating to the capability statement and/or its
8472   * contents. Copyright statements are generally legal restrictions on the use
8473   * and publishing of the capability statement.
8474   */
8475  @Child(name = "copyright", type = {
8476      MarkdownType.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
8477  @Description(shortDefinition = "Use and/or publishing restrictions", formalDefinition = "A copyright statement relating to the capability statement and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the capability statement.")
8478  protected MarkdownType copyright;
8479
8480  /**
8481   * The way that this statement is intended to be used, to describe an actual
8482   * running instance of software, a particular product (kind, not instance of
8483   * software) or a class of implementation (e.g. a desired purchase).
8484   */
8485  @Child(name = "kind", type = { CodeType.class }, order = 2, min = 1, max = 1, modifier = false, summary = true)
8486  @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).")
8487  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/capability-statement-kind")
8488  protected Enumeration<CapabilityStatementKind> kind;
8489
8490  /**
8491   * Reference to a canonical URL of another CapabilityStatement that this
8492   * software implements. This capability statement is a published API description
8493   * that corresponds to a business service. The server may actually implement a
8494   * subset of the capability statement it claims to implement, so the capability
8495   * statement must specify the full capability details.
8496   */
8497  @Child(name = "instantiates", type = {
8498      CanonicalType.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8499  @Description(shortDefinition = "Canonical URL of another capability statement this implements", formalDefinition = "Reference to a canonical URL of another CapabilityStatement that this software implements. This capability statement is a published API description that corresponds to a business service. The server may actually implement a subset of the capability statement it claims to implement, so the capability statement must specify the full capability details.")
8500  protected List<CanonicalType> instantiates;
8501
8502  /**
8503   * Reference to a canonical URL of another CapabilityStatement that this
8504   * software adds to. The capability statement automatically includes everything
8505   * in the other statement, and it is not duplicated, though the server may
8506   * repeat the same resources, interactions and operations to add additional
8507   * details to them.
8508   */
8509  @Child(name = "imports", type = {
8510      CanonicalType.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8511  @Description(shortDefinition = "Canonical URL of another capability statement this adds to", formalDefinition = "Reference to a canonical URL of another CapabilityStatement that this software adds to. The capability statement automatically includes everything in the other statement, and it is not duplicated, though the server may repeat the same resources, interactions and operations to add additional details to them.")
8512  protected List<CanonicalType> imports;
8513
8514  /**
8515   * Software that is covered by this capability statement. It is used when the
8516   * capability statement describes the capabilities of a particular software
8517   * version, independent of an installation.
8518   */
8519  @Child(name = "software", type = {}, order = 5, min = 0, max = 1, modifier = false, summary = true)
8520  @Description(shortDefinition = "Software that is covered by this capability statement", formalDefinition = "Software that is covered by this capability statement.  It is used when the capability statement describes the capabilities of a particular software version, independent of an installation.")
8521  protected CapabilityStatementSoftwareComponent software;
8522
8523  /**
8524   * Identifies a specific implementation instance that is described by the
8525   * capability statement - i.e. a particular installation, rather than the
8526   * capabilities of a software program.
8527   */
8528  @Child(name = "implementation", type = {}, order = 6, min = 0, max = 1, modifier = false, summary = true)
8529  @Description(shortDefinition = "If this describes a specific instance", formalDefinition = "Identifies a specific implementation instance that is described by the capability statement - i.e. a particular installation, rather than the capabilities of a software program.")
8530  protected CapabilityStatementImplementationComponent implementation;
8531
8532  /**
8533   * The version of the FHIR specification that this CapabilityStatement describes
8534   * (which SHALL be the same as the FHIR version of the CapabilityStatement
8535   * itself). There is no default value.
8536   */
8537  @Child(name = "fhirVersion", type = { CodeType.class }, order = 7, min = 1, max = 1, modifier = false, summary = true)
8538  @Description(shortDefinition = "FHIR Version the system supports", formalDefinition = "The version of the FHIR specification that this CapabilityStatement describes (which SHALL be the same as the FHIR version of the CapabilityStatement itself). There is no default value.")
8539  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/FHIR-version")
8540  protected Enumeration<FHIRVersion> fhirVersion;
8541
8542  /**
8543   * A list of the formats supported by this implementation using their content
8544   * types.
8545   */
8546  @Child(name = "format", type = {
8547      CodeType.class }, order = 8, min = 1, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8548  @Description(shortDefinition = "formats supported (xml | json | ttl | mime type)", formalDefinition = "A list of the formats supported by this implementation using their content types.")
8549  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/mimetypes")
8550  protected List<CodeType> format;
8551
8552  /**
8553   * A list of the patch formats supported by this implementation using their
8554   * content types.
8555   */
8556  @Child(name = "patchFormat", type = {
8557      CodeType.class }, order = 9, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8558  @Description(shortDefinition = "Patch formats supported", formalDefinition = "A list of the patch formats supported by this implementation using their content types.")
8559  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/mimetypes")
8560  protected List<CodeType> patchFormat;
8561
8562  /**
8563   * A list of implementation guides that the server does (or should) support in
8564   * their entirety.
8565   */
8566  @Child(name = "implementationGuide", type = {
8567      CanonicalType.class }, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8568  @Description(shortDefinition = "Implementation guides supported", formalDefinition = "A list of implementation guides that the server does (or should) support in their entirety.")
8569  protected List<CanonicalType> implementationGuide;
8570
8571  /**
8572   * A definition of the restful capabilities of the solution, if any.
8573   */
8574  @Child(name = "rest", type = {}, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8575  @Description(shortDefinition = "If the endpoint is a RESTful one", formalDefinition = "A definition of the restful capabilities of the solution, if any.")
8576  protected List<CapabilityStatementRestComponent> rest;
8577
8578  /**
8579   * A description of the messaging capabilities of the solution.
8580   */
8581  @Child(name = "messaging", type = {}, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8582  @Description(shortDefinition = "If messaging is supported", formalDefinition = "A description of the messaging capabilities of the solution.")
8583  protected List<CapabilityStatementMessagingComponent> messaging;
8584
8585  /**
8586   * A document definition.
8587   */
8588  @Child(name = "document", type = {}, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
8589  @Description(shortDefinition = "Document definition", formalDefinition = "A document definition.")
8590  protected List<CapabilityStatementDocumentComponent> document;
8591
8592  private static final long serialVersionUID = -1050288843L;
8593
8594  /**
8595   * Constructor
8596   */
8597  public CapabilityStatement() {
8598    super();
8599  }
8600
8601  /**
8602   * Constructor
8603   */
8604  public CapabilityStatement(Enumeration<PublicationStatus> status, DateTimeType date,
8605      Enumeration<CapabilityStatementKind> kind, Enumeration<FHIRVersion> fhirVersion) {
8606    super();
8607    this.status = status;
8608    this.date = date;
8609    this.kind = kind;
8610    this.fhirVersion = fhirVersion;
8611  }
8612
8613  /**
8614   * @return {@link #url} (An absolute URI that is used to identify this
8615   *         capability statement when it is referenced in a specification, model,
8616   *         design or an instance; also called its canonical identifier. This
8617   *         SHOULD be globally unique and SHOULD be a literal address at which at
8618   *         which an authoritative instance of this capability statement is (or
8619   *         will be) published. This URL can be the target of a canonical
8620   *         reference. It SHALL remain the same when the capability statement is
8621   *         stored on different servers.). This is the underlying object with id,
8622   *         value and extensions. The accessor "getUrl" gives direct access to
8623   *         the value
8624   */
8625  public UriType getUrlElement() {
8626    if (this.url == null)
8627      if (Configuration.errorOnAutoCreate())
8628        throw new Error("Attempt to auto-create CapabilityStatement.url");
8629      else if (Configuration.doAutoCreate())
8630        this.url = new UriType(); // bb
8631    return this.url;
8632  }
8633
8634  public boolean hasUrlElement() {
8635    return this.url != null && !this.url.isEmpty();
8636  }
8637
8638  public boolean hasUrl() {
8639    return this.url != null && !this.url.isEmpty();
8640  }
8641
8642  /**
8643   * @param value {@link #url} (An absolute URI that is used to identify this
8644   *              capability statement when it is referenced in a specification,
8645   *              model, design or an instance; also called its canonical
8646   *              identifier. This SHOULD be globally unique and SHOULD be a
8647   *              literal address at which at which an authoritative instance of
8648   *              this capability statement is (or will be) published. This URL
8649   *              can be the target of a canonical reference. It SHALL remain the
8650   *              same when the capability statement is stored on different
8651   *              servers.). This is the underlying object with id, value and
8652   *              extensions. The accessor "getUrl" gives direct access to the
8653   *              value
8654   */
8655  public CapabilityStatement setUrlElement(UriType value) {
8656    this.url = value;
8657    return this;
8658  }
8659
8660  /**
8661   * @return An absolute URI that is used to identify this capability statement
8662   *         when it is referenced in a specification, model, design or an
8663   *         instance; also called its canonical identifier. This SHOULD be
8664   *         globally unique and SHOULD be a literal address at which at which an
8665   *         authoritative instance of this capability statement is (or will be)
8666   *         published. This URL can be the target of a canonical reference. It
8667   *         SHALL remain the same when the capability statement is stored on
8668   *         different servers.
8669   */
8670  public String getUrl() {
8671    return this.url == null ? null : this.url.getValue();
8672  }
8673
8674  /**
8675   * @param value An absolute URI that is used to identify this capability
8676   *              statement when it is referenced in a specification, model,
8677   *              design or an instance; also called its canonical identifier.
8678   *              This SHOULD be globally unique and SHOULD be a literal address
8679   *              at which at which an authoritative instance of this capability
8680   *              statement is (or will be) published. This URL can be the target
8681   *              of a canonical reference. It SHALL remain the same when the
8682   *              capability statement is stored on different servers.
8683   */
8684  public CapabilityStatement setUrl(String value) {
8685    if (Utilities.noString(value))
8686      this.url = null;
8687    else {
8688      if (this.url == null)
8689        this.url = new UriType();
8690      this.url.setValue(value);
8691    }
8692    return this;
8693  }
8694
8695  /**
8696   * @return {@link #version} (The identifier that is used to identify this
8697   *         version of the capability statement when it is referenced in a
8698   *         specification, model, design or instance. This is an arbitrary value
8699   *         managed by the capability statement author and is not expected to be
8700   *         globally unique. For example, it might be a timestamp (e.g. yyyymmdd)
8701   *         if a managed version is not available. There is also no expectation
8702   *         that versions can be placed in a lexicographical sequence.). This is
8703   *         the underlying object with id, value and extensions. The accessor
8704   *         "getVersion" gives direct access to the value
8705   */
8706  public StringType getVersionElement() {
8707    if (this.version == null)
8708      if (Configuration.errorOnAutoCreate())
8709        throw new Error("Attempt to auto-create CapabilityStatement.version");
8710      else if (Configuration.doAutoCreate())
8711        this.version = new StringType(); // bb
8712    return this.version;
8713  }
8714
8715  public boolean hasVersionElement() {
8716    return this.version != null && !this.version.isEmpty();
8717  }
8718
8719  public boolean hasVersion() {
8720    return this.version != null && !this.version.isEmpty();
8721  }
8722
8723  /**
8724   * @param value {@link #version} (The identifier that is used to identify this
8725   *              version of the capability statement when it is referenced in a
8726   *              specification, model, design or instance. This is an arbitrary
8727   *              value managed by the capability statement author and is not
8728   *              expected to be globally unique. For example, it might be a
8729   *              timestamp (e.g. yyyymmdd) if a managed version is not available.
8730   *              There is also no expectation that versions can be placed in a
8731   *              lexicographical sequence.). This is the underlying object with
8732   *              id, value and extensions. The accessor "getVersion" gives direct
8733   *              access to the value
8734   */
8735  public CapabilityStatement setVersionElement(StringType value) {
8736    this.version = value;
8737    return this;
8738  }
8739
8740  /**
8741   * @return The identifier that is used to identify this version of the
8742   *         capability statement when it is referenced in a specification, model,
8743   *         design or instance. This is an arbitrary value managed by the
8744   *         capability statement author and is not expected to be globally
8745   *         unique. For example, it might be a timestamp (e.g. yyyymmdd) if a
8746   *         managed version is not available. There is also no expectation that
8747   *         versions can be placed in a lexicographical sequence.
8748   */
8749  public String getVersion() {
8750    return this.version == null ? null : this.version.getValue();
8751  }
8752
8753  /**
8754   * @param value The identifier that is used to identify this version of the
8755   *              capability statement when it is referenced in a specification,
8756   *              model, design or instance. This is an arbitrary value managed by
8757   *              the capability statement author and is not expected to be
8758   *              globally unique. For example, it might be a timestamp (e.g.
8759   *              yyyymmdd) if a managed version is not available. There is also
8760   *              no expectation that versions can be placed in a lexicographical
8761   *              sequence.
8762   */
8763  public CapabilityStatement setVersion(String value) {
8764    if (Utilities.noString(value))
8765      this.version = null;
8766    else {
8767      if (this.version == null)
8768        this.version = new StringType();
8769      this.version.setValue(value);
8770    }
8771    return this;
8772  }
8773
8774  /**
8775   * @return {@link #name} (A natural language name identifying the capability
8776   *         statement. This name should be usable as an identifier for the module
8777   *         by machine processing applications such as code generation.). This is
8778   *         the underlying object with id, value and extensions. The accessor
8779   *         "getName" gives direct access to the value
8780   */
8781  public StringType getNameElement() {
8782    if (this.name == null)
8783      if (Configuration.errorOnAutoCreate())
8784        throw new Error("Attempt to auto-create CapabilityStatement.name");
8785      else if (Configuration.doAutoCreate())
8786        this.name = new StringType(); // bb
8787    return this.name;
8788  }
8789
8790  public boolean hasNameElement() {
8791    return this.name != null && !this.name.isEmpty();
8792  }
8793
8794  public boolean hasName() {
8795    return this.name != null && !this.name.isEmpty();
8796  }
8797
8798  /**
8799   * @param value {@link #name} (A natural language name identifying the
8800   *              capability statement. This name should be usable as an
8801   *              identifier for the module by machine processing applications
8802   *              such as code generation.). This is the underlying object with
8803   *              id, value and extensions. The accessor "getName" gives direct
8804   *              access to the value
8805   */
8806  public CapabilityStatement setNameElement(StringType value) {
8807    this.name = value;
8808    return this;
8809  }
8810
8811  /**
8812   * @return A natural language name identifying the capability statement. This
8813   *         name should be usable as an identifier for the module by machine
8814   *         processing applications such as code generation.
8815   */
8816  public String getName() {
8817    return this.name == null ? null : this.name.getValue();
8818  }
8819
8820  /**
8821   * @param value A natural language name identifying the capability statement.
8822   *              This name should be usable as an identifier for the module by
8823   *              machine processing applications such as code generation.
8824   */
8825  public CapabilityStatement setName(String value) {
8826    if (Utilities.noString(value))
8827      this.name = null;
8828    else {
8829      if (this.name == null)
8830        this.name = new StringType();
8831      this.name.setValue(value);
8832    }
8833    return this;
8834  }
8835
8836  /**
8837   * @return {@link #title} (A short, descriptive, user-friendly title for the
8838   *         capability statement.). This is the underlying object with id, value
8839   *         and extensions. The accessor "getTitle" gives direct access to the
8840   *         value
8841   */
8842  public StringType getTitleElement() {
8843    if (this.title == null)
8844      if (Configuration.errorOnAutoCreate())
8845        throw new Error("Attempt to auto-create CapabilityStatement.title");
8846      else if (Configuration.doAutoCreate())
8847        this.title = new StringType(); // bb
8848    return this.title;
8849  }
8850
8851  public boolean hasTitleElement() {
8852    return this.title != null && !this.title.isEmpty();
8853  }
8854
8855  public boolean hasTitle() {
8856    return this.title != null && !this.title.isEmpty();
8857  }
8858
8859  /**
8860   * @param value {@link #title} (A short, descriptive, user-friendly title for
8861   *              the capability statement.). This is the underlying object with
8862   *              id, value and extensions. The accessor "getTitle" gives direct
8863   *              access to the value
8864   */
8865  public CapabilityStatement setTitleElement(StringType value) {
8866    this.title = value;
8867    return this;
8868  }
8869
8870  /**
8871   * @return A short, descriptive, user-friendly title for the capability
8872   *         statement.
8873   */
8874  public String getTitle() {
8875    return this.title == null ? null : this.title.getValue();
8876  }
8877
8878  /**
8879   * @param value A short, descriptive, user-friendly title for the capability
8880   *              statement.
8881   */
8882  public CapabilityStatement setTitle(String value) {
8883    if (Utilities.noString(value))
8884      this.title = null;
8885    else {
8886      if (this.title == null)
8887        this.title = new StringType();
8888      this.title.setValue(value);
8889    }
8890    return this;
8891  }
8892
8893  /**
8894   * @return {@link #status} (The status of this capability statement. Enables
8895   *         tracking the life-cycle of the content.). This is the underlying
8896   *         object with id, value and extensions. The accessor "getStatus" gives
8897   *         direct access to the value
8898   */
8899  public Enumeration<PublicationStatus> getStatusElement() {
8900    if (this.status == null)
8901      if (Configuration.errorOnAutoCreate())
8902        throw new Error("Attempt to auto-create CapabilityStatement.status");
8903      else if (Configuration.doAutoCreate())
8904        this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory()); // bb
8905    return this.status;
8906  }
8907
8908  public boolean hasStatusElement() {
8909    return this.status != null && !this.status.isEmpty();
8910  }
8911
8912  public boolean hasStatus() {
8913    return this.status != null && !this.status.isEmpty();
8914  }
8915
8916  /**
8917   * @param value {@link #status} (The status of this capability statement.
8918   *              Enables tracking the life-cycle of the content.). This is the
8919   *              underlying object with id, value and extensions. The accessor
8920   *              "getStatus" gives direct access to the value
8921   */
8922  public CapabilityStatement setStatusElement(Enumeration<PublicationStatus> value) {
8923    this.status = value;
8924    return this;
8925  }
8926
8927  /**
8928   * @return The status of this capability statement. Enables tracking the
8929   *         life-cycle of the content.
8930   */
8931  public PublicationStatus getStatus() {
8932    return this.status == null ? null : this.status.getValue();
8933  }
8934
8935  /**
8936   * @param value The status of this capability statement. Enables tracking the
8937   *              life-cycle of the content.
8938   */
8939  public CapabilityStatement setStatus(PublicationStatus value) {
8940    if (this.status == null)
8941      this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory());
8942    this.status.setValue(value);
8943    return this;
8944  }
8945
8946  /**
8947   * @return {@link #experimental} (A Boolean value to indicate that this
8948   *         capability statement is authored for testing purposes (or
8949   *         education/evaluation/marketing) and is not intended to be used for
8950   *         genuine usage.). This is the underlying object with id, value and
8951   *         extensions. The accessor "getExperimental" gives direct access to the
8952   *         value
8953   */
8954  public BooleanType getExperimentalElement() {
8955    if (this.experimental == null)
8956      if (Configuration.errorOnAutoCreate())
8957        throw new Error("Attempt to auto-create CapabilityStatement.experimental");
8958      else if (Configuration.doAutoCreate())
8959        this.experimental = new BooleanType(); // bb
8960    return this.experimental;
8961  }
8962
8963  public boolean hasExperimentalElement() {
8964    return this.experimental != null && !this.experimental.isEmpty();
8965  }
8966
8967  public boolean hasExperimental() {
8968    return this.experimental != null && !this.experimental.isEmpty();
8969  }
8970
8971  /**
8972   * @param value {@link #experimental} (A Boolean value to indicate that this
8973   *              capability statement is authored for testing purposes (or
8974   *              education/evaluation/marketing) and is not intended to be used
8975   *              for genuine usage.). This is the underlying object with id,
8976   *              value and extensions. The accessor "getExperimental" gives
8977   *              direct access to the value
8978   */
8979  public CapabilityStatement setExperimentalElement(BooleanType value) {
8980    this.experimental = value;
8981    return this;
8982  }
8983
8984  /**
8985   * @return A Boolean value to indicate that this capability statement is
8986   *         authored for testing purposes (or education/evaluation/marketing) and
8987   *         is not intended to be used for genuine usage.
8988   */
8989  public boolean getExperimental() {
8990    return this.experimental == null || this.experimental.isEmpty() ? false : this.experimental.getValue();
8991  }
8992
8993  /**
8994   * @param value A Boolean value to indicate that this capability statement is
8995   *              authored for testing purposes (or
8996   *              education/evaluation/marketing) and is not intended to be used
8997   *              for genuine usage.
8998   */
8999  public CapabilityStatement setExperimental(boolean value) {
9000    if (this.experimental == null)
9001      this.experimental = new BooleanType();
9002    this.experimental.setValue(value);
9003    return this;
9004  }
9005
9006  /**
9007   * @return {@link #date} (The date (and optionally time) when the capability
9008   *         statement was published. The date must change when the business
9009   *         version changes and it must change if the status code changes. In
9010   *         addition, it should change when the substantive content of the
9011   *         capability statement changes.). This is the underlying object with
9012   *         id, value and extensions. The accessor "getDate" gives direct access
9013   *         to the value
9014   */
9015  public DateTimeType getDateElement() {
9016    if (this.date == null)
9017      if (Configuration.errorOnAutoCreate())
9018        throw new Error("Attempt to auto-create CapabilityStatement.date");
9019      else if (Configuration.doAutoCreate())
9020        this.date = new DateTimeType(); // bb
9021    return this.date;
9022  }
9023
9024  public boolean hasDateElement() {
9025    return this.date != null && !this.date.isEmpty();
9026  }
9027
9028  public boolean hasDate() {
9029    return this.date != null && !this.date.isEmpty();
9030  }
9031
9032  /**
9033   * @param value {@link #date} (The date (and optionally time) when the
9034   *              capability statement was published. The date must change when
9035   *              the business version changes and it must change if the status
9036   *              code changes. In addition, it should change when the substantive
9037   *              content of the capability statement changes.). This is the
9038   *              underlying object with id, value and extensions. The accessor
9039   *              "getDate" gives direct access to the value
9040   */
9041  public CapabilityStatement setDateElement(DateTimeType value) {
9042    this.date = value;
9043    return this;
9044  }
9045
9046  /**
9047   * @return The date (and optionally time) when the capability statement was
9048   *         published. The date must change when the business version changes and
9049   *         it must change if the status code changes. In addition, it should
9050   *         change when the substantive content of the capability statement
9051   *         changes.
9052   */
9053  public Date getDate() {
9054    return this.date == null ? null : this.date.getValue();
9055  }
9056
9057  /**
9058   * @param value The date (and optionally time) when the capability statement was
9059   *              published. The date must change when the business version
9060   *              changes and it must change if the status code changes. In
9061   *              addition, it should change when the substantive content of the
9062   *              capability statement changes.
9063   */
9064  public CapabilityStatement setDate(Date value) {
9065    if (this.date == null)
9066      this.date = new DateTimeType();
9067    this.date.setValue(value);
9068    return this;
9069  }
9070
9071  /**
9072   * @return {@link #publisher} (The name of the organization or individual that
9073   *         published the capability statement.). This is the underlying object
9074   *         with id, value and extensions. The accessor "getPublisher" gives
9075   *         direct access to the value
9076   */
9077  public StringType getPublisherElement() {
9078    if (this.publisher == null)
9079      if (Configuration.errorOnAutoCreate())
9080        throw new Error("Attempt to auto-create CapabilityStatement.publisher");
9081      else if (Configuration.doAutoCreate())
9082        this.publisher = new StringType(); // bb
9083    return this.publisher;
9084  }
9085
9086  public boolean hasPublisherElement() {
9087    return this.publisher != null && !this.publisher.isEmpty();
9088  }
9089
9090  public boolean hasPublisher() {
9091    return this.publisher != null && !this.publisher.isEmpty();
9092  }
9093
9094  /**
9095   * @param value {@link #publisher} (The name of the organization or individual
9096   *              that published the capability statement.). This is the
9097   *              underlying object with id, value and extensions. The accessor
9098   *              "getPublisher" gives direct access to the value
9099   */
9100  public CapabilityStatement setPublisherElement(StringType value) {
9101    this.publisher = value;
9102    return this;
9103  }
9104
9105  /**
9106   * @return The name of the organization or individual that published the
9107   *         capability statement.
9108   */
9109  public String getPublisher() {
9110    return this.publisher == null ? null : this.publisher.getValue();
9111  }
9112
9113  /**
9114   * @param value The name of the organization or individual that published the
9115   *              capability statement.
9116   */
9117  public CapabilityStatement setPublisher(String value) {
9118    if (Utilities.noString(value))
9119      this.publisher = null;
9120    else {
9121      if (this.publisher == null)
9122        this.publisher = new StringType();
9123      this.publisher.setValue(value);
9124    }
9125    return this;
9126  }
9127
9128  /**
9129   * @return {@link #contact} (Contact details to assist a user in finding and
9130   *         communicating with the publisher.)
9131   */
9132  public List<ContactDetail> getContact() {
9133    if (this.contact == null)
9134      this.contact = new ArrayList<ContactDetail>();
9135    return this.contact;
9136  }
9137
9138  /**
9139   * @return Returns a reference to <code>this</code> for easy method chaining
9140   */
9141  public CapabilityStatement setContact(List<ContactDetail> theContact) {
9142    this.contact = theContact;
9143    return this;
9144  }
9145
9146  public boolean hasContact() {
9147    if (this.contact == null)
9148      return false;
9149    for (ContactDetail item : this.contact)
9150      if (!item.isEmpty())
9151        return true;
9152    return false;
9153  }
9154
9155  public ContactDetail addContact() { // 3
9156    ContactDetail t = new ContactDetail();
9157    if (this.contact == null)
9158      this.contact = new ArrayList<ContactDetail>();
9159    this.contact.add(t);
9160    return t;
9161  }
9162
9163  public CapabilityStatement addContact(ContactDetail t) { // 3
9164    if (t == null)
9165      return this;
9166    if (this.contact == null)
9167      this.contact = new ArrayList<ContactDetail>();
9168    this.contact.add(t);
9169    return this;
9170  }
9171
9172  /**
9173   * @return The first repetition of repeating field {@link #contact}, creating it
9174   *         if it does not already exist
9175   */
9176  public ContactDetail getContactFirstRep() {
9177    if (getContact().isEmpty()) {
9178      addContact();
9179    }
9180    return getContact().get(0);
9181  }
9182
9183  /**
9184   * @return {@link #description} (A free text natural language description of the
9185   *         capability statement from a consumer's perspective. Typically, this
9186   *         is used when the capability statement describes a desired rather than
9187   *         an actual solution, for example as a formal expression of
9188   *         requirements as part of an RFP.). This is the underlying object with
9189   *         id, value and extensions. The accessor "getDescription" gives direct
9190   *         access to the value
9191   */
9192  public MarkdownType getDescriptionElement() {
9193    if (this.description == null)
9194      if (Configuration.errorOnAutoCreate())
9195        throw new Error("Attempt to auto-create CapabilityStatement.description");
9196      else if (Configuration.doAutoCreate())
9197        this.description = new MarkdownType(); // bb
9198    return this.description;
9199  }
9200
9201  public boolean hasDescriptionElement() {
9202    return this.description != null && !this.description.isEmpty();
9203  }
9204
9205  public boolean hasDescription() {
9206    return this.description != null && !this.description.isEmpty();
9207  }
9208
9209  /**
9210   * @param value {@link #description} (A free text natural language description
9211   *              of the capability statement from a consumer's perspective.
9212   *              Typically, this is used when the capability statement describes
9213   *              a desired rather than an actual solution, for example as a
9214   *              formal expression of requirements as part of an RFP.). This is
9215   *              the underlying object with id, value and extensions. The
9216   *              accessor "getDescription" gives direct access to the value
9217   */
9218  public CapabilityStatement setDescriptionElement(MarkdownType value) {
9219    this.description = value;
9220    return this;
9221  }
9222
9223  /**
9224   * @return A free text natural language description of the capability statement
9225   *         from a consumer's perspective. Typically, this is used when the
9226   *         capability statement describes a desired rather than an actual
9227   *         solution, for example as a formal expression of requirements as part
9228   *         of an RFP.
9229   */
9230  public String getDescription() {
9231    return this.description == null ? null : this.description.getValue();
9232  }
9233
9234  /**
9235   * @param value A free text natural language description of the capability
9236   *              statement from a consumer's perspective. Typically, this is used
9237   *              when the capability statement describes a desired rather than an
9238   *              actual solution, for example as a formal expression of
9239   *              requirements as part of an RFP.
9240   */
9241  public CapabilityStatement setDescription(String value) {
9242    if (value == null)
9243      this.description = null;
9244    else {
9245      if (this.description == null)
9246        this.description = new MarkdownType();
9247      this.description.setValue(value);
9248    }
9249    return this;
9250  }
9251
9252  /**
9253   * @return {@link #useContext} (The content was developed with a focus and
9254   *         intent of supporting the contexts that are listed. These contexts may
9255   *         be general categories (gender, age, ...) or may be references to
9256   *         specific programs (insurance plans, studies, ...) and may be used to
9257   *         assist with indexing and searching for appropriate capability
9258   *         statement instances.)
9259   */
9260  public List<UsageContext> getUseContext() {
9261    if (this.useContext == null)
9262      this.useContext = new ArrayList<UsageContext>();
9263    return this.useContext;
9264  }
9265
9266  /**
9267   * @return Returns a reference to <code>this</code> for easy method chaining
9268   */
9269  public CapabilityStatement setUseContext(List<UsageContext> theUseContext) {
9270    this.useContext = theUseContext;
9271    return this;
9272  }
9273
9274  public boolean hasUseContext() {
9275    if (this.useContext == null)
9276      return false;
9277    for (UsageContext item : this.useContext)
9278      if (!item.isEmpty())
9279        return true;
9280    return false;
9281  }
9282
9283  public UsageContext addUseContext() { // 3
9284    UsageContext t = new UsageContext();
9285    if (this.useContext == null)
9286      this.useContext = new ArrayList<UsageContext>();
9287    this.useContext.add(t);
9288    return t;
9289  }
9290
9291  public CapabilityStatement addUseContext(UsageContext t) { // 3
9292    if (t == null)
9293      return this;
9294    if (this.useContext == null)
9295      this.useContext = new ArrayList<UsageContext>();
9296    this.useContext.add(t);
9297    return this;
9298  }
9299
9300  /**
9301   * @return The first repetition of repeating field {@link #useContext}, creating
9302   *         it if it does not already exist
9303   */
9304  public UsageContext getUseContextFirstRep() {
9305    if (getUseContext().isEmpty()) {
9306      addUseContext();
9307    }
9308    return getUseContext().get(0);
9309  }
9310
9311  /**
9312   * @return {@link #jurisdiction} (A legal or geographic region in which the
9313   *         capability statement is intended to be used.)
9314   */
9315  public List<CodeableConcept> getJurisdiction() {
9316    if (this.jurisdiction == null)
9317      this.jurisdiction = new ArrayList<CodeableConcept>();
9318    return this.jurisdiction;
9319  }
9320
9321  /**
9322   * @return Returns a reference to <code>this</code> for easy method chaining
9323   */
9324  public CapabilityStatement setJurisdiction(List<CodeableConcept> theJurisdiction) {
9325    this.jurisdiction = theJurisdiction;
9326    return this;
9327  }
9328
9329  public boolean hasJurisdiction() {
9330    if (this.jurisdiction == null)
9331      return false;
9332    for (CodeableConcept item : this.jurisdiction)
9333      if (!item.isEmpty())
9334        return true;
9335    return false;
9336  }
9337
9338  public CodeableConcept addJurisdiction() { // 3
9339    CodeableConcept t = new CodeableConcept();
9340    if (this.jurisdiction == null)
9341      this.jurisdiction = new ArrayList<CodeableConcept>();
9342    this.jurisdiction.add(t);
9343    return t;
9344  }
9345
9346  public CapabilityStatement addJurisdiction(CodeableConcept t) { // 3
9347    if (t == null)
9348      return this;
9349    if (this.jurisdiction == null)
9350      this.jurisdiction = new ArrayList<CodeableConcept>();
9351    this.jurisdiction.add(t);
9352    return this;
9353  }
9354
9355  /**
9356   * @return The first repetition of repeating field {@link #jurisdiction},
9357   *         creating it if it does not already exist
9358   */
9359  public CodeableConcept getJurisdictionFirstRep() {
9360    if (getJurisdiction().isEmpty()) {
9361      addJurisdiction();
9362    }
9363    return getJurisdiction().get(0);
9364  }
9365
9366  /**
9367   * @return {@link #purpose} (Explanation of why this capability statement is
9368   *         needed and why it has been designed as it has.). This is the
9369   *         underlying object with id, value and extensions. The accessor
9370   *         "getPurpose" gives direct access to the value
9371   */
9372  public MarkdownType getPurposeElement() {
9373    if (this.purpose == null)
9374      if (Configuration.errorOnAutoCreate())
9375        throw new Error("Attempt to auto-create CapabilityStatement.purpose");
9376      else if (Configuration.doAutoCreate())
9377        this.purpose = new MarkdownType(); // bb
9378    return this.purpose;
9379  }
9380
9381  public boolean hasPurposeElement() {
9382    return this.purpose != null && !this.purpose.isEmpty();
9383  }
9384
9385  public boolean hasPurpose() {
9386    return this.purpose != null && !this.purpose.isEmpty();
9387  }
9388
9389  /**
9390   * @param value {@link #purpose} (Explanation of why this capability statement
9391   *              is needed and why it has been designed as it has.). This is the
9392   *              underlying object with id, value and extensions. The accessor
9393   *              "getPurpose" gives direct access to the value
9394   */
9395  public CapabilityStatement setPurposeElement(MarkdownType value) {
9396    this.purpose = value;
9397    return this;
9398  }
9399
9400  /**
9401   * @return Explanation of why this capability statement is needed and why it has
9402   *         been designed as it has.
9403   */
9404  public String getPurpose() {
9405    return this.purpose == null ? null : this.purpose.getValue();
9406  }
9407
9408  /**
9409   * @param value Explanation of why this capability statement is needed and why
9410   *              it has been designed as it has.
9411   */
9412  public CapabilityStatement setPurpose(String value) {
9413    if (value == null)
9414      this.purpose = null;
9415    else {
9416      if (this.purpose == null)
9417        this.purpose = new MarkdownType();
9418      this.purpose.setValue(value);
9419    }
9420    return this;
9421  }
9422
9423  /**
9424   * @return {@link #copyright} (A copyright statement relating to the capability
9425   *         statement and/or its contents. Copyright statements are generally
9426   *         legal restrictions on the use and publishing of the capability
9427   *         statement.). This is the underlying object with id, value and
9428   *         extensions. The accessor "getCopyright" gives direct access to the
9429   *         value
9430   */
9431  public MarkdownType getCopyrightElement() {
9432    if (this.copyright == null)
9433      if (Configuration.errorOnAutoCreate())
9434        throw new Error("Attempt to auto-create CapabilityStatement.copyright");
9435      else if (Configuration.doAutoCreate())
9436        this.copyright = new MarkdownType(); // bb
9437    return this.copyright;
9438  }
9439
9440  public boolean hasCopyrightElement() {
9441    return this.copyright != null && !this.copyright.isEmpty();
9442  }
9443
9444  public boolean hasCopyright() {
9445    return this.copyright != null && !this.copyright.isEmpty();
9446  }
9447
9448  /**
9449   * @param value {@link #copyright} (A copyright statement relating to the
9450   *              capability statement and/or its contents. Copyright statements
9451   *              are generally legal restrictions on the use and publishing of
9452   *              the capability statement.). This is the underlying object with
9453   *              id, value and extensions. The accessor "getCopyright" gives
9454   *              direct access to the value
9455   */
9456  public CapabilityStatement setCopyrightElement(MarkdownType value) {
9457    this.copyright = value;
9458    return this;
9459  }
9460
9461  /**
9462   * @return A copyright statement relating to the capability statement and/or its
9463   *         contents. Copyright statements are generally legal restrictions on
9464   *         the use and publishing of the capability statement.
9465   */
9466  public String getCopyright() {
9467    return this.copyright == null ? null : this.copyright.getValue();
9468  }
9469
9470  /**
9471   * @param value A copyright statement relating to the capability statement
9472   *              and/or its contents. Copyright statements are generally legal
9473   *              restrictions on the use and publishing of the capability
9474   *              statement.
9475   */
9476  public CapabilityStatement setCopyright(String value) {
9477    if (value == null)
9478      this.copyright = null;
9479    else {
9480      if (this.copyright == null)
9481        this.copyright = new MarkdownType();
9482      this.copyright.setValue(value);
9483    }
9484    return this;
9485  }
9486
9487  /**
9488   * @return {@link #kind} (The way that this statement is intended to be used, to
9489   *         describe an actual running instance of software, a particular product
9490   *         (kind, not instance of software) or a class of implementation (e.g. a
9491   *         desired purchase).). This is the underlying object with id, value and
9492   *         extensions. The accessor "getKind" gives direct access to the value
9493   */
9494  public Enumeration<CapabilityStatementKind> getKindElement() {
9495    if (this.kind == null)
9496      if (Configuration.errorOnAutoCreate())
9497        throw new Error("Attempt to auto-create CapabilityStatement.kind");
9498      else if (Configuration.doAutoCreate())
9499        this.kind = new Enumeration<CapabilityStatementKind>(new CapabilityStatementKindEnumFactory()); // bb
9500    return this.kind;
9501  }
9502
9503  public boolean hasKindElement() {
9504    return this.kind != null && !this.kind.isEmpty();
9505  }
9506
9507  public boolean hasKind() {
9508    return this.kind != null && !this.kind.isEmpty();
9509  }
9510
9511  /**
9512   * @param value {@link #kind} (The way that this statement is intended to be
9513   *              used, to describe an actual running instance of software, a
9514   *              particular product (kind, not instance of software) or a class
9515   *              of implementation (e.g. a desired purchase).). This is the
9516   *              underlying object with id, value and extensions. The accessor
9517   *              "getKind" gives direct access to the value
9518   */
9519  public CapabilityStatement setKindElement(Enumeration<CapabilityStatementKind> value) {
9520    this.kind = value;
9521    return this;
9522  }
9523
9524  /**
9525   * @return The way that this statement is intended to be used, to describe an
9526   *         actual running instance of software, a particular product (kind, not
9527   *         instance of software) or a class of implementation (e.g. a desired
9528   *         purchase).
9529   */
9530  public CapabilityStatementKind getKind() {
9531    return this.kind == null ? null : this.kind.getValue();
9532  }
9533
9534  /**
9535   * @param value The way that this statement is intended to be used, to describe
9536   *              an actual running instance of software, a particular product
9537   *              (kind, not instance of software) or a class of implementation
9538   *              (e.g. a desired purchase).
9539   */
9540  public CapabilityStatement setKind(CapabilityStatementKind value) {
9541    if (this.kind == null)
9542      this.kind = new Enumeration<CapabilityStatementKind>(new CapabilityStatementKindEnumFactory());
9543    this.kind.setValue(value);
9544    return this;
9545  }
9546
9547  /**
9548   * @return {@link #instantiates} (Reference to a canonical URL of another
9549   *         CapabilityStatement that this software implements. This capability
9550   *         statement is a published API description that corresponds to a
9551   *         business service. The server may actually implement a subset of the
9552   *         capability statement it claims to implement, so the capability
9553   *         statement must specify the full capability details.)
9554   */
9555  public List<CanonicalType> getInstantiates() {
9556    if (this.instantiates == null)
9557      this.instantiates = new ArrayList<CanonicalType>();
9558    return this.instantiates;
9559  }
9560
9561  /**
9562   * @return Returns a reference to <code>this</code> for easy method chaining
9563   */
9564  public CapabilityStatement setInstantiates(List<CanonicalType> theInstantiates) {
9565    this.instantiates = theInstantiates;
9566    return this;
9567  }
9568
9569  public boolean hasInstantiates() {
9570    if (this.instantiates == null)
9571      return false;
9572    for (CanonicalType item : this.instantiates)
9573      if (!item.isEmpty())
9574        return true;
9575    return false;
9576  }
9577
9578  /**
9579   * @return {@link #instantiates} (Reference to a canonical URL of another
9580   *         CapabilityStatement that this software implements. This capability
9581   *         statement is a published API description that corresponds to a
9582   *         business service. The server may actually implement a subset of the
9583   *         capability statement it claims to implement, so the capability
9584   *         statement must specify the full capability details.)
9585   */
9586  public CanonicalType addInstantiatesElement() {// 2
9587    CanonicalType t = new CanonicalType();
9588    if (this.instantiates == null)
9589      this.instantiates = new ArrayList<CanonicalType>();
9590    this.instantiates.add(t);
9591    return t;
9592  }
9593
9594  /**
9595   * @param value {@link #instantiates} (Reference to a canonical URL of another
9596   *              CapabilityStatement that this software implements. This
9597   *              capability statement is a published API description that
9598   *              corresponds to a business service. The server may actually
9599   *              implement a subset of the capability statement it claims to
9600   *              implement, so the capability statement must specify the full
9601   *              capability details.)
9602   */
9603  public CapabilityStatement addInstantiates(String value) { // 1
9604    CanonicalType t = new CanonicalType();
9605    t.setValue(value);
9606    if (this.instantiates == null)
9607      this.instantiates = new ArrayList<CanonicalType>();
9608    this.instantiates.add(t);
9609