/**
* Copyright (c) 2011, SOCIETIES Consortium (WATERFORD INSTITUTE OF TECHNOLOGY (TSSG), HERIOT-WATT UNIVERSITY (HWU), SOLUTA.NET
* (SN), GERMAN AEROSPACE CENTRE (Deutsches Zentrum fuer Luft- und Raumfahrt e.V.) (DLR), Zavod za varnostne tehnologije
* informacijske družbe in elektronsko poslovanje (SETCCE), INSTITUTE OF COMMUNICATION AND COMPUTER SYSTEMS (ICCS), LAKE
* COMMUNICATIONS (LAKE), INTEL PERFORMANCE LEARNING SOLUTIONS LTD (INTEL), PORTUGAL TELECOM INOVAÇÃO, SA (PTIN), IBM Corp.,
* INSTITUT TELECOM (ITSUD), AMITEC DIACHYTI EFYIA PLIROFORIKI KAI EPIKINONIES ETERIA PERIORISMENIS EFTHINIS (AMITEC), TELECOM
* ITALIA S.p.a.(TI), TRIALOG (TRIALOG), Stiftelsen SINTEF (SINTEF), NEC EUROPE LTD (NEC))
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following
* conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
* SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.societies.api.activity;
import org.societies.utilities.annotations.SocietiesExternalInterface;
import org.societies.utilities.annotations.SocietiesExternalInterface.SocietiesInterfaceType;
/**
* This interface is mainly a container for passing the parameter
* Activity into the {@link IActivityFeed} calls. This interface
* only provides getters and setters to the activity container.
*
* To illustrate the usage of this interface, I will use an example througout the documentation:
* "Jack says 'hi' to Jane" (and this activity was published 00:00:00 01 january 1970 UTC)
*
* For more information of the standard this interface represents a subset of, see:
* http://activitystrea.ms/specs/json/1.0/
*
* @author Babak.Farshchian@sintef.no
* @author Bjørn Magnus
* @author Thomas Vilarinho
*
*/
@SocietiesExternalInterface(type = SocietiesInterfaceType.PROVIDED)
public interface IActivity {
/**
* This method returns the ID of the activity.
* This ID is not of any use outside the internal functions in activityfeed, it is autogenerated per activityfeed database table.
*
* e.g. "129317741200"
*
* @return {@link Long} the ID.
*/
public Long getId();
/**
* This method returns the verb of the activity
*
* e.g. "says"
*
* @return {@link String} the ID.
*/
public String getVerb();
/**
* This methods lets you set the verb of the activity
*
* e.g. "says"
*
* @param {@link String} verb
*/
public void setVerb(String verb);
/**
* This method returns the actor of the activity
*
* e.g. "Jack"
*
* @return {@link String}
*/
public String getActor();
/**
* This method lets you set the actor of the activity
*
* e.g. "Jack"
*
* @param {@link String} actor
*/
public void setActor(String actor);
/**
* This method returns the object of the activity
*
* e.g. "hi"
*
* @return {@link String}
*/
public String getObject();
/**
* This method lets you set the object of the activity
*
* e.g. "hi"
*
* @param {@link String} object
*/
public void setObject(String object);
/**
* This method returns the target of the activity
*
* e.g. "Jane"
*
* @return {@link String}
*/
public String getTarget();
/**
* This method lets you set the target of the activity
*
* e.g. "Jane"
*
* @param {@link String} target
*/
public void setTarget(String target);
/**
* This method returns the time of publication of the activity in ms since unix epoch represented as a string.
*
* e.g. "0"
*
* @return {@link String}
*/
public String getPublished();
/**
* This method is not of any practical use for API/3rd party service developers, this method is only for use within the activityfeed implementation, and may be refactored at any moment of time.
* This method lets you set the time of publication of the activity in ms since unix epoch represented as a string.
*
* e.g. "0"
*
* @return {@link String}
*/
@Deprecated
public void setPublished(String published);
}