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

org.mitre.cybox.objects.WindowsVolume 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 org.mitre.cybox.objects;

import java.io.StringReader;
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.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
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.cybox.common_2.CustomPropertiesType;
import org.mitre.cybox.common_2.DateTimeObjectPropertyType;
import org.mitre.cybox.common_2.PositiveIntegerObjectPropertyType;
import org.mitre.cybox.common_2.StringObjectPropertyType;
import org.mitre.cybox.common_2.UnsignedIntegerObjectPropertyType;
import org.mitre.cybox.common_2.UnsignedLongObjectPropertyType;
import org.mitre.stix.DocumentUtilities;
import org.mitre.stix.STIXSchema;
import org.mitre.stix.ValidationEventHandler;
import org.xml.sax.SAXException;

/**
 * The WindowsVolumeObjectType type is intended to characterize Windows disk volumes.
 * 
 * 

Java class for WindowsVolumeObjectType complex type. * *

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

 * <complexType name="WindowsVolumeObjectType">
 *   <complexContent>
 *     <extension base="{http://cybox.mitre.org/objects#VolumeObject-2}VolumeObjectType">
 *       <sequence>
 *         <element name="Attributes_List" type="{http://cybox.mitre.org/objects#WinVolumeObject-2}WindowsVolumeAttributesListType" minOccurs="0"/>
 *         <element name="Drive_Letter" type="{http://cybox.mitre.org/common-2}StringObjectPropertyType" minOccurs="0"/>
 *         <element name="Drive_Type" type="{http://cybox.mitre.org/objects#WinVolumeObject-2}WindowsDriveType" minOccurs="0"/>
 *       </sequence>
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "WindowsVolumeObjectType", namespace = "http://cybox.mitre.org/objects#WinVolumeObject-2", propOrder = { "attributesList", "driveLetter", "driveType" }) @XmlRootElement(name = "Windows_Volume", namespace = "http://cybox.mitre.org/objects#WinVolumeObject-2") public class WindowsVolume extends VolumeObjectType implements Equals, HashCode, ToString { @XmlElement(name = "Attributes_List") protected WindowsVolumeAttributesListType attributesList; @XmlElement(name = "Drive_Letter") protected StringObjectPropertyType driveLetter; @XmlElement(name = "Drive_Type") protected WindowsDriveType driveType; /** * Default no-arg constructor * */ public WindowsVolume() { super(); } /** * Fully-initialising value constructor * */ public WindowsVolume( final CustomPropertiesType customProperties, final QName objectReference, final StringObjectPropertyType name, final StringObjectPropertyType devicePath, final StringObjectPropertyType fileSystemType, final UnsignedLongObjectPropertyType totalAllocationUnits, final UnsignedIntegerObjectPropertyType sectorsPerAllocationUnit, final PositiveIntegerObjectPropertyType bytesPerSector, final UnsignedLongObjectPropertyType actualAvailableAllocationUnits, final DateTimeObjectPropertyType creationTime, final FileSystemFlagListType fileSystemFlagList, final StringObjectPropertyType serialNumber, final Boolean isMounted, final WindowsVolumeAttributesListType attributesList, final StringObjectPropertyType driveLetter, final WindowsDriveType driveType) { super(customProperties, objectReference, name, devicePath, fileSystemType, totalAllocationUnits, sectorsPerAllocationUnit, bytesPerSector, actualAvailableAllocationUnits, creationTime, fileSystemFlagList, serialNumber, isMounted); this.attributesList = attributesList; this.driveLetter = driveLetter; this.driveType = driveType; } /** * Gets the value of the attributesList property. * * @return * possible object is * {@link WindowsVolumeAttributesListType } * */ public WindowsVolumeAttributesListType getAttributesList() { return attributesList; } /** * Sets the value of the attributesList property. * * @param value * allowed object is * {@link WindowsVolumeAttributesListType } * */ public void setAttributesList(WindowsVolumeAttributesListType value) { this.attributesList = value; } /** * Gets the value of the driveLetter property. * * @return * possible object is * {@link StringObjectPropertyType } * */ public StringObjectPropertyType getDriveLetter() { return driveLetter; } /** * Sets the value of the driveLetter property. * * @param value * allowed object is * {@link StringObjectPropertyType } * */ public void setDriveLetter(StringObjectPropertyType value) { this.driveLetter = value; } /** * Gets the value of the driveType property. * * @return * possible object is * {@link WindowsDriveType } * */ public WindowsDriveType getDriveType() { return driveType; } /** * Sets the value of the driveType property. * * @param value * allowed object is * {@link WindowsDriveType } * */ public void setDriveType(WindowsDriveType value) { this.driveType = value; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof WindowsVolume)) { return false; } if (this == object) { return true; } if (!super.equals(thisLocator, thatLocator, object, strategy)) { return false; } final WindowsVolume that = ((WindowsVolume) object); { WindowsVolumeAttributesListType lhsAttributesList; lhsAttributesList = this.getAttributesList(); WindowsVolumeAttributesListType rhsAttributesList; rhsAttributesList = that.getAttributesList(); if (!strategy.equals(LocatorUtils.property(thisLocator, "attributesList", lhsAttributesList), LocatorUtils.property(thatLocator, "attributesList", rhsAttributesList), lhsAttributesList, rhsAttributesList)) { return false; } } { StringObjectPropertyType lhsDriveLetter; lhsDriveLetter = this.getDriveLetter(); StringObjectPropertyType rhsDriveLetter; rhsDriveLetter = that.getDriveLetter(); if (!strategy.equals(LocatorUtils.property(thisLocator, "driveLetter", lhsDriveLetter), LocatorUtils.property( thatLocator, "driveLetter", rhsDriveLetter), lhsDriveLetter, rhsDriveLetter)) { return false; } } { WindowsDriveType lhsDriveType; lhsDriveType = this.getDriveType(); WindowsDriveType rhsDriveType; rhsDriveType = that.getDriveType(); if (!strategy.equals(LocatorUtils.property(thisLocator, "driveType", lhsDriveType), LocatorUtils.property( thatLocator, "driveType", rhsDriveType), lhsDriveType, rhsDriveType)) { 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 = super.hashCode(locator, strategy); { WindowsVolumeAttributesListType theAttributesList; theAttributesList = this.getAttributesList(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "attributesList", theAttributesList), currentHashCode, theAttributesList); } { StringObjectPropertyType theDriveLetter; theDriveLetter = this.getDriveLetter(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "driveLetter", theDriveLetter), currentHashCode, theDriveLetter); } { WindowsDriveType theDriveType; theDriveType = this.getDriveType(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "driveType", theDriveType), currentHashCode, theDriveType); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public WindowsVolume withAttributesList( WindowsVolumeAttributesListType value) { setAttributesList(value); return this; } public WindowsVolume withDriveLetter(StringObjectPropertyType value) { setDriveLetter(value); return this; } public WindowsVolume withDriveType(WindowsDriveType value) { setDriveType(value); return this; } @Override public WindowsVolume withName(StringObjectPropertyType value) { setName(value); return this; } @Override public WindowsVolume withDevicePath(StringObjectPropertyType value) { setDevicePath(value); return this; } @Override public WindowsVolume withFileSystemType(StringObjectPropertyType value) { setFileSystemType(value); return this; } @Override public WindowsVolume withTotalAllocationUnits( UnsignedLongObjectPropertyType value) { setTotalAllocationUnits(value); return this; } @Override public WindowsVolume withSectorsPerAllocationUnit( UnsignedIntegerObjectPropertyType value) { setSectorsPerAllocationUnit(value); return this; } @Override public WindowsVolume withBytesPerSector( PositiveIntegerObjectPropertyType value) { setBytesPerSector(value); return this; } @Override public WindowsVolume withActualAvailableAllocationUnits( UnsignedLongObjectPropertyType value) { setActualAvailableAllocationUnits(value); return this; } @Override public WindowsVolume withCreationTime(DateTimeObjectPropertyType value) { setCreationTime(value); return this; } @Override public WindowsVolume withFileSystemFlagList(FileSystemFlagListType value) { setFileSystemFlagList(value); return this; } @Override public WindowsVolume withSerialNumber(StringObjectPropertyType value) { setSerialNumber(value); return this; } @Override public WindowsVolume withIsMounted(Boolean value) { setIsMounted(value); return this; } @Override public WindowsVolume withCustomProperties(CustomPropertiesType value) { setCustomProperties(value); return this; } @Override public WindowsVolume withObjectReference(QName value) { setObjectReference(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) { super.appendFields(locator, buffer, strategy); { WindowsVolumeAttributesListType theAttributesList; theAttributesList = this.getAttributesList(); strategy.appendField(locator, this, "attributesList", buffer, theAttributesList); } { StringObjectPropertyType theDriveLetter; theDriveLetter = this.getDriveLetter(); strategy.appendField(locator, this, "driveLetter", buffer, theDriveLetter); } { WindowsDriveType theDriveType; theDriveType = this.getDriveType(); strategy.appendField(locator, this, "driveType", buffer, theDriveType); } 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, WindowsVolume.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 WindowsVolume instance for XML String * * @param text * XML String for the document * @return The WindowsVolume instance for the passed XML String */ public static WindowsVolume fromXMLString(String text) { JAXBContext jaxbContext; try { jaxbContext = JAXBContext.newInstance(WindowsVolume.class .getPackage().getName()); Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); unmarshaller.setSchema(STIXSchema.getInstance().getSchema()); unmarshaller.setEventHandler(new ValidationEventHandler()); StreamSource streamSource = new StreamSource(new StringReader(text)); return (WindowsVolume) unmarshaller.unmarshal(streamSource); } catch (JAXBException e) { throw new RuntimeException(e); } } /** * Validates the XML representation of this WindowsVolume 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