org.mitre.cybox.objects.WindowsUserAccount Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of stix Show documentation
Show all versions of stix Show documentation
The Java bindings for STIX v.1.2.0.2
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 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.DurationObjectPropertyType;
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;
import org.xml.sax.SAXException;
/**
* The WinUserAccountObjectType type is intended to characterize Windows user accounts.
*
* Java class for WindowsUserAccountObjectType complex type.
*
*
The following schema fragment specifies the expected content contained within this class.
*
*
* <complexType name="WindowsUserAccountObjectType">
* <complexContent>
* <extension base="{http://cybox.mitre.org/objects#UserAccountObject-2}UserAccountObjectType">
* <sequence>
* <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"/>
* </sequence>
* </extension>
* </complexContent>
* </complexType>
*
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "WindowsUserAccountObjectType", namespace = "http://cybox.mitre.org/objects#WinUserAccountObject-2", propOrder = {
"securityID", "securityType" })
@XmlRootElement(name = "Windows_User_Account", namespace = "http://cybox.mitre.org/objects#WinUserAccountObject-2")
public class WindowsUserAccount extends UserAccountObjectType implements
Equals, HashCode, ToString {
@XmlElement(name = "Security_ID")
protected StringObjectPropertyType securityID;
@XmlElement(name = "Security_Type")
protected SIDType securityType;
/**
* Default no-arg constructor
*
*/
public WindowsUserAccount() {
super();
}
/**
* Fully-initialising value constructor
*
*/
public WindowsUserAccount(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 StringObjectPropertyType fullName,
final GroupListType groupList,
final StringObjectPropertyType homeDirectory,
final DateTimeObjectPropertyType lastLogin,
final PrivilegeListType privilegeList,
final StringObjectPropertyType scriptPath,
final StringObjectPropertyType username,
final DurationObjectPropertyType userPasswordAge,
final Boolean passwordRequired,
final StringObjectPropertyType securityID,
final SIDType securityType) {
super(customProperties, objectReference, description, domain,
authentications, creationDate, modifiedDate, lastAccessedTime,
disabled, lockedOut, fullName, groupList, homeDirectory,
lastLogin, privilegeList, scriptPath, username,
userPasswordAge, passwordRequired);
this.securityID = securityID;
this.securityType = securityType;
}
/**
* 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;
}
public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator,
Object object, EqualsStrategy strategy) {
if (!(object instanceof WindowsUserAccount)) {
return false;
}
if (this == object) {
return true;
}
if (!super.equals(thisLocator, thatLocator, object, strategy)) {
return false;
}
final WindowsUserAccount that = ((WindowsUserAccount) object);
{
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;
}
}
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);
{
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);
}
return currentHashCode;
}
public int hashCode() {
final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE;
return this.hashCode(null, strategy);
}
public WindowsUserAccount withSecurityID(StringObjectPropertyType value) {
setSecurityID(value);
return this;
}
public WindowsUserAccount withSecurityType(SIDType value) {
setSecurityType(value);
return this;
}
@Override
public WindowsUserAccount withFullName(StringObjectPropertyType value) {
setFullName(value);
return this;
}
@Override
public WindowsUserAccount withGroupList(GroupListType value) {
setGroupList(value);
return this;
}
@Override
public WindowsUserAccount withHomeDirectory(StringObjectPropertyType value) {
setHomeDirectory(value);
return this;
}
@Override
public WindowsUserAccount withLastLogin(DateTimeObjectPropertyType value) {
setLastLogin(value);
return this;
}
@Override
public WindowsUserAccount withPrivilegeList(PrivilegeListType value) {
setPrivilegeList(value);
return this;
}
@Override
public WindowsUserAccount withScriptPath(StringObjectPropertyType value) {
setScriptPath(value);
return this;
}
@Override
public WindowsUserAccount withUsername(StringObjectPropertyType value) {
setUsername(value);
return this;
}
@Override
public WindowsUserAccount withUserPasswordAge(
DurationObjectPropertyType value) {
setUserPasswordAge(value);
return this;
}
@Override
public WindowsUserAccount withPasswordRequired(Boolean value) {
setPasswordRequired(value);
return this;
}
@Override
public WindowsUserAccount withDescription(StringObjectPropertyType value) {
setDescription(value);
return this;
}
@Override
public WindowsUserAccount withDomain(StringObjectPropertyType value) {
setDomain(value);
return this;
}
@Override
public WindowsUserAccount withAuthentications(AuthenticationType... values) {
if (values != null) {
for (AuthenticationType value : values) {
getAuthentications().add(value);
}
}
return this;
}
@Override
public WindowsUserAccount withAuthentications(
Collection values) {
if (values != null) {
getAuthentications().addAll(values);
}
return this;
}
@Override
public WindowsUserAccount withCreationDate(DateTimeObjectPropertyType value) {
setCreationDate(value);
return this;
}
@Override
public WindowsUserAccount withModifiedDate(DateTimeObjectPropertyType value) {
setModifiedDate(value);
return this;
}
@Override
public WindowsUserAccount withLastAccessedTime(
DateTimeObjectPropertyType value) {
setLastAccessedTime(value);
return this;
}
@Override
public WindowsUserAccount withDisabled(Boolean value) {
setDisabled(value);
return this;
}
@Override
public WindowsUserAccount withLockedOut(Boolean value) {
setLockedOut(value);
return this;
}
@Override
public WindowsUserAccount withCustomProperties(CustomPropertiesType value) {
setCustomProperties(value);
return this;
}
@Override
public WindowsUserAccount 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);
{
StringObjectPropertyType theSecurityID;
theSecurityID = this.getSecurityID();
strategy.appendField(locator, this, "securityID", buffer,
theSecurityID);
}
{
SIDType theSecurityType;
theSecurityType = this.getSecurityType();
strategy.appendField(locator, this, "securityType", buffer,
theSecurityType);
}
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, WindowsUserAccount.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 WindowsUserAccount instance for XML String
*
* @param text
* XML String for the document
* @return The WindowsUserAccount instance for the passed XML String
*/
public static WindowsUserAccount fromXMLString(String text) {
JAXBContext jaxbContext;
try {
jaxbContext = JAXBContext.newInstance(WindowsUserAccount.class
.getPackage().getName());
Unmarshaller unmarshaller = jaxbContext.createUnmarshaller();
unmarshaller.setSchema(STIXSchema.getInstance().getSchema());
unmarshaller.setEventHandler(new ValidationEventHandler());
StreamSource streamSource = new StreamSource(new StringReader(text));
return (WindowsUserAccount) unmarshaller.unmarshal(streamSource);
} catch (JAXBException e) {
throw new RuntimeException(e);
}
}
/**
* Validates the XML representation of this WindowsUserAccount 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());
}
}