/* * Copyright 2010-2013, Plutext Pty Ltd. * * This file is part of xlsx4j, a component of docx4j. docx4j is licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ package org.xlsx4j.sml; import java.util.ArrayList; import java.util.List; import javax.xml.bind.Unmarshaller; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlSchemaType; import javax.xml.bind.annotation.XmlTransient; import javax.xml.bind.annotation.XmlType; import javax.xml.bind.annotation.adapters.HexBinaryAdapter; import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter; import org.jvnet.jaxb2_commons.ppp.Child; /** * <p>Java class for CT_ProtectedRange complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="CT_ProtectedRange"> * <complexContent> * <restriction base="{http://www.w3.org/2001/XMLSchema}anyType"> * <sequence> * <element name="securityDescriptor" type="{http://www.w3.org/2001/XMLSchema}string" maxOccurs="unbounded" minOccurs="0"/> * </sequence> * <attribute name="password" type="{http://schemas.openxmlformats.org/spreadsheetml/2006/main}ST_UnsignedShortHex" /> * <attribute name="sqref" use="required" type="{http://schemas.openxmlformats.org/spreadsheetml/2006/main}ST_Sqref" /> * <attribute name="name" use="required" type="{http://schemas.openxmlformats.org/officeDocument/2006/sharedTypes}ST_Xstring" /> * <attribute name="securityDescriptor" type="{http://www.w3.org/2001/XMLSchema}string" /> * <attribute name="algorithmName" type="{http://schemas.openxmlformats.org/officeDocument/2006/sharedTypes}ST_Xstring" /> * <attribute name="hashValue" type="{http://www.w3.org/2001/XMLSchema}base64Binary" /> * <attribute name="saltValue" type="{http://www.w3.org/2001/XMLSchema}base64Binary" /> * <attribute name="spinCount" type="{http://www.w3.org/2001/XMLSchema}unsignedInt" /> * </restriction> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "CT_ProtectedRange", propOrder = { "securityDescriptor" }) public class CTProtectedRange implements Child { protected List<String> securityDescriptor; @XmlAttribute(name = "password") @XmlJavaTypeAdapter(HexBinaryAdapter.class) protected byte[] password; @XmlAttribute(name = "sqref", required = true) protected List<String> sqref; @XmlAttribute(name = "name", required = true) protected String name; @XmlAttribute(name = "securityDescriptor") protected String securityDescriptorAttr; @XmlAttribute(name = "algorithmName") protected String algorithmName; @XmlAttribute(name = "hashValue") protected byte[] hashValue; @XmlAttribute(name = "saltValue") protected byte[] saltValue; @XmlAttribute(name = "spinCount") @XmlSchemaType(name = "unsignedInt") protected Long spinCount; @XmlTransient private Object parent; /** * Gets the value of the securityDescriptor property. * * <p> * This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a <CODE>set</CODE> method for the securityDescriptor property. * * <p> * For example, to add a new item, do as follows: * <pre> * getSecurityDescriptor().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link String } * * */ public List<String> getSecurityDescriptor() { if (securityDescriptor == null) { securityDescriptor = new ArrayList<String>(); } return this.securityDescriptor; } /** * Gets the value of the password property. * * @return * possible object is * {@link String } * */ public byte[] getPassword() { return password; } /** * Sets the value of the password property. * * @param value * allowed object is * {@link String } * */ public void setPassword(byte[] value) { this.password = value; } /** * Gets the value of the sqref property. * * <p> * This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a <CODE>set</CODE> method for the sqref property. * * <p> * For example, to add a new item, do as follows: * <pre> * getSqref().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link String } * * */ public List<String> getSqref() { if (sqref == null) { sqref = new ArrayList<String>(); } return this.sqref; } /** * Gets the value of the name property. * * @return * possible object is * {@link String } * */ public String getName() { return name; } /** * Sets the value of the name property. * * @param value * allowed object is * {@link String } * */ public void setName(String value) { this.name = value; } /** * Gets the value of the securityDescriptorAttr property. * * @return * possible object is * {@link String } * */ public String getSecurityDescriptorAttr() { return securityDescriptorAttr; } /** * Sets the value of the securityDescriptorAttr property. * * @param value * allowed object is * {@link String } * */ public void setSecurityDescriptorAttr(String value) { this.securityDescriptorAttr = value; } /** * Gets the value of the algorithmName property. * * @return * possible object is * {@link String } * */ public String getAlgorithmName() { return algorithmName; } /** * Sets the value of the algorithmName property. * * @param value * allowed object is * {@link String } * */ public void setAlgorithmName(String value) { this.algorithmName = value; } /** * Gets the value of the hashValue property. * * @return * possible object is * byte[] */ public byte[] getHashValue() { return hashValue; } /** * Sets the value of the hashValue property. * * @param value * allowed object is * byte[] */ public void setHashValue(byte[] value) { this.hashValue = value; } /** * Gets the value of the saltValue property. * * @return * possible object is * byte[] */ public byte[] getSaltValue() { return saltValue; } /** * Sets the value of the saltValue property. * * @param value * allowed object is * byte[] */ public void setSaltValue(byte[] value) { this.saltValue = value; } /** * Gets the value of the spinCount property. * * @return * possible object is * {@link Long } * */ public Long getSpinCount() { return spinCount; } /** * Sets the value of the spinCount property. * * @param value * allowed object is * {@link Long } * */ public void setSpinCount(Long value) { this.spinCount = value; } /** * Gets the parent object in the object tree representing the unmarshalled xml document. * * @return * The parent object. */ public Object getParent() { return this.parent; } public void setParent(Object parent) { this.parent = parent; } /** * This method is invoked by the JAXB implementation on each instance when unmarshalling completes. * * @param parent * The parent object in the object tree. * @param unmarshaller * The unmarshaller that generated the instance. */ public void afterUnmarshal(Unmarshaller unmarshaller, Object parent) { setParent(parent); } }