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

org.mitre.cybox.objects.WindowsHook 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.NonNegativeIntegerObjectPropertyType;
import org.mitre.cybox.common_2.ObjectPropertiesType;
import org.mitre.cybox.common_2.StringObjectPropertyType;
import org.mitre.stix.DocumentUtilities;
import org.mitre.stix.STIXSchema;
import org.mitre.stix.ValidationEventHandler;
import org.xml.sax.SAXException;

/**
 * For more information please see http://msdn.microsoft.com/en-us/library/windows/desktop/ms644990(v=vs.85).aspx.
 * 
 * 

Java class for WindowsHookObjectType complex type. * *

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

 * <complexType name="WindowsHookObjectType">
 *   <complexContent>
 *     <extension base="{http://cybox.mitre.org/common-2}ObjectPropertiesType">
 *       <sequence>
 *         <element name="Type" type="{http://cybox.mitre.org/objects#WinHookObject-1}WinHookType" minOccurs="0"/>
 *         <element name="Handle" type="{http://cybox.mitre.org/objects#WinHandleObject-2}WindowsHandleObjectType" minOccurs="0"/>
 *         <element name="Hooking_Function_Name" type="{http://cybox.mitre.org/common-2}StringObjectPropertyType" minOccurs="0"/>
 *         <element name="Hooking_Module" type="{http://cybox.mitre.org/objects#LibraryObject-2}LibraryObjectType" minOccurs="0"/>
 *         <element name="Thread_ID" type="{http://cybox.mitre.org/common-2}NonNegativeIntegerObjectPropertyType" minOccurs="0"/>
 *       </sequence>
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "WindowsHookObjectType", namespace = "http://cybox.mitre.org/objects#WinHookObject-1", propOrder = { "type", "handle", "hookingFunctionName", "hookingModule", "threadID" }) @XmlRootElement(name = "Windows_Hook", namespace = "http://cybox.mitre.org/objects#WinHookObject-1") public class WindowsHook extends ObjectPropertiesType implements Equals, HashCode, ToString { @XmlElement(name = "Type") protected WinHookType type; @XmlElement(name = "Handle") protected WindowsHandle handle; @XmlElement(name = "Hooking_Function_Name") protected StringObjectPropertyType hookingFunctionName; @XmlElement(name = "Hooking_Module") protected Library hookingModule; @XmlElement(name = "Thread_ID") protected NonNegativeIntegerObjectPropertyType threadID; /** * Default no-arg constructor * */ public WindowsHook() { super(); } /** * Fully-initialising value constructor * */ public WindowsHook(final CustomPropertiesType customProperties, final QName objectReference, final WinHookType type, final WindowsHandle handle, final StringObjectPropertyType hookingFunctionName, final Library hookingModule, final NonNegativeIntegerObjectPropertyType threadID) { super(customProperties, objectReference); this.type = type; this.handle = handle; this.hookingFunctionName = hookingFunctionName; this.hookingModule = hookingModule; this.threadID = threadID; } /** * Gets the value of the type property. * * @return * possible object is * {@link WinHookType } * */ public WinHookType getType() { return type; } /** * Sets the value of the type property. * * @param value * allowed object is * {@link WinHookType } * */ public void setType(WinHookType value) { this.type = value; } /** * Gets the value of the handle property. * * @return * possible object is * {@link WindowsHandle } * */ public WindowsHandle getHandle() { return handle; } /** * Sets the value of the handle property. * * @param value * allowed object is * {@link WindowsHandle } * */ public void setHandle(WindowsHandle value) { this.handle = value; } /** * Gets the value of the hookingFunctionName property. * * @return * possible object is * {@link StringObjectPropertyType } * */ public StringObjectPropertyType getHookingFunctionName() { return hookingFunctionName; } /** * Sets the value of the hookingFunctionName property. * * @param value * allowed object is * {@link StringObjectPropertyType } * */ public void setHookingFunctionName(StringObjectPropertyType value) { this.hookingFunctionName = value; } /** * Gets the value of the hookingModule property. * * @return * possible object is * {@link Library } * */ public Library getHookingModule() { return hookingModule; } /** * Sets the value of the hookingModule property. * * @param value * allowed object is * {@link Library } * */ public void setHookingModule(Library value) { this.hookingModule = value; } /** * Gets the value of the threadID property. * * @return * possible object is * {@link NonNegativeIntegerObjectPropertyType } * */ public NonNegativeIntegerObjectPropertyType getThreadID() { return threadID; } /** * Sets the value of the threadID property. * * @param value * allowed object is * {@link NonNegativeIntegerObjectPropertyType } * */ public void setThreadID(NonNegativeIntegerObjectPropertyType value) { this.threadID = value; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof WindowsHook)) { return false; } if (this == object) { return true; } if (!super.equals(thisLocator, thatLocator, object, strategy)) { return false; } final WindowsHook that = ((WindowsHook) object); { WinHookType lhsType; lhsType = this.getType(); WinHookType rhsType; rhsType = that.getType(); if (!strategy.equals( LocatorUtils.property(thisLocator, "type", lhsType), LocatorUtils.property(thatLocator, "type", rhsType), lhsType, rhsType)) { return false; } } { WindowsHandle lhsHandle; lhsHandle = this.getHandle(); WindowsHandle rhsHandle; rhsHandle = that.getHandle(); if (!strategy.equals( LocatorUtils.property(thisLocator, "handle", lhsHandle), LocatorUtils.property(thatLocator, "handle", rhsHandle), lhsHandle, rhsHandle)) { return false; } } { StringObjectPropertyType lhsHookingFunctionName; lhsHookingFunctionName = this.getHookingFunctionName(); StringObjectPropertyType rhsHookingFunctionName; rhsHookingFunctionName = that.getHookingFunctionName(); if (!strategy.equals(LocatorUtils.property(thisLocator, "hookingFunctionName", lhsHookingFunctionName), LocatorUtils.property(thatLocator, "hookingFunctionName", rhsHookingFunctionName), lhsHookingFunctionName, rhsHookingFunctionName)) { return false; } } { Library lhsHookingModule; lhsHookingModule = this.getHookingModule(); Library rhsHookingModule; rhsHookingModule = that.getHookingModule(); if (!strategy.equals(LocatorUtils.property(thisLocator, "hookingModule", lhsHookingModule), LocatorUtils.property( thatLocator, "hookingModule", rhsHookingModule), lhsHookingModule, rhsHookingModule)) { return false; } } { NonNegativeIntegerObjectPropertyType lhsThreadID; lhsThreadID = this.getThreadID(); NonNegativeIntegerObjectPropertyType rhsThreadID; rhsThreadID = that.getThreadID(); if (!strategy .equals(LocatorUtils.property(thisLocator, "threadID", lhsThreadID), LocatorUtils.property(thatLocator, "threadID", rhsThreadID), lhsThreadID, rhsThreadID)) { 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); { WinHookType theType; theType = this.getType(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "type", theType), currentHashCode, theType); } { WindowsHandle theHandle; theHandle = this.getHandle(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "handle", theHandle), currentHashCode, theHandle); } { StringObjectPropertyType theHookingFunctionName; theHookingFunctionName = this.getHookingFunctionName(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "hookingFunctionName", theHookingFunctionName), currentHashCode, theHookingFunctionName); } { Library theHookingModule; theHookingModule = this.getHookingModule(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "hookingModule", theHookingModule), currentHashCode, theHookingModule); } { NonNegativeIntegerObjectPropertyType theThreadID; theThreadID = this.getThreadID(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "threadID", theThreadID), currentHashCode, theThreadID); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public WindowsHook withType(WinHookType value) { setType(value); return this; } public WindowsHook withHandle(WindowsHandle value) { setHandle(value); return this; } public WindowsHook withHookingFunctionName(StringObjectPropertyType value) { setHookingFunctionName(value); return this; } public WindowsHook withHookingModule(Library value) { setHookingModule(value); return this; } public WindowsHook withThreadID(NonNegativeIntegerObjectPropertyType value) { setThreadID(value); return this; } @Override public WindowsHook withCustomProperties(CustomPropertiesType value) { setCustomProperties(value); return this; } @Override public WindowsHook 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); { WinHookType theType; theType = this.getType(); strategy.appendField(locator, this, "type", buffer, theType); } { WindowsHandle theHandle; theHandle = this.getHandle(); strategy.appendField(locator, this, "handle", buffer, theHandle); } { StringObjectPropertyType theHookingFunctionName; theHookingFunctionName = this.getHookingFunctionName(); strategy.appendField(locator, this, "hookingFunctionName", buffer, theHookingFunctionName); } { Library theHookingModule; theHookingModule = this.getHookingModule(); strategy.appendField(locator, this, "hookingModule", buffer, theHookingModule); } { NonNegativeIntegerObjectPropertyType theThreadID; theThreadID = this.getThreadID(); strategy.appendField(locator, this, "threadID", buffer, theThreadID); } 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, WindowsHook.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 WindowsHook instance for XML String * * @param text * XML String for the document * @return The WindowsHook instance for the passed XML String */ public static WindowsHook fromXMLString(String text) { JAXBContext jaxbContext; try { jaxbContext = JAXBContext.newInstance(WindowsHook.class .getPackage().getName()); Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); unmarshaller.setSchema(STIXSchema.getInstance().getSchema()); unmarshaller.setEventHandler(new ValidationEventHandler()); StreamSource streamSource = new StreamSource(new StringReader(text)); return (WindowsHook) unmarshaller.unmarshal(streamSource); } catch (JAXBException e) { throw new RuntimeException(e); } } /** * Validates the XML representation of this WindowsHook 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