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

com.mandiant.schemas._2010.ioc.IocIndicator Maven / Gradle / Ivy

The 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.07.01 at 03:19:53 PM EDT 
//

package com.mandiant.schemas._2010.ioc;

import com.mandiant.schemas._2010.ioc.tr.Param;
import java.io.StringReader;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
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.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
import javax.xml.namespace.QName;
import javax.xml.transform.stream.StreamSource;
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;
import org.xml.sax.SAXException;

/**
 * 

Java class for IocIndicator complex type. * *

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

 * <complexType name="IocIndicator">
 *   <complexContent>
 *     <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
 *       <sequence>
 *         <element name="IndicatorItem" type="{http://schemas.mandiant.com/2010/ioc}IndicatorItem" maxOccurs="unbounded" minOccurs="0"/>
 *         <element name="Indicator" type="{http://schemas.mandiant.com/2010/ioc}IocIndicator" maxOccurs="unbounded" minOccurs="0"/>
 *         <element ref="{http://schemas.mandiant.com/2010/ioc/TR/}param" maxOccurs="unbounded" minOccurs="0"/>
 *       </sequence>
 *       <attribute name="operator" use="required" type="{http://schemas.mandiant.com/2010/ioc}IocOperator" />
 *       <attribute name="id" type="{http://www.w3.org/2001/XMLSchema}string" />
 *     </restriction>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "IocIndicator", propOrder = { "indicatorItems", "indicators", "params" }) public class IocIndicator implements Equals, HashCode, ToString { @XmlElement(name = "IndicatorItem") protected List indicatorItems; @XmlElement(name = "Indicator") protected List indicators; @XmlElement(name = "param", namespace = "http://schemas.mandiant.com/2010/ioc/TR/") protected List params; @XmlAttribute(name = "operator", required = true) protected IocOperator operator; @XmlAttribute(name = "id") protected String id; /** * Default no-arg constructor * */ public IocIndicator() { super(); } /** * Fully-initialising value constructor * */ public IocIndicator(final List indicatorItems, final List indicators, final List params, final IocOperator operator, final String id) { this.indicatorItems = indicatorItems; this.indicators = indicators; this.params = params; this.operator = operator; this.id = id; } /** * Gets the value of the indicatorItems 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 indicatorItems property. * *

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

	 *    getIndicatorItems().add(newItem);
	 * 
* * *

* Objects of the following type(s) are allowed in the list * {@link IndicatorItem } * * */ public List getIndicatorItems() { if (indicatorItems == null) { indicatorItems = new ArrayList(); } return this.indicatorItems; } /** * Gets the value of the indicators 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 indicators property. * *

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

	 *    getIndicators().add(newItem);
	 * 
* * *

* Objects of the following type(s) are allowed in the list * {@link IocIndicator } * * */ public List getIndicators() { if (indicators == null) { indicators = new ArrayList(); } return this.indicators; } /** * Gets the value of the params 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 params property. * *

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

	 *    getParams().add(newItem);
	 * 
* * *

* Objects of the following type(s) are allowed in the list * {@link Param } * * */ public List getParams() { if (params == null) { params = new ArrayList(); } return this.params; } /** * Gets the value of the operator property. * * @return * possible object is * {@link IocOperator } * */ public IocOperator getOperator() { return operator; } /** * Sets the value of the operator property. * * @param value * allowed object is * {@link IocOperator } * */ public void setOperator(IocOperator value) { this.operator = value; } /** * Gets the value of the id property. * * @return * possible object is * {@link String } * */ public String getId() { return id; } /** * Sets the value of the id property. * * @param value * allowed object is * {@link String } * */ public void setId(String value) { this.id = value; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof IocIndicator)) { return false; } if (this == object) { return true; } final IocIndicator that = ((IocIndicator) object); { List lhsIndicatorItems; lhsIndicatorItems = (((this.indicatorItems != null) && (!this.indicatorItems .isEmpty())) ? this.getIndicatorItems() : null); List rhsIndicatorItems; rhsIndicatorItems = (((that.indicatorItems != null) && (!that.indicatorItems .isEmpty())) ? that.getIndicatorItems() : null); if (!strategy.equals(LocatorUtils.property(thisLocator, "indicatorItems", lhsIndicatorItems), LocatorUtils.property(thatLocator, "indicatorItems", rhsIndicatorItems), lhsIndicatorItems, rhsIndicatorItems)) { return false; } } { List lhsIndicators; lhsIndicators = (((this.indicators != null) && (!this.indicators .isEmpty())) ? this.getIndicators() : null); List rhsIndicators; rhsIndicators = (((that.indicators != null) && (!that.indicators .isEmpty())) ? that.getIndicators() : null); if (!strategy.equals(LocatorUtils.property(thisLocator, "indicators", lhsIndicators), LocatorUtils.property( thatLocator, "indicators", rhsIndicators), lhsIndicators, rhsIndicators)) { return false; } } { List lhsParams; lhsParams = (((this.params != null) && (!this.params.isEmpty())) ? this .getParams() : null); List rhsParams; rhsParams = (((that.params != null) && (!that.params.isEmpty())) ? that .getParams() : null); if (!strategy.equals( LocatorUtils.property(thisLocator, "params", lhsParams), LocatorUtils.property(thatLocator, "params", rhsParams), lhsParams, rhsParams)) { return false; } } { IocOperator lhsOperator; lhsOperator = this.getOperator(); IocOperator rhsOperator; rhsOperator = that.getOperator(); if (!strategy .equals(LocatorUtils.property(thisLocator, "operator", lhsOperator), LocatorUtils.property(thatLocator, "operator", rhsOperator), lhsOperator, rhsOperator)) { return false; } } { String lhsId; lhsId = this.getId(); String rhsId; rhsId = that.getId(); if (!strategy.equals( LocatorUtils.property(thisLocator, "id", lhsId), LocatorUtils.property(thatLocator, "id", rhsId), lhsId, rhsId)) { 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 theIndicatorItems; theIndicatorItems = (((this.indicatorItems != null) && (!this.indicatorItems .isEmpty())) ? this.getIndicatorItems() : null); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "indicatorItems", theIndicatorItems), currentHashCode, theIndicatorItems); } { List theIndicators; theIndicators = (((this.indicators != null) && (!this.indicators .isEmpty())) ? this.getIndicators() : null); currentHashCode = strategy .hashCode(LocatorUtils.property(locator, "indicators", theIndicators), currentHashCode, theIndicators); } { List theParams; theParams = (((this.params != null) && (!this.params.isEmpty())) ? this .getParams() : null); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "params", theParams), currentHashCode, theParams); } { IocOperator theOperator; theOperator = this.getOperator(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "operator", theOperator), currentHashCode, theOperator); } { String theId; theId = this.getId(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "id", theId), currentHashCode, theId); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public IocIndicator withIndicatorItems(IndicatorItem... values) { if (values != null) { for (IndicatorItem value : values) { getIndicatorItems().add(value); } } return this; } public IocIndicator withIndicatorItems(Collection values) { if (values != null) { getIndicatorItems().addAll(values); } return this; } public IocIndicator withIndicators(IocIndicator... values) { if (values != null) { for (IocIndicator value : values) { getIndicators().add(value); } } return this; } public IocIndicator withIndicators(Collection values) { if (values != null) { getIndicators().addAll(values); } return this; } public IocIndicator withParams(Param... values) { if (values != null) { for (Param value : values) { getParams().add(value); } } return this; } public IocIndicator withParams(Collection values) { if (values != null) { getParams().addAll(values); } return this; } public IocIndicator withOperator(IocOperator value) { setOperator(value); return this; } public IocIndicator withId(String value) { setId(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) { { List theIndicatorItems; theIndicatorItems = (((this.indicatorItems != null) && (!this.indicatorItems .isEmpty())) ? this.getIndicatorItems() : null); strategy.appendField(locator, this, "indicatorItems", buffer, theIndicatorItems); } { List theIndicators; theIndicators = (((this.indicators != null) && (!this.indicators .isEmpty())) ? this.getIndicators() : null); strategy.appendField(locator, this, "indicators", buffer, theIndicators); } { List theParams; theParams = (((this.params != null) && (!this.params.isEmpty())) ? this .getParams() : null); strategy.appendField(locator, this, "params", buffer, theParams); } { IocOperator theOperator; theOperator = this.getOperator(); strategy.appendField(locator, this, "operator", buffer, theOperator); } { String theId; theId = this.getId(); strategy.appendField(locator, this, "id", buffer, theId); } 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, IocIndicator.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 IocIndicator instance for XML String * * @param text * XML String for the document * @return The IocIndicator instance for the passed XML String */ public static IocIndicator fromXMLString(String text) { JAXBContext jaxbContext; try { jaxbContext = JAXBContext.newInstance(IocIndicator.class .getPackage().getName()); Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); unmarshaller.setSchema(STIXSchema.getInstance().getSchema()); unmarshaller.setEventHandler(new ValidationEventHandler()); StreamSource streamSource = new StreamSource(new StringReader(text)); return (IocIndicator) unmarshaller.unmarshal(streamSource); } catch (JAXBException e) { throw new RuntimeException(e); } } /** * Validates the XML representation of this IocIndicator instance * Returning true indicating a successful validation, false if not. * * @return boolean True If it validates against the schema * @throws SAXException * If the a validation ErrorHandler has not been set, and * validation throws a SAXException */ public boolean validate() throws SAXException { return STIXSchema.getInstance().validate(toXMLString()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy