You are viewing a plain text version of this content. The canonical link for it is here.
Posted to nuvem-commits@incubator.apache.org by jo...@apache.org on 2011/05/07 22:44:15 UTC

svn commit: r1100647 [3/4] - in /incubator/nuvem/trunk/nuvem-samples: store-appengine-webapp/ store-appengine-webapp/src/ store-appengine-webapp/src/services/ store-appengine-webapp/war/ store-appengine-webapp/war/META-INF/ store-appengine-webapp/war/W...

Added: incubator/nuvem/trunk/nuvem-samples/store-catalog-ibmcloud-webapp/store.svg
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-catalog-ibmcloud-webapp/store.svg?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-catalog-ibmcloud-webapp/store.svg (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-catalog-ibmcloud-webapp/store.svg Sat May  7 22:44:12 2011
@@ -0,0 +1,304 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!--
+ * 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.
+-->
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://web.resource.org/cc/"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:xlink="http://www.w3.org/1999/xlink"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="1052.3622"
+   height="744.09448"
+   id="svg2"
+   sodipodi:version="0.32"
+   inkscape:version="0.45.1"
+   sodipodi:docbase="C:\simon\tuscany\java-head\sca\samples\store"
+   sodipodi:docname="store.svg"
+   version="1.0"
+   inkscape:output_extension="org.inkscape.output.svg.inkscape"
+   inkscape:export-filename="C:\simon\tuscany\java-head\sca\samples\store\store.png"
+   inkscape:export-xdpi="52.84"
+   inkscape:export-ydpi="52.84">
+  <defs
+     id="defs4" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     gridtolerance="10000"
+     guidetolerance="10"
+     objecttolerance="10"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="1.4"
+     inkscape:cx="538.06165"
+     inkscape:cy="341.69129"
+     inkscape:document-units="px"
+     inkscape:current-layer="g2997"
+     inkscape:window-width="1466"
+     inkscape:window-height="831"
+     inkscape:window-x="117"
+     inkscape:window-y="80" />
+  <metadata
+     id="metadata7">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Layer 1"
+     inkscape:groupmode="layer"
+     id="layer1">
+    <g
+       id="g2997">
+      <rect
+         rx="14.335117"
+         ry="17.743465"
+         y="197.1973"
+         x="447.35422"
+         height="419.39099"
+         width="464.23727"
+         id="rect2067"
+         style="opacity:1;fill:#90baf4;fill-opacity:1;stroke:#060000;stroke-width:2.28840661;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1" />
+      <flowRoot
+         id="flowRoot2954"
+         xml:space="preserve"
+         transform="translate(189.90868,1.0101522)"><flowRegion
+           id="flowRegion2956"><rect
+             y="212.66591"
+             x="281.42856"
+             height="61.42857"
+             width="170"
+             id="rect2958" /></flowRegion><flowPara
+           id="flowPara2171">store</flowPara></flowRoot>      <rect
+         style="fill:#317fed;fill-opacity:1;stroke:#060000;stroke-width:2.30182266;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+         id="rect2175"
+         width="118.21779"
+         height="111.27543"
+         x="491.60019"
+         y="247.75989"
+         rx="7.1507306"
+         ry="9.2311935" />
+      <flowRoot
+         xml:space="preserve"
+         id="flowRoot2177"
+         transform="translate(223.8585,41.670449)"><flowRegion
+           id="flowRegion2179"><rect
+             id="rect2181"
+             width="170"
+             height="61.42857"
+             x="281.42856"
+             y="212.66591" /></flowRegion><flowPara
+           id="flowPara2183">ufs</flowPara></flowRoot>      <path
+         style="fill:#5b9d05;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 474.29877,279.45598 L 507.63381,279.45598 L 513.69472,292.58796 L 506.62366,304.7098 L 474.29877,304.7098 L 481.87492,292.58796 L 474.29877,279.45598 z "
+         id="path2187" />
+      <rect
+         style="fill:#317fed;fill-opacity:1;stroke:#060000;stroke-width:2;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+         id="rect2191"
+         width="115.66247"
+         height="85.862968"
+         x="493.07068"
+         y="503.27759"
+         rx="6.9961648"
+         ry="7.1230249" />
+      <flowRoot
+         xml:space="preserve"
+         id="flowRoot2193"
+         transform="translate(225.47992,297.33908)"><flowRegion
+           id="flowRegion2195"><rect
+             id="rect2197"
+             width="170"
+             height="61.42857"
+             x="281.42856"
+             y="212.66591" /></flowRegion><flowPara
+           id="flowPara2199">ShoppingCart</flowPara></flowRoot>      <path
+         style="fill:#5b9d05;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 475.92019,535.12461 L 509.25523,535.12461 L 515.31614,548.25659 L 508.24508,560.37843 L 475.92019,560.37843 L 483.49634,548.25659 L 475.92019,535.12461 z "
+         id="path2203" />
+      <rect
+         style="fill:#317fed;fill-opacity:1;stroke:#060000;stroke-width:2;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+         id="rect2207"
+         width="115.66247"
+         height="85.862968"
+         x="761.44415"
+         y="391.31604"
+         rx="6.9961648"
+         ry="7.1230249" />
+      <flowRoot
+         xml:space="preserve"
+         id="flowRoot2209"
+         transform="translate(487.8534,185.37751)"><flowRegion
+           id="flowRegion2211"><rect
+             id="rect2213"
+             width="170"
+             height="61.42857"
+             x="281.42856"
+             y="212.66591" /></flowRegion><flowPara
+           id="flowPara2215">CurrencyConverter</flowPara></flowRoot>      <path
+         style="fill:#5b9d05;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 744.29367,423.16304 L 777.62871,423.16304 L 783.68962,436.29502 L 776.61856,448.41686 L 744.29367,448.41686 L 751.86982,436.29502 L 744.29367,423.16304 z "
+         id="path2219" />
+      <rect
+         style="opacity:1;fill:#0064ff;fill-opacity:1;stroke:#000000;stroke-width:0.9612025;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+         id="rect2223"
+         width="104.08451"
+         height="113.17588"
+         x="138.37151"
+         y="350.1156"
+         rx="0"
+         ry="0.048917599" />
+      <path
+         style="fill:#1a73fe;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;fill-opacity:1"
+         d="M 138.21429,462.66591 L 115.35714,479.80877 L 267.85714,479.80877 L 241.78571,463.02305 L 138.21429,462.66591 z "
+         id="path3197" />
+      <rect
+         style="opacity:1;fill:#f1f4f8;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+         id="rect3199"
+         width="92.5"
+         height="97.14286"
+         x="143.57143"
+         y="358.38019"
+         ry="3.6203461"
+         rx="3.9285715" />
+      <image
+         y="366.6889"
+         x="156.24066"
+         id="image3323"
+         height="78.571434"
+         width="58.57143"
+         sodipodi:absref="C:\simon\tuscany\evangelism\whitepapers\shoppingcart.png"
+         xlink:href="C:\simon\tuscany\evangelism\whitepapers\shoppingcart.png" />
+      <image
+         y="270.52304"
+         x="526.42859"
+         id="image3342"
+         height="78.571434"
+         width="58.57143"
+         sodipodi:absref="C:\simon\tuscany\evangelism\whitepapers\shoppingcart.png"
+         xlink:href="C:\simon\tuscany\evangelism\whitepapers\shoppingcart.png" />
+      <path
+         style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 242.85714,374.80877 C 245.71429,374.80877 345.71429,374.80877 345.71429,374.80877 L 345.71429,291.95162 L 481.42858,291.95162"
+         id="path3348"
+         sodipodi:nodetypes="cccc" />
+      <path
+         style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 210.71429,406.95163 L 345,406.95163 L 345,437.66591 L 481.42857,437.66591"
+         id="path3350"
+         sodipodi:nodetypes="cccc" />
+      <path
+         style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 210.71429,439.09448 L 325.71429,439.09448 L 325.71429,548.3802 L 482.85714,548.3802"
+         id="path3352"
+         sodipodi:nodetypes="cccc" />
+      <path
+         style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+         d="M 626.42857,436.23734 C 750,437.66591 752.14286,436.23734 752.14286,436.23734"
+         id="path3354"
+         sodipodi:nodetypes="cc" />
+      <flowRoot
+         xml:space="preserve"
+         id="flowRoot3356"
+         transform="translate(-94.285714,25)"><flowRegion
+           id="flowRegion3358"><rect
+             id="rect3360"
+             width="142.14285"
+             height="21.428572"
+             x="655"
+             y="349.80878" /></flowRegion><flowPara
+           id="flowPara3362">CurrenyCode</flowPara></flowRoot>      <flowRoot
+         xml:space="preserve"
+         id="flowRoot3364"
+         transform="translate(-250.76562,-76.210859)"><flowRegion
+           id="flowRegion3366"><rect
+             id="rect3368"
+             width="142.14285"
+             height="21.428572"
+             x="655"
+             y="349.80878" /></flowRegion><flowPara
+           id="flowPara3370">HTTP</flowPara></flowRoot>      <flowRoot
+         xml:space="preserve"
+         id="flowRoot3372"
+         transform="translate(-273.62277,70.931998)"><flowRegion
+           id="flowRegion3374"><rect
+             id="rect3376"
+             width="142.14285"
+             height="21.428572"
+             x="655"
+             y="349.80878" /></flowRegion><flowPara
+           id="flowPara3378">JSONRPC</flowPara></flowRoot>      <flowRoot
+         xml:space="preserve"
+         id="flowRoot3380"
+         transform="translate(-243.62277,183.07485)"><flowRegion
+           id="flowRegion3382"><rect
+             id="rect3384"
+             width="142.14285"
+             height="21.428572"
+             x="655"
+             y="349.80878" /></flowRegion><flowPara
+           id="flowPara3386">Atom</flowPara></flowRoot>    </g>
+    <rect
+       style="fill:#317fed;fill-opacity:1;stroke:#060000;stroke-width:2;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+       id="rect2988"
+       width="115.66247"
+       height="85.862968"
+       x="491.56897"
+       y="392.70135"
+       rx="6.9961648"
+       ry="7.1230249" />
+    <flowRoot
+       xml:space="preserve"
+       id="flowRoot2966"
+       transform="translate(223.97819,186.76283)"><flowRegion
+         id="flowRegion2968"><rect
+           id="rect2970"
+           width="170"
+           height="61.42857"
+           x="281.42856"
+           y="212.66591" /></flowRegion><flowPara
+         id="flowPara2972">Catalog</flowPara></flowRoot>    <rect
+       style="opacity:1;fill:#fff62c;fill-opacity:1;stroke:#060000;stroke-width:1;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
+       id="rect3006"
+       width="21.718224"
+       height="20.708065"
+       x="537.53094"
+       y="377.04398"
+       rx="10.859112"
+       ry="0" />
+    <path
+       style="fill:#5b9d05;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 474.41846,424.54836 L 507.7535,424.54836 L 513.81441,437.68034 L 506.74335,449.80218 L 474.41846,449.80218 L 481.99461,437.68034 L 474.41846,424.54836 z "
+       id="path3017" />
+    <path
+       style="fill:#ae62bf;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 587.6709,422.71008 L 621.00594,422.71008 L 627.06685,435.84206 L 619.99579,447.9639 L 587.6709,447.9639 L 595.24705,435.84206 L 587.6709,422.71008 z "
+       id="path3019" />
+  </g>
+</svg>

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/build-dojo.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/build-dojo.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/build-dojo.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/build-dojo.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,92 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ * 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.
+-->
+<project name="DojoZipInstaller">
+	
+
+    <property name="dojo.version" value="1.3.0"/>
+    <property name="unpack.location" value="${basedir}/war/dojo"/>
+	
+
+    <target name="check-dojo-installed">
+        <condition property="already.installed" >
+            <available file="${localRepository}/dojo/dojo/${dojo.version}/dojo-${dojo.version}.zip"/>
+        </condition>
+        <condition property="maven.suffix" value="">
+            <os family="unix"/>
+        </condition>
+        <condition property="maven.suffix" value=".bat">
+            <os family="windows"/>
+        </condition>
+    </target>
+	
+
+    <target name="check-dojo-unpacked">
+        <condition property="already.unpacked" >
+            <available file="${unpack.location}"/>
+        </condition>
+    </target>
+
+    <target name="install-dojo" depends="check-dojo-installed" unless="already.installed">
+        <mkdir dir="${basedir}/target/dojo-download/"/>
+        <get src="http://download.dojotoolkit.org/release-${dojo.version}/dojo-release-${dojo.version}.zip"
+            dest="${basedir}/target/dojo-download/dojo-release-${dojo.version}.zip"
+            verbose="true"
+            usetimestamp="true"/>
+        <exec executable="mvn${maven.suffix}" dir="${basedir}" failonerror="false">
+            <arg line="install:install-file -DgroupId=dojo  -DartifactId=dojo -Dversion=${dojo.version} -Dpackaging=zip -DgeneratePom=true -Dfile=${basedir}/target/dojo-download/dojo-release-${dojo.version}.zip"/>
+        </exec>
+    </target>
+
+    <target name="install-dojo-nomaven" depends="check-dojo-installed" unless="already.installed">
+        <mkdir dir="${basedir}/target/dojo-download/"/>
+        <get src="http://download.dojotoolkit.org/release-${dojo.version}/dojo-release-${dojo.version}.zip"
+            dest="${basedir}/target/dojo-download/dojo-release-${dojo.version}.zip"
+            verbose="true"
+            usetimestamp="true"/>
+        <copy file="${basedir}/target/dojo-download/dojo-release-${dojo.version}.zip" 
+              tofile="${localRepository}/dojo/dojo/${dojo.version}/dojo-${dojo.version}.zip"/>
+    </target>
+	
+
+    <target name="unpack-dojo-files" depends="check-dojo-installed, check-dojo-unpacked" unless="already.unpacked">
+        <fail message="dojo zip file not installed in local repository: ${localRepository}" unless="already.installed"/>
+        <mkdir dir="${basedir}/target/dojo-unpack-temp/"/>
+        <unzip src="${localRepository}/dojo/dojo/${dojo.version}/dojo-${dojo.version}.zip"
+               dest="${basedir}/target/dojo-unpack-temp/"
+               overwrite="false">
+            <patternset>
+                <include name="dojo-release-${dojo.version}/dojo/**"/>
+                <exclude name="dojo-release-${dojo.version}/dojo/tests/**"/>
+                <include name="dojo-release-${dojo.version}/dijit/**"/>
+                <exclude name="dojo-release-${dojo.version}/dojox/**"/>
+                <exclude name="dojo-release-${dojo.version}/util/**"/>
+            </patternset>
+        </unzip>
+        <move file="${basedir}/target/dojo-unpack-temp/dojo-release-${dojo.version}"
+              tofile="${unpack.location}"
+              verbose="true"/>
+        <delete dir="${basedir}/target/dojo-unpack-temp/"/>
+    </target>
+	
+
+    <target name="clean-dojo-files">
+        <delete dir="${unpack.location}"/>
+    </target>
+</project>

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/pom.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/pom.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/pom.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/pom.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,217 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+    * 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.
+-->
+<project>
+    <modelVersion>4.0.0</modelVersion>
+    <parent>
+        <groupId>org.apache.nuvem</groupId>
+        <artifactId>nuvem-samples</artifactId>
+        <version>1.0-incubating-SNAPSHOT</version>
+        <relativePath>../pom.xml</relativePath>
+    </parent>
+    <artifactId>store-merger-appengine-webapp</artifactId>
+	<version>1.0-incubating-SNAPSHOT</version>
+    <packaging>war</packaging>
+    <name>Apache Nuvem Cloud Store Scenario for Google App Engine</name>
+
+    <dependencies>
+        <dependency>
+            <groupId>org.apache.nuvem</groupId>
+            <artifactId>store-assets</artifactId>
+            <version>${project.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.nuvem</groupId>
+            <artifactId>nuvem-api</artifactId>
+            <version>${project.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.nuvem</groupId>
+            <artifactId>nuvem-google</artifactId>
+            <version>${project.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-sca-api</artifactId>
+            <version>${tuscany.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-implementation-java-runtime</artifactId>
+            <version>${tuscany.version}</version>
+            <scope>runtime</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-binding-jsonrpc-runtime</artifactId>
+            <version>${tuscany.version}</version>
+            <scope>runtime</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-host-webapp</artifactId>
+            <version>${tuscany.version}</version>
+            <scope>runtime</scope>
+            <exclusions>
+                <exclusion>
+                    <groupId>org.apache.tuscany.sca</groupId>
+                    <artifactId>tuscany-databinding-jaxb</artifactId>
+                </exclusion>
+                <exclusion>
+                    <groupId>org.apache.tuscany.sca</groupId>
+                    <artifactId>tuscany-interface-java-jaxws</artifactId>
+                </exclusion>
+            </exclusions>
+        </dependency>
+
+        <dependency>
+            <groupId>javax.servlet</groupId>
+            <artifactId>servlet-api</artifactId>
+            <version>2.5</version>
+            <scope>provided</scope>
+        </dependency>
+    </dependencies>
+
+    <build>
+        <finalName>${artifactId}</finalName>
+        <sourceDirectory>src</sourceDirectory>
+        <outputDirectory>war/WEB-INF/classes</outputDirectory>
+        <plugins>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-eclipse-plugin</artifactId>
+                <configuration>
+                    <sourceIncludes>
+                        <sourceInclude>**/*</sourceInclude>
+                    </sourceIncludes>
+
+                    <projectnatures>
+                        <projectnature>org.eclipse.jdt.core.javanature</projectnature>
+                        <projectnature>com.google.appengine.eclipse.core.gaeNature</projectnature>
+                        <projectnature>com.google.gdt.eclipse.core.webAppNature</projectnature>
+                    </projectnatures>
+                    <buildcommands>
+                        <buildcommand>org.eclipse.jdt.core.javabuilder</buildcommand>
+                        <buildcommand>com.google.appengine.eclipse.core.enhancerbuilder</buildcommand>
+                        <buildcommand>com.google.appengine.eclipse.core.projectValidator</buildcommand>
+                        <buildcommand>com.google.gdt.eclipse.core.webAppProjectValidator</buildcommand>
+                    </buildcommands>
+                    <classpathContainers>
+                        <classpathContainer>org.eclipse.jdt.launching.JRE_CONTAINER</classpathContainer>
+                        <classpathContainer>com.google.appengine.eclipse.core.GAE_CONTAINER</classpathContainer>
+                    </classpathContainers>
+                </configuration>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-antrun-plugin</artifactId>
+                <!-- version>1.1</version -->
+                <dependencies>
+                    <dependency>
+                        <groupId>ant</groupId>
+                        <artifactId>ant-trax</artifactId>
+                        <version>1.6.5</version>
+                    </dependency>
+                </dependencies>
+                <executions>
+                    <execution>
+                        <id>install-dojo</id>
+                        <phase>validate</phase>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <configuration>
+                            <tasks>
+                                <ant antfile="./build-dojo.xml" target="install-dojo">
+                                    <property name="localRepository" value="${settings.localRepository}" />
+                                </ant>
+                            </tasks>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <id>copy-dojo-files</id>
+                        <phase>generate-resources</phase>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <configuration>
+                            <tasks>
+                                <ant antfile="./build-dojo.xml" target="unpack-dojo-files">
+                                    <property name="localRepository" value="${settings.localRepository}" />
+                                    <property name="artifactId" value="${artifactId}" />
+                                </ant>
+                            </tasks>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <id>clean-dojo-files</id>
+                        <phase>clean</phase>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <configuration>
+                            <tasks>
+                                <ant antfile="./build-dojo.xml" target="clean-dojo-files">
+                                    <property name="localRepository" value="${settings.localRepository}" />
+                                    <property name="artifactId" value="${artifactId}" />
+                                </ant>
+                            </tasks>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-dependency-plugin</artifactId>
+                <version>2.1</version>
+                <executions>
+                    <execution>
+                        <id>copy-dependencies</id>
+                        <phase>process-sources</phase>
+                        <goals>
+                            <goal>copy-dependencies</goal>
+                        </goals>
+                        <configuration>
+                            <outputDirectory>war/WEB-INF/lib</outputDirectory>
+                            <overWriteIfNewer>true</overWriteIfNewer>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-war-plugin</artifactId>
+                <version>2.1-beta-1</version>
+                <configuration>
+                    <warSourceDirectory>war</warSourceDirectory>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+
+</project>

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/src/Workaround.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/src/Workaround.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/src/Workaround.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/src/Workaround.java Sat May  7 22:44:12 2011
@@ -0,0 +1,22 @@
+/*
+ * 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.    
+ */
+
+public class Workaround {
+
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/META-INF/sca-contribution.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/META-INF/sca-contribution.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/META-INF/sca-contribution.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/META-INF/sca-contribution.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,26 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+    * 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.
+-->
+<contribution xmlns="http://docs.oasis-open.org/ns/opencsa/sca/200912"
+	xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+	xmlns:store="http://store">
+
+	<deployable composite="store:store" />
+	<!-- import.java package="services" / -->
+</contribution>
\ No newline at end of file

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/appengine-web.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/appengine-web.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/appengine-web.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/appengine-web.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,29 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!--
+  * 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.
+-->
+<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
+	<application>tuscany-store-merger</application>
+	<version>3</version>
+
+	<!-- Configure java.util.logging -->
+	<system-properties>
+		<property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
+	</system-properties>
+
+</appengine-web-app>
\ No newline at end of file

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/logging.properties
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/logging.properties?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/logging.properties (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/logging.properties Sat May  7 22:44:12 2011
@@ -0,0 +1,37 @@
+#
+#
+#    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.
+#
+#
+# A default java.util.logging configuration.
+# (All App Engine logging is through java.util.logging by default).
+#
+# To use this configuration, copy it into your application's WEB-INF
+# folder and add the following to your appengine-web.xml:
+# 
+# <system-properties>
+#   <property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
+# </system-properties>
+#
+
+# Set the default logging level for all loggers to WARNING
+.level = WARNING
+
+#tuscany debug messages
+org.apache.tuscany.level = WARNING
+

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/web.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/web.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/web.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/WEB-INF/web.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,42 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  * 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 web-app
+    PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
+    "http://java.sun.com/dtd/web-app_2_3.dtd">
+
+<web-app>
+
+	<!-- Tuscany Filter -->
+	<filter>
+		<filter-name>tuscany</filter-name>
+		<filter-class>org.apache.tuscany.sca.host.webapp.TuscanyServletFilter</filter-class>
+	</filter>
+
+	<filter-mapping>
+		<filter-name>tuscany</filter-name>
+		<url-pattern>/*</url-pattern>
+	</filter-mapping>
+
+	<!-- Default page to serve -->
+	<welcome-file-list>
+		<welcome-file>store.html</welcome-file>
+	</welcome-file-list>
+
+</web-app>

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.composite
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.composite?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.composite (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.composite Sat May  7 22:44:12 2011
@@ -0,0 +1,68 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ * 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.
+-->
+<composite xmlns="http://docs.oasis-open.org/ns/opencsa/sca/200912"
+           xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+	       xmlns:s="http://store"
+	       targetNamespace="http://store"
+	       name="store">
+
+	<component name="CatalogAggregator">
+		<implementation.java class="services.CatalogAggregatorImpl"/>
+		<property name="currencyCode">USD</property>
+		<service name="Catalog">
+		    <interface.java interface="services.Catalog"/>
+			<tuscany:binding.jsonrpc uri="/Catalog"/>
+		</service>
+		<reference name="fruitsCatalog">
+		    <interface.java interface="services.Catalog"/>
+			<tuscany:binding.jsonrpc uri="http://tuscany-store-catalog.appspot.com/Catalog"/>
+		</reference>
+		<!--reference name="vegetablesCatalog">
+		    <interface.java interface="services.Catalog"/>
+			<tuscany:binding.jsonrpc uri="http://tuscany.figueiredos.com/store-catalog-ibmcloud-webapp/Catalog"/>
+		</reference-->
+		<reference name="currencyConverter" target="CurrencyConverter" />
+	</component>
+
+	<component name="CurrencyConverter">
+		<implementation.java class="services.CurrencyConverterImpl" />
+		<service name="CurrencyConverter">
+			<interface.java interface="services.CurrencyConverter"/>
+		</service>
+	</component>
+
+	<component name="ShoppingCartManager">
+		<implementation.java class="services.ShoppingCartManager"/>
+		<service name="ShoppingCart">
+			<tuscany:binding.jsonrpc uri="/ShoppingCart"/>
+		</service>
+		<reference name="userService" target="UserService">
+			<binding.sca name="local"/>
+		</reference>
+	</component>
+
+	<component name="UserService">
+		<implementation.java class="org.apache.nuvem.cloud.user.impl.GoogleUserService"/>
+		<service name="UserService">
+			<binding.sca name="local"/>
+			<tuscany:binding.jsonrpc uri="/User"/>
+		</service>
+	</component>
+</composite>

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.css
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.css?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.css (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.css Sat May  7 22:44:12 2011
@@ -0,0 +1,39 @@
+/*
+ * 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
+ */
+<style type="text/css">
+
+html, body {
+	height:100%;
+	margin:0;
+	overflow:hidden;
+	width:100%;
+}
+
+.header {
+	font-size:13px;
+	text-align:right;
+	color:#CCCCCC;
+
+
+	padding:5px 5px 0;
+	padding-right:8px;
+	padding-top:0px !important;
+	padding-bottom: 0px;
+	border-bottom: 1px solid black;
+}
+</style>
\ No newline at end of file

Added: incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.html
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.html?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.html (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-merger-appengine-webapp/war/store.html Sat May  7 22:44:12 2011
@@ -0,0 +1,194 @@
+<!--
+    * 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.
+-->
+<html>
+<head>
+<meta http-equiv="content-type" content="text/html; charset=UTF-8">
+<title>Online Store - Powered by Apache Tuscany</title>
+
+<link href="store.css" rel="stylesheet" type="text/css">
+
+<script type="text/javascript" src="dojo/dojo/dojo.js"></script>
+
+<script type="text/javascript">
+    	dojo.require("dojo.rpc.JsonService");
+</script>
+
+<script language="JavaScript">
+
+	var userServices = new dojo.rpc.JsonService("/User?smd");
+
+	var catalog = new dojo.rpc.JsonService("/Catalog?smd");
+
+	var shoppingCart = new dojo.rpc.JsonService("/ShoppingCart?smd");
+
+	var userContext;
+
+	var catalogItems;
+
+	function showHeader() {
+		var userContextCallback = function(context) {
+			userContext = context;
+			//alert(userContext.userId + " --> " + userContext.loginUrl);
+
+			var html='';
+			if(! userContext.userId) {
+				 html = "<a href='" + userContext.loginUrl +"'>Login</a>";
+			} else {
+				html = userContext.email + " | <a href='" + userContext.logoutUrl +"'> Logout</a>";
+			}
+
+			document.getElementById('appHeader').innerHTML = html;
+		}
+
+		userServices.getUserContext(document.URL, "").addCallback(userContextCallback);
+	}
+
+	function showCatalogs() {
+		var catalogCallback = function(items) {
+			var catalog = "";
+			for (var i=0; i<items.length; i++) {
+				var item = items[i].name + ' - ' + items[i].currencySymbol + items[i].price;
+				catalog += '<input name="items" type="checkbox" value="' +
+							item + '">' + item + ' <br>';
+			}
+			document.getElementById('catalog').innerHTML=catalog;
+			catalogItems = items;
+		}
+
+		catalog.items().addCallback(catalogCallback);
+	}
+
+
+	// This handles the response from shoppingCart.getAll
+	// which is a collection of Entry<K,D>
+	function shoppingCart_getResponse(items) {
+		var list='';
+		for (var i=0; i<items.length; i++) {
+			//get the actual item, that is Entry.data
+			var item = items[i].data;
+			// process its attributes
+			var name = item.name;
+			var symbol = item.currencySymbol;
+			var price = item.price
+			list += name + ' - ' + symbol + price + ' <br>';
+		}
+		document.getElementById("shoppingCart").innerHTML = list;
+
+		if (items.length != 0) {
+			try	{
+				shoppingCart.getTotal().addCallback(shoppingCart_getTotalResponse);
+			}
+			catch(e){
+				alert(e);
+			}
+		}
+	}
+
+	function shoppingCart_getTotalResponse(total,exception) {
+		if(exception) {
+			alert(exception.message);
+			return;
+		}
+		document.getElementById('total').innerHTML = total;
+	}
+
+	function shoppingCart_postResponse(entry) {
+		shoppingCart.getAll().addCallback(shoppingCart_getResponse);
+	}
+
+	function addToCart() {
+		var items  = document.catalogForm.items;
+		var j = 0;
+		for (var i=0; i<items.length; i++)
+			if (items[i].checked) {
+				shoppingCart.post("", catalogItems[i]).addCallback(shoppingCart_postResponse);
+				items[i].checked = false;
+			}
+	}
+	function checkoutCart() {
+		document.getElementById('store').innerHTML='<h2>' +
+				'Thanks for Shopping With Us!</h2>'+
+				'<h2>Your Order</h2>'+
+				'<form name="orderForm">'+
+					document.getElementById('shoppingCart').innerHTML+
+					'<br>'+
+					document.getElementById('total').innerHTML+
+					'<br>'+
+					'<br>'+
+					'<input type="submit" value="Continue Shopping">'+
+				'</form>';
+		shoppingCart.delete("");
+	}
+	function deleteCart() {
+		shoppingCart.delete("");
+		document.getElementById('shoppingCart').innerHTML = "";
+		document.getElementById('total').innerHTML = "";
+	}
+
+
+
+	function init() {
+		try {
+			showHeader();
+
+			showCatalogs();
+
+			shoppingCart.getAll().addCallback(shoppingCart_getResponse);
+		} catch (e) {
+			alert(e);
+		}
+	}
+
+
+</script>
+
+</head>
+
+<body onload="init()">
+   <div id="appHeader" class="header">
+   </div>
+
+   <h1>Store</h1>
+
+
+
+  <div id="store">
+   	<h2>Catalog</h2>
+   	<form name="catalogForm">
+		<div id="catalog" ></div>
+        <br>
+		<input type="button" onClick="addToCart()"  value="Add to Cart">
+   	</form>
+
+
+ 	<br>
+
+   	<h2>Your Shopping Cart</h2>
+   	<form name="shoppingCartForm">
+		<div id="shoppingCart"></div>
+		<br>
+		<div id="total"></div>
+		<br>
+		<input type="button" onClick="checkoutCart()" value="Checkout">
+		<input type="button" onClick="deleteCart()" value="Empty">
+	</form>
+  </div>
+</body>
+
+</html>
\ No newline at end of file

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/README
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/README?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/README (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/README Sat May  7 22:44:12 2011
@@ -0,0 +1,28 @@
+Store Sample
+======================================
+
+This is a sample store scenario that is used as a getting started guide
+for Tuscany SCA. For detailed information, please see:
+
+http://tuscany.apache.org/getting-started-with-tuscany.html
+
+or
+
+http://tuscany.apache.org/getting-started-with-tuscany-using-tuscany-eclipse-plugin.html
+
+
+Building And Running The Sample Using Ant
+-----------------------------------------
+With the binary distribution the sample can be built using Ant as follows:
+
+cd store
+ant compile
+
+and then, to run:
+
+ant run
+
+Once the store application is running use your browser to visit the following
+URL:
+
+http://localhost:8080/store

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/pom.xml
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/pom.xml?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/pom.xml (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/pom.xml Sat May  7 22:44:12 2011
@@ -0,0 +1,85 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+    * 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.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0"
+         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+    <parent>
+        <groupId>org.apache.nuvem</groupId>
+        <artifactId>nuvem-samples</artifactId>
+        <version>1.0-incubating-SNAPSHOT</version>
+        <relativePath>../pom.xml</relativePath>
+    </parent>
+    <artifactId>store-standalone</artifactId>
+    <name>Apache Nuvem Cloud Store Scenarion (standalone)</name>
+
+	<dependencies>
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-sca-api</artifactId>
+            <version>${tuscany.version}</version>
+        </dependency>
+
+		<dependency>
+			<groupId>org.apache.tuscany.sca</groupId>
+			<artifactId>tuscany-data-api</artifactId>
+			<version>${tuscany.version}</version>
+		</dependency>
+
+		<dependency>
+			<groupId>org.apache.tuscany.sca</groupId>
+			<artifactId>tuscany-node-impl</artifactId>
+			<version>${tuscany.version}</version>
+		</dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-feature-web20</artifactId>
+            <type>pom</type>
+            <version>${tuscany.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>javax.servlet</groupId>
+            <artifactId>servlet-api</artifactId>
+            <version>2.5</version>
+            <scope>provided</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>net.sourceforge.htmlunit</groupId>
+            <artifactId>htmlunit</artifactId>
+            <version>2.6</version>
+            <scope>test</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>junit</groupId>
+            <artifactId>junit</artifactId>
+            <version>4.8.1</version>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+
+    <build>
+       <finalName>${artifactId}</finalName>
+    </build>
+
+</project>

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/launch/Launch.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/launch/Launch.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/launch/Launch.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/launch/Launch.java Sat May  7 22:44:12 2011
@@ -0,0 +1,39 @@
+/*
+ * 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.    
+ */
+
+package launch;
+
+import org.apache.tuscany.sca.node.Contribution;
+import org.apache.tuscany.sca.node.ContributionLocationHelper;
+import org.apache.tuscany.sca.node.Node;
+import org.apache.tuscany.sca.node.NodeFactory;
+
+public class Launch {
+    public static void main(String[] args) throws Exception {
+        System.out.println("Starting ...");
+        String contribution = ContributionLocationHelper.getContributionLocation(Launch.class);
+        Node node = NodeFactory.newInstance().createNode("store.composite", new Contribution("test", contribution));
+        node.start();
+        System.out.println("store.composite ready for big business !!!");
+        System.in.read();
+        System.out.println("Stopping ...");
+        node.stop();
+        System.out.println();
+    }
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Cart.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Cart.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Cart.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Cart.java Sat May  7 22:44:12 2011
@@ -0,0 +1,28 @@
+/*
+ * 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.    
+ */
+
+package services;
+
+import org.apache.tuscany.sca.data.collection.Collection;
+import org.oasisopen.sca.annotation.Remotable;
+
+@Remotable
+public interface Cart extends Collection<String, Item> {
+
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Catalog.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Catalog.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Catalog.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Catalog.java Sat May  7 22:44:12 2011
@@ -0,0 +1,27 @@
+/*
+ * 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.
+ */
+
+package services;
+
+import org.oasisopen.sca.annotation.Remotable;
+
+@Remotable
+public interface Catalog {
+    Item[] items();
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CatalogImpl.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CatalogImpl.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CatalogImpl.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CatalogImpl.java Sat May  7 22:44:12 2011
@@ -0,0 +1,39 @@
+/*
+ * 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.
+ */
+
+package services;
+
+import org.oasisopen.sca.annotation.Property;
+import org.oasisopen.sca.annotation.Reference;
+
+public class CatalogImpl implements Catalog {
+
+    @Property
+    public String currencyCode = "USD";
+
+    @Reference
+    public Catalog catalog;
+
+    @Reference
+    public CurrencyConverter currencyConverter;
+
+    public Item[] items() {
+        return catalog.items();
+    }
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverter.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverter.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverter.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverter.java Sat May  7 22:44:12 2011
@@ -0,0 +1,29 @@
+/*
+ * 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.    
+ */
+
+package services;
+
+import org.oasisopen.sca.annotation.Remotable;
+
+@Remotable
+public interface CurrencyConverter {
+    public double getConversion(String fromCurrenycCode, String toCurrencyCode, double amount);
+
+    public String getCurrencySymbol(String currencyCode);
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverterImpl.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverterImpl.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverterImpl.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/CurrencyConverterImpl.java Sat May  7 22:44:12 2011
@@ -0,0 +1,38 @@
+/*
+ * 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.    
+ */
+
+package services;
+
+public class CurrencyConverterImpl implements CurrencyConverter {
+    public double getConversion(String fromCurrencyCode, String toCurrencyCode, double amount) {
+        if (toCurrencyCode.equals("USD"))
+            return amount;
+        else if (toCurrencyCode.equals("EUR"))
+            return ((double)Math.round(amount * 0.7256 * 100)) / 100;
+        return 0;
+    }
+
+    public String getCurrencySymbol(String currencyCode) {
+        if (currencyCode.equals("USD"))
+            return "$";
+        else if (currencyCode.equals("EUR"))
+            return "E"; // "€";
+        return "?";
+    }
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/FruitsCatalogImpl.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/FruitsCatalogImpl.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/FruitsCatalogImpl.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/FruitsCatalogImpl.java Sat May  7 22:44:12 2011
@@ -0,0 +1,60 @@
+/*
+ * 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.
+ */
+package services;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.oasisopen.sca.annotation.Init;
+import org.oasisopen.sca.annotation.Property;
+import org.oasisopen.sca.annotation.Reference;
+import org.oasisopen.sca.annotation.Scope;
+import org.oasisopen.sca.annotation.Service;
+
+@Service(Catalog.class)
+@Scope("COMPOSITE")
+public class FruitsCatalogImpl implements Catalog {
+    @Property
+    public String currencyCode = "USD";
+
+    @Reference
+    public CurrencyConverter currencyConverter;
+
+    private List<Item> catalog = new ArrayList<Item>();
+
+    @Init
+    public void init() {
+        String currencySymbol = currencyConverter.getCurrencySymbol(currencyCode);
+        catalog.add(new Item("Acai", currencyCode, currencySymbol, currencyConverter.getConversion("USD",
+                                                                                                   currencyCode,
+                                                                                                   2.99)));
+        catalog.add(new Item("Carambola", currencyCode, currencySymbol, currencyConverter.getConversion("USD",
+                                                                                                        currencyCode,
+                                                                                                        3.55)));
+        catalog.add(new Item("Cashew", currencyCode, currencySymbol, currencyConverter.getConversion("USD",
+                                                                                                     currencyCode,
+                                                                                                     1.55)));
+    }
+
+    public Item[] items() {
+        Item[] catalogArray = new Item[catalog.size()];
+        catalog.toArray(catalogArray);
+        return catalogArray;
+    }
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Item.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Item.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Item.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Item.java Sat May  7 22:44:12 2011
@@ -0,0 +1,73 @@
+/*
+ * 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.
+ */
+
+package services;
+
+import java.io.Serializable;
+
+public class Item implements Serializable {
+    private static final long serialVersionUID = -5847326138627338217L;
+
+    private String name;
+    private String currencyCode;
+    private String currencySymbol;
+    private double price;
+
+    public Item() {
+    }
+
+    public Item(String name, String currencyCode, String currencySymbol, double price) {
+        this.name = name;
+        this.currencyCode = currencyCode;
+        this.currencySymbol = currencySymbol;
+        this.price = price;
+    }
+
+    public String getName() {
+        return name;
+    }
+
+    public void setName(String name) {
+        this.name = name;
+    }
+
+    public String getCurrencyCode() {
+        return this.currencyCode;
+    }
+
+    public void setCurrencyCode(String currencyCode) {
+        this.currencyCode = currencyCode;
+    }
+
+    public String getCurrencySymbol() {
+        return this.currencySymbol;
+    }
+
+    public void setCurrencySymbol(String currencySymbol) {
+        this.currencySymbol = currencySymbol;
+    }
+
+    public double getPrice() {
+        return price;
+    }
+
+    public void setPrice(double price) {
+        this.price = price;
+    }
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/ShoppingCartImpl.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/ShoppingCartImpl.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/ShoppingCartImpl.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/ShoppingCartImpl.java Sat May  7 22:44:12 2011
@@ -0,0 +1,113 @@
+/*
+ * 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.
+ */
+
+package services;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+
+import org.apache.tuscany.sca.data.collection.Entry;
+import org.apache.tuscany.sca.data.collection.NotFoundException;
+import org.oasisopen.sca.annotation.Init;
+import org.oasisopen.sca.annotation.Scope;
+
+@Scope("COMPOSITE")
+public class ShoppingCartImpl implements Cart, Total {
+
+    private Map<String, Item> cart;
+
+    @Init
+    public void init() {
+        cart = new HashMap<String, Item>();
+    }
+
+    public Entry<String, Item>[] getAll() {
+        Entry<String, Item>[] entries = new Entry[cart.size()];
+        int i = 0;
+        for (Map.Entry<String, Item> e : cart.entrySet()) {
+            entries[i++] = new Entry<String, Item>(e.getKey(), e.getValue());
+        }
+        return entries;
+    }
+
+    public Item get(String key) throws NotFoundException {
+        Item item = cart.get(key);
+        if (item == null) {
+            throw new NotFoundException(key);
+        } else {
+            return item;
+        }
+    }
+
+    public String post(String key, Item item) {
+        if (key == null) {
+            key = "cart-" + UUID.randomUUID().toString();
+        }
+        cart.put(key, item);
+        return key;
+    }
+
+    public void put(String key, Item item) throws NotFoundException {
+        if (!cart.containsKey(key)) {
+            throw new NotFoundException(key);
+        }
+        cart.put(key, item);
+    }
+
+    public void delete(String key) throws NotFoundException {
+        if (key == null || key.equals("")) {
+            cart.clear();
+        } else {
+            Item item = cart.remove(key);
+            if (item == null)
+                throw new NotFoundException(key);
+        }
+    }
+
+    public Entry<String, Item>[] query(String queryString) {
+        List<Entry<String, Item>> entries = new ArrayList<Entry<String, Item>>();
+        if (queryString.startsWith("name=")) {
+            String name = queryString.substring(5);
+            for (Map.Entry<String, Item> e : cart.entrySet()) {
+                Item item = e.getValue();
+                if (item.getName().equals(name)) {
+                    entries.add(new Entry<String, Item>(e.getKey(), e.getValue()));
+                }
+            }
+        }
+        return entries.toArray(new Entry[entries.size()]);
+    }
+
+    public String getTotal() {
+        double total = 0;
+        String currencySymbol = "";
+        if (!cart.isEmpty()) {
+            Item item = cart.values().iterator().next();
+            currencySymbol = item.getCurrencySymbol();
+        }
+        for (Item item : cart.values()) {
+            total += item.getPrice();
+        }
+        return currencySymbol + String.valueOf(total);
+    }
+
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Total.java
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Total.java?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Total.java (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/java/services/Total.java Sat May  7 22:44:12 2011
@@ -0,0 +1,29 @@
+/*
+ * 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.    
+ */
+
+package services;
+
+import org.oasisopen.sca.annotation.Remotable;
+
+@Remotable
+public interface Total {
+
+    String getTotal();
+
+}

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/store.composite
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/store.composite?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/store.composite (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/store.composite Sat May  7 22:44:12 2011
@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ * 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.
+-->
+<composite	xmlns="http://docs.oasis-open.org/ns/opencsa/sca/200912"
+		xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+		targetNamespace="http://store"
+		name="store">
+
+    <component name="Store">
+        <tuscany:implementation.widget location="uiservices/store.html"/>
+        <service name="Widget">
+        	<tuscany:binding.http uri="/store"/>
+        </service>
+		<reference name="catalog" target="Catalog"/>
+		 <reference name="shoppingCart" target="ShoppingCart/Cart"/>
+		 <reference name="shoppingTotal" target="ShoppingCart/Total"/>
+    </component>
+
+	<component name="Catalog">
+		<implementation.java class="services.CatalogImpl"/>
+		<property name="currencyCode">USD</property>
+		<service name="Catalog">
+			<tuscany:binding.jsonrpc uri="/Catalog"/>
+   		</service>
+		<reference name="currencyConverter" target="CurrencyConverter"/>
+
+        <reference name="catalog" target="FruitsCatalog"/>
+
+        <!-- Cheat sheet for demo
+        <reference name="catalog" target="FruitsCatalog"/>
+
+		<reference name="catalog">
+            <tuscany:binding.jsonrpc uri="https://sca-store-catalog.appspot.com/catalog"/>
+		</reference>
+
+            <tuscany:binding.jsonrpc uri="http://tuscany-store.appspot.com/Catalog"/>
+            <tuscany:binding.jsonrpc uri="http://ec2-204-236-142-71.us-west-1.compute.amazonaws.com:8090/catalog"/>
+            <tuscany:binding.jsonrpc uri="http://localhost:8090/catalog"/>
+        -->
+	</component>
+
+	<component name="FruitsCatalog">
+		<implementation.java class="services.FruitsCatalogImpl"/>
+		<property name="currencyCode">USD</property>
+		<service name="Catalog">
+		    <interface.java interface="services.Catalog"/>
+		</service>
+		<reference name="currencyConverter" target="CurrencyConverter" />
+	</component>
+
+	<component name="ShoppingCart">
+		<implementation.java class="services.ShoppingCartImpl"/>
+		<service name="Cart">
+			<tuscany:binding.atom uri="/ShoppingCart/Cart"/>
+		</service>
+		<service name="Total">
+			<tuscany:binding.jsonrpc uri="/ShoppingCart/Total"/>
+		</service>
+	</component>
+
+	<component name="CurrencyConverter">
+		<implementation.java class="services.CurrencyConverterImpl"/>
+	</component>
+
+</composite>

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.css
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.css?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.css (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.css Sat May  7 22:44:12 2011
@@ -0,0 +1,39 @@
+/*
+ * 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
+ */
+<style type="text/css">
+
+html, body {
+	height:100%;
+	margin:0;
+	overflow:hidden;
+	width:100%;
+}
+
+.header {
+	font-size:13px;
+	text-align:right;
+	color:#CCCCCC;
+
+
+	padding:5px 5px 0;
+	padding-right:8px;
+	padding-top:0px !important;
+	padding-bottom: 0px;
+	border-bottom: 1px solid black;
+}
+</style>
\ No newline at end of file

Added: incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.html
URL: http://svn.apache.org/viewvc/incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.html?rev=1100647&view=auto
==============================================================================
--- incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.html (added)
+++ incubator/nuvem/trunk/nuvem-samples/store-standalone/src/main/resources/uiservices/store.html Sat May  7 22:44:12 2011
@@ -0,0 +1,193 @@
+<!--
+    * 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.
+-->
+<html>
+<head>
+<title>Store</title>
+
+<link href="store.css" rel="stylesheet" type="text/css">
+<script type="text/javascript" src="../dojo/dojo.js"></script>
+<script type="text/javascript" src="store.js"></script>
+
+<script language="JavaScript">
+
+	//@Reference
+	var catalog = new tuscany.sca.Reference("catalog");
+
+	//@Reference
+	var shoppingCart = new tuscany.sca.Reference("shoppingCart");
+
+	//@Reference
+	var shoppingTotal = new tuscany.sca.Reference("shoppingTotal");
+
+	var catalogItems;
+
+	function catalog_getResponse(items,exception) {
+		if(exception){
+			alert(exception.message);
+			return;
+		}
+		var catalog = "";
+
+		for (var i=0; i<items.length; i++) {
+			var item = items[i].name + ' - ' + items[i].currencySymbol + items[i].price;
+			catalog += '<input name="items" type="checkbox" value="' +
+						item + '">' + item + ' <br>';
+		}
+		document.getElementById('catalog').innerHTML=catalog;
+		catalogItems = items;
+	}
+
+
+	// This handles the response from shoppingCart.getAll
+	// which is a collection of Entry<K,D>
+	function shoppingCart_getResponse(items) {
+		var list='';
+		for (var i=0; i<items.length; i++) {
+			//get the actual item, that is Entry.data
+			var item = items[i].data;
+			// process its attributes
+			var name = item.name;
+			var symbol = item.currencySymbol;
+			var price = item.price
+			list += name + ' - ' + symbol + price + ' <br>';
+		}
+		document.getElementById("shoppingCart").innerHTML = list;
+
+		if (items.length != 0) {
+			try	{
+				shoppingTotal.getTotal().addCallback(shoppingTotal_getTotalResponse);
+			}
+			catch(e){
+				alert(e);
+			}
+		}
+	}
+
+	function shoppingCart_getResponse(feed) {
+		if (feed != null) {
+			var entries = feed.getElementsByTagName("entry");
+			var list = "";
+			for (var i=0; i<entries.length; i++) {
+				var content = entries[i].getElementsByTagName("content")[0];
+				var name = content.getElementsByTagName("name")[0].firstChild.nodeValue;
+				var symbol = content.getElementsByTagName("currencySymbol")[0].firstChild.nodeValue;
+				var price = content.getElementsByTagName("price")[0].firstChild.nodeValue;
+				list += name + ' - '  + symbol + price + ' <br>';
+			}
+			document.getElementById("shoppingCart").innerHTML = list;
+
+			if (entries.length != 0) {
+				try	{
+					shoppingTotal.getTotal().addCallback(shoppingTotal_getTotalResponse);
+				}
+				catch(e){
+					alert(e);
+				}
+			}
+		}
+	}
+
+	function shoppingTotal_getTotalResponse(total,exception) {
+		if(exception) {
+			alert(exception.message);
+			return;
+		}
+		document.getElementById('total').innerHTML = total;
+	}
+
+	function shoppingCart_postResponse(entry) {
+		shoppingCart.get("").addCallback(shoppingCart_getResponse);
+	}
+
+	function addToCart() {
+		var items  = document.catalogForm.items;
+		var j = 0;
+		for (var i=0; i<items.length; i++) {
+			if (items[i].checked) {
+				var entry = '<entry xmlns="http://www.w3.org/2005/Atom"><title>item</title><content type="text/xml">' +
+                	'<Item xmlns="http://services/">' +
+                	'<name xmlns="">' + catalogItems[i].name + '</name>' +
+                	'<currencyCode xmlns="">' + catalogItems[i].currencyCode + '</currencyCode>' +
+                    '<currencySymbol xmlns="">' + catalogItems[i].currencySymbol + '</currencySymbol>' +
+                    '<price xmlns="">' + catalogItems[i].price + '</price>' +
+                 	'</Item>' + '</content></entry>';
+				shoppingCart.post(entry).addCallback(shoppingCart_postResponse);
+				items[i].checked = false;
+			}
+		}
+	}
+	function checkoutCart() {
+		document.getElementById('store').innerHTML='<h2>' +
+				'Thanks for Shopping With Us!</h2>'+
+				'<h2>Your Order</h2>'+
+				'<form name="orderForm">'+
+					document.getElementById('shoppingCart').innerHTML+
+					'<br>'+
+					document.getElementById('total').innerHTML+
+					'<br>'+
+					'<br>'+
+					'<input type="submit" value="Continue Shopping">'+
+				'</form>';
+		shoppingCart.del("");
+	}
+	function deleteCart() {
+		shoppingCart.del("");
+		document.getElementById('shoppingCart').innerHTML = "";
+		document.getElementById('total').innerHTML = "";
+	}
+
+	function init() {
+		try	{
+			catalog.items().addCallback(catalog_getResponse);
+			shoppingCart.get("").addCallback(shoppingCart_getResponse);
+		}
+		catch(e){
+			alert(e);
+		}
+	}
+
+</script>
+
+</head>
+
+<body onload="init()">
+<h1>Store</h1>
+  <div id="store">
+   	<h2>Catalog</h2>
+   	<form name="catalogForm">
+		<div id="catalog" ></div>
+		<br>
+		<input type="button" onClick="addToCart()"  value="Add to Cart">
+   	</form>
+
+ 	<br>
+
+   	<h2>Your Shopping Cart</h2>
+   	<form name="shoppingCartForm">
+		<div id="shoppingCart"></div>
+		<br>
+		<div id="total"></div>
+		<br>
+		<input type="button" onClick="checkoutCart()" value="Checkout">
+		<input type="button" onClick="deleteCart()" value="Empty">
+	   	<a href="../ShoppingCart/Cart/">(feed)</a>
+	</form>
+  </div>
+</body>
+</html>