From d67dcb9c027f8aeb197f288d7c8ae115d7fd9f25 Mon Sep 17 00:00:00 2001 From: antelder Date: Mon, 23 Mar 2009 09:35:27 +0000 Subject: Create 2.0-M2 release branch git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@757361 13f79535-47bb-0310-9956-ffa450edef68 --- .../java/org/oasisopen/sca/CallableReference.java | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 branches/sca-java-2.0-M2/modules/sca-api/src/main/java/org/oasisopen/sca/CallableReference.java (limited to 'branches/sca-java-2.0-M2/modules/sca-api/src/main/java/org/oasisopen/sca/CallableReference.java') diff --git a/branches/sca-java-2.0-M2/modules/sca-api/src/main/java/org/oasisopen/sca/CallableReference.java b/branches/sca-java-2.0-M2/modules/sca-api/src/main/java/org/oasisopen/sca/CallableReference.java new file mode 100644 index 0000000000..cdfaded693 --- /dev/null +++ b/branches/sca-java-2.0-M2/modules/sca-api/src/main/java/org/oasisopen/sca/CallableReference.java @@ -0,0 +1,54 @@ +/* + * (c) Copyright BEA Systems, Inc., Cape Clear Software, International Business Machines Corp, Interface21, IONA Technologies, + * Oracle, Primeton Technologies, Progress Software, Red Hat, Rogue Wave Software, SAP AG., Siemens AG., Software AG., Sybase + * Inc., TIBCO Software Inc., 2005, 2007. All rights reserved. + * + * see http://www.osoa.org/display/Main/Service+Component+Architecture+Specifications + */ +package org.oasisopen.sca; + +/** + * Common superclass for references that can be passed between components. + * + * @version $Rev$ $Date$ + * @param the Java interface associated with this reference + */ +public interface CallableReference { + /** + * Returns a type-safe reference to the target of this reference. + * The instance returned is guaranteed to implement the business interface for this reference + * but may not be a proxy as defined by java.lang.reflect.Proxy. + * + * @return a proxy to the target that implements the business interface associated with this reference + */ + B getService(); + + /** + * Returns the Java class for the business interface associated with this reference. + * + * @return the Class for the business interface associated with this reference + */ + Class getBusinessInterface(); + + /** + * Returns true if this reference is conversational. + * + * @return true if this reference is conversational + */ + boolean isConversational(); + + /** + * Returns the conversation associated with this reference. + * Returns null if no conversation is currently active. + * + * @return the conversation associated with this reference; may be null + */ + Conversation getConversation(); + + /** + * Returns the callback ID. + * + * @return the callback ID + */ + Object getCallbackID(); +} -- cgit v1.2.3