summaryrefslogtreecommitdiffstats
path: root/site/trunk/site-publish/mike-edwards-ramble-through-adding-a-new-implementation-type.html
blob: 3fb2672b360e5eff92c3899d4db56a2b3db6a159 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
<!--

    Licensed to the Apache Software Foundation (ASF) under one or more
    contributor license agreements.  See the NOTICE file distributed with
    this work for additional information regarding copyright ownership.
    The ASF licenses this file to You under the Apache 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://www.apache.org/licenses/LICENSE- 2.0

    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.
-->


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML>
    <HEAD>
		<!-- generateKeywords macro -->
	    <META name="description" content="Apache Tuscany">
        <META name="keywords" content="apache, apache tuscany, tuscany, service, services, fabric, soa, service oriented architecture,  sca, service component architecture, das, sdo, csa, ruby, opensource">
		<!-- generateKeywords macro end -->
		
        <LINK type="text/css" rel="stylesheet" href="http://tuscany.apache.org/stylesheets/default.css">
        <LINK rel="SHORTCUT ICON" href="https://cwiki.apache.org/confluence/display/TUSCANY/$images/favicon.ico">   
        <TITLE>Apache Tuscany : Mike Edwards Ramble through Adding a New Implementation Type</TITLE>
    <META http-equiv="Content-Type" content="text/html;charset=UTF-8"></HEAD>
    
    <BODY onload="init()">
        <!-- topNav macro -->
		<TABLE valign="top" border="0" cellspacing="0" cellpadding="0" width="100%" background="http://tuscany.apache.org/images/TuscanyLogoNEW_Text_120px_bg.jpg">
			<TR>
				<TD valing="top" align="left">
					<A href="https://cwiki.apache.org/confluence/pages/viewpage.action?spaceKey=TUSCANY&title=$siteroot"><IMG src="http://tuscany.apache.org/images/TuscanyLogoNEW_Text_120px_bg.jpg" height="91" width="25" border="0"></A>
				</TD>
				<TD>
					<A href="http://tuscany.apache.org/"><IMG src="http://tuscany.apache.org/images/TuscanyLogo.jpg" border="0"></A>
				</TD>
				
				<TD width="100%">
					&nbsp;
				</TD>

				<!-- Adds the edit page link to the top banner-->
				<TD valign="bottom">
					<DIV style="padding: 2px 10px; margin: 0px;">
						<A href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=53224">
						<IMG src="http://tuscany.apache.org/images/notep_16.gif" height="16" width="16" border="0" align="absmiddle" title="Edit Page"></A>
					</DIV>
				</TD>

			</TR>
		</TABLE>
        <!-- topNav macro end -->

		<!-- breadCrumbs macro -->
		<TABLE border="0" cellpadding="2" cellspacing="0" width="100%">
			<TR class="topBar">
				<TD align="left" valign="middle" class="topBarDiv" nowrap="true" width="100%">
					&nbsp;<A href="home.html" title="Apache Tuscany">Apache Tuscany</A>&nbsp;&gt;&nbsp;<A href="home.html" title="Home">Home</A>&nbsp;&gt;&nbsp;<A href="sca-overview.html" title="SCA Overview">SCA Overview</A>&nbsp;&gt;&nbsp;<A href="sca-java.html" title="SCA Java">SCA Java</A>&nbsp;&gt;&nbsp;<A href="java-sca-documentation-menu.html" title="Java SCA Documentation Menu">Java SCA Documentation Menu</A>&nbsp;&gt;&nbsp;<A href="sca-java-extension-development-guide.html" title="SCA Java Extension Development Guide">SCA Java Extension Development Guide</A>&nbsp;&gt;&nbsp;<A href="" title="Mike Edwards Ramble through Adding a New Implementation Type">Mike Edwards Ramble through Adding a New Implementation Type</A>
				</TD>
				
				<TD align="right" valign="middle" class="topBarDiv" align="left" nowrap="true">
				<A href="http://mail-archives.apache.org/mod_mbox/tuscany-user">User List</A> | <A href="http://mail-archives.apache.org/mod_mbox/tuscany-dev">Dev List</A> | <A href="http://issues.apache.org/jira/browse/Tuscany">Issue Tracker</A>&nbsp;&nbsp;
				</TD>
			</TR>
		</TABLE>
		<!-- breadCrumbs macro end -->


        <TABLE border="0" cellpadding="0" width="100%" bgcolor="#FFFFFF">
            <TR>
                <TD align="left" valign="top">

					<!-- pageContent macro -->
					<DIV id="PageContent">
												
						<DIV class="pagecontent">
							<DIV class="wiki-content">
								<H2><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-AddingaNewImplementationType"></A>Adding a New Implementation Type</H2>

<P>(3rd May 2007) I wanted to get the Spring and BPEL implementation types running with the new Tuscany Java core.&nbsp; This page and those hung off it are my ramblings as I go through the process of building the code for these implementation types.&nbsp; I hope that these will help anyone else who wants to venture down the path of adding an implementation type.&nbsp; Beware that I make no claims as to great insight or special knowledge - and I am sure that there will be things that I have not tackled.</P>

<P>Associated with this general page is a set of pages dedicated to <A href="adding-the-spring-implementation-type.html" title="Adding the Spring Implementation Type">Adding the Spring Implementation Type</A> where specifics relating to the Spring implementation are described.</P>

