001
002
003
004
005
006
007
008
009
010
011
012
013
014
015
016
017package ca.uhn.fhir.model.dstu2.resource;
018
019import java.math.BigDecimal;
020import java.net.URI;
021import java.util.*;
022import ca.uhn.fhir.model.api.*;
023import ca.uhn.fhir.model.api.annotation.*;
024import ca.uhn.fhir.rest.gclient.*;
025
026import ca.uhn.fhir.model.dstu2.valueset.AccountStatusEnum;
027import ca.uhn.fhir.model.dstu2.valueset.ActionListEnum;
028import ca.uhn.fhir.model.dstu2.composite.AddressDt;
029import ca.uhn.fhir.model.dstu2.valueset.AdjudicationCodesEnum;
030import ca.uhn.fhir.model.dstu2.valueset.AdjudicationErrorCodesEnum;
031import ca.uhn.fhir.model.dstu2.valueset.AdjustmentReasonCodesEnum;
032import ca.uhn.fhir.model.dstu2.valueset.AdministrativeGenderEnum;
033import ca.uhn.fhir.model.dstu2.valueset.AdmitSourceEnum;
034import ca.uhn.fhir.model.dstu2.resource.AllergyIntolerance;
035import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCategoryEnum;
036import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCertaintyEnum;
037import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceCriticalityEnum;
038import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceSeverityEnum;
039import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceStatusEnum;
040import ca.uhn.fhir.model.dstu2.valueset.AllergyIntoleranceTypeEnum;
041import ca.uhn.fhir.model.dstu2.valueset.AnimalSpeciesEnum;
042import ca.uhn.fhir.model.dstu2.composite.AnnotationDt;
043import ca.uhn.fhir.model.dstu2.valueset.AnswerFormatEnum;
044import ca.uhn.fhir.model.dstu2.resource.Appointment;
045import ca.uhn.fhir.model.dstu2.valueset.AppointmentStatusEnum;
046import ca.uhn.fhir.model.dstu2.valueset.AssertionDirectionTypeEnum;
047import ca.uhn.fhir.model.dstu2.valueset.AssertionOperatorTypeEnum;
048import ca.uhn.fhir.model.dstu2.valueset.AssertionResponseTypesEnum;
049import ca.uhn.fhir.model.dstu2.composite.AttachmentDt;
050import ca.uhn.fhir.model.dstu2.valueset.AuditEventActionEnum;
051import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectLifecycleEnum;
052import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectRoleEnum;
053import ca.uhn.fhir.model.dstu2.valueset.AuditEventObjectTypeEnum;
054import ca.uhn.fhir.model.dstu2.valueset.AuditEventOutcomeEnum;
055import ca.uhn.fhir.model.dstu2.valueset.AuditEventParticipantNetworkTypeEnum;
056import ca.uhn.fhir.model.dstu2.valueset.AuditEventSourceTypeEnum;
057import ca.uhn.fhir.model.dstu2.valueset.BindingStrengthEnum;
058import ca.uhn.fhir.model.dstu2.resource.BodySite;
059import ca.uhn.fhir.model.dstu2.valueset.BundleTypeEnum;
060import ca.uhn.fhir.model.dstu2.resource.CarePlan;
061import ca.uhn.fhir.model.dstu2.valueset.CarePlanActivityCategoryEnum;
062import ca.uhn.fhir.model.dstu2.valueset.CarePlanActivityStatusEnum;
063import ca.uhn.fhir.model.dstu2.valueset.CarePlanRelationshipEnum;
064import ca.uhn.fhir.model.dstu2.valueset.CarePlanStatusEnum;
065import ca.uhn.fhir.model.dstu2.resource.Claim;
066import ca.uhn.fhir.model.dstu2.resource.ClaimResponse;
067import ca.uhn.fhir.model.dstu2.valueset.ClaimTypeEnum;
068import ca.uhn.fhir.model.dstu2.resource.ClinicalImpression;
069import ca.uhn.fhir.model.dstu2.valueset.ClinicalImpressionStatusEnum;
070import ca.uhn.fhir.model.dstu2.composite.CodeableConceptDt;
071import ca.uhn.fhir.model.dstu2.composite.CodingDt;
072import ca.uhn.fhir.model.dstu2.resource.CommunicationRequest;
073import ca.uhn.fhir.model.dstu2.valueset.CommunicationRequestStatusEnum;
074import ca.uhn.fhir.model.dstu2.valueset.CommunicationStatusEnum;
075import ca.uhn.fhir.model.dstu2.resource.Composition;
076import ca.uhn.fhir.model.dstu2.valueset.CompositionAttestationModeEnum;
077import ca.uhn.fhir.model.dstu2.valueset.CompositionStatusEnum;
078import ca.uhn.fhir.model.dstu2.valueset.ConceptMapEquivalenceEnum;
079import ca.uhn.fhir.model.dstu2.resource.Condition;
080import ca.uhn.fhir.model.dstu2.valueset.ConditionCategoryCodesEnum;
081import ca.uhn.fhir.model.dstu2.valueset.ConditionClinicalStatusCodesEnum;
082import ca.uhn.fhir.model.dstu2.valueset.ConditionVerificationStatusEnum;
083import ca.uhn.fhir.model.dstu2.valueset.ConditionalDeleteStatusEnum;
084import ca.uhn.fhir.model.dstu2.valueset.ConditionsCodesEnum;
085import ca.uhn.fhir.model.dstu2.resource.Conformance;
086import ca.uhn.fhir.model.dstu2.valueset.ConformanceEventModeEnum;
087import ca.uhn.fhir.model.dstu2.valueset.ConformanceResourceStatusEnum;
088import ca.uhn.fhir.model.dstu2.valueset.ConformanceStatementKindEnum;
089import ca.uhn.fhir.model.dstu2.composite.ContactPointDt;
090import ca.uhn.fhir.model.dstu2.valueset.ContentTypeEnum;
091import ca.uhn.fhir.model.dstu2.resource.Contract;
092import ca.uhn.fhir.model.dstu2.valueset.ContractActionCodesEnum;
093import ca.uhn.fhir.model.dstu2.valueset.ContractActorRoleCodesEnum;
094import ca.uhn.fhir.model.dstu2.valueset.ContractSubtypeCodesEnum;
095import ca.uhn.fhir.model.dstu2.valueset.ContractTermTypeCodesEnum;
096import ca.uhn.fhir.model.dstu2.valueset.ContractTypeCodesEnum;
097import ca.uhn.fhir.model.dstu2.resource.Coverage;
098import ca.uhn.fhir.model.dstu2.valueset.DataElementStringencyEnum;
099import ca.uhn.fhir.model.dstu2.valueset.DaysOfWeekEnum;
100import ca.uhn.fhir.model.dstu2.valueset.DetectedIssueSeverityEnum;
101import ca.uhn.fhir.model.dstu2.resource.Device;
102import ca.uhn.fhir.model.dstu2.resource.DeviceComponent;
103import ca.uhn.fhir.model.dstu2.resource.DeviceMetric;
104import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCalibrationStateEnum;
105import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCalibrationTypeEnum;
106import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricCategoryEnum;
107import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricColorEnum;
108import ca.uhn.fhir.model.dstu2.valueset.DeviceMetricOperationalStatusEnum;
109import ca.uhn.fhir.model.dstu2.valueset.DeviceStatusEnum;
110import ca.uhn.fhir.model.dstu2.resource.DeviceUseRequest;
111import ca.uhn.fhir.model.dstu2.valueset.DeviceUseRequestPriorityEnum;
112import ca.uhn.fhir.model.dstu2.valueset.DeviceUseRequestStatusEnum;
113import ca.uhn.fhir.model.dstu2.resource.DiagnosticOrder;
114import ca.uhn.fhir.model.dstu2.valueset.DiagnosticOrderPriorityEnum;
115import ca.uhn.fhir.model.dstu2.valueset.DiagnosticOrderStatusEnum;
116import ca.uhn.fhir.model.dstu2.resource.DiagnosticReport;
117import ca.uhn.fhir.model.dstu2.valueset.DiagnosticReportStatusEnum;
118import ca.uhn.fhir.model.dstu2.valueset.DigitalMediaTypeEnum;
119import ca.uhn.fhir.model.dstu2.valueset.DocumentModeEnum;
120import ca.uhn.fhir.model.dstu2.resource.DocumentReference;
121import ca.uhn.fhir.model.dstu2.valueset.DocumentReferenceStatusEnum;
122import ca.uhn.fhir.model.dstu2.valueset.DocumentRelationshipTypeEnum;
123import ca.uhn.fhir.model.dstu2.composite.ElementDefinitionDt;
124import ca.uhn.fhir.model.dstu2.resource.EligibilityRequest;
125import ca.uhn.fhir.model.dstu2.resource.Encounter;
126import ca.uhn.fhir.model.dstu2.valueset.EncounterClassEnum;
127import ca.uhn.fhir.model.dstu2.valueset.EncounterLocationStatusEnum;
128import ca.uhn.fhir.model.dstu2.valueset.EncounterStateEnum;
129import ca.uhn.fhir.model.dstu2.valueset.EncounterTypeEnum;
130import ca.uhn.fhir.model.dstu2.resource.EnrollmentRequest;
131import ca.uhn.fhir.model.dstu2.valueset.EnteralFormulaTypeCodesEnum;
132import ca.uhn.fhir.model.dstu2.resource.EpisodeOfCare;
133import ca.uhn.fhir.model.dstu2.valueset.EpisodeOfCareStatusEnum;
134import ca.uhn.fhir.model.dstu2.valueset.ExceptionCodesEnum;
135import ca.uhn.fhir.model.dstu2.valueset.ExtensionContextEnum;
136import ca.uhn.fhir.model.dstu2.valueset.FamilyHistoryStatusEnum;
137import ca.uhn.fhir.model.dstu2.resource.FamilyMemberHistory;
138import ca.uhn.fhir.model.dstu2.valueset.FilterOperatorEnum;
139import ca.uhn.fhir.model.dstu2.valueset.FlagCategoryCodesEnum;
140import ca.uhn.fhir.model.dstu2.valueset.FlagStatusEnum;
141import ca.uhn.fhir.model.dstu2.valueset.FluidConsistencyTypeCodesEnum;
142import ca.uhn.fhir.model.dstu2.resource.Goal;
143import ca.uhn.fhir.model.dstu2.valueset.GoalCategoryEnum;
144import ca.uhn.fhir.model.dstu2.valueset.GoalPriorityEnum;
145import ca.uhn.fhir.model.dstu2.valueset.GoalStartEventEnum;
146import ca.uhn.fhir.model.dstu2.valueset.GoalStatusEnum;
147import ca.uhn.fhir.model.dstu2.valueset.GoalStatusReasonEnum;
148import ca.uhn.fhir.model.dstu2.resource.Group;
149import ca.uhn.fhir.model.dstu2.valueset.GroupTypeEnum;
150import ca.uhn.fhir.model.dstu2.valueset.GuideDependencyTypeEnum;
151import ca.uhn.fhir.model.dstu2.valueset.GuidePageKindEnum;
152import ca.uhn.fhir.model.dstu2.valueset.GuideResourcePurposeEnum;
153import ca.uhn.fhir.model.dstu2.valueset.HTTPVerbEnum;
154import ca.uhn.fhir.model.dstu2.resource.HealthcareService;
155import ca.uhn.fhir.model.dstu2.composite.HumanNameDt;
156import ca.uhn.fhir.model.dstu2.composite.IdentifierDt;
157import ca.uhn.fhir.model.dstu2.valueset.IdentifierTypeCodesEnum;
158import ca.uhn.fhir.model.dstu2.valueset.IdentityAssuranceLevelEnum;
159import ca.uhn.fhir.model.dstu2.resource.ImagingObjectSelection;
160import ca.uhn.fhir.model.dstu2.resource.ImagingStudy;
161import ca.uhn.fhir.model.dstu2.resource.Immunization;
162import ca.uhn.fhir.model.dstu2.valueset.ImmunizationReasonCodesEnum;
163import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRecommendationDateCriterionCodesEnum;
164import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRecommendationStatusCodesEnum;
165import ca.uhn.fhir.model.dstu2.valueset.ImmunizationRouteCodesEnum;
166import ca.uhn.fhir.model.dstu2.valueset.InstanceAvailabilityEnum;
167import ca.uhn.fhir.model.dstu2.valueset.InterventionCodesEnum;
168import ca.uhn.fhir.model.dstu2.valueset.IssueSeverityEnum;
169import ca.uhn.fhir.model.dstu2.valueset.IssueTypeEnum;
170import ca.uhn.fhir.model.dstu2.valueset.KOStitleEnum;
171import ca.uhn.fhir.model.dstu2.valueset.LateralityEnum;
172import ca.uhn.fhir.model.dstu2.valueset.LinkTypeEnum;
173import ca.uhn.fhir.model.dstu2.valueset.ListModeEnum;
174import ca.uhn.fhir.model.dstu2.valueset.ListOrderCodesEnum;
175import ca.uhn.fhir.model.dstu2.valueset.ListStatusEnum;
176import ca.uhn.fhir.model.dstu2.resource.Location;
177import ca.uhn.fhir.model.dstu2.valueset.LocationModeEnum;
178import ca.uhn.fhir.model.dstu2.valueset.LocationStatusEnum;
179import ca.uhn.fhir.model.dstu2.valueset.LocationTypeEnum;
180import ca.uhn.fhir.model.dstu2.valueset.MaritalStatusCodesEnum;
181import ca.uhn.fhir.model.dstu2.valueset.MeasmntPrincipleEnum;
182import ca.uhn.fhir.model.dstu2.resource.Media;
183import ca.uhn.fhir.model.dstu2.resource.Medication;
184import ca.uhn.fhir.model.dstu2.valueset.MedicationAdministrationStatusEnum;
185import ca.uhn.fhir.model.dstu2.valueset.MedicationDispenseStatusEnum;
186import ca.uhn.fhir.model.dstu2.resource.MedicationOrder;
187import ca.uhn.fhir.model.dstu2.valueset.MedicationOrderStatusEnum;
188import ca.uhn.fhir.model.dstu2.resource.MedicationStatement;
189import ca.uhn.fhir.model.dstu2.valueset.MedicationStatementStatusEnum;
190import ca.uhn.fhir.model.dstu2.valueset.MessageEventEnum;
191import ca.uhn.fhir.model.dstu2.valueset.MessageSignificanceCategoryEnum;
192import ca.uhn.fhir.model.dstu2.valueset.MessageTransportEnum;
193import ca.uhn.fhir.model.dstu2.resource.NamingSystem;
194import ca.uhn.fhir.model.dstu2.valueset.NamingSystemIdentifierTypeEnum;
195import ca.uhn.fhir.model.dstu2.valueset.NamingSystemTypeEnum;
196import ca.uhn.fhir.model.dstu2.valueset.NoteTypeEnum;
197import ca.uhn.fhir.model.dstu2.valueset.NutrientModifierCodesEnum;
198import ca.uhn.fhir.model.dstu2.resource.NutritionOrder;
199import ca.uhn.fhir.model.dstu2.valueset.NutritionOrderStatusEnum;
200import ca.uhn.fhir.model.dstu2.resource.Observation;
201import ca.uhn.fhir.model.dstu2.valueset.ObservationCategoryCodesEnum;
202import ca.uhn.fhir.model.dstu2.valueset.ObservationRelationshipTypeEnum;
203import ca.uhn.fhir.model.dstu2.valueset.ObservationStatusEnum;
204import ca.uhn.fhir.model.dstu2.resource.OperationDefinition;
205import ca.uhn.fhir.model.dstu2.valueset.OperationKindEnum;
206import ca.uhn.fhir.model.dstu2.resource.OperationOutcome;
207import ca.uhn.fhir.model.dstu2.valueset.OperationParameterUseEnum;
208import ca.uhn.fhir.model.dstu2.resource.Order;
209import ca.uhn.fhir.model.dstu2.valueset.OrderStatusEnum;
210import ca.uhn.fhir.model.dstu2.resource.Organization;
211import ca.uhn.fhir.model.dstu2.valueset.OrganizationTypeEnum;
212import ca.uhn.fhir.model.dstu2.valueset.ParticipantRequiredEnum;
213import ca.uhn.fhir.model.dstu2.valueset.ParticipantStatusEnum;
214import ca.uhn.fhir.model.dstu2.valueset.ParticipantTypeEnum;
215import ca.uhn.fhir.model.dstu2.valueset.ParticipationStatusEnum;
216import ca.uhn.fhir.model.dstu2.resource.Patient;
217import ca.uhn.fhir.model.dstu2.valueset.PayeeTypeCodesEnum;
218import ca.uhn.fhir.model.dstu2.valueset.PaymentStatusCodesEnum;
219import ca.uhn.fhir.model.dstu2.valueset.PaymentTypeCodesEnum;
220import ca.uhn.fhir.model.dstu2.composite.PeriodDt;
221import ca.uhn.fhir.model.dstu2.resource.Person;
222import ca.uhn.fhir.model.dstu2.resource.Practitioner;
223import ca.uhn.fhir.model.dstu2.valueset.PractitionerRoleEnum;
224import ca.uhn.fhir.model.dstu2.valueset.PractitionerSpecialtyEnum;
225import ca.uhn.fhir.model.dstu2.valueset.PriorityCodesEnum;
226import ca.uhn.fhir.model.dstu2.resource.Procedure;
227import ca.uhn.fhir.model.dstu2.resource.ProcedureRequest;
228import ca.uhn.fhir.model.dstu2.valueset.ProcedureRequestPriorityEnum;
229import ca.uhn.fhir.model.dstu2.valueset.ProcedureRequestStatusEnum;
230import ca.uhn.fhir.model.dstu2.valueset.ProcedureStatusEnum;
231import ca.uhn.fhir.model.dstu2.resource.ProcessRequest;
232import ca.uhn.fhir.model.dstu2.valueset.ProvenanceEntityRoleEnum;
233import ca.uhn.fhir.model.dstu2.composite.QuantityDt;
234import ca.uhn.fhir.model.dstu2.resource.Questionnaire;
235import ca.uhn.fhir.model.dstu2.resource.QuestionnaireResponse;
236import ca.uhn.fhir.model.dstu2.valueset.QuestionnaireResponseStatusEnum;
237import ca.uhn.fhir.model.dstu2.valueset.QuestionnaireStatusEnum;
238import ca.uhn.fhir.model.dstu2.composite.RangeDt;
239import ca.uhn.fhir.model.dstu2.composite.RatioDt;
240import ca.uhn.fhir.model.dstu2.valueset.ReferralMethodEnum;
241import ca.uhn.fhir.model.dstu2.resource.ReferralRequest;
242import ca.uhn.fhir.model.dstu2.valueset.ReferralStatusEnum;
243import ca.uhn.fhir.model.dstu2.resource.RelatedPerson;
244import ca.uhn.fhir.model.dstu2.valueset.RemittanceOutcomeEnum;
245import ca.uhn.fhir.model.dstu2.valueset.ResourceTypeEnum;
246import ca.uhn.fhir.model.dstu2.valueset.ResourceVersionPolicyEnum;
247import ca.uhn.fhir.model.dstu2.valueset.ResponseTypeEnum;
248import ca.uhn.fhir.model.dstu2.valueset.RestfulConformanceModeEnum;
249import ca.uhn.fhir.model.dstu2.valueset.RestfulSecurityServiceEnum;
250import ca.uhn.fhir.model.dstu2.resource.RiskAssessment;
251import ca.uhn.fhir.model.dstu2.valueset.RulesetCodesEnum;
252import ca.uhn.fhir.model.dstu2.composite.SampledDataDt;
253import ca.uhn.fhir.model.dstu2.resource.Schedule;
254import ca.uhn.fhir.model.dstu2.valueset.SearchEntryModeEnum;
255import ca.uhn.fhir.model.dstu2.valueset.SearchModifierCodeEnum;
256import ca.uhn.fhir.model.dstu2.valueset.SearchParamTypeEnum;
257import ca.uhn.fhir.model.dstu2.valueset.ServiceProvisionConditionsEnum;
258import ca.uhn.fhir.model.dstu2.composite.SignatureDt;
259import ca.uhn.fhir.model.dstu2.resource.Slot;
260import ca.uhn.fhir.model.dstu2.valueset.SlotStatusEnum;
261import ca.uhn.fhir.model.dstu2.resource.Specimen;
262import ca.uhn.fhir.model.dstu2.valueset.SpecimenCollectionMethodEnum;
263import ca.uhn.fhir.model.dstu2.valueset.SpecimenStatusEnum;
264import ca.uhn.fhir.model.dstu2.resource.StructureDefinition;
265import ca.uhn.fhir.model.dstu2.valueset.StructureDefinitionKindEnum;
266import ca.uhn.fhir.model.dstu2.valueset.SubscriptionChannelTypeEnum;
267import ca.uhn.fhir.model.dstu2.valueset.SubscriptionStatusEnum;
268import ca.uhn.fhir.model.dstu2.valueset.SubscriptionTagEnum;
269import ca.uhn.fhir.model.dstu2.resource.Substance;
270import ca.uhn.fhir.model.dstu2.valueset.SubstanceCategoryCodesEnum;
271import ca.uhn.fhir.model.dstu2.valueset.SupplementTypeCodesEnum;
272import ca.uhn.fhir.model.dstu2.valueset.SupplyDeliveryStatusEnum;
273import ca.uhn.fhir.model.dstu2.resource.SupplyRequest;
274import ca.uhn.fhir.model.dstu2.valueset.SupplyRequestReasonEnum;
275import ca.uhn.fhir.model.dstu2.valueset.SupplyRequestStatusEnum;
276import ca.uhn.fhir.model.dstu2.valueset.SurfaceCodesEnum;
277import ca.uhn.fhir.model.dstu2.valueset.SystemRestfulInteractionEnum;
278import ca.uhn.fhir.model.api.TemporalPrecisionEnum;
279import ca.uhn.fhir.model.dstu2.valueset.TextureModifiedFoodTypeCodesEnum;
280import ca.uhn.fhir.model.dstu2.valueset.TextureModifierCodesEnum;
281import ca.uhn.fhir.model.dstu2.composite.TimingDt;
282import ca.uhn.fhir.model.dstu2.valueset.TransactionModeEnum;
283import ca.uhn.fhir.model.dstu2.valueset.TypeRestfulInteractionEnum;
284import ca.uhn.fhir.model.dstu2.valueset.UDICodesEnum;
285import ca.uhn.fhir.model.dstu2.valueset.UnknownContentCodeEnum;
286import ca.uhn.fhir.model.dstu2.valueset.UseEnum;
287import ca.uhn.fhir.model.dstu2.resource.ValueSet;
288import ca.uhn.fhir.model.dstu2.valueset.VisionBaseEnum;
289import ca.uhn.fhir.model.dstu2.valueset.VisionEyesEnum;
290import ca.uhn.fhir.model.dstu2.resource.VisionPrescription;
291import ca.uhn.fhir.model.dstu2.valueset.XPathUsageTypeEnum;
292import ca.uhn.fhir.model.api.IResource;
293import ca.uhn.fhir.model.dstu2.composite.AgeDt;
294import ca.uhn.fhir.model.dstu2.composite.BoundCodeableConceptDt;
295import ca.uhn.fhir.model.dstu2.composite.DurationDt;
296import ca.uhn.fhir.model.dstu2.composite.MoneyDt;
297import ca.uhn.fhir.model.dstu2.composite.NarrativeDt;
298import ca.uhn.fhir.model.dstu2.composite.ResourceReferenceDt;
299import ca.uhn.fhir.model.dstu2.composite.SimpleQuantityDt;
300import ca.uhn.fhir.model.primitive.Base64BinaryDt;
301import ca.uhn.fhir.model.primitive.BooleanDt;
302import ca.uhn.fhir.model.primitive.BoundCodeDt;
303import ca.uhn.fhir.model.primitive.CodeDt;
304import ca.uhn.fhir.model.primitive.DateDt;
305import ca.uhn.fhir.model.primitive.DateTimeDt;
306import ca.uhn.fhir.model.primitive.DecimalDt;
307import ca.uhn.fhir.model.primitive.IdDt;
308import ca.uhn.fhir.model.primitive.InstantDt;
309import ca.uhn.fhir.model.primitive.IntegerDt;
310import ca.uhn.fhir.model.primitive.OidDt;
311import ca.uhn.fhir.model.primitive.PositiveIntDt;
312import ca.uhn.fhir.model.primitive.StringDt;
313import ca.uhn.fhir.model.primitive.TimeDt;
314import ca.uhn.fhir.model.primitive.UnsignedIntDt;
315import ca.uhn.fhir.model.primitive.UriDt;
316
317
318/**
319 * HAPI/FHIR <b>Account</b> Resource
320 * ()
321 *
322 * <p>
323 * <b>Definition:</b>
324 * A financial tool for tracking value accrued for a particular purpose.  In the healthcare field, used to track charges for a patient, cost centres, etc.
325 * </p> 
326 *
327 * <p>
328 * <b>Requirements:</b>
329 * 
330 * </p> 
331 *
332 * <p>
333 * <b>Profile Definition:</b>
334 * <a href="http://hl7.org/fhir/profiles/Account">http://hl7.org/fhir/profiles/Account</a> 
335 * </p>
336 *
337 */
338@ResourceDef(name="Account", profile="http://hl7.org/fhir/profiles/Account", id="account")
339public class Account extends ca.uhn.fhir.model.dstu2.resource.BaseResource
340    implements  IResource     {
341
342        /**
343         * Search parameter constant for <b>identifier</b>
344         * <p>
345         * Description: <b></b><br>
346         * Type: <b>token</b><br>
347         * Path: <b>Account.identifier</b><br>
348         * </p>
349         */
350        @SearchParamDefinition(name="identifier", path="Account.identifier", description="", type="token"  )
351        public static final String SP_IDENTIFIER = "identifier";
352
353        /**
354         * <b>Fluent Client</b> search parameter constant for <b>identifier</b>
355         * <p>
356         * Description: <b></b><br>
357         * Type: <b>token</b><br>
358         * Path: <b>Account.identifier</b><br>
359         * </p>
360         */
361        public static final TokenClientParam IDENTIFIER = new TokenClientParam(SP_IDENTIFIER);
362
363        /**
364         * Search parameter constant for <b>name</b>
365         * <p>
366         * Description: <b></b><br>
367         * Type: <b>string</b><br>
368         * Path: <b>Account.name</b><br>
369         * </p>
370         */
371        @SearchParamDefinition(name="name", path="Account.name", description="", type="string"  )
372        public static final String SP_NAME = "name";
373
374        /**
375         * <b>Fluent Client</b> search parameter constant for <b>name</b>
376         * <p>
377         * Description: <b></b><br>
378         * Type: <b>string</b><br>
379         * Path: <b>Account.name</b><br>
380         * </p>
381         */
382        public static final StringClientParam NAME = new StringClientParam(SP_NAME);
383
384        /**
385         * Search parameter constant for <b>type</b>
386         * <p>
387         * Description: <b></b><br>
388         * Type: <b>token</b><br>
389         * Path: <b>Account.type</b><br>
390         * </p>
391         */
392        @SearchParamDefinition(name="type", path="Account.type", description="", type="token"  )
393        public static final String SP_TYPE = "type";
394
395        /**
396         * <b>Fluent Client</b> search parameter constant for <b>type</b>
397         * <p>
398         * Description: <b></b><br>
399         * Type: <b>token</b><br>
400         * Path: <b>Account.type</b><br>
401         * </p>
402         */
403        public static final TokenClientParam TYPE = new TokenClientParam(SP_TYPE);
404
405        /**
406         * Search parameter constant for <b>status</b>
407         * <p>
408         * Description: <b></b><br>
409         * Type: <b>token</b><br>
410         * Path: <b>Account.status</b><br>
411         * </p>
412         */
413        @SearchParamDefinition(name="status", path="Account.status", description="", type="token"  )
414        public static final String SP_STATUS = "status";
415
416        /**
417         * <b>Fluent Client</b> search parameter constant for <b>status</b>
418         * <p>
419         * Description: <b></b><br>
420         * Type: <b>token</b><br>
421         * Path: <b>Account.status</b><br>
422         * </p>
423         */
424        public static final TokenClientParam STATUS = new TokenClientParam(SP_STATUS);
425
426        /**
427         * Search parameter constant for <b>balance</b>
428         * <p>
429         * Description: <b></b><br>
430         * Type: <b>quantity</b><br>
431         * Path: <b>Account.balance</b><br>
432         * </p>
433         */
434        @SearchParamDefinition(name="balance", path="Account.balance", description="", type="quantity"  )
435        public static final String SP_BALANCE = "balance";
436
437        /**
438         * <b>Fluent Client</b> search parameter constant for <b>balance</b>
439         * <p>
440         * Description: <b></b><br>
441         * Type: <b>quantity</b><br>
442         * Path: <b>Account.balance</b><br>
443         * </p>
444         */
445        public static final QuantityClientParam BALANCE = new QuantityClientParam(SP_BALANCE);
446
447        /**
448         * Search parameter constant for <b>period</b>
449         * <p>
450         * Description: <b></b><br>
451         * Type: <b>date</b><br>
452         * Path: <b>Account.coveragePeriod</b><br>
453         * </p>
454         */
455        @SearchParamDefinition(name="period", path="Account.coveragePeriod", description="", type="date"  )
456        public static final String SP_PERIOD = "period";
457
458        /**
459         * <b>Fluent Client</b> search parameter constant for <b>period</b>
460         * <p>
461         * Description: <b></b><br>
462         * Type: <b>date</b><br>
463         * Path: <b>Account.coveragePeriod</b><br>
464         * </p>
465         */
466        public static final DateClientParam PERIOD = new DateClientParam(SP_PERIOD);
467
468        /**
469         * Search parameter constant for <b>subject</b>
470         * <p>
471         * Description: <b></b><br>
472         * Type: <b>reference</b><br>
473         * Path: <b>Account.subject</b><br>
474         * </p>
475         */
476        @SearchParamDefinition(name="subject", path="Account.subject", description="", type="reference"  )
477        public static final String SP_SUBJECT = "subject";
478
479        /**
480         * <b>Fluent Client</b> search parameter constant for <b>subject</b>
481         * <p>
482         * Description: <b></b><br>
483         * Type: <b>reference</b><br>
484         * Path: <b>Account.subject</b><br>
485         * </p>
486         */
487        public static final ReferenceClientParam SUBJECT = new ReferenceClientParam(SP_SUBJECT);
488
489        /**
490         * Search parameter constant for <b>owner</b>
491         * <p>
492         * Description: <b></b><br>
493         * Type: <b>reference</b><br>
494         * Path: <b>Account.owner</b><br>
495         * </p>
496         */
497        @SearchParamDefinition(name="owner", path="Account.owner", description="", type="reference"  )
498        public static final String SP_OWNER = "owner";
499
500        /**
501         * <b>Fluent Client</b> search parameter constant for <b>owner</b>
502         * <p>
503         * Description: <b></b><br>
504         * Type: <b>reference</b><br>
505         * Path: <b>Account.owner</b><br>
506         * </p>
507         */
508        public static final ReferenceClientParam OWNER = new ReferenceClientParam(SP_OWNER);
509
510        /**
511         * Search parameter constant for <b>patient</b>
512         * <p>
513         * Description: <b></b><br>
514         * Type: <b>reference</b><br>
515         * Path: <b>Account.subject</b><br>
516         * </p>
517         */
518        @SearchParamDefinition(name="patient", path="Account.subject", description="", type="reference"  )
519        public static final String SP_PATIENT = "patient";
520
521        /**
522         * <b>Fluent Client</b> search parameter constant for <b>patient</b>
523         * <p>
524         * Description: <b></b><br>
525         * Type: <b>reference</b><br>
526         * Path: <b>Account.subject</b><br>
527         * </p>
528         */
529        public static final ReferenceClientParam PATIENT = new ReferenceClientParam(SP_PATIENT);
530
531
532        /**
533         * Constant for fluent queries to be used to add include statements. Specifies
534         * the path value of "<b>Account:owner</b>".
535         */
536        public static final Include INCLUDE_OWNER = new Include("Account:owner");
537
538        /**
539         * Constant for fluent queries to be used to add include statements. Specifies
540         * the path value of "<b>Account:patient</b>".
541         */
542        public static final Include INCLUDE_PATIENT = new Include("Account:patient");
543
544        /**
545         * Constant for fluent queries to be used to add include statements. Specifies
546         * the path value of "<b>Account:subject</b>".
547         */
548        public static final Include INCLUDE_SUBJECT = new Include("Account:subject");
549
550
551        @Child(name="identifier", type=IdentifierDt.class, order=0, min=0, max=Child.MAX_UNLIMITED, summary=false, modifier=false)      
552        @Description(
553                shortDefinition="",
554                formalDefinition="Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)"
555        )
556        private java.util.List<IdentifierDt> myIdentifier;
557        
558        @Child(name="name", type=StringDt.class, order=1, min=0, max=1, summary=false, modifier=false)  
559        @Description(
560                shortDefinition="",
561                formalDefinition="Name used for the account when displaying it to humans in reports, etc."
562        )
563        private StringDt myName;
564        
565        @Child(name="type", type=CodeableConceptDt.class, order=2, min=0, max=1, summary=false, modifier=false) 
566        @Description(
567                shortDefinition="",
568                formalDefinition="Categorizes the account for reporting and searching purposes"
569        )
570        private CodeableConceptDt myType;
571        
572        @Child(name="status", type=CodeDt.class, order=3, min=0, max=1, summary=false, modifier=true)   
573        @Description(
574                shortDefinition="",
575                formalDefinition="Indicates whether the account is presently used/useable or not"
576        )
577        private BoundCodeDt<AccountStatusEnum> myStatus;
578        
579        @Child(name="activePeriod", type=PeriodDt.class, order=4, min=0, max=1, summary=false, modifier=false)  
580        @Description(
581                shortDefinition="",
582                formalDefinition="Indicates the period of time over which the account is allowed"
583        )
584        private PeriodDt myActivePeriod;
585        
586        @Child(name="currency", type=CodingDt.class, order=5, min=0, max=1, summary=false, modifier=false)      
587        @Description(
588                shortDefinition="",
589                formalDefinition="Identifies the currency to which transactions must be converted when crediting or debiting the account."
590        )
591        private CodingDt myCurrency;
592        
593        @Child(name="balance", type=MoneyDt.class, order=6, min=0, max=1, summary=false, modifier=false)        
594        @Description(
595                shortDefinition="",
596                formalDefinition="Represents the sum of all credits less all debits associated with the account.  Might be positive, zero or negative."
597        )
598        private MoneyDt myBalance;
599        
600        @Child(name="coveragePeriod", type=PeriodDt.class, order=7, min=0, max=1, summary=false, modifier=false)        
601        @Description(
602                shortDefinition="",
603                formalDefinition="Identifies the period of time the account applies to; e.g. accounts created per fiscal year, quarter, etc."
604        )
605        private PeriodDt myCoveragePeriod;
606        
607        @Child(name="subject", order=8, min=0, max=1, summary=false, modifier=false, type={
608                ca.uhn.fhir.model.dstu2.resource.Patient.class,                 ca.uhn.fhir.model.dstu2.resource.Device.class,          ca.uhn.fhir.model.dstu2.resource.Practitioner.class,            ca.uhn.fhir.model.dstu2.resource.Location.class,                ca.uhn.fhir.model.dstu2.resource.HealthcareService.class,               ca.uhn.fhir.model.dstu2.resource.Organization.class     })
609        @Description(
610                shortDefinition="",
611                formalDefinition="Identifies the patient, device, practitioner, location or other object the account is associated with"
612        )
613        private ResourceReferenceDt mySubject;
614        
615        @Child(name="owner", order=9, min=0, max=1, summary=false, modifier=false, type={
616                ca.uhn.fhir.model.dstu2.resource.Organization.class     })
617        @Description(
618                shortDefinition="",
619                formalDefinition="Indicates the organization, department, etc. with responsibility for the account."
620        )
621        private ResourceReferenceDt myOwner;
622        
623        @Child(name="description", type=StringDt.class, order=10, min=0, max=1, summary=false, modifier=false)  
624        @Description(
625                shortDefinition="",
626                formalDefinition="Provides additional information about what the account tracks and how it is used"
627        )
628        private StringDt myDescription;
629        
630
631        @Override
632        public boolean isEmpty() {
633                return super.isBaseEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(  myIdentifier,  myName,  myType,  myStatus,  myActivePeriod,  myCurrency,  myBalance,  myCoveragePeriod,  mySubject,  myOwner,  myDescription);
634        }
635        
636        @Override
637        public <T extends IElement> List<T> getAllPopulatedChildElementsOfType(Class<T> theType) {
638                return ca.uhn.fhir.util.ElementUtil.allPopulatedChildElements(theType, myIdentifier, myName, myType, myStatus, myActivePeriod, myCurrency, myBalance, myCoveragePeriod, mySubject, myOwner, myDescription);
639        }
640
641        /**
642         * Gets the value(s) for <b>identifier</b> ().
643         * creating it if it does
644         * not exist. Will not return <code>null</code>.
645         *
646     * <p>
647     * <b>Definition:</b>
648     * Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)
649     * </p> 
650         */
651        public java.util.List<IdentifierDt> getIdentifier() {  
652                if (myIdentifier == null) {
653                        myIdentifier = new java.util.ArrayList<IdentifierDt>();
654                }
655                return myIdentifier;
656        }
657
658        /**
659         * Sets the value(s) for <b>identifier</b> ()
660         *
661     * <p>
662     * <b>Definition:</b>
663     * Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)
664     * </p> 
665         */
666        public Account setIdentifier(java.util.List<IdentifierDt> theValue) {
667                myIdentifier = theValue;
668                return this;
669        }
670        
671        
672
673        /**
674         * Adds and returns a new value for <b>identifier</b> ()
675         *
676     * <p>
677     * <b>Definition:</b>
678     * Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)
679     * </p> 
680         */
681        public IdentifierDt addIdentifier() {
682                IdentifierDt newType = new IdentifierDt();
683                getIdentifier().add(newType);
684                return newType; 
685        }
686
687        /**
688         * Adds a given new value for <b>identifier</b> ()
689         *
690         * <p>
691         * <b>Definition:</b>
692         * Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)
693         * </p>
694         * @param theValue The identifier to add (must not be <code>null</code>)
695         */
696        public Account addIdentifier(IdentifierDt theValue) {
697                if (theValue == null) {
698                        throw new NullPointerException("theValue must not be null");
699                }
700                getIdentifier().add(theValue);
701                return this;
702        }
703
704        /**
705         * Gets the first repetition for <b>identifier</b> (),
706         * creating it if it does not already exist.
707         *
708     * <p>
709     * <b>Definition:</b>
710     * Unique identifier used to reference the account.  May or may not be intended for human use (e.g. credit card number)
711     * </p> 
712         */
713        public IdentifierDt getIdentifierFirstRep() {
714                if (getIdentifier().isEmpty()) {
715                        return addIdentifier();
716                }
717                return getIdentifier().get(0); 
718        }
719  
720        /**
721         * Gets the value(s) for <b>name</b> ().
722         * creating it if it does
723         * not exist. Will not return <code>null</code>.
724         *
725     * <p>
726     * <b>Definition:</b>
727     * Name used for the account when displaying it to humans in reports, etc.
728     * </p> 
729         */
730        public StringDt getNameElement() {  
731                if (myName == null) {
732                        myName = new StringDt();
733                }
734                return myName;
735        }
736
737        
738        /**
739         * Gets the value(s) for <b>name</b> ().
740         * creating it if it does
741         * not exist. Will not return <code>null</code>.
742         *
743     * <p>
744     * <b>Definition:</b>
745     * Name used for the account when displaying it to humans in reports, etc.
746     * </p> 
747         */
748        public String getName() {  
749                return getNameElement().getValue();
750        }
751
752        /**
753         * Sets the value(s) for <b>name</b> ()
754         *
755     * <p>
756     * <b>Definition:</b>
757     * Name used for the account when displaying it to humans in reports, etc.
758     * </p> 
759         */
760        public Account setName(StringDt theValue) {
761                myName = theValue;
762                return this;
763        }
764        
765        
766
767        /**
768         * Sets the value for <b>name</b> ()
769         *
770     * <p>
771     * <b>Definition:</b>
772     * Name used for the account when displaying it to humans in reports, etc.
773     * </p> 
774         */
775        public Account setName( String theString) {
776                myName = new StringDt(theString); 
777                return this; 
778        }
779
780 
781        /**
782         * Gets the value(s) for <b>type</b> ().
783         * creating it if it does
784         * not exist. Will not return <code>null</code>.
785         *
786     * <p>
787     * <b>Definition:</b>
788     * Categorizes the account for reporting and searching purposes
789     * </p> 
790         */
791        public CodeableConceptDt getType() {  
792                if (myType == null) {
793                        myType = new CodeableConceptDt();
794                }
795                return myType;
796        }
797
798        /**
799         * Sets the value(s) for <b>type</b> ()
800         *
801     * <p>
802     * <b>Definition:</b>
803     * Categorizes the account for reporting and searching purposes
804     * </p> 
805         */
806        public Account setType(CodeableConceptDt theValue) {
807                myType = theValue;
808                return this;
809        }
810        
811        
812
813  
814        /**
815         * Gets the value(s) for <b>status</b> ().
816         * creating it if it does
817         * not exist. Will not return <code>null</code>.
818         *
819     * <p>
820     * <b>Definition:</b>
821     * Indicates whether the account is presently used/useable or not
822     * </p> 
823         */
824        public BoundCodeDt<AccountStatusEnum> getStatusElement() {  
825                if (myStatus == null) {
826                        myStatus = new BoundCodeDt<AccountStatusEnum>(AccountStatusEnum.VALUESET_BINDER);
827                }
828                return myStatus;
829        }
830
831        
832        /**
833         * Gets the value(s) for <b>status</b> ().
834         * creating it if it does
835         * not exist. Will not return <code>null</code>.
836         *
837     * <p>
838     * <b>Definition:</b>
839     * Indicates whether the account is presently used/useable or not
840     * </p> 
841         */
842        public String getStatus() {  
843                return getStatusElement().getValue();
844        }
845
846        /**
847         * Sets the value(s) for <b>status</b> ()
848         *
849     * <p>
850     * <b>Definition:</b>
851     * Indicates whether the account is presently used/useable or not
852     * </p> 
853         */
854        public Account setStatus(BoundCodeDt<AccountStatusEnum> theValue) {
855                myStatus = theValue;
856                return this;
857        }
858        
859        
860
861        /**
862         * Sets the value(s) for <b>status</b> ()
863         *
864     * <p>
865     * <b>Definition:</b>
866     * Indicates whether the account is presently used/useable or not
867     * </p> 
868         */
869        public Account setStatus(AccountStatusEnum theValue) {
870                setStatus(new BoundCodeDt<AccountStatusEnum>(AccountStatusEnum.VALUESET_BINDER, theValue));
871                
872/*
873                getStatusElement().setValueAsEnum(theValue);
874*/
875                return this;
876        }
877
878  
879        /**
880         * Gets the value(s) for <b>activePeriod</b> ().
881         * creating it if it does
882         * not exist. Will not return <code>null</code>.
883         *
884     * <p>
885     * <b>Definition:</b>
886     * Indicates the period of time over which the account is allowed
887     * </p> 
888         */
889        public PeriodDt getActivePeriod() {  
890                if (myActivePeriod == null) {
891                        myActivePeriod = new PeriodDt();
892                }
893                return myActivePeriod;
894        }
895
896        /**
897         * Sets the value(s) for <b>activePeriod</b> ()
898         *
899     * <p>
900     * <b>Definition:</b>
901     * Indicates the period of time over which the account is allowed
902     * </p> 
903         */
904        public Account setActivePeriod(PeriodDt theValue) {
905                myActivePeriod = theValue;
906                return this;
907        }
908        
909        
910
911  
912        /**
913         * Gets the value(s) for <b>currency</b> ().
914         * creating it if it does
915         * not exist. Will not return <code>null</code>.
916         *
917     * <p>
918     * <b>Definition:</b>
919     * Identifies the currency to which transactions must be converted when crediting or debiting the account.
920     * </p> 
921         */
922        public CodingDt getCurrency() {  
923                if (myCurrency == null) {
924                        myCurrency = new CodingDt();
925                }
926                return myCurrency;
927        }
928
929        /**
930         * Sets the value(s) for <b>currency</b> ()
931         *
932     * <p>
933     * <b>Definition:</b>
934     * Identifies the currency to which transactions must be converted when crediting or debiting the account.
935     * </p> 
936         */
937        public Account setCurrency(CodingDt theValue) {
938                myCurrency = theValue;
939                return this;
940        }
941        
942        
943
944  
945        /**
946         * Gets the value(s) for <b>balance</b> ().
947         * creating it if it does
948         * not exist. Will not return <code>null</code>.
949         *
950     * <p>
951     * <b>Definition:</b>
952     * Represents the sum of all credits less all debits associated with the account.  Might be positive, zero or negative.
953     * </p> 
954         */
955        public MoneyDt getBalance() {  
956                if (myBalance == null) {
957                        myBalance = new MoneyDt();
958                }
959                return myBalance;
960        }
961
962        /**
963         * Sets the value(s) for <b>balance</b> ()
964         *
965     * <p>
966     * <b>Definition:</b>
967     * Represents the sum of all credits less all debits associated with the account.  Might be positive, zero or negative.
968     * </p> 
969         */
970        public Account setBalance(MoneyDt theValue) {
971                myBalance = theValue;
972                return this;
973        }
974        
975        
976
977  
978        /**
979         * Gets the value(s) for <b>coveragePeriod</b> ().
980         * creating it if it does
981         * not exist. Will not return <code>null</code>.
982         *
983     * <p>
984     * <b>Definition:</b>
985     * Identifies the period of time the account applies to; e.g. accounts created per fiscal year, quarter, etc.
986     * </p> 
987         */
988        public PeriodDt getCoveragePeriod() {  
989                if (myCoveragePeriod == null) {
990                        myCoveragePeriod = new PeriodDt();
991                }
992                return myCoveragePeriod;
993        }
994
995        /**
996         * Sets the value(s) for <b>coveragePeriod</b> ()
997         *
998     * <p>
999     * <b>Definition:</b>
1000     * Identifies the period of time the account applies to; e.g. accounts created per fiscal year, quarter, etc.
1001     * </p> 
1002         */
1003        public Account setCoveragePeriod(PeriodDt theValue) {
1004                myCoveragePeriod = theValue;
1005                return this;
1006        }
1007        
1008        
1009
1010  
1011        /**
1012         * Gets the value(s) for <b>subject</b> ().
1013         * creating it if it does
1014         * not exist. Will not return <code>null</code>.
1015         *
1016     * <p>
1017     * <b>Definition:</b>
1018     * Identifies the patient, device, practitioner, location or other object the account is associated with
1019     * </p> 
1020         */
1021        public ResourceReferenceDt getSubject() {  
1022                if (mySubject == null) {
1023                        mySubject = new ResourceReferenceDt();
1024                }
1025                return mySubject;
1026        }
1027
1028        /**
1029         * Sets the value(s) for <b>subject</b> ()
1030         *
1031     * <p>
1032     * <b>Definition:</b>
1033     * Identifies the patient, device, practitioner, location or other object the account is associated with
1034     * </p> 
1035         */
1036        public Account setSubject(ResourceReferenceDt theValue) {
1037                mySubject = theValue;
1038                return this;
1039        }
1040        
1041        
1042
1043  
1044        /**
1045         * Gets the value(s) for <b>owner</b> ().
1046         * creating it if it does
1047         * not exist. Will not return <code>null</code>.
1048         *
1049     * <p>
1050     * <b>Definition:</b>
1051     * Indicates the organization, department, etc. with responsibility for the account.
1052     * </p> 
1053         */
1054        public ResourceReferenceDt getOwner() {  
1055                if (myOwner == null) {
1056                        myOwner = new ResourceReferenceDt();
1057                }
1058                return myOwner;
1059        }
1060
1061        /**
1062         * Sets the value(s) for <b>owner</b> ()
1063         *
1064     * <p>
1065     * <b>Definition:</b>
1066     * Indicates the organization, department, etc. with responsibility for the account.
1067     * </p> 
1068         */
1069        public Account setOwner(ResourceReferenceDt theValue) {
1070                myOwner = theValue;
1071                return this;
1072        }
1073        
1074        
1075
1076  
1077        /**
1078         * Gets the value(s) for <b>description</b> ().
1079         * creating it if it does
1080         * not exist. Will not return <code>null</code>.
1081         *
1082     * <p>
1083     * <b>Definition:</b>
1084     * Provides additional information about what the account tracks and how it is used
1085     * </p> 
1086         */
1087        public StringDt getDescriptionElement() {  
1088                if (myDescription == null) {
1089                        myDescription = new StringDt();
1090                }
1091                return myDescription;
1092        }
1093
1094        
1095        /**
1096         * Gets the value(s) for <b>description</b> ().
1097         * creating it if it does
1098         * not exist. Will not return <code>null</code>.
1099         *
1100     * <p>
1101     * <b>Definition:</b>
1102     * Provides additional information about what the account tracks and how it is used
1103     * </p> 
1104         */
1105        public String getDescription() {  
1106                return getDescriptionElement().getValue();
1107        }
1108
1109        /**
1110         * Sets the value(s) for <b>description</b> ()
1111         *
1112     * <p>
1113     * <b>Definition:</b>
1114     * Provides additional information about what the account tracks and how it is used
1115     * </p> 
1116         */
1117        public Account setDescription(StringDt theValue) {
1118                myDescription = theValue;
1119                return this;
1120        }
1121        
1122        
1123
1124        /**
1125         * Sets the value for <b>description</b> ()
1126         *
1127     * <p>
1128     * <b>Definition:</b>
1129     * Provides additional information about what the account tracks and how it is used
1130     * </p> 
1131         */
1132        public Account setDescription( String theString) {
1133                myDescription = new StringDt(theString); 
1134                return this; 
1135        }
1136
1137 
1138
1139
1140    @Override
1141    public String getResourceName() {
1142        return "Account";
1143    }
1144    
1145    public ca.uhn.fhir.context.FhirVersionEnum getStructureFhirVersionEnum() {
1146        return ca.uhn.fhir.context.FhirVersionEnum.DSTU2;
1147    }
1148
1149
1150}