All Downloads are FREE. Search and download functionalities are using the official Maven repository.

oasis.names.tc.ciq.xpil._3.Preferences Maven / Gradle / Ivy

There is a newer version: 1.2.0.2
Show newest version
/**
 * Copyright (c) 2015, The MITRE Corporation. All rights reserved.
 * See LICENSE for complete terms.
 */

//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.5-2 
// See http://java.sun.com/xml/jaxb 
// Any modifications to this file will be lost upon recompilation of the source schema. 
// Generated on: 2015.06.23 at 10:59:44 AM EDT 
//

package oasis.names.tc.ciq.xpil._3;

import java.io.StringReader;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Unmarshaller;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAnyAttribute;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlSchemaType;
import javax.xml.bind.annotation.XmlType;
import javax.xml.bind.annotation.XmlValue;
import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import javax.xml.datatype.XMLGregorianCalendar;
import javax.xml.namespace.QName;
import javax.xml.transform.stream.StreamSource;
import oasis.names.tc.ciq.ct._3.DataQualityTypeList;
import org.jvnet.jaxb2_commons.lang.Equals;
import org.jvnet.jaxb2_commons.lang.EqualsStrategy;
import org.jvnet.jaxb2_commons.lang.HashCode;
import org.jvnet.jaxb2_commons.lang.HashCodeStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBEqualsStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBHashCodeStrategy;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
import org.jvnet.jaxb2_commons.lang.ToString;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
import org.jvnet.jaxb2_commons.locator.util.LocatorUtils;
import org.mitre.stix.DocumentUtilities;
import org.mitre.stix.STIXSchema;
import org.mitre.stix.ValidationEventHandler;