<H2><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-BasicInformationaboutcodeforanImplementationType%26nbsp%3B"></A>Basic Information about code for an Implementation Type&nbsp;</H2>

<P>To create a Module which supports an Implementation Type, you need to implement a series of interfaces to the Tuscany Core, plus a set of related files which declare your Module to the core:</P>
<UL>
	<LI>xxxModuleActivator class, which implements the ModuleActivator interface</LI>
	<LI>ModuleActivator file, which identifies your code to the core as providing an implementation type</LI>
	<LI>xxxArtifactProcessor class, which processes the XML for an implementation type</LI>
	<LI>xxxImplementation class, which represents a runtime instance of the implementation type</LI>
</UL>


<H3><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-HowdoesaImplementationTypeModuledeclaretheXMLthatithandles%3F"></A>How does a Implementation Type Module declare the XML that it handles?</H3>

<P>For an Implementation Type module, it is going to handle the XML &lt;implementation.xxx.../&gt;, which is a child of a &lt;component.../&gt; element in the SCDL.</P>

<P>How does the module indicate to the core that it handles the &lt;implementation.xxx.../&gt; element?</P>

<P>This is done through the xxxArtifactProcessor.getArtifactType() method.&nbsp; This method returns a QName for the XML element that it implements (ie a combination of the Namespace and the Element name of the element).&nbsp;</P>

<P>The QName for the implementation type is read by the core at the point where the xxxModuleActivator class invokes the addArtifactProcessor() method of the StAXArtifactProcessorExtensionPoint for the core Registry, typically in the start() method of the xxxModuleActivator class.</P>


<H3><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-xxxModuleActivatorclass"></A>xxxModuleActivator class</H3>

<P>Called when the Tuscany core is loading, starting and stopping the Module which provides the implementation type.</P>

<P>Implements ModuleActivator interface, with 3 methods:</P>
<UL>
	<LI>start</LI>
	<LI>stop</LI>
	<LI>getExtensionPoints</LI>
</UL>


<P>Of these, start() is the most important - it seems possible to get by with the other 2 doing nothing.</P>

<P>start() handles:&nbsp;</P>
<UL>
	<LI>Registration of xxxArtifactProcessor, which handles the &lt;implementation.xxx..../&gt; XML</LI>
	<LI>Registration of xxxImplementationProviderFactory, which is a factory class for xxxImplementation objects, which represent instances of the implementation type provided by the module</LI>
	<LI>Creation of objects of various types that may be required by the xxxArtifactProcessor and xxxImplementationProviderFactory classes</LI>
</UL>


<H3><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-TheModuleActivatorfile%26nbsp%3B"></A>The ModuleActivator file&nbsp;</H3>

<P>This must be placed into the location</P>

<P>META-INF/services/org.apache.tuscany.spi.bootstrap.ModuleActivator</P>

<P>... this will be under the Resources directory in the source tree</P>

<P>The file contains the class name for the implementation of your Module, eg:</P>
<DIV class="code panel" style="border-width: 1px;"><DIV class="codeContent panelContent">
<PRE class="code-java"># Implementation class <SPAN class="code-keyword">for</SPAN> the ExtensionActivator <SPAN class="code-keyword">for</SPAN> module Foo
org.apache.tuscany.implementation.foo.FooModuleActivator
</PRE>
</DIV></DIV>

<H3><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-ThexxxArtifactProcessorclass"></A>The xxxArtifactProcessor class</H3>

<P>This class is called to deal with the XML in the composite SCDL files which relates to the implementation type - ie. &lt;implementation.xxx.../&gt;</P>

<P>The class is passed an XML stream which it reads and parses out the contents of the &lt;implementation.xxx.../&gt; element, principally getting all of the attributes and child elements (if present).</P>

<P>When the information has been parsed out, the xxxArtifactProcessor class creates an xxxImplementation object which represents the runtime component corresponding to the implementation.xxx element.</P>

<P>One other step that is handled by the xxxArtifactProcessor class is the resolution of the componentType for the component - teasing out its services, references and properties.&nbsp; This is either done by introspection of the implementation (instance) or via reading a componentType side file.&nbsp;</P>

<H3><A name="MikeEdwardsRamblethroughAddingaNewImplementationType-xxxImplementationclass"></A>xxxImplementation class</H3>

<P>The xxxImplementation class represents the implementation instances themselves.</P>

<P>Implements the org.apache.tuscany.assembly.Implementation interface&nbsp;</P>
							</DIV>
						</DIV>
					</DIV>	
		            <!-- pageContent macro end -->
					
                </TD>
            </TR>
        </TABLE>

		<!-- footer macro -->
				<SCRIPT src="http://www.google-analytics.com/urchin.js" type="text/javascript">
		</SCRIPT>
		<SCRIPT type="text/javascript">
		   _uacct = "UA-1174707-5";
		   urchinTracker();
		</SCRIPT>
		
				<A href="http://www.statcounter.com/" target="_blank"><IMG src="http://c26.statcounter.com/counter.php?sc_project=2619156&java=0&security=94bd7e7d&invisible=0" alt="website stats" border="0"></A>    

		<DIV class="footer">
			Copyright � 2003-2012, The Apache Software Foundation&nbsp;&nbsp;</BR>
                        Apache Tuscany and the Apache Tuscany project logo are trademarks of The Apache Software Foundation.
		</DIV>
		<!-- footer macro end -->

    </BODY>
</HTML>