From 200a40b332420f94992eb39a6d0ea1cf1490ffc4 Mon Sep 17 00:00:00 2001 From: coreyg Date: Fri, 21 Nov 2014 09:30:19 +0000 Subject: Adding tuscany's website to their svn repo for svnpubsub git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1640879 13f79535-47bb-0310-9956-ffa450edef68 --- .../java-sca-extension-developer-guide.html | 241 +++++++++++++++++++++ 1 file changed, 241 insertions(+) create mode 100644 site/trunk/site-publish/java-sca-extension-developer-guide.html (limited to 'site/trunk/site-publish/java-sca-extension-developer-guide.html') diff --git a/site/trunk/site-publish/java-sca-extension-developer-guide.html b/site/trunk/site-publish/java-sca-extension-developer-guide.html new file mode 100644 index 0000000000..8b971c6aed --- /dev/null +++ b/site/trunk/site-publish/java-sca-extension-developer-guide.html @@ -0,0 +1,241 @@ + + + + + + + Java SCA Extension Developer Guide : Apache Tuscany + + + + + + + + + + + + + + +
+ + + + +   + +
+ + +
+
+ + + + + + + +
+  Apache Tuscany > Home > Java SCA Subproject > Java SCA Documentation Menu > Java SCA Extension Developer Guide + + User List | Dev List | Issue Tracker   +
+ + + + + +
+
+ +
+
+
Apache Tuscany SCA Java Extension Guide
+ +
+ +

This page is work in progress. Thanks for your contribution
+This is a guide for developers who would like to extend Tuscany SCA Java.

+ + + + + + +

A presentation on how to extend Tuscany in Microsoft PowerPoint format

+

ExtendingTuscany

+ + +

What is an extension?

+ +

Extension is a module (or a set of modules),when built with Tuscany SCA, can extend it to work with additional bindings, language implementations, programming models or databindings.

+ +

SCA assembly model is defined such that extensions can be added for new interface types or for new implementation types such as ruby and python, or new binding types such as CXF. However, the definition of extension SPIs is left to the implementor. Tuscany SCA Java provides a simple set of SPIs for implementing extensions. It also defines additional extension points such as data binding, for example support for SDO and JAXB.

+ +

This guide explains the steps to add each of these extension types. Please help us refine the guide as you go through the steps of adding extensions.

+ +

Name spaces used by extensions

+ + +

How to add a new component implementation?

+ +

Musings on Adding a New Component Type by Mike E 

+ +

How to add a new binding?

+ + +

How to add a new interface binding?

+ + +

How to add a new databinding?

+ + +

General guide for developing extensions

+ +
    +
  • Familiarize yourself with SCA 1.0 Assembly and the SCA Java 1.0 programming model. Specifications can be found at www.osoa.org.
  • +
  • Never reference any classes in core. These classes are implementation-specific and subject to change; they are not part of the public SPI contract.
  • +
  • Use autowire when assembling extension components.
  • +
  • Do not play with classloaders such as setting the current context classloader unless it is absolutely necessary, i.e. a library used by an extension makes assumptions about context classloaders. Ideally the library can be refactored to not make these assumptions. If not, make sure the extension properly resets the current context classloader.
  • +
+ + +

Detail on extension architecture

+ + +

The ExtensionPointRegistry

+ +
+
package org.apache.tuscany.sca.core;
+
+
+/**
+ * The registry for the Tuscany core extension points. As the point of contact
+ * for all extension artifacts this registry allows loaded extensions to find
+ * all other parts of the system and register themselves appropriately.
+ *
+ * @version $Rev: 539355 $ $Date: 2007-05-18 03:05:14 -0700 (Fri, 18 May 2007) $
+ */
+public interface ExtensionPointRegistry {
+
+    /**
+     * Add an extension point to the registry
+     * @param extensionPoint The instance of the extension point
+     */
+    void addExtensionPoint(Object extensionPoint);
+
+    /**
+     * Get the extension point by the interface
+     * @param extensionPointType The lookup key (extension point interface)
+     * @return The instance of the extension point
+     */
+    <T> T getExtensionPoint(Class<T> extensionPointType);
+
+    /**
+     * Remove an extension point
+     * @param extensionPoint The extension point to remove
+     */
+    void removeExtensionPoint(Object extensionPoint);
+}
+
+ +

The ModuleActivator

+ +
+
package org.apache.tuscany.core;
+
+import java.util.Map;
+
+/**
+ * ModuleActivator represents a module that plugs into the Tuscany system. Each module should
+ * provide an implementation of this interface and registry the implementation class by defining
+ * a file named as "META-INF/services/org.apache.tuscany.spi.bootstrp.ModuleActivator". The
+ * content of the file is the class name of the implementation. The implementation class must
+ * have a no-arg constructor. The same instance will be used to invoke all the methods during
+ * different phases of the module activation.
+ *
+ * @version $Rev: 529327 $ $Date: 2007-04-16 10:10:43 -0700 (Mon, 16 Apr 2007) $
+ */
+public interface ModuleActivator {
+    /**
+     * Get a map of the extension points defined by this module. The key is the
+     * java interface to represent the extension point and the the value is the
+     * instance of the implementation of the interface.
+     *
+     * @return All the extension points defined by this module
+     */
+    Map<Class, Object> getExtensionPoints();
+
+    /**
+     * This method is invoked when the module is started by the Tuscany system.
+     * It can be used by this module to registr extensions against extension
+     * points.
+     *
+     * @param registry The extension point registry
+     */
+    void start(ExtensionPointRegistry registry);
+
+    /**
+     * This method is invoked when the module is stopped by the Tuscany system.
+     * It can be used by this module to unregister extensions against the
+     * extension points.
+     *
+     * @param registry The extension point registry
+     */
+    void stop(ExtensionPointRegistry registry);
+}
+
+

The ModuleActivator represents a module that plugs into the Tuscany system.
+Each module should provide an implementation 3 of this interface and
+registry the implementation class by defining a file named as
+"META-INF/services/org.apache.tuscany.spi.bootstrp.ModuleActivator" 4. The
+content of the file is the class name of the implementation. The
+implementation class must have a no-arg constructor. The same instance will
+be used to invoke all the methods during different phases of the module
+activation.

+ +

During bootstraping, the following sequence will happen:

+ +

1) All the module activators will be discovered by the presence of
+META-INF/services/org.apache.tuscany.spi.bootstrp.ModuleActivator
+2) The activator class is instantiated using the no-arg constructor.
+3) ModuleActivator.getExtensionPoints() is invoked for all modules and the
+extension points contributed by each module are added to the
+ExtensionRegistry.
+4) ModuleActivator.start(ExtensionRegistry) is invoked for all the modules.
+The module can then get interested extension points and contribute
+extensions to them. The contract bwteen the extension and extension point is
+private to the extension point. The extension point can follow similar
+patterns such as Registry. If it happens that one extension point has a
+dependency on another extension point, they can linked at this phase.

+ +

During shutting down, the stop() method is invoked for all the modules to
+perform cleanups. A module can choose to unregister the extension from the
+extension points.

+
+
+
+
+ + + + + \ No newline at end of file -- cgit v1.2.3