/* * 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.jboss.resteasy.plugins.providers.atom.app; import org.w3c.dom.Element; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAnyElement; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlSchemaType; import javax.xml.bind.annotation.XmlType; import java.util.ArrayList; import java.util.List; /** * <p> * Per RFC5023: * </p> * <p/> * * <pre> * The "app:collection" element describes a Collection. The app: * collection element MUST contain one atom:title element. * * The app:collection element MAY contain any number of app:accept * elements, indicating the types of representations accepted by the * Collection. The order of such elements is not significant. * * The app:collection element MAY contain any number of app:categories * elements. * * appCollection = * element app:collection { * appCommonAttributes, * attribute href { atomURI }, * ( atomTitle * & appAccept* * & appCategories* * & extensionSansTitleElement* ) * } * <p/> * </pre> * * @author <a href="mailto:kurt.stam@gmail.com">Kurt Stam</a> * @version $Revision: 1 $ */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "collection", propOrder = { "href", "title", "accept", "categories", "any" }) public class AppCollection extends AppCommonAttributes { private static final long serialVersionUID = 3466473348035916400L; @XmlAttribute @XmlSchemaType(name = "anyURI") protected String href; @XmlElement(namespace = "http://www.w3.org/2005/Atom", required = true) protected String title; protected List<AppAccept> accept; protected List<AppCategories> categories; @XmlAnyElement(lax = true) protected List<Object> any; public AppCollection() {} public AppCollection(String href, String title) { super(); this.href = href; this.title = title; } /** * Gets the value of the title property. * * @return possible object is {@link String } * */ public String getTitle() { return title; } /** * Sets the value of the title property. * * @param value * allowed object is {@link String } * */ public void setTitle(String value) { this.title = value; } /** * Gets the value of the accept 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 accept property. * * <p> * For example, to add a new item, do as follows: * * <pre> * getAccept().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list {@link String } * * */ public List<AppAccept> getAccept() { if (accept == null) { accept = new ArrayList<AppAccept>(); } return this.accept; } /** * Gets the value of the categories 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 categories property. * * <p> * For example, to add a new item, do as follows: * * <pre> * getCategories().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link AppCategoriesType } * * */ public List<AppCategories> getCategories() { if (categories == null) { categories = new ArrayList<AppCategories>(); } return this.categories; } /** * Gets the value of the any 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 any property. * * <p> * For example, to add a new item, do as follows: * * <pre> * getAny().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list {@link Element } * {@link Object } * * */ public List<Object> getAny() { if (any == null) { any = new ArrayList<Object>(); } return this.any; } /** * Gets the value of the href property. * * @return possible object is {@link String } * */ public String getHref() { return href; } /** * Sets the value of the href property. * * @param value * allowed object is {@link String } * */ public void setHref(String value) { this.href = value; } }