/* * Permission to copy, display and distribute the Service Component Architecture Specification and/or * portions thereof, without modification, in any medium without fee or royalty is hereby granted, provided * that you include the following on ALL copies of the Service Component Architecture Specification, or * portions thereof, that you make: * 1. A link or URL to the Service Component Architecture Specification at this location: * http://www.osoa.org/display/Main/Service+Component+Architecture+Specifications * 2. The full text of the copyright notice as shown in the Service Component Architecture Specification. * BEA, Cape Clear, IBM, Interface21, IONA, Oracle, Primeton, Progress Software, Red Hat, Rogue Wave, * SAP, Siemens, Software AG., Sun, Sybase, TIBCO (collectively, the "Authors") agree to grant you a * royalty-free license, under reasonable, non-discriminatory terms and conditions to patents that they deem * necessary to implement the Service Component Architecture Specification. * THE Service Component Architecture SPECIFICATION IS PROVIDED "AS IS," AND THE * AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, * REGARDING THIS SPECIFICATION AND THE IMPLEMENTATION OF ITS CONTENTS, * INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * PARTICULAR PURPOSE, NON-INFRINGEMENT OR TITLE. * THE AUTHORS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL * OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO ANY USE OR * DISTRIBUTION OF THE Service Components Architecture SPECIFICATION. * The name and trademarks of the Authors may NOT be used in any manner, including advertising or * publicity pertaining to the Service Component Architecture Specification or its contents without specific, */ package org.osoa.sca; /** * A ServiceReference represents a client's perspective of a reference to another service. * * @version $Rev$ $Date$ * @param the Java interface associated with this reference */ public interface ServiceReference extends CallableReference { /** * Returns the id supplied by the user that will be associated with conversations initiated through this reference. * * @return the id to associated with any conversation initiated through this reference */ Object getConversationID(); /** * Set the id to associate with any conversation started through this reference. * If the value supplied is null then the id will be generated by the implementation. * * @param conversationId the user-defined id to associated with a conversation * @throws IllegalStateException if a conversation is currently associated with this reference */ void setConversationID(Object conversationId) throws IllegalStateException; /** * Sets the callback ID. * * @param callbackID the callback ID */ void setCallbackID(Object callbackID); /** * Returns the callback object. * * @return the callback object */ Object getCallback(); /** * Sets the callback object. * * @param callback the callback object */ void setCallback(Object callback); }