/**
 * 

Java class for anonymous complex type. * *

The following schema fragment specifies the expected content contained within this class. * *

 * <complexType>
 *   <complexContent>
 *     <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
 *       <sequence>
 *         <element name="Preference" maxOccurs="unbounded">
 *           <complexType>
 *             <simpleContent>
 *               <extension base="<urn:oasis:names:tc:ciq:ct:3>String">
 *                 <attGroup ref="{urn:oasis:names:tc:ciq:ct:3}grDataQuality"/>
 *                 <attribute name="Type" type="{urn:oasis:names:tc:ciq:xpil:3}PreferenceTypeList" />
 *                 <anyAttribute processContents='lax' namespace='##other'/>
 *               </extension>
 *             </simpleContent>
 *           </complexType>
 *         </element>
 *       </sequence>
 *       <anyAttribute processContents='lax' namespace='##other'/>
 *     </restriction>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "", propOrder = { "preferences" }) @XmlRootElement(name = "Preferences") public class Preferences implements Equals, HashCode, ToString { @XmlElement(name = "Preference", required = true) protected List preferences; @XmlAnyAttribute private Map otherAttributes = new HashMap(); /** * Default no-arg constructor * */ public Preferences() { super(); } /** * Fully-initialising value constructor * */ public Preferences(final List preferences, final Map otherAttributes) { this.preferences = preferences; this.otherAttributes = otherAttributes; } /** * Gets the value of the preferences property. * *

* This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a set method for the preferences property. * *

* For example, to add a new item, do as follows: *

	 *    getPreferences().add(newItem);
	 * 
* * *

* Objects of the following type(s) are allowed in the list * {@link Preferences.Preference } * * */ public List getPreferences() { if (preferences == null) { preferences = new ArrayList(); } return this.preferences; } /** * Gets a map that contains attributes that aren't bound to any typed property on this class. * *

* the map is keyed by the name of the attribute and * the value is the string value of the attribute. * * the map returned by this method is live, and you can add new attribute * by updating the map directly. Because of this design, there's no setter. * * * @return * always non-null */ public Map getOtherAttributes() { return otherAttributes; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof Preferences)) { return false; } if (this == object) { return true; } final Preferences that = ((Preferences) object); { List lhsPreferences; lhsPreferences = (((this.preferences != null) && (!this.preferences .isEmpty())) ? this.getPreferences() : null); List rhsPreferences; rhsPreferences = (((that.preferences != null) && (!that.preferences .isEmpty())) ? that.getPreferences() : null); if (!strategy.equals(LocatorUtils.property(thisLocator, "preferences", lhsPreferences), LocatorUtils.property( thatLocator, "preferences", rhsPreferences), lhsPreferences, rhsPreferences)) { return false; } } return true; } public boolean equals(Object object) { final EqualsStrategy strategy = JAXBEqualsStrategy.INSTANCE; return equals(null, null, object, strategy); } public int hashCode(ObjectLocator locator, HashCodeStrategy strategy) { int currentHashCode = 1; { List thePreferences; thePreferences = (((this.preferences != null) && (!this.preferences .isEmpty())) ? this.getPreferences() : null); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "preferences", thePreferences), currentHashCode, thePreferences); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public Preferences withPreferences(Preferences.Preference... values) { if (values != null) { for (Preferences.Preference value : values) { getPreferences().add(value); } } return this; } public Preferences withPreferences(Collection values) { if (values != null) { getPreferences().addAll(values); } return this; } public String toString() { final ToStringStrategy strategy = JAXBToStringStrategy.INSTANCE; final StringBuilder buffer = new StringBuilder(); append(null, buffer, strategy); return buffer.toString(); } public StringBuilder append(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) { strategy.appendStart(locator, this, buffer); appendFields(locator, buffer, strategy); strategy.appendEnd(locator, this, buffer); return buffer; } public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) { { List thePreferences; thePreferences = (((this.preferences != null) && (!this.preferences .isEmpty())) ? this.getPreferences() : null); strategy.appendField(locator, this, "preferences", buffer, thePreferences); } return buffer; } /** *

Java class for anonymous complex type. * *

The following schema fragment specifies the expected content contained within this class. * *

	 * <complexType>
	 *   <simpleContent>
	 *     <extension base="<urn:oasis:names:tc:ciq:ct:3>String">
	 *       <attGroup ref="{urn:oasis:names:tc:ciq:ct:3}grDataQuality"/>
	 *       <attribute name="Type" type="{urn:oasis:names:tc:ciq:xpil:3}PreferenceTypeList" />
	 *       <anyAttribute processContents='lax' namespace='##other'/>
	 *     </extension>
	 *   </simpleContent>
	 * </complexType>
	 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "", propOrder = { "value" }) public static class Preference implements Equals, HashCode, ToString { @XmlValue @XmlJavaTypeAdapter(NormalizedStringAdapter.class) protected String value; @XmlAttribute(name = "Type", namespace = "urn:oasis:names:tc:ciq:xpil:3") @XmlJavaTypeAdapter(NormalizedStringAdapter.class) protected String type; @XmlAttribute(name = "DataQualityType", namespace = "urn:oasis:names:tc:ciq:ct:3") protected DataQualityTypeList dataQualityType; @XmlAttribute(name = "ValidFrom", namespace = "urn:oasis:names:tc:ciq:ct:3") @XmlSchemaType(name = "dateTime") protected XMLGregorianCalendar validFrom; @XmlAttribute(name = "ValidTo", namespace = "urn:oasis:names:tc:ciq:ct:3") @XmlSchemaType(name = "dateTime") protected XMLGregorianCalendar validTo; @XmlAnyAttribute private Map otherAttributes = new HashMap(); /** * Default no-arg constructor * */ public Preference() { super(); } /** * Fully-initialising value constructor * */ public Preference(final String value, final String type, final DataQualityTypeList dataQualityType, final XMLGregorianCalendar validFrom, final XMLGregorianCalendar validTo, final Map otherAttributes) { this.value = value; this.type = type; this.dataQualityType = dataQualityType; this.validFrom = validFrom; this.validTo = validTo; this.otherAttributes = otherAttributes; } /** * Normalized and Collapsed String * * @return * possible object is * {@link String } * */ public String getValue() { return value; } /** * Sets the value of the value property. * * @param value * allowed object is * {@link String } * */ public void setValue(String value) { this.value = value; } /** * Gets the value of the type property. * * @return * possible object is * {@link String } * */ public String getType() { return type; } /** * Sets the value of the type property. * * @param value * allowed object is * {@link String } * */ public void setType(String value) { this.type = value; } /** * Gets the value of the dataQualityType property. * * @return * possible object is * {@link DataQualityTypeList } * */ public DataQualityTypeList getDataQualityType() { return dataQualityType; } /** * Sets the value of the dataQualityType property. * * @param value * allowed object is * {@link DataQualityTypeList } * */ public void setDataQualityType(DataQualityTypeList value) { this.dataQualityType = value; } /** * Gets the value of the validFrom property. * * @return * possible object is * {@link XMLGregorianCalendar } * */ public XMLGregorianCalendar getValidFrom() { return validFrom; } /** * Sets the value of the validFrom property. * * @param value * allowed object is * {@link XMLGregorianCalendar } * */ public void setValidFrom(XMLGregorianCalendar value) { this.validFrom = value; } /** * Gets the value of the validTo property. * * @return * possible object is * {@link XMLGregorianCalendar } * */ public XMLGregorianCalendar getValidTo() { return validTo; } /** * Sets the value of the validTo property. * * @param value * allowed object is * {@link XMLGregorianCalendar } * */ public void setValidTo(XMLGregorianCalendar value) { this.validTo = value; } /** * Gets a map that contains attributes that aren't bound to any typed property on this class. * *

* the map is keyed by the name of the attribute and * the value is the string value of the attribute. * * the map returned by this method is live, and you can add new attribute * by updating the map directly. Because of this design, there's no setter. * * * @return * always non-null */ public Map getOtherAttributes() { return otherAttributes; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof Preferences.Preference)) { return false; } if (this == object) { return true; } final Preferences.Preference that = ((Preferences.Preference) object); { String lhsValue; lhsValue = this.getValue(); String rhsValue; rhsValue = that.getValue(); if (!strategy.equals( LocatorUtils.property(thisLocator, "value", lhsValue), LocatorUtils.property(thatLocator, "value", rhsValue), lhsValue, rhsValue)) { return false; } } { String lhsType; lhsType = this.getType(); String rhsType; rhsType = that.getType(); if (!strategy.equals( LocatorUtils.property(thisLocator, "type", lhsType), LocatorUtils.property(thatLocator, "type", rhsType), lhsType, rhsType)) { return false; } } { DataQualityTypeList lhsDataQualityType; lhsDataQualityType = this.getDataQualityType(); DataQualityTypeList rhsDataQualityType; rhsDataQualityType = that.getDataQualityType(); if (!strategy.equals(LocatorUtils.property(thisLocator, "dataQualityType", lhsDataQualityType), LocatorUtils .property(thatLocator, "dataQualityType", rhsDataQualityType), lhsDataQualityType, rhsDataQualityType)) { return false; } } { XMLGregorianCalendar lhsValidFrom; lhsValidFrom = this.getValidFrom(); XMLGregorianCalendar rhsValidFrom; rhsValidFrom = that.getValidFrom(); if (!strategy.equals(LocatorUtils.property(thisLocator, "validFrom", lhsValidFrom), LocatorUtils.property( thatLocator, "validFrom", rhsValidFrom), lhsValidFrom, rhsValidFrom)) { return false; } } { XMLGregorianCalendar lhsValidTo; lhsValidTo = this.getValidTo(); XMLGregorianCalendar rhsValidTo; rhsValidTo = that.getValidTo(); if (!strategy.equals(LocatorUtils.property(thisLocator, "validTo", lhsValidTo), LocatorUtils.property( thatLocator, "validTo", rhsValidTo), lhsValidTo, rhsValidTo)) { return false; } } return true; } public boolean equals(Object object) { final EqualsStrategy strategy = JAXBEqualsStrategy.INSTANCE; return equals(null, null, object, strategy); } public int hashCode(ObjectLocator locator, HashCodeStrategy strategy) { int currentHashCode = 1; { String theValue; theValue = this.getValue(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "value", theValue), currentHashCode, theValue); } { String theType; theType = this.getType(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "type", theType), currentHashCode, theType); } { DataQualityTypeList theDataQualityType; theDataQualityType = this.getDataQualityType(); currentHashCode = strategy.hashCode(LocatorUtils.property( locator, "dataQualityType", theDataQualityType), currentHashCode, theDataQualityType); } { XMLGregorianCalendar theValidFrom; theValidFrom = this.getValidFrom(); currentHashCode = strategy.hashCode(LocatorUtils.property( locator, "validFrom", theValidFrom), currentHashCode, theValidFrom); } { XMLGregorianCalendar theValidTo; theValidTo = this.getValidTo(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "validTo", theValidTo), currentHashCode, theValidTo); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public Preferences.Preference withValue(String value) { setValue(value); return this; } public Preferences.Preference withType(String value) { setType(value); return this; } public Preferences.Preference withDataQualityType( DataQualityTypeList value) { setDataQualityType(value); return this; } public Preferences.Preference withValidFrom(XMLGregorianCalendar value) { setValidFrom(value); return this; } public Preferences.Preference withValidTo(XMLGregorianCalendar value) { setValidTo(value); return this; } public String toString() { final ToStringStrategy strategy = JAXBToStringStrategy.INSTANCE; final StringBuilder buffer = new StringBuilder(); append(null, buffer, strategy); return buffer.toString(); } public StringBuilder append(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) { strategy.appendStart(locator, this, buffer); appendFields(locator, buffer, strategy); strategy.appendEnd(locator, this, buffer); return buffer; } public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) { { String theValue; theValue = this.getValue(); strategy.appendField(locator, this, "value", buffer, theValue); } { String theType; theType = this.getType(); strategy.appendField(locator, this, "type", buffer, theType); } { DataQualityTypeList theDataQualityType; theDataQualityType = this.getDataQualityType(); strategy.appendField(locator, this, "dataQualityType", buffer, theDataQualityType); } { XMLGregorianCalendar theValidFrom; theValidFrom = this.getValidFrom(); strategy.appendField(locator, this, "validFrom", buffer, theValidFrom); } { XMLGregorianCalendar theValidTo; theValidTo = this.getValidTo(); strategy.appendField(locator, this, "validTo", buffer, theValidTo); } return buffer; } } /** * Returns A Document representation of this instance that is not formatted. * * @return The Document representation for this instance. */ public org.w3c.dom.Document toDocument() { return toDocument(false); } /** * Returns A Document representation for this instance. * * @param prettyPrint * True for pretty print, otherwise false * * @return The Document representation for this instance. */ public org.w3c.dom.Document toDocument(boolean prettyPrint) { return DocumentUtilities.toDocument(toJAXBElement(), prettyPrint); } /** * Returns JAXBElement for this instance. * * @return The JAXBElement for this instance. */ @SuppressWarnings({ "rawtypes", "unchecked" }) public JAXBElement toJAXBElement() { QName qualifiedName = STIXSchema.getQualifiedName(this); return new JAXBElement(qualifiedName, Preferences.class, this); } /** * Returns String representation of this instance that is not formatted. * * @return The String containing the XML mark-up. */ public String toXMLString() { return toXMLString(false); } /** * Returns XML String for JAXB Document Object Model object. * * @param prettyPrint * True for pretty print, otherwise false * * @return The String containing the XML mark-up. */ public String toXMLString(boolean prettyPrint) { return DocumentUtilities.toXMLString(toDocument(), prettyPrint); } /** * Creates Preferences instance for XML String * * @param text * XML String for the document * @return The Preferences instance for the passed XML String */ public static Preferences fromXMLString(String text) { JAXBContext jaxbContext; try { jaxbContext = JAXBContext.newInstance(Preferences.class .getPackage().getName()); Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); unmarshaller.setSchema(STIXSchema.getInstance().getSchema()); unmarshaller.setEventHandler(new ValidationEventHandler()); StreamSource streamSource = new StreamSource(new StringReader(text)); return (Preferences) unmarshaller.unmarshal(streamSource); } catch (JAXBException e) { throw new RuntimeException(e); } } /** * Validates the XML representation of this Preferences instance * Returning true indicating a successful validation, false if not. * * @return boolean */ public boolean validate() { return STIXSchema.getInstance().validate(toXMLString()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy