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

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

import java.io.StringReader;
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.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.SIDType;
import org.mitre.cybox.common_2.StringObjectPropertyType;
import org.mitre.stix.DocumentUtilities;
import org.mitre.stix.STIXSchema;
import org.mitre.stix.ValidationEventHandler;

/**
 * The WinComputerAccountObject type is intended to characterize Windows computer accounts.
 * 
 * 

Java class for WindowsComputerAccountObjectType complex type. * *

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

 * <complexType name="WindowsComputerAccountObjectType">
 *   <complexContent>
 *     <extension base="{http://cybox.mitre.org/objects#AccountObject-2}AccountObjectType">
 *       <sequence>
 *         <element name="Fully_Qualified_Name" type="{http://cybox.mitre.org/objects#WinComputerAccountObject-2}FullyQualifiedNameType" minOccurs="0"/>
 *         <element name="Kerberos" type="{http://cybox.mitre.org/objects#WinComputerAccountObject-2}KerberosType" minOccurs="0"/>
 *         <element name="Security_ID" type="{http://cybox.mitre.org/common-2}StringObjectPropertyType" minOccurs="0"/>
 *         <element name="Security_Type" type="{http://cybox.mitre.org/common-2}SIDType" minOccurs="0"/>
 *         <element name="Type" type="{http://cybox.mitre.org/common-2}StringObjectPropertyType" minOccurs="0"/>
 *       </sequence>
 *     </extension>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "WindowsComputerAccountObjectType", namespace = "http://cybox.mitre.org/objects#WinComputerAccountObject-2", propOrder = { "fullyQualifiedName", "kerberos", "securityID", "securityType", "type" }) @XmlRootElement(name = "Windows_Computer_Account", namespace = "http://cybox.mitre.org/objects#WinComputerAccountObject-2") public class WindowsComputerAccount extends AccountObjectType implements Equals, HashCode, ToString { @XmlElement(name = "Fully_Qualified_Name") protected FullyQualifiedNameType fullyQualifiedName; @XmlElement(name = "Kerberos") protected KerberosType kerberos; @XmlElement(name = "Security_ID") protected StringObjectPropertyType securityID; @XmlElement(name = "Security_Type") protected SIDType securityType; @XmlElement(name = "Type") protected StringObjectPropertyType type; /** * Default no-arg constructor * */ public WindowsComputerAccount() { super(); } /** * Fully-initialising value constructor * */ public WindowsComputerAccount(final CustomPropertiesType customProperties, final QName objectReference, final StringObjectPropertyType description, final StringObjectPropertyType domain, final List authentications, final DateTimeObjectPropertyType creationDate, final DateTimeObjectPropertyType modifiedDate, final DateTimeObjectPropertyType lastAccessedTime, final Boolean disabled, final Boolean lockedOut, final FullyQualifiedNameType fullyQualifiedName, final KerberosType kerberos, final StringObjectPropertyType securityID, final SIDType securityType, final StringObjectPropertyType type) { super(customProperties, objectReference, description, domain, authentications, creationDate, modifiedDate, lastAccessedTime, disabled, lockedOut); this.fullyQualifiedName = fullyQualifiedName; this.kerberos = kerberos; this.securityID = securityID; this.securityType = securityType; this.type = type; } /** * Gets the value of the fullyQualifiedName property. * * @return * possible object is * {@link FullyQualifiedNameType } * */ public FullyQualifiedNameType getFullyQualifiedName() { return fullyQualifiedName; } /** * Sets the value of the fullyQualifiedName property. * * @param value * allowed object is * {@link FullyQualifiedNameType } * */ public void setFullyQualifiedName(FullyQualifiedNameType value) { this.fullyQualifiedName = value; } /** * Gets the value of the kerberos property. * * @return * possible object is * {@link KerberosType } * */ public KerberosType getKerberos() { return kerberos; } /** * Sets the value of the kerberos property. * * @param value * allowed object is * {@link KerberosType } * */ public void setKerberos(KerberosType value) { this.kerberos = value; } /** * Gets the value of the securityID property. * * @return * possible object is * {@link StringObjectPropertyType } * */ public StringObjectPropertyType getSecurityID() { return securityID; } /** * Sets the value of the securityID property. * * @param value * allowed object is * {@link StringObjectPropertyType } * */ public void setSecurityID(StringObjectPropertyType value) { this.securityID = value; } /** * Gets the value of the securityType property. * * @return * possible object is * {@link SIDType } * */ public SIDType getSecurityType() { return securityType; } /** * Sets the value of the securityType property. * * @param value * allowed object is * {@link SIDType } * */ public void setSecurityType(SIDType value) { this.securityType = value; } /** * Gets the value of the type property. * * @return * possible object is * {@link StringObjectPropertyType } * */ public StringObjectPropertyType getType() { return type; } /** * Sets the value of the type property. * * @param value * allowed object is * {@link StringObjectPropertyType } * */ public void setType(StringObjectPropertyType value) { this.type = value; } public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator, Object object, EqualsStrategy strategy) { if (!(object instanceof WindowsComputerAccount)) { return false; } if (this == object) { return true; } if (!super.equals(thisLocator, thatLocator, object, strategy)) { return false; } final WindowsComputerAccount that = ((WindowsComputerAccount) object); { FullyQualifiedNameType lhsFullyQualifiedName; lhsFullyQualifiedName = this.getFullyQualifiedName(); FullyQualifiedNameType rhsFullyQualifiedName; rhsFullyQualifiedName = that.getFullyQualifiedName(); if (!strategy.equals(LocatorUtils.property(thisLocator, "fullyQualifiedName", lhsFullyQualifiedName), LocatorUtils .property(thatLocator, "fullyQualifiedName", rhsFullyQualifiedName), lhsFullyQualifiedName, rhsFullyQualifiedName)) { return false; } } { KerberosType lhsKerberos; lhsKerberos = this.getKerberos(); KerberosType rhsKerberos; rhsKerberos = that.getKerberos(); if (!strategy .equals(LocatorUtils.property(thisLocator, "kerberos", lhsKerberos), LocatorUtils.property(thatLocator, "kerberos", rhsKerberos), lhsKerberos, rhsKerberos)) { return false; } } { StringObjectPropertyType lhsSecurityID; lhsSecurityID = this.getSecurityID(); StringObjectPropertyType rhsSecurityID; rhsSecurityID = that.getSecurityID(); if (!strategy.equals(LocatorUtils.property(thisLocator, "securityID", lhsSecurityID), LocatorUtils.property( thatLocator, "securityID", rhsSecurityID), lhsSecurityID, rhsSecurityID)) { return false; } } { SIDType lhsSecurityType; lhsSecurityType = this.getSecurityType(); SIDType rhsSecurityType; rhsSecurityType = that.getSecurityType(); if (!strategy.equals(LocatorUtils.property(thisLocator, "securityType", lhsSecurityType), LocatorUtils.property( thatLocator, "securityType", rhsSecurityType), lhsSecurityType, rhsSecurityType)) { return false; } } { StringObjectPropertyType lhsType; lhsType = this.getType(); StringObjectPropertyType rhsType; rhsType = that.getType(); if (!strategy.equals( LocatorUtils.property(thisLocator, "type", lhsType), LocatorUtils.property(thatLocator, "type", rhsType), lhsType, rhsType)) { 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); { FullyQualifiedNameType theFullyQualifiedName; theFullyQualifiedName = this.getFullyQualifiedName(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "fullyQualifiedName", theFullyQualifiedName), currentHashCode, theFullyQualifiedName); } { KerberosType theKerberos; theKerberos = this.getKerberos(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "kerberos", theKerberos), currentHashCode, theKerberos); } { StringObjectPropertyType theSecurityID; theSecurityID = this.getSecurityID(); currentHashCode = strategy .hashCode(LocatorUtils.property(locator, "securityID", theSecurityID), currentHashCode, theSecurityID); } { SIDType theSecurityType; theSecurityType = this.getSecurityType(); currentHashCode = strategy.hashCode(LocatorUtils.property(locator, "securityType", theSecurityType), currentHashCode, theSecurityType); } { StringObjectPropertyType theType; theType = this.getType(); currentHashCode = strategy.hashCode( LocatorUtils.property(locator, "type", theType), currentHashCode, theType); } return currentHashCode; } public int hashCode() { final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE; return this.hashCode(null, strategy); } public WindowsComputerAccount withFullyQualifiedName( FullyQualifiedNameType value) { setFullyQualifiedName(value); return this; } public WindowsComputerAccount withKerberos(KerberosType value) { setKerberos(value); return this; } public WindowsComputerAccount withSecurityID(StringObjectPropertyType value) { setSecurityID(value); return this; } public WindowsComputerAccount withSecurityType(SIDType value) { setSecurityType(value); return this; } public WindowsComputerAccount withType(StringObjectPropertyType value) { setType(value); return this; } @Override public WindowsComputerAccount withDescription(StringObjectPropertyType value) { setDescription(value); return this; } @Override public WindowsComputerAccount withDomain(StringObjectPropertyType value) { setDomain(value); return this; } @Override public WindowsComputerAccount withAuthentications( AuthenticationType... values) { if (values != null) { for (AuthenticationType value : values) { getAuthentications().add(value); } } return this; } @Override public WindowsComputerAccount withAuthentications( Collection values) { if (values != null) { getAuthentications().addAll(values); } return this; } @Override public WindowsComputerAccount withCreationDate( DateTimeObjectPropertyType value) { setCreationDate(value); return this; } @Override public WindowsComputerAccount withModifiedDate( DateTimeObjectPropertyType value) { setModifiedDate(value); return this; } @Override public WindowsComputerAccount withLastAccessedTime( DateTimeObjectPropertyType value) { setLastAccessedTime(value); return this; } @Override public WindowsComputerAccount withDisabled(Boolean value) { setDisabled(value); return this; } @Override public WindowsComputerAccount withLockedOut(Boolean value) { setLockedOut(value); return this; } @Override public WindowsComputerAccount withCustomProperties( CustomPropertiesType value) { setCustomProperties(value); return this; } @Override public WindowsComputerAccount 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); { FullyQualifiedNameType theFullyQualifiedName; theFullyQualifiedName = this.getFullyQualifiedName(); strategy.appendField(locator, this, "fullyQualifiedName", buffer, theFullyQualifiedName); } { KerberosType theKerberos; theKerberos = this.getKerberos(); strategy.appendField(locator, this, "kerberos", buffer, theKerberos); } { StringObjectPropertyType theSecurityID; theSecurityID = this.getSecurityID(); strategy.appendField(locator, this, "securityID", buffer, theSecurityID); } { SIDType theSecurityType; theSecurityType = this.getSecurityType(); strategy.appendField(locator, this, "securityType", buffer, theSecurityType); } { StringObjectPropertyType theType; theType = this.getType(); strategy.appendField(locator, this, "type", buffer, theType); } 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, WindowsComputerAccount.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 WindowsComputerAccount instance for XML String * * @param text * XML String for the document * @return The WindowsComputerAccount instance for the passed XML String */ public static WindowsComputerAccount fromXMLString(String text) { JAXBContext jaxbContext; try { jaxbContext = JAXBContext.newInstance(WindowsComputerAccount.class .getPackage().getName()); Unmarshaller unmarshaller = jaxbContext.createUnmarshaller(); unmarshaller.setSchema(STIXSchema.getInstance().getSchema()); unmarshaller.setEventHandler(new ValidationEventHandler()); StreamSource streamSource = new StreamSource(new StringReader(text)); return (WindowsComputerAccount) unmarshaller .unmarshal(streamSource); } catch (JAXBException e) { throw new RuntimeException(e); } } /** * Validates the XML representation of this WindowsComputerAccount instance * Returning true indicating a successful validation, false if not. * * @return boolean */ public boolean validate() { return STIXSchema.getInstance().validate(toXMLString()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy