org.opencastproject.mediapackage.MediaPackage Maven / Gradle / Ivy
/**
* Licensed to The Apereo Foundation under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional
* information regarding copyright ownership.
*
*
* The Apereo Foundation licenses this file to you under the Educational
* Community 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://opensource.org/licenses/ecl2.txt
*
* 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.opencastproject.mediapackage;
import org.opencastproject.mediapackage.identifier.Id;
import java.net.URI;
import java.util.Collection;
import java.util.Date;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
/**
* Interface for a media package, which is a data container moving through the system, containing metadata, tracks and
* attachments.
*/
@XmlJavaTypeAdapter(MediaPackageImpl.Adapter.class)
public interface MediaPackage extends Cloneable {
/**
* Returns the media package identifier.
*
* @return the identifier
*/
Id getIdentifier();
void setIdentifier(Id id);
void setTitle(String title);
/**
* Returns the title for the associated series, if any.
*
* @return The series title
*/
String getSeriesTitle();
void setSeriesTitle(String seriesTitle);
/**
* Returns the title of the episode that this mediapackage represents.
*
* @return The episode title
*/
String getTitle();
void addCreator(String creator);
void removeCreator(String creator);
/**
* Returns the names of the institutions or people who created this mediapackage
*
* @return the creators of this mediapackage
*/
String[] getCreators();
void setSeries(String identifier);
/**
* Returns the series, if any, to which this mediapackage belongs
*
* @return the series
*/
String getSeries();
void setLicense(String license);
/**
* The license for the content in this mediapackage
*
* @return the license
*/
String getLicense();
void addContributor(String contributor);
void removeContributor(String contributor);
/**
* Returns the names of the institutions or people who contributed to the content within this mediapackage
*
* @return the contributors
*/
String[] getContributors();
void setLanguage(String language);
/**
* Returns the language written and/or spoken in the media content of this mediapackage
*
* @return the language
*/
String getLanguage();
void addSubject(String subject);
void removeSubject(String subject);
/**
* The keywords describing the subject(s) or categories describing the content of this mediapackage
*
* @return the subjects
*/
String[] getSubjects();
void setDate(Date date);
/**
* Returns the media package start time.
*
* @return the start time
*/
Date getDate();
/**
* Returns the media package duration in milliseconds or null
if no duration is available.
*
* @return the duration
*/
Long getDuration();
/**
* Sets the duration of the media package in milliseconds. This method will throw an {@link IllegalStateException} if
* tracks have been added to the mediapackage already. Also note that as soon as the first track is added, the
* duration will be udpated according to the track's length.
*
* @param duration
* the duration in milliseconds
* @throws IllegalStateException
* if the mediapackage already contains a track
*/
void setDuration(Long duration) throws IllegalStateException;
/**
* Returns true
if the given element is part of the media package.
*
* @param element
* the element
* @return true
if the element belongs to the media package
*/
boolean contains(MediaPackageElement element);
/**
* Returns an iteration of the media package elements.
*
* @return the media package elements
*/
Iterable elements();
/**
* Returns all of the elements.
*
* @return the elements
*/
MediaPackageElement[] getElements();
/**
* Returns the element that is identified by the given reference or null
if no such element exists.
*
* @param reference
* the reference
* @return the element
*/
MediaPackageElement getElementByReference(MediaPackageReference reference);
/**
* Returns the element that is identified by the given identifier or null
if no such element exists.
*
* @param id
* the element identifier
* @return the element
*/
MediaPackageElement getElementById(String id);
/**
* Returns the elements that are tagged with any of the given tags or an empty array if no such elements are found. If
* any of the tags in the tags
collection start with a '-' character, any elements matching the tag will
* be excluded from the returned MediaPackageElement[]. If tags
is empty or null, all elements are
* returned.
*
* @param tags
* the tags
* @return the elements
*/
MediaPackageElement[] getElementsByTags(Collection tags);
/**
* Returns all elements of this media package with the given flavor.
*
* @return the media package elements
*/
MediaPackageElement[] getElementsByFlavor(MediaPackageElementFlavor flavor);
/**
* Returns the track identified by trackId
or null
if that track doesn't exists.
*
* @param trackId
* the track identifier
* @return the tracks
*/
Track getTrack(String trackId);
/**
* Returns the tracks that are part of this media package.
*
* @return the tracks
*/
Track[] getTracks();
/**
* Returns the tracks that are tagged with the given tag or an empty array if no such tracks are found.
*
* @param tag
* the tag
* @return the tracks
*/
Track[] getTracksByTag(String tag);
/**
* Returns the tracks that are tagged with any of the given tags or an empty array if no such elements are found. If
* any of the tags in the tags
collection start with a '-' character, any elements matching the tag will
* be excluded from the returned Track[]. If tags
is empty or null, all tracks are returned.
*
* @param tags
* the tags
* @return the tracks
*/
Track[] getTracksByTags(Collection tags);
/**
* Returns the tracks that are part of this media package and match the given flavor as defined in {@link Track}.
*
* @param flavor
* the track's flavor
* @return the tracks with the specified flavor
*/
Track[] getTracks(MediaPackageElementFlavor flavor);
/**
* Returns true
if the media package contains media tracks of any kind.
*
* @return true
if the media package contains tracks
*/
boolean hasTracks();
/**
* Returns the attachment identified by attachmentId
or null
if that attachment doesn't
* exists.
*
* @param attachmentId
* the attachment identifier
* @return the attachments
*/
Attachment getAttachment(String attachmentId);
/**
* Returns the attachments that are part of this media package.
*
* @return the attachments
*/
Attachment[] getAttachments();
/**
* Returns the attachments that are part of this media package and match the specified flavor.
*
* @param flavor
* the attachment flavor
* @return the attachments
*/
Attachment[] getAttachments(MediaPackageElementFlavor flavor);
/**
* Returns the presentations that are part of this media package.
*
* @return the attachments
*/
Publication[] getPublications();
/**
* Returns the catalog identified by catalogId
or null
if that catalog doesn't exists.
*
* @param catalogId
* the catalog identifier
* @return the catalogs
*/
Catalog getCatalog(String catalogId);
/**
* Returns the catalogs associated with this media package.
*
* @return the catalogs
*/
Catalog[] getCatalogs();
/**
* Returns the catalogs that are tagged with any of the given tags or an empty array if no such elements are found. If
* any of the tags in the tags
collection start with a '-' character, any elements matching the tag will
* be excluded from the returned Catalog[]. If tags
is empty or null, all catalogs are returned.
*
* @param tags
* the tags
* @return the catalogs
*/
Catalog[] getCatalogsByTags(Collection tags);
/**
* Returns the catalogs associated with this media package that matches the specified flavor.
*
* @param flavor
* the catalog type
* @return the media package catalogs
*/
Catalog[] getCatalogs(MediaPackageElementFlavor flavor);
/**
* Returns the catalogs that are part of this media package and are refering to the element identified by
* reference
.
*
* @param reference
* the reference
* @return the catalogs with the specified reference
*/
Catalog[] getCatalogs(MediaPackageReference reference);
/**
* Returns the catalogs that are part of this media package and are refering to the element identified by
* reference
.
*
* @param flavor
* the element flavor
* @param reference
* the reference
* @return the catalogs with the specified reference
*/
Catalog[] getCatalogs(MediaPackageElementFlavor flavor, MediaPackageReference reference);
/**
* Returns media package elements that are neither, attachments, catalogs nor tracks.
*
* @return the other media package elements
*/
MediaPackageElement[] getUnclassifiedElements();
/**
* Adds an arbitrary {@link URI} to this media package, utilizing a {@link MediaPackageBuilder} to create a suitable
* media package element out of the url. If the content cannot be recognized as being either a metadata catalog or
* multimedia track, it is added as an attachment.
*
* @param uri
* the element location
*/
MediaPackageElement add(URI uri);
/**
* Adds an arbitrary {@link URI} to this media package, utilizing a {@link MediaPackageBuilder} to create a suitable
* media package element out of the url. If the content cannot be recognized as being either a metadata catalog or
* multimedia track, it is added as an attachment.
*
* @param uri
* the element location
* @param type
* the element type
* @param flavor
* the element flavor
*/
MediaPackageElement add(URI uri, MediaPackageElement.Type type, MediaPackageElementFlavor flavor);
/**
* Adds an arbitrary {@link MediaPackageElement} to this media package.
*
* @param element
* the element
*/
void add(MediaPackageElement element);
/**
* Adds a track to this media package, actually moving the underlying file in the filesystem. Use this method
* only if you do not need the track in its originial place anymore.
*
* Depending on the implementation, this method may provide significant performance benefits over copying the track.
*
* @param track
* the track
*/
void add(Track track);
/**
* Removes the element with the given identifier from the mediapackage and returns it.
*
* @param id
* the element identifier
*/
MediaPackageElement removeElementById(String id);
/**
* Removes the track from the media package.
*
* @param track
* the track
*/
void remove(Track track);
/**
* Adds catalog information to this media package.
*
* @param catalog
* the catalog
*/
void add(Catalog catalog);
/**
* Removes the catalog from the media package.
*
* @param catalog
* the catalog
*/
void remove(Catalog catalog);
/**
* Adds an attachment to this media package.
*
* @param attachment
* the attachment
*/
void add(Attachment attachment);
/**
* Removes an arbitrary media package element.
*
* @param element
* the media package element
*/
void remove(MediaPackageElement element);
/**
* Removes the attachment from the media package.
*
* @param attachment
* the attachment
*/
void remove(Attachment attachment);
/**
* Adds an element to this media package that represents a derived version of sourceElement
. Examples of
* a derived element could be an encoded version of a track or a converted version of a time text captions file.
*
* This method will add derviedElement
to the media package and add a reference to the original element
* sourceElement
. Make sure that derivedElement
features the right flavor, so that you are
* later able to look up derived work using {@link #getDerived(MediaPackageElement, MediaPackageElementFlavor)}.
*
* @param derivedElement
* the derived element
* @param sourceElement
* the source element
*/
void addDerived(MediaPackageElement derivedElement, MediaPackageElement sourceElement);
/**
* Returns those media package elements that are derivates of sourceElement
and feature the flavor
* derivateFlavor
. Using this method, you could easily look up e. g. flash-encoded versions of the
* presenter track or converted versions of a time text captions file.
*
* @param sourceElement
* the original track, catalog or attachment
* @param derivateFlavor
* the derivate flavor you are looking for
* @return the derivates
*/
MediaPackageElement[] getDerived(MediaPackageElement sourceElement, MediaPackageElementFlavor derivateFlavor);
/**
* Verifies the media package consistency by checking the media package elements for mimetypes and checksums.
*
* @throws MediaPackageException
* if an error occurs while checking the media package
*/
void verify() throws MediaPackageException;
/**
* Creates a deep copy of the media package.
*
* @return the cloned media package
*/
Object clone();
}