package org.hl7.fhir.instance.model; /* Copyright (c) 2011+, HL7, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of HL7 nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ // Generated on Wed, Nov 11, 2015 10:54-0500 for FHIR v1.0.2 import java.util.ArrayList; import java.util.Date; import java.util.List; import org.hl7.fhir.instance.utilities.Utilities; import ca.uhn.fhir.model.api.annotation.Child; import ca.uhn.fhir.model.api.annotation.Description; import ca.uhn.fhir.model.api.annotation.ResourceDef; import ca.uhn.fhir.model.api.annotation.SearchParamDefinition; /** * This resource identifies an instance of a manufactured item that is used in the provision of healthcare without being substantially changed through that activity. The device may be a medical or non-medical device. Medical devices includes durable (reusable) medical equipment, implantable devices, as well as disposable equipment used for diagnostic, treatment, and research for healthcare and public health. Non-medical devices may include items such as a machine, cellphone, computer, application, etc. */ @ResourceDef(name="Device", profile="http://hl7.org/fhir/Profile/Device") public class Device extends DomainResource { public enum DeviceStatus { /** * The Device is available for use. */ AVAILABLE, /** * The Device is no longer available for use (e.g. lost, expired, damaged). */ NOTAVAILABLE, /** * The Device was entered in error and voided. */ ENTEREDINERROR, /** * added to help the parsers */ NULL; public static DeviceStatus fromCode(String codeString) throws Exception { if (codeString == null || "".equals(codeString)) return null; if ("available".equals(codeString)) return AVAILABLE; if ("not-available".equals(codeString)) return NOTAVAILABLE; if ("entered-in-error".equals(codeString)) return ENTEREDINERROR; throw new Exception("Unknown DeviceStatus code '"+codeString+"'"); } public String toCode() { switch (this) { case AVAILABLE: return "available"; case NOTAVAILABLE: return "not-available"; case ENTEREDINERROR: return "entered-in-error"; default: return "?"; } } public String getSystem() { switch (this) { case AVAILABLE: return "http://hl7.org/fhir/devicestatus"; case NOTAVAILABLE: return "http://hl7.org/fhir/devicestatus"; case ENTEREDINERROR: return "http://hl7.org/fhir/devicestatus"; default: return "?"; } } public String getDefinition() { switch (this) { case AVAILABLE: return "The Device is available for use."; case NOTAVAILABLE: return "The Device is no longer available for use (e.g. lost, expired, damaged)."; case ENTEREDINERROR: return "The Device was entered in error and voided."; default: return "?"; } } public String getDisplay() { switch (this) { case AVAILABLE: return "Available"; case NOTAVAILABLE: return "Not Available"; case ENTEREDINERROR: return "Entered in Error"; default: return "?"; } } } public static class DeviceStatusEnumFactory implements EnumFactory<DeviceStatus> { public DeviceStatus fromCode(String codeString) throws IllegalArgumentException { if (codeString == null || "".equals(codeString)) if (codeString == null || "".equals(codeString)) return null; if ("available".equals(codeString)) return DeviceStatus.AVAILABLE; if ("not-available".equals(codeString)) return DeviceStatus.NOTAVAILABLE; if ("entered-in-error".equals(codeString)) return DeviceStatus.ENTEREDINERROR; throw new IllegalArgumentException("Unknown DeviceStatus code '"+codeString+"'"); } public String toCode(DeviceStatus code) { if (code == DeviceStatus.AVAILABLE) return "available"; if (code == DeviceStatus.NOTAVAILABLE) return "not-available"; if (code == DeviceStatus.ENTEREDINERROR) return "entered-in-error"; return "?"; } } /** * Unique instance identifiers assigned to a device by organizations like manufacturers or owners. If the identifier identifies the type of device, Device.type should be used. */ @Child(name = "identifier", type = {Identifier.class}, order=0, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Instance id from manufacturer, owner, and others", formalDefinition="Unique instance identifiers assigned to a device by organizations like manufacturers or owners. If the identifier identifies the type of device, Device.type should be used." ) protected List<Identifier> identifier; /** * Code or identifier to identify a kind of device. */ @Child(name = "type", type = {CodeableConcept.class}, order=1, min=1, max=1, modifier=false, summary=false) @Description(shortDefinition="What kind of device this is", formalDefinition="Code or identifier to identify a kind of device." ) protected CodeableConcept type; /** * Descriptive information, usage information or implantation information that is not captured in an existing element. */ @Child(name = "note", type = {Annotation.class}, order=2, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Device notes and comments", formalDefinition="Descriptive information, usage information or implantation information that is not captured in an existing element." ) protected List<Annotation> note; /** * Status of the Device availability. */ @Child(name = "status", type = {CodeType.class}, order=3, min=0, max=1, modifier=true, summary=true) @Description(shortDefinition="available | not-available | entered-in-error", formalDefinition="Status of the Device availability." ) protected Enumeration<DeviceStatus> status; /** * A name of the manufacturer. */ @Child(name = "manufacturer", type = {StringType.class}, order=4, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Name of device manufacturer", formalDefinition="A name of the manufacturer." ) protected StringType manufacturer; /** * The "model" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type. */ @Child(name = "model", type = {StringType.class}, order=5, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Model id assigned by the manufacturer", formalDefinition="The \"model\" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type." ) protected StringType model; /** * The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware. */ @Child(name = "version", type = {StringType.class}, order=6, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Version number (i.e. software)", formalDefinition="The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware." ) protected StringType version; /** * The date and time when the device was manufactured. */ @Child(name = "manufactureDate", type = {DateTimeType.class}, order=7, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Manufacture date", formalDefinition="The date and time when the device was manufactured." ) protected DateTimeType manufactureDate; /** * The date and time beyond which this device is no longer valid or should not be used (if applicable). */ @Child(name = "expiry", type = {DateTimeType.class}, order=8, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Date and time of expiry of this device (if applicable)", formalDefinition="The date and time beyond which this device is no longer valid or should not be used (if applicable)." ) protected DateTimeType expiry; /** * United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm. */ @Child(name = "udi", type = {StringType.class}, order=9, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="FDA mandated Unique Device Identifier", formalDefinition="United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm." ) protected StringType udi; /** * Lot number assigned by the manufacturer. */ @Child(name = "lotNumber", type = {StringType.class}, order=10, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Lot number of manufacture", formalDefinition="Lot number assigned by the manufacturer." ) protected StringType lotNumber; /** * An organization that is responsible for the provision and ongoing maintenance of the device. */ @Child(name = "owner", type = {Organization.class}, order=11, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Organization responsible for device", formalDefinition="An organization that is responsible for the provision and ongoing maintenance of the device." ) protected Reference owner; /** * The actual object that is the target of the reference (An organization that is responsible for the provision and ongoing maintenance of the device.) */ protected Organization ownerTarget; /** * The place where the device can be found. */ @Child(name = "location", type = {Location.class}, order=12, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Where the resource is found", formalDefinition="The place where the device can be found." ) protected Reference location; /** * The actual object that is the target of the reference (The place where the device can be found.) */ protected Location locationTarget; /** * Patient information, if the resource is affixed to a person. */ @Child(name = "patient", type = {Patient.class}, order=13, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="If the resource is affixed to a person", formalDefinition="Patient information, if the resource is affixed to a person." ) protected Reference patient; /** * The actual object that is the target of the reference (Patient information, if the resource is affixed to a person.) */ protected Patient patientTarget; /** * Contact details for an organization or a particular human that is responsible for the device. */ @Child(name = "contact", type = {ContactPoint.class}, order=14, min=0, max=Child.MAX_UNLIMITED, modifier=false, summary=false) @Description(shortDefinition="Details for human/organization for support", formalDefinition="Contact details for an organization or a particular human that is responsible for the device." ) protected List<ContactPoint> contact; /** * A network address on which the device may be contacted directly. */ @Child(name = "url", type = {UriType.class}, order=15, min=0, max=1, modifier=false, summary=false) @Description(shortDefinition="Network address to contact device", formalDefinition="A network address on which the device may be contacted directly." ) protected UriType url; private static final long serialVersionUID = 366690094L; /* * Constructor */ public Device() { super(); } /* * Constructor */ public Device(CodeableConcept type) { super(); this.type = type; } /** * @return {@link #identifier} (Unique instance identifiers assigned to a device by organizations like manufacturers or owners. If the identifier identifies the type of device, Device.type should be used.) */ public List<Identifier> getIdentifier() { if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); return this.identifier; } public boolean hasIdentifier() { if (this.identifier == null) return false; for (Identifier item : this.identifier) if (!item.isEmpty()) return true; return false; } /** * @return {@link #identifier} (Unique instance identifiers assigned to a device by organizations like manufacturers or owners. If the identifier identifies the type of device, Device.type should be used.) */ // syntactic sugar public Identifier addIdentifier() { //3 Identifier t = new Identifier(); if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); this.identifier.add(t); return t; } // syntactic sugar public Device addIdentifier(Identifier t) { //3 if (t == null) return this; if (this.identifier == null) this.identifier = new ArrayList<Identifier>(); this.identifier.add(t); return this; } /** * @return {@link #type} (Code or identifier to identify a kind of device.) */ public CodeableConcept getType() { if (this.type == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.type"); else if (Configuration.doAutoCreate()) this.type = new CodeableConcept(); // cc return this.type; } public boolean hasType() { return this.type != null && !this.type.isEmpty(); } /** * @param value {@link #type} (Code or identifier to identify a kind of device.) */ public Device setType(CodeableConcept value) { this.type = value; return this; } /** * @return {@link #note} (Descriptive information, usage information or implantation information that is not captured in an existing element.) */ public List<Annotation> getNote() { if (this.note == null) this.note = new ArrayList<Annotation>(); return this.note; } public boolean hasNote() { if (this.note == null) return false; for (Annotation item : this.note) if (!item.isEmpty()) return true; return false; } /** * @return {@link #note} (Descriptive information, usage information or implantation information that is not captured in an existing element.) */ // syntactic sugar public Annotation addNote() { //3 Annotation t = new Annotation(); if (this.note == null) this.note = new ArrayList<Annotation>(); this.note.add(t); return t; } // syntactic sugar public Device addNote(Annotation t) { //3 if (t == null) return this; if (this.note == null) this.note = new ArrayList<Annotation>(); this.note.add(t); return this; } /** * @return {@link #status} (Status of the Device availability.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public Enumeration<DeviceStatus> getStatusElement() { if (this.status == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.status"); else if (Configuration.doAutoCreate()) this.status = new Enumeration<DeviceStatus>(new DeviceStatusEnumFactory()); // bb return this.status; } public boolean hasStatusElement() { return this.status != null && !this.status.isEmpty(); } public boolean hasStatus() { return this.status != null && !this.status.isEmpty(); } /** * @param value {@link #status} (Status of the Device availability.). This is the underlying object with id, value and extensions. The accessor "getStatus" gives direct access to the value */ public Device setStatusElement(Enumeration<DeviceStatus> value) { this.status = value; return this; } /** * @return Status of the Device availability. */ public DeviceStatus getStatus() { return this.status == null ? null : this.status.getValue(); } /** * @param value Status of the Device availability. */ public Device setStatus(DeviceStatus value) { if (value == null) this.status = null; else { if (this.status == null) this.status = new Enumeration<DeviceStatus>(new DeviceStatusEnumFactory()); this.status.setValue(value); } return this; } /** * @return {@link #manufacturer} (A name of the manufacturer.). This is the underlying object with id, value and extensions. The accessor "getManufacturer" gives direct access to the value */ public StringType getManufacturerElement() { if (this.manufacturer == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.manufacturer"); else if (Configuration.doAutoCreate()) this.manufacturer = new StringType(); // bb return this.manufacturer; } public boolean hasManufacturerElement() { return this.manufacturer != null && !this.manufacturer.isEmpty(); } public boolean hasManufacturer() { return this.manufacturer != null && !this.manufacturer.isEmpty(); } /** * @param value {@link #manufacturer} (A name of the manufacturer.). This is the underlying object with id, value and extensions. The accessor "getManufacturer" gives direct access to the value */ public Device setManufacturerElement(StringType value) { this.manufacturer = value; return this; } /** * @return A name of the manufacturer. */ public String getManufacturer() { return this.manufacturer == null ? null : this.manufacturer.getValue(); } /** * @param value A name of the manufacturer. */ public Device setManufacturer(String value) { if (Utilities.noString(value)) this.manufacturer = null; else { if (this.manufacturer == null) this.manufacturer = new StringType(); this.manufacturer.setValue(value); } return this; } /** * @return {@link #model} (The "model" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type.). This is the underlying object with id, value and extensions. The accessor "getModel" gives direct access to the value */ public StringType getModelElement() { if (this.model == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.model"); else if (Configuration.doAutoCreate()) this.model = new StringType(); // bb return this.model; } public boolean hasModelElement() { return this.model != null && !this.model.isEmpty(); } public boolean hasModel() { return this.model != null && !this.model.isEmpty(); } /** * @param value {@link #model} (The "model" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type.). This is the underlying object with id, value and extensions. The accessor "getModel" gives direct access to the value */ public Device setModelElement(StringType value) { this.model = value; return this; } /** * @return The "model" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type. */ public String getModel() { return this.model == null ? null : this.model.getValue(); } /** * @param value The "model" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type. */ public Device setModel(String value) { if (Utilities.noString(value)) this.model = null; else { if (this.model == null) this.model = new StringType(); this.model.setValue(value); } return this; } /** * @return {@link #version} (The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public StringType getVersionElement() { if (this.version == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.version"); else if (Configuration.doAutoCreate()) this.version = new StringType(); // bb return this.version; } public boolean hasVersionElement() { return this.version != null && !this.version.isEmpty(); } public boolean hasVersion() { return this.version != null && !this.version.isEmpty(); } /** * @param value {@link #version} (The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware.). This is the underlying object with id, value and extensions. The accessor "getVersion" gives direct access to the value */ public Device setVersionElement(StringType value) { this.version = value; return this; } /** * @return The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware. */ public String getVersion() { return this.version == null ? null : this.version.getValue(); } /** * @param value The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware. */ public Device setVersion(String value) { if (Utilities.noString(value)) this.version = null; else { if (this.version == null) this.version = new StringType(); this.version.setValue(value); } return this; } /** * @return {@link #manufactureDate} (The date and time when the device was manufactured.). This is the underlying object with id, value and extensions. The accessor "getManufactureDate" gives direct access to the value */ public DateTimeType getManufactureDateElement() { if (this.manufactureDate == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.manufactureDate"); else if (Configuration.doAutoCreate()) this.manufactureDate = new DateTimeType(); // bb return this.manufactureDate; } public boolean hasManufactureDateElement() { return this.manufactureDate != null && !this.manufactureDate.isEmpty(); } public boolean hasManufactureDate() { return this.manufactureDate != null && !this.manufactureDate.isEmpty(); } /** * @param value {@link #manufactureDate} (The date and time when the device was manufactured.). This is the underlying object with id, value and extensions. The accessor "getManufactureDate" gives direct access to the value */ public Device setManufactureDateElement(DateTimeType value) { this.manufactureDate = value; return this; } /** * @return The date and time when the device was manufactured. */ public Date getManufactureDate() { return this.manufactureDate == null ? null : this.manufactureDate.getValue(); } /** * @param value The date and time when the device was manufactured. */ public Device setManufactureDate(Date value) { if (value == null) this.manufactureDate = null; else { if (this.manufactureDate == null) this.manufactureDate = new DateTimeType(); this.manufactureDate.setValue(value); } return this; } /** * @return {@link #expiry} (The date and time beyond which this device is no longer valid or should not be used (if applicable).). This is the underlying object with id, value and extensions. The accessor "getExpiry" gives direct access to the value */ public DateTimeType getExpiryElement() { if (this.expiry == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.expiry"); else if (Configuration.doAutoCreate()) this.expiry = new DateTimeType(); // bb return this.expiry; } public boolean hasExpiryElement() { return this.expiry != null && !this.expiry.isEmpty(); } public boolean hasExpiry() { return this.expiry != null && !this.expiry.isEmpty(); } /** * @param value {@link #expiry} (The date and time beyond which this device is no longer valid or should not be used (if applicable).). This is the underlying object with id, value and extensions. The accessor "getExpiry" gives direct access to the value */ public Device setExpiryElement(DateTimeType value) { this.expiry = value; return this; } /** * @return The date and time beyond which this device is no longer valid or should not be used (if applicable). */ public Date getExpiry() { return this.expiry == null ? null : this.expiry.getValue(); } /** * @param value The date and time beyond which this device is no longer valid or should not be used (if applicable). */ public Device setExpiry(Date value) { if (value == null) this.expiry = null; else { if (this.expiry == null) this.expiry = new DateTimeType(); this.expiry.setValue(value); } return this; } /** * @return {@link #udi} (United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm.). This is the underlying object with id, value and extensions. The accessor "getUdi" gives direct access to the value */ public StringType getUdiElement() { if (this.udi == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.udi"); else if (Configuration.doAutoCreate()) this.udi = new StringType(); // bb return this.udi; } public boolean hasUdiElement() { return this.udi != null && !this.udi.isEmpty(); } public boolean hasUdi() { return this.udi != null && !this.udi.isEmpty(); } /** * @param value {@link #udi} (United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm.). This is the underlying object with id, value and extensions. The accessor "getUdi" gives direct access to the value */ public Device setUdiElement(StringType value) { this.udi = value; return this; } /** * @return United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm. */ public String getUdi() { return this.udi == null ? null : this.udi.getValue(); } /** * @param value United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm. */ public Device setUdi(String value) { if (Utilities.noString(value)) this.udi = null; else { if (this.udi == null) this.udi = new StringType(); this.udi.setValue(value); } return this; } /** * @return {@link #lotNumber} (Lot number assigned by the manufacturer.). This is the underlying object with id, value and extensions. The accessor "getLotNumber" gives direct access to the value */ public StringType getLotNumberElement() { if (this.lotNumber == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.lotNumber"); else if (Configuration.doAutoCreate()) this.lotNumber = new StringType(); // bb return this.lotNumber; } public boolean hasLotNumberElement() { return this.lotNumber != null && !this.lotNumber.isEmpty(); } public boolean hasLotNumber() { return this.lotNumber != null && !this.lotNumber.isEmpty(); } /** * @param value {@link #lotNumber} (Lot number assigned by the manufacturer.). This is the underlying object with id, value and extensions. The accessor "getLotNumber" gives direct access to the value */ public Device setLotNumberElement(StringType value) { this.lotNumber = value; return this; } /** * @return Lot number assigned by the manufacturer. */ public String getLotNumber() { return this.lotNumber == null ? null : this.lotNumber.getValue(); } /** * @param value Lot number assigned by the manufacturer. */ public Device setLotNumber(String value) { if (Utilities.noString(value)) this.lotNumber = null; else { if (this.lotNumber == null) this.lotNumber = new StringType(); this.lotNumber.setValue(value); } return this; } /** * @return {@link #owner} (An organization that is responsible for the provision and ongoing maintenance of the device.) */ public Reference getOwner() { if (this.owner == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.owner"); else if (Configuration.doAutoCreate()) this.owner = new Reference(); // cc return this.owner; } public boolean hasOwner() { return this.owner != null && !this.owner.isEmpty(); } /** * @param value {@link #owner} (An organization that is responsible for the provision and ongoing maintenance of the device.) */ public Device setOwner(Reference value) { this.owner = value; return this; } /** * @return {@link #owner} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (An organization that is responsible for the provision and ongoing maintenance of the device.) */ public Organization getOwnerTarget() { if (this.ownerTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.owner"); else if (Configuration.doAutoCreate()) this.ownerTarget = new Organization(); // aa return this.ownerTarget; } /** * @param value {@link #owner} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (An organization that is responsible for the provision and ongoing maintenance of the device.) */ public Device setOwnerTarget(Organization value) { this.ownerTarget = value; return this; } /** * @return {@link #location} (The place where the device can be found.) */ public Reference getLocation() { if (this.location == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.location"); else if (Configuration.doAutoCreate()) this.location = new Reference(); // cc return this.location; } public boolean hasLocation() { return this.location != null && !this.location.isEmpty(); } /** * @param value {@link #location} (The place where the device can be found.) */ public Device setLocation(Reference value) { this.location = value; return this; } /** * @return {@link #location} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (The place where the device can be found.) */ public Location getLocationTarget() { if (this.locationTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.location"); else if (Configuration.doAutoCreate()) this.locationTarget = new Location(); // aa return this.locationTarget; } /** * @param value {@link #location} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (The place where the device can be found.) */ public Device setLocationTarget(Location value) { this.locationTarget = value; return this; } /** * @return {@link #patient} (Patient information, if the resource is affixed to a person.) */ public Reference getPatient() { if (this.patient == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.patient"); else if (Configuration.doAutoCreate()) this.patient = new Reference(); // cc return this.patient; } public boolean hasPatient() { return this.patient != null && !this.patient.isEmpty(); } /** * @param value {@link #patient} (Patient information, if the resource is affixed to a person.) */ public Device setPatient(Reference value) { this.patient = value; return this; } /** * @return {@link #patient} The actual object that is the target of the reference. The reference library doesn't populate this, but you can use it to hold the resource if you resolve it. (Patient information, if the resource is affixed to a person.) */ public Patient getPatientTarget() { if (this.patientTarget == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.patient"); else if (Configuration.doAutoCreate()) this.patientTarget = new Patient(); // aa return this.patientTarget; } /** * @param value {@link #patient} The actual object that is the target of the reference. The reference library doesn't use these, but you can use it to hold the resource if you resolve it. (Patient information, if the resource is affixed to a person.) */ public Device setPatientTarget(Patient value) { this.patientTarget = value; return this; } /** * @return {@link #contact} (Contact details for an organization or a particular human that is responsible for the device.) */ public List<ContactPoint> getContact() { if (this.contact == null) this.contact = new ArrayList<ContactPoint>(); return this.contact; } public boolean hasContact() { if (this.contact == null) return false; for (ContactPoint item : this.contact) if (!item.isEmpty()) return true; return false; } /** * @return {@link #contact} (Contact details for an organization or a particular human that is responsible for the device.) */ // syntactic sugar public ContactPoint addContact() { //3 ContactPoint t = new ContactPoint(); if (this.contact == null) this.contact = new ArrayList<ContactPoint>(); this.contact.add(t); return t; } // syntactic sugar public Device addContact(ContactPoint t) { //3 if (t == null) return this; if (this.contact == null) this.contact = new ArrayList<ContactPoint>(); this.contact.add(t); return this; } /** * @return {@link #url} (A network address on which the device may be contacted directly.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public UriType getUrlElement() { if (this.url == null) if (Configuration.errorOnAutoCreate()) throw new Error("Attempt to auto-create Device.url"); else if (Configuration.doAutoCreate()) this.url = new UriType(); // bb return this.url; } public boolean hasUrlElement() { return this.url != null && !this.url.isEmpty(); } public boolean hasUrl() { return this.url != null && !this.url.isEmpty(); } /** * @param value {@link #url} (A network address on which the device may be contacted directly.). This is the underlying object with id, value and extensions. The accessor "getUrl" gives direct access to the value */ public Device setUrlElement(UriType value) { this.url = value; return this; } /** * @return A network address on which the device may be contacted directly. */ public String getUrl() { return this.url == null ? null : this.url.getValue(); } /** * @param value A network address on which the device may be contacted directly. */ public Device setUrl(String value) { if (Utilities.noString(value)) this.url = null; else { if (this.url == null) this.url = new UriType(); this.url.setValue(value); } return this; } protected void listChildren(List<Property> childrenList) { super.listChildren(childrenList); childrenList.add(new Property("identifier", "Identifier", "Unique instance identifiers assigned to a device by organizations like manufacturers or owners. If the identifier identifies the type of device, Device.type should be used.", 0, java.lang.Integer.MAX_VALUE, identifier)); childrenList.add(new Property("type", "CodeableConcept", "Code or identifier to identify a kind of device.", 0, java.lang.Integer.MAX_VALUE, type)); childrenList.add(new Property("note", "Annotation", "Descriptive information, usage information or implantation information that is not captured in an existing element.", 0, java.lang.Integer.MAX_VALUE, note)); childrenList.add(new Property("status", "code", "Status of the Device availability.", 0, java.lang.Integer.MAX_VALUE, status)); childrenList.add(new Property("manufacturer", "string", "A name of the manufacturer.", 0, java.lang.Integer.MAX_VALUE, manufacturer)); childrenList.add(new Property("model", "string", "The \"model\" is an identifier assigned by the manufacturer to identify the product by its type. This number is shared by the all devices sold as the same type.", 0, java.lang.Integer.MAX_VALUE, model)); childrenList.add(new Property("version", "string", "The version of the device, if the device has multiple releases under the same model, or if the device is software or carries firmware.", 0, java.lang.Integer.MAX_VALUE, version)); childrenList.add(new Property("manufactureDate", "dateTime", "The date and time when the device was manufactured.", 0, java.lang.Integer.MAX_VALUE, manufactureDate)); childrenList.add(new Property("expiry", "dateTime", "The date and time beyond which this device is no longer valid or should not be used (if applicable).", 0, java.lang.Integer.MAX_VALUE, expiry)); childrenList.add(new Property("udi", "string", "United States Food and Drug Administration mandated Unique Device Identifier (UDI). Use the human readable information (the content that the user sees, which is sometimes different to the exact syntax represented in the barcode) - see http://www.fda.gov/MedicalDevices/DeviceRegulationandGuidance/UniqueDeviceIdentification/default.htm.", 0, java.lang.Integer.MAX_VALUE, udi)); childrenList.add(new Property("lotNumber", "string", "Lot number assigned by the manufacturer.", 0, java.lang.Integer.MAX_VALUE, lotNumber)); childrenList.add(new Property("owner", "Reference(Organization)", "An organization that is responsible for the provision and ongoing maintenance of the device.", 0, java.lang.Integer.MAX_VALUE, owner)); childrenList.add(new Property("location", "Reference(Location)", "The place where the device can be found.", 0, java.lang.Integer.MAX_VALUE, location)); childrenList.add(new Property("patient", "Reference(Patient)", "Patient information, if the resource is affixed to a person.", 0, java.lang.Integer.MAX_VALUE, patient)); childrenList.add(new Property("contact", "ContactPoint", "Contact details for an organization or a particular human that is responsible for the device.", 0, java.lang.Integer.MAX_VALUE, contact)); childrenList.add(new Property("url", "uri", "A network address on which the device may be contacted directly.", 0, java.lang.Integer.MAX_VALUE, url)); } public Device copy() { Device dst = new Device(); copyValues(dst); if (identifier != null) { dst.identifier = new ArrayList<Identifier>(); for (Identifier i : identifier) dst.identifier.add(i.copy()); }; dst.type = type == null ? null : type.copy(); if (note != null) { dst.note = new ArrayList<Annotation>(); for (Annotation i : note) dst.note.add(i.copy()); }; dst.status = status == null ? null : status.copy(); dst.manufacturer = manufacturer == null ? null : manufacturer.copy(); dst.model = model == null ? null : model.copy(); dst.version = version == null ? null : version.copy(); dst.manufactureDate = manufactureDate == null ? null : manufactureDate.copy(); dst.expiry = expiry == null ? null : expiry.copy(); dst.udi = udi == null ? null : udi.copy(); dst.lotNumber = lotNumber == null ? null : lotNumber.copy(); dst.owner = owner == null ? null : owner.copy(); dst.location = location == null ? null : location.copy(); dst.patient = patient == null ? null : patient.copy(); if (contact != null) { dst.contact = new ArrayList<ContactPoint>(); for (ContactPoint i : contact) dst.contact.add(i.copy()); }; dst.url = url == null ? null : url.copy(); return dst; } protected Device typedCopy() { return copy(); } @Override public boolean equalsDeep(Base other) { if (!super.equalsDeep(other)) return false; if (!(other instanceof Device)) return false; Device o = (Device) other; return compareDeep(identifier, o.identifier, true) && compareDeep(type, o.type, true) && compareDeep(note, o.note, true) && compareDeep(status, o.status, true) && compareDeep(manufacturer, o.manufacturer, true) && compareDeep(model, o.model, true) && compareDeep(version, o.version, true) && compareDeep(manufactureDate, o.manufactureDate, true) && compareDeep(expiry, o.expiry, true) && compareDeep(udi, o.udi, true) && compareDeep(lotNumber, o.lotNumber, true) && compareDeep(owner, o.owner, true) && compareDeep(location, o.location, true) && compareDeep(patient, o.patient, true) && compareDeep(contact, o.contact, true) && compareDeep(url, o.url, true); } @Override public boolean equalsShallow(Base other) { if (!super.equalsShallow(other)) return false; if (!(other instanceof Device)) return false; Device o = (Device) other; return compareValues(status, o.status, true) && compareValues(manufacturer, o.manufacturer, true) && compareValues(model, o.model, true) && compareValues(version, o.version, true) && compareValues(manufactureDate, o.manufactureDate, true) && compareValues(expiry, o.expiry, true) && compareValues(udi, o.udi, true) && compareValues(lotNumber, o.lotNumber, true) && compareValues(url, o.url, true); } public boolean isEmpty() { return super.isEmpty() && (identifier == null || identifier.isEmpty()) && (type == null || type.isEmpty()) && (note == null || note.isEmpty()) && (status == null || status.isEmpty()) && (manufacturer == null || manufacturer.isEmpty()) && (model == null || model.isEmpty()) && (version == null || version.isEmpty()) && (manufactureDate == null || manufactureDate.isEmpty()) && (expiry == null || expiry.isEmpty()) && (udi == null || udi.isEmpty()) && (lotNumber == null || lotNumber.isEmpty()) && (owner == null || owner.isEmpty()) && (location == null || location.isEmpty()) && (patient == null || patient.isEmpty()) && (contact == null || contact.isEmpty()) && (url == null || url.isEmpty()); } @Override public ResourceType getResourceType() { return ResourceType.Device; } @SearchParamDefinition(name="identifier", path="Device.identifier", description="Instance id from manufacturer, owner, and others", type="token" ) public static final String SP_IDENTIFIER = "identifier"; @SearchParamDefinition(name="patient", path="Device.patient", description="Patient information, if the resource is affixed to a person", type="reference" ) public static final String SP_PATIENT = "patient"; @SearchParamDefinition(name="organization", path="Device.owner", description="The organization responsible for the device", type="reference" ) public static final String SP_ORGANIZATION = "organization"; @SearchParamDefinition(name="model", path="Device.model", description="The model of the device", type="string" ) public static final String SP_MODEL = "model"; @SearchParamDefinition(name="location", path="Device.location", description="A location, where the resource is found", type="reference" ) public static final String SP_LOCATION = "location"; @SearchParamDefinition(name="udi", path="Device.udi", description="FDA mandated Unique Device Identifier", type="string" ) public static final String SP_UDI = "udi"; @SearchParamDefinition(name="type", path="Device.type", description="The type of the device", type="token" ) public static final String SP_TYPE = "type"; @SearchParamDefinition(name="url", path="Device.url", description="Network address to contact device", type="uri" ) public static final String SP_URL = "url"; @SearchParamDefinition(name="manufacturer", path="Device.manufacturer", description="The manufacturer of the device", type="string" ) public static final String SP_MANUFACTURER = "manufacturer"; }