package com.temenos.interaction.core.resource;
/*
* #%L
* interaction-core
* %%
* Copyright (C) 2012 - 2013 Temenos Holdings N.V.
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* #L%
*/
import java.util.Collection;
import java.util.Map;
import javax.ws.rs.core.GenericEntity;
import javax.xml.bind.annotation.XmlTransient;
import com.temenos.interaction.core.hypermedia.Link;
import com.temenos.interaction.core.hypermedia.Transition;
/**
* A CollectionResource is the RESTful representation of a collection of
* 'things' within our system. A 'thing' is addressable by a globally
* unique key, it has a set of simple & complex named properties, and a set
* of links to find other resources linked to this resource.
* @author aphethean
*/
public class CollectionResource<T> implements RESTResource {
private Collection<EntityResource<T>> entities;
// TODO implement JAXB Adapter for OProperty
// private List<OProperty<?>> properties;
@XmlTransient
private String entitySetName;
// links from a collection
@XmlTransient
private Collection<Link> links;
@XmlTransient
private Map<Transition, RESTResource> embedded;
@XmlTransient
private String entityTag = null;
@XmlTransient
private Integer inlineCount;
public CollectionResource() {}
/**
* Construct a new instance of a CollectionResource. EntitySetName will be set by the interaction-core
* before passing to a Provider
* @param entities
*/
public CollectionResource(Collection<EntityResource<T>> entities) {
this.entities = entities;
}
/**
* This constructor expected to be used internally.
* @param entitySetName
* @param entities
*/
public CollectionResource(String entitySetName, Collection<EntityResource<T>> entities) {
this.entitySetName = entitySetName;
this.entities = entities;
}
public String getEntitySetName() {
return entitySetName;
}
public Collection<EntityResource<T>> getEntities() {
return entities;
}
@Override
public GenericEntity<CollectionResource<T>> getGenericEntity() {
return new GenericEntity<CollectionResource<T>>(this, this.getClass().getGenericSuperclass());
}
@Override
public Collection<Link> getLinks() {
return this.links;
}
/**
* Called during resource building phase to set the links for
* serialization by the provider.
* @param links
*/
@Override
public void setLinks(Collection<Link> links) {
this.links = links;
}
@Override
public Map<Transition, RESTResource> getEmbedded() {
return this.embedded;
}
/**
* Called during resource building phase to set the embedded
* resources for serialization by the provider.
* @param embedded
*/
@Override
public void setEmbedded(Map<Transition, RESTResource> embedded) {
this.embedded = embedded;
}
@Override
public String getEntityName() {
return entitySetName;
}
@Override
public void setEntityName(String entityName) {
this.entitySetName = entityName;
}
@Override
public String getEntityTag() {
return entityTag;
}
@Override
public void setEntityTag(String entityTag) {
this.entityTag = entityTag;
}
/**
* Sets the inline count value of the collection response.
*
* @param inline
* count
*/
public void setInlineCount(Integer inlineCount) {
this.inlineCount = inlineCount;
}
/**
* Returns the inline count value of the collection response.
*
* @return inline count or null if inline count is not available
*/
public Integer getInlineCount() {
return this.inlineCount;
}
}