org.unitedinternet.cosmo.dao.ContentDao Maven / Gradle / Ivy
/*
* Copyright 2006 Open Source Applications Foundation
*
* 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.unitedinternet.cosmo.dao;
import java.util.Date;
import java.util.Set;
import org.unitedinternet.cosmo.model.CollectionItem;
import org.unitedinternet.cosmo.model.ContentItem;
import org.unitedinternet.cosmo.model.User;
/**
* Interface for DAO that provides base operations for content items.
*
* A content item is either a piece of content (or file) or a collection
* containing content items or other collection items.
*
*/
public interface ContentDao extends ItemDao {
/**
* Create a new collection.
*
* @param parent
* parent of collection.
* @param collection
* collection to create
* @return newly created collection
*/
public CollectionItem createCollection(CollectionItem parent,
CollectionItem collection);
/**
* Update collection and children. The set of children can contain
* new items, existing items, and item removals. An item removal
* is recognized by Item.isActive==false.
* @param collection collection to update
* @param children children to updated
* @return updated collection
*/
@ExternalizableContent
public CollectionItem updateCollection(CollectionItem collection,
Set children);
/**
* Update an existing collection.
*
* @param collection
* collection to update
* @return updated collection
*/
public CollectionItem updateCollection(CollectionItem collection);
/**
* Create new content item. A content item represents a piece of content or
* file.
*
* @param parent
* parent collection of content. If null, content is assumed to
* live in the top-level user collection
* @param content
* content to create
* @return newly created content
*/
@ExternalizableContent
public ContentItem createContent(CollectionItem parent, ContentItem content);
/**
* creates a set of content items, used during events import from other calendar
*
* @param parent
* parent collection of content. If null, content is assumed to
* live in the top-level user collection
*
* @param contents
* the set of contents to create
*/
@ExternalizableContent
public void createBatchContent(CollectionItem parent, Set contents);
/**
*
* @param contents Set
*/
public void updateBatchContent(Set contents);
/**
*
* @param parent CollectionItem
* @param contents Set
*/
@ExternalizableContent
public void removeBatchContent(CollectionItem parent, Set contents);
/**
* Create new content item and associate with multiple parent collections.
*
* @param parents
* parent collections of content.
* @param content
* content to create
* @return newly created content
*/
public ContentItem createContent(Set parents, ContentItem content);
/**
* Update an existing content item.
*
* @param content
* content item to update
* @return updated content item
*/
public ContentItem updateContent(ContentItem content);
/**
* Remove content item
*
* @param content
* content item to remove
*/
public void removeContent(ContentItem content);
/**
* Remove all content owned by a user
*
* @param user
* user to remove content for
*/
public void removeUserContent(User user);
/**
* Remove collection item
*
* @param collection
* collection item to remove
*/
public void removeCollection(CollectionItem collection);
/**
* Update timestamp on collection.
* @param collection collection to update
* @return updated collection
*/
public CollectionItem updateCollectionTimestamp(CollectionItem collection);
/**
* Load all children for collection that have been updated since a
* given timestamp. If no timestamp is specified, then return all
* children.
* @param collection collection
* @param timestamp timestamp
* @return children of collection that have been updated since
* timestamp, or all children if timestamp is null
*/
public Set loadChildren(CollectionItem collection, Date timestamp);
/**
* Removes all items from a given collection.
* @param collection The collection which contains all items which will be deleted.
*/
public void removeItemsFromCollection(CollectionItem collection);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy