org.mitre.cybox.objects.X509Certificate 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
/**
* 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 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.ObjectPropertiesType;
import org.mitre.cybox.common_2.StringObjectPropertyType;
import org.mitre.stix.DocumentUtilities;
import org.mitre.stix.STIXSchema;
import org.mitre.stix.ValidationEventHandler;
/**
* The X509CertificateObjectType type is intended to characterize X.509 certificates.
*
* Java class for X509CertificateObjectType complex type.
*
*
The following schema fragment specifies the expected content contained within this class.
*
*
* <complexType name="X509CertificateObjectType">
* <complexContent>
* <extension base="{http://cybox.mitre.org/common-2}ObjectPropertiesType">
* <sequence>
* <element name="Certificate" type="{http://cybox.mitre.org/objects#X509CertificateObject-2}X509CertificateContentsType" minOccurs="0"/>
* <element name="Raw_Certificate" type="{http://cybox.mitre.org/common-2}StringObjectPropertyType" minOccurs="0"/>
* <element name="Certificate_Signature" type="{http://cybox.mitre.org/objects#X509CertificateObject-2}X509CertificateSignatureType" minOccurs="0"/>
* </sequence>
* </extension>
* </complexContent>
* </complexType>
*
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "X509CertificateObjectType", namespace = "http://cybox.mitre.org/objects#X509CertificateObject-2", propOrder = {
"certificate", "rawCertificate", "certificateSignature" })
@XmlRootElement(name = "X509_Certificate", namespace = "http://cybox.mitre.org/objects#X509CertificateObject-2")
public class X509Certificate extends ObjectPropertiesType implements Equals,
HashCode, ToString {
@XmlElement(name = "Certificate")
protected X509CertificateContentsType certificate;
@XmlElement(name = "Raw_Certificate")
protected StringObjectPropertyType rawCertificate;
@XmlElement(name = "Certificate_Signature")
protected X509CertificateSignatureType certificateSignature;
/**
* Default no-arg constructor
*
*/
public X509Certificate() {
super();
}
/**
* Fully-initialising value constructor
*
*/
public X509Certificate(final CustomPropertiesType customProperties,
final QName objectReference,
final X509CertificateContentsType certificate,
final StringObjectPropertyType rawCertificate,
final X509CertificateSignatureType certificateSignature) {
super(customProperties, objectReference);
this.certificate = certificate;
this.rawCertificate = rawCertificate;
this.certificateSignature = certificateSignature;
}
/**
* Gets the value of the certificate property.
*
* @return
* possible object is
* {@link X509CertificateContentsType }
*
*/
public X509CertificateContentsType getCertificate() {
return certificate;
}
/**
* Sets the value of the certificate property.
*
* @param value
* allowed object is
* {@link X509CertificateContentsType }
*
*/
public void setCertificate(X509CertificateContentsType value) {
this.certificate = value;
}
/**
* Gets the value of the rawCertificate property.
*
* @return
* possible object is
* {@link StringObjectPropertyType }
*
*/
public StringObjectPropertyType getRawCertificate() {
return rawCertificate;
}
/**
* Sets the value of the rawCertificate property.
*
* @param value
* allowed object is
* {@link StringObjectPropertyType }
*
*/
public void setRawCertificate(StringObjectPropertyType value) {
this.rawCertificate = value;
}
/**
* Gets the value of the certificateSignature property.
*
* @return
* possible object is
* {@link X509CertificateSignatureType }
*
*/
public X509CertificateSignatureType getCertificateSignature() {
return certificateSignature;
}
/**
* Sets the value of the certificateSignature property.
*
* @param value
* allowed object is
* {@link X509CertificateSignatureType }
*
*/
public void setCertificateSignature(X509CertificateSignatureType value) {
this.certificateSignature = value;
}
public boolean equals(ObjectLocator thisLocator, ObjectLocator thatLocator,
Object object, EqualsStrategy strategy) {
if (!(object instanceof X509Certificate)) {
return false;
}
if (this == object) {
return true;
}
if (!super.equals(thisLocator, thatLocator, object, strategy)) {
return false;
}
final X509Certificate that = ((X509Certificate) object);
{
X509CertificateContentsType lhsCertificate;
lhsCertificate = this.getCertificate();
X509CertificateContentsType rhsCertificate;
rhsCertificate = that.getCertificate();
if (!strategy.equals(LocatorUtils.property(thisLocator,
"certificate", lhsCertificate), LocatorUtils.property(
thatLocator, "certificate", rhsCertificate),
lhsCertificate, rhsCertificate)) {
return false;
}
}
{
StringObjectPropertyType lhsRawCertificate;
lhsRawCertificate = this.getRawCertificate();
StringObjectPropertyType rhsRawCertificate;
rhsRawCertificate = that.getRawCertificate();
if (!strategy.equals(LocatorUtils.property(thisLocator,
"rawCertificate", lhsRawCertificate),
LocatorUtils.property(thatLocator, "rawCertificate",
rhsRawCertificate), lhsRawCertificate,
rhsRawCertificate)) {
return false;
}
}
{
X509CertificateSignatureType lhsCertificateSignature;
lhsCertificateSignature = this.getCertificateSignature();
X509CertificateSignatureType rhsCertificateSignature;
rhsCertificateSignature = that.getCertificateSignature();
if (!strategy.equals(LocatorUtils.property(thisLocator,
"certificateSignature", lhsCertificateSignature),
LocatorUtils.property(thatLocator, "certificateSignature",
rhsCertificateSignature), lhsCertificateSignature,
rhsCertificateSignature)) {
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);
{
X509CertificateContentsType theCertificate;
theCertificate = this.getCertificate();
currentHashCode = strategy.hashCode(LocatorUtils.property(locator,
"certificate", theCertificate), currentHashCode,
theCertificate);
}
{
StringObjectPropertyType theRawCertificate;
theRawCertificate = this.getRawCertificate();
currentHashCode = strategy.hashCode(LocatorUtils.property(locator,
"rawCertificate", theRawCertificate), currentHashCode,
theRawCertificate);
}
{
X509CertificateSignatureType theCertificateSignature;
theCertificateSignature = this.getCertificateSignature();
currentHashCode = strategy.hashCode(LocatorUtils.property(locator,
"certificateSignature", theCertificateSignature),
currentHashCode, theCertificateSignature);
}
return currentHashCode;
}
public int hashCode() {
final HashCodeStrategy strategy = JAXBHashCodeStrategy.INSTANCE;
return this.hashCode(null, strategy);
}
public X509Certificate withCertificate(X509CertificateContentsType value) {
setCertificate(value);
return this;
}
public X509Certificate withRawCertificate(StringObjectPropertyType value) {
setRawCertificate(value);
return this;
}
public X509Certificate withCertificateSignature(
X509CertificateSignatureType value) {
setCertificateSignature(value);
return this;
}
@Override
public X509Certificate withCustomProperties(CustomPropertiesType value) {
setCustomProperties(value);
return this;
}
@Override
public X509Certificate 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);
{
X509CertificateContentsType theCertificate;
theCertificate = this.getCertificate();
strategy.appendField(locator, this, "certificate", buffer,
theCertificate);
}
{
StringObjectPropertyType theRawCertificate;
theRawCertificate = this.getRawCertificate();
strategy.appendField(locator, this, "rawCertificate", buffer,
theRawCertificate);
}
{
X509CertificateSignatureType theCertificateSignature;
theCertificateSignature = this.getCertificateSignature();
strategy.appendField(locator, this, "certificateSignature", buffer,
theCertificateSignature);
}
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, X509Certificate.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 X509Certificate instance for XML String
*
* @param text
* XML String for the document
* @return The X509Certificate instance for the passed XML String
*/
public static X509Certificate fromXMLString(String text) {
JAXBContext jaxbContext;
try {
jaxbContext = JAXBContext.newInstance(X509Certificate.class
.getPackage().getName());
Unmarshaller unmarshaller = jaxbContext.createUnmarshaller();
unmarshaller.setSchema(STIXSchema.getInstance().getSchema());
unmarshaller.setEventHandler(new ValidationEventHandler());
StreamSource streamSource = new StreamSource(new StringReader(text));
return (X509Certificate) unmarshaller.unmarshal(streamSource);
} catch (JAXBException e) {
throw new RuntimeException(e);
}
}
/**
* Validates the XML representation of this X509Certificate instance
* Returning true indicating a successful validation, false if not.
*
* @return boolean
*/
public boolean validate() {
return STIXSchema.getInstance().validate(toXMLString());
}
}