Author: lresende
Date: Wed Aug 13 16:17:32 2008
New Revision: 685726

URL: http://svn.apache.org/viewvc?rev=685726&view=rev
Log:
Working in progress for cross-domain support in implementation.widget

Added:
    tuscany/sandbox/lresende/sca/samples/store-distributed/   (props changed)
      - copied from r685580, tuscany/java/sca/samples/store-distributed/
    tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/
      - copied from r685724, 
tuscany/java/sca/samples/store-distributed/src/main/resources/
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js
   (with props)
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js
   (with props)
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js
   (with props)
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
   (with props)
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js
   (with props)
Modified:
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/cloud/NodeC.composite
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/store.composite
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/store.composite
    
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/store.composite

Propchange: tuscany/sandbox/lresende/sca/samples/store-distributed/
------------------------------------------------------------------------------
--- svn:ignore (added)
+++ svn:ignore Wed Aug 13 16:17:32 2008
@@ -0,0 +1,20 @@
+target
+work
+dojo
+*.iws
+*.ipr
+*.iml
+derby.log
+maven.log
+maven-eclipse.xml
+build.xml
+build-dependency.xml
+velocity.log*
+junit*.properties
+surefire*.properties
+.project
+.classpath
+.settings
+.deployables
+.wtpmodules
+.externalToolBuilders

Propchange: tuscany/sandbox/lresende/sca/samples/store-distributed/
------------------------------------------------------------------------------
    svn:mergeinfo = /tuscany/branches/sca-java-1.3/samples/store:671193

Modified: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/cloud/NodeC.composite
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/cloud/NodeC.composite?rev=685726&r1=685724&r2=685726&view=diff
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/cloud/NodeC.composite
 (original)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/cloud/NodeC.composite
 Wed Aug 13 16:17:32 2008
@@ -27,9 +27,9 @@
                <t:implementation.node uri="nodeC" composite="store:storeC"/>
                <service name="Node">
                        <binding.sca uri="http://localhost:8300"/>
-            <t:binding.jsonrpc uri="http://localhost:8300"/>
-            <t:binding.atom uri="http://localhost:8300"/>
-            <t:binding.http uri="http://localhost:8300"/>                      
+            <t:binding.jsonrpc uri="http://localhost:8400"/>
+            <t:binding.atom uri="http://localhost:8400"/>
+            <t:binding.http uri="http://localhost:8400"/>                      
                </service>
        </component> 
 

Added: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js?rev=685726&view=auto
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js
 (added)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js
 Wed Aug 13 16:17:32 2008
@@ -0,0 +1,510 @@
+/* Apache Tuscany SCA Widget header */
+
+/*
+ * JSON-RPC JavaScript client
+ *
+ * $Id: jsonrpc.js,v 1.36.2.3 2006/03/08 15:09:37 mclark Exp $
+ *
+ * Copyright (c) 2003-2004 Jan-Klaas Kollhof
+ * Copyright (c) 2005 Michael Clark, Metaparadigm Pte Ltd
+ *
+ * This code is based on Jan-Klaas' JavaScript o lait library (jsolait).
+ *
+ * Licensed 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.
+ *
+ */
+
+/*
+ * Modifications for Apache Tuscany:
+ * - JSONRpcClient_createMethod changed so callback is last arg
+ */
+
+/* escape a character */
+
+alert('loading sotre.js from nodeA');
+
+escapeJSONChar =
+function escapeJSONChar(c)
+{
+    if(c == "\"" || c == "\\") return "\\" + c;
+    else if (c == "\b") return "\\b";
+    else if (c == "\f") return "\\f";
+    else if (c == "\n") return "\\n";
+    else if (c == "\r") return "\\r";
+    else if (c == "\t") return "\\t";
+    var hex = c.charCodeAt(0).toString(16);
+    if(hex.length == 1) return "\\u000" + hex;
+    else if(hex.length == 2) return "\\u00" + hex;
+    else if(hex.length == 3) return "\\u0" + hex;
+    else return "\\u" + hex;
+};
+
+
+/* encode a string into JSON format */
+
+escapeJSONString =
+function escapeJSONString(s)
+{
+    /* The following should suffice but Safari's regex is b0rken
+       (doesn't support callback substitutions)
+       return "\"" + s.replace(/([^\u0020-\u007f]|[\\\"])/g,
+       escapeJSONChar) + "\"";
+    */
+
+    /* Rather inefficient way to do it */
+    var parts = s.split("");
+    for(var i=0; i < parts.length; i++) {
+       var c =parts[i];
+       if(c == '"' ||
+          c == '\\' ||
+          c.charCodeAt(0) < 32 ||
+          c.charCodeAt(0) >= 128)
+           parts[i] = escapeJSONChar(parts[i]);
+    }
+    return "\"" + parts.join("") + "\"";
+};
+
+
+/* Marshall objects to JSON format */
+
+toJSON = function toJSON(o)
+{
+    if(o == null) {
+       return "null";
+    } else if(o.constructor == String) {
+       return escapeJSONString(o);
+    } else if(o.constructor == Number) {
+       return o.toString();
+    } else if(o.constructor == Boolean) {
+       return o.toString();
+    } else if(o.constructor == Date) {
+       return '{javaClass: "java.util.Date", time: ' + o.valueOf() +'}';
+    } else if(o.constructor == Array) {
+       var v = [];
+       for(var i = 0; i < o.length; i++) v.push(toJSON(o[i]));
+       return "[" + v.join(", ") + "]";
+    } else {
+       var v = [];
+       for(attr in o) {
+           if(o[attr] == null) v.push("\"" + attr + "\": null");
+           else if(typeof o[attr] == "function"); /* skip */
+           else v.push(escapeJSONString(attr) + ": " + toJSON(o[attr]));
+       }
+       return "{" + v.join(", ") + "}";
+    }
+};
+
+
+/* JSONRpcClient constructor */
+
+JSONRpcClient =
+function JSONRpcClient_ctor(serverURL, user, pass, objectID)
+{
+    this.serverURL = serverURL;
+    this.user = user;
+    this.pass = pass;
+    this.objectID = objectID;
+
+    /* Add standard methods */
+    if(this.objectID) {
+       this._addMethods(["listMethods"]);
+       var req = this._makeRequest("listMethods", []);
+    } else {
+       this._addMethods(["system.listMethods"]);
+       var req = this._makeRequest("system.listMethods", []);
+    }
+    var m = this._sendRequest(req);
+    this._addMethods(m);
+};
+
+
+/* JSONRpcCLient.Exception */
+
+JSONRpcClient.Exception =
+function JSONRpcClient_Exception_ctor(code, message, javaStack)
+{
+    this.code = code;
+    var name;
+    if(javaStack) {
+       this.javaStack = javaStack;
+       var m = javaStack.match(/^([^:]*)/);
+       if(m) name = m[0];
+    }
+    if(name) this.name = name;
+    else this.name = "JSONRpcClientException";
+    this.message = message;
+};
+
+JSONRpcClient.Exception.CODE_REMOTE_EXCEPTION = 490;
+JSONRpcClient.Exception.CODE_ERR_CLIENT = 550;
+JSONRpcClient.Exception.CODE_ERR_PARSE = 590;
+JSONRpcClient.Exception.CODE_ERR_NOMETHOD = 591;
+JSONRpcClient.Exception.CODE_ERR_UNMARSHALL = 592;
+JSONRpcClient.Exception.CODE_ERR_MARSHALL = 593;
+
+JSONRpcClient.Exception.prototype = new Error();
+
+JSONRpcClient.Exception.prototype.toString =
+function JSONRpcClient_Exception_toString(code, msg)
+{
+    return this.name + ": " + this.message;
+};
+
+
+/* Default top level exception handler */
+
+JSONRpcClient.default_ex_handler =
+function JSONRpcClient_default_ex_handler(e) { alert(e); };
+
+
+/* Client settable variables */
+
+JSONRpcClient.toplevel_ex_handler = JSONRpcClient.default_ex_handler;
+JSONRpcClient.profile_async = false;
+JSONRpcClient.max_req_active = 1;
+JSONRpcClient.requestId = 1;
+
+
+/* JSONRpcClient implementation */
+
+JSONRpcClient.prototype._createMethod =
+function JSONRpcClient_createMethod(methodName)
+{
+    var fn=function()
+    {
+       var args = [];
+       var callback = null;
+       for(var i=0;i<arguments.length;i++) args.push(arguments[i]);
+
+/*     TUSCANY change callback to be last arg instead of first to match 
binding.ajax
+       if(typeof args[0] == "function") callback = args.shift();
+*/
+       if(typeof args[arguments.length-1] == "function") callback = args.pop();
+
+       var req = fn.client._makeRequest.call(fn.client, fn.methodName,
+                                             args, callback);
+       if(callback == null) {
+           return fn.client._sendRequest.call(fn.client, req);
+       } else {
+           JSONRpcClient.async_requests.push(req);
+           JSONRpcClient.kick_async();
+           return req.requestId;
+       }
+    };
+    fn.client = this;
+    fn.methodName = methodName;
+    return fn;
+};
+
+JSONRpcClient.prototype._addMethods =
+function JSONRpcClient_addMethods(methodNames)
+{
+    for(var i=0; i<methodNames.length; i++) {
+       var obj = this;
+       var names = methodNames[i].split(".");
+       for(var n=0; n<names.length-1; n++) {
+           var name = names[n];
+           if(obj[name]) {
+               obj = obj[name];
+           } else {
+               obj[name]  = new Object();
+               obj = obj[name];
+           }
+       }
+       var name = names[names.length-1];
+       if(!obj[name]) {
+           var method = this._createMethod(methodNames[i]);
+           obj[name] = method;
+       }
+    }
+};
+
+JSONRpcClient._getCharsetFromHeaders =
+function JSONRpcClient_getCharsetFromHeaders(http)
+{
+    try {
+       var contentType = http.getResponseHeader("Content-type");
+       var parts = contentType.split(/\s*;\s*/);
+       for(var i =0; i < parts.length; i++) {
+           if(parts[i].substring(0, 8) == "charset=")
+               return parts[i].substring(8, parts[i].length);
+       }
+    } catch (e) {}
+    return "UTF-8"; /* default */
+};
+
+/* Async queue globals */
+JSONRpcClient.async_requests = [];
+JSONRpcClient.async_inflight = {};
+JSONRpcClient.async_responses = [];
+JSONRpcClient.async_timeout = null;
+JSONRpcClient.num_req_active = 0;
+
+JSONRpcClient._async_handler =
+function JSONRpcClient_async_handler()
+{
+    JSONRpcClient.async_timeout = null;
+
+    while(JSONRpcClient.async_responses.length > 0) {
+       var res = JSONRpcClient.async_responses.shift();
+       if(res.canceled) continue;
+       if(res.profile) res.profile.dispatch = new Date();
+       try {
+           res.cb(res.result, res.ex, res.profile);
+       } catch(e) {
+           JSONRpcClient.toplevel_ex_handler(e);
+       }
+    }
+
+    while(JSONRpcClient.async_requests.length > 0 &&
+         JSONRpcClient.num_req_active < JSONRpcClient.max_req_active) {
+       var req = JSONRpcClient.async_requests.shift();
+       if(req.canceled) continue;
+       req.client._sendRequest.call(req.client, req);
+    }
+};
+
+JSONRpcClient.kick_async =
+function JSONRpcClient_kick_async()
+{
+    if(JSONRpcClient.async_timeout == null)
+       JSONRpcClient.async_timeout =
+           setTimeout(JSONRpcClient._async_handler, 0);
+};
+
+JSONRpcClient.cancelRequest =
+function JSONRpcClient_cancelRequest(requestId)
+{
+    /* If it is in flight then mark it as canceled in the inflight map
+       and the XMLHttpRequest callback will discard the reply. */
+    if(JSONRpcClient.async_inflight[requestId]) {
+       JSONRpcClient.async_inflight[requestId].canceled = true;
+       return true;
+    }
+
+    /* If its not in flight yet then we can just mark it as canceled in
+       the the request queue and it will get discarded before being sent. */
+    for(var i in JSONRpcClient.async_requests) {
+       if(JSONRpcClient.async_requests[i].requestId == requestId) {
+           JSONRpcClient.async_requests[i].canceled = true;
+           return true;
+       }
+    }
+
+    /* It may have returned from the network and be waiting for its callback
+       to be dispatched, so mark it as canceled in the response queue
+       and the response will get discarded before calling the callback. */
+    for(var i in JSONRpcClient.async_responses) {
+       if(JSONRpcClient.async_responses[i].requestId == requestId) {
+           JSONRpcClient.async_responses[i].canceled = true;
+           return true;
+       }
+    }
+
+    return false;
+};
+
+JSONRpcClient.prototype._makeRequest =
+function JSONRpcClient_makeRequest(methodName, args, cb)
+{
+    var req = {};
+    req.client = this;
+    req.requestId = JSONRpcClient.requestId++;
+
+    var obj = {};
+    obj.id = req.requestId;
+    if (this.objectID)
+       obj.method = ".obj#" + this.objectID + "." + methodName;
+    else
+       obj.method = methodName;
+    obj.params = args;
+
+    if (cb) req.cb = cb;
+    if (JSONRpcClient.profile_async)
+       req.profile = { "submit": new Date() };
+    req.data = toJSON(obj);
+
+    return req;
+};
+
+JSONRpcClient.prototype._sendRequest =
+function JSONRpcClient_sendRequest(req)
+{
+    if(req.profile) req.profile.start = new Date();
+
+    /* Get free http object from the pool */
+    var http = JSONRpcClient.poolGetHTTPRequest();
+    JSONRpcClient.num_req_active++;
+
+    /* Send the request */
+    if (typeof(this.user) == "undefined") {
+       http.open("POST", this.serverURL, (req.cb != null));
+    } else {
+       http.open("POST", this.serverURL, (req.cb != null), this.user, 
this.pass);
+    }
+
+    /* setRequestHeader is missing in Opera 8 Beta */
+    try { http.setRequestHeader("Content-type", "text/plain"); } catch(e) {}
+
+    /* Construct call back if we have one */
+    if(req.cb) {
+       var self = this;
+       http.onreadystatechange = function() {
+           if(http.readyState == 4) {
+               http.onreadystatechange = function () {};
+               var res = { "cb": req.cb, "result": null, "ex": null};
+               if (req.profile) {
+                   res.profile = req.profile;
+                   res.profile.end = new Date();
+               }
+               try { res.result = self._handleResponse(http); }
+               catch(e) { res.ex = e; }
+               if(!JSONRpcClient.async_inflight[req.requestId].canceled)
+                   JSONRpcClient.async_responses.push(res);
+               delete JSONRpcClient.async_inflight[req.requestId];
+               JSONRpcClient.kick_async();
+           }
+       };
+    } else {
+       http.onreadystatechange = function() {};
+    }
+
+    JSONRpcClient.async_inflight[req.requestId] = req;
+       
+    try {
+       http.send(req.data);
+    } catch(e) {
+       JSONRpcClient.poolReturnHTTPRequest(http);
+       JSONRpcClient.num_req_active--;
+       throw new JSONRpcClient.Exception
+           (JSONRpcClient.Exception.CODE_ERR_CLIENT, "Connection failed");
+    }
+
+    if(!req.cb) return this._handleResponse(http);
+};
+
+JSONRpcClient.prototype._handleResponse =
+function JSONRpcClient_handleResponse(http)
+{
+    /* Get the charset */
+    if(!this.charset) {
+       this.charset = JSONRpcClient._getCharsetFromHeaders(http);
+    }
+
+    /* Get request results */
+    var status, statusText, data;
+    try {
+       status = http.status;
+       statusText = http.statusText;
+       data = http.responseText;
+    } catch(e) {
+       JSONRpcClient.poolReturnHTTPRequest(http);
+       JSONRpcClient.num_req_active--;
+       JSONRpcClient.kick_async();
+       throw new JSONRpcClient.Exception
+           (JSONRpcClient.Exception.CODE_ERR_CLIENT, "Connection failed");
+    }
+
+    /* Return http object to the pool; */
+    JSONRpcClient.poolReturnHTTPRequest(http);
+    JSONRpcClient.num_req_active--;
+
+    /* Unmarshall the response */
+    if(status != 200) {
+       throw new JSONRpcClient.Exception(status, statusText);
+    }
+    var obj;
+    try {
+       eval("obj = " + data);
+    } catch(e) {
+       throw new JSONRpcClient.Exception(550, "error parsing result");
+    }
+    if(obj.error)
+       throw new JSONRpcClient.Exception(obj.error.code, obj.error.msg,
+                                         obj.error.trace);
+    var res = obj.result;
+
+    /* Handle CallableProxy */
+    if(res && res.objectID && res.JSONRPCType == "CallableReference")
+       return new JSONRpcClient(this.serverURL, this.user,
+                                this.pass, res.objectID);
+
+    return res;
+};
+
+
+/* XMLHttpRequest wrapper code */
+
+/* XMLHttpRequest pool globals */
+JSONRpcClient.http_spare = [];
+JSONRpcClient.http_max_spare = 8;
+
+JSONRpcClient.poolGetHTTPRequest =
+function JSONRpcClient_pool_getHTTPRequest()
+{
+    if(JSONRpcClient.http_spare.length > 0) {
+       return JSONRpcClient.http_spare.pop();
+    }
+    return JSONRpcClient.getHTTPRequest();
+};
+
+JSONRpcClient.poolReturnHTTPRequest =
+function JSONRpcClient_poolReturnHTTPRequest(http)
+{
+    if(JSONRpcClient.http_spare.length >= JSONRpcClient.http_max_spare)
+       delete http;
+    else
+       JSONRpcClient.http_spare.push(http);
+};
+
+JSONRpcClient.msxmlNames = [ "MSXML2.XMLHTTP.5.0",
+                            "MSXML2.XMLHTTP.4.0",
+                            "MSXML2.XMLHTTP.3.0",
+                            "MSXML2.XMLHTTP",
+                            "Microsoft.XMLHTTP" ];
+
+JSONRpcClient.getHTTPRequest =
+function JSONRpcClient_getHTTPRequest()
+{
+    /* Mozilla XMLHttpRequest */
+    try {
+       JSONRpcClient.httpObjectName = "XMLHttpRequest";
+       return new XMLHttpRequest();
+    } catch(e) {}
+
+    /* Microsoft MSXML ActiveX */
+    for (var i=0;i < JSONRpcClient.msxmlNames.length; i++) {
+       try {
+           JSONRpcClient.httpObjectName = JSONRpcClient.msxmlNames[i];
+           return new ActiveXObject(JSONRpcClient.msxmlNames[i]);
+       } catch (e) {}
+    }
+
+    /* None found */
+    JSONRpcClient.httpObjectName = null;
+    throw new JSONRpcClient.Exception(0, "Can't create XMLHttpRequest object");
+};
+
+//---------------------
+
+
+var propertyMapA = new Object();
+var referenceMapA = new Object();
+
+alert("referenceMapA : " + referenceMapA);
+referenceMapA.catalog = new 
JSONRpcClient("http://luck.ibm.com:8100/Catalog";).Service;
+
+alert('finished loading store.js from nodeA');
+
+/** End of Apache Tuscany SCA Widget */
+

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/content/store.js
------------------------------------------------------------------------------
    svn:eol-style = native

Modified: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/store.composite
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/store.composite?rev=685726&r1=685724&r2=685726&view=diff
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/store.composite
 (original)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeA/store.composite
 Wed Aug 13 16:17:32 2008
@@ -33,6 +33,14 @@
            
        <component name="CurrencyConverter">
                <implementation.java class="services.CurrencyConverterImpl"/>
-       </component>     
+       </component>   
+       
+       <!-- http://localhost:8100/store/nodeA/store.js -->
+       <component name="jsNodeA">
+               <t:implementation.resource location="content"/>
+               <service name="Resource">
+               <t:binding.http uri="/store/nodeA"/>
+       </service>
+       </component>  
 
 </composite>

Added: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js?rev=685726&view=auto
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js
 (added)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js
 Wed Aug 13 16:17:32 2008
@@ -0,0 +1,647 @@
+/* Apache Tuscany SCA Widget header */
+
+/*
+ * JSON-RPC JavaScript client
+ *
+ * $Id: jsonrpc.js,v 1.36.2.3 2006/03/08 15:09:37 mclark Exp $
+ *
+ * Copyright (c) 2003-2004 Jan-Klaas Kollhof
+ * Copyright (c) 2005 Michael Clark, Metaparadigm Pte Ltd
+ *
+ * This code is based on Jan-Klaas' JavaScript o lait library (jsolait).
+ *
+ * Licensed 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.
+ *
+ */
+
+/*
+ * Modifications for Apache Tuscany:
+ * - JSONRpcClient_createMethod changed so callback is last arg
+ */
+
+/* escape a character */
+
+alert('loading sotre.js from nodeB');
+
+escapeJSONChar =
+function escapeJSONChar(c)
+{
+    if(c == "\"" || c == "\\") return "\\" + c;
+    else if (c == "\b") return "\\b";
+    else if (c == "\f") return "\\f";
+    else if (c == "\n") return "\\n";
+    else if (c == "\r") return "\\r";
+    else if (c == "\t") return "\\t";
+    var hex = c.charCodeAt(0).toString(16);
+    if(hex.length == 1) return "\\u000" + hex;
+    else if(hex.length == 2) return "\\u00" + hex;
+    else if(hex.length == 3) return "\\u0" + hex;
+    else return "\\u" + hex;
+};
+
+
+/* encode a string into JSON format */
+
+escapeJSONString =
+function escapeJSONString(s)
+{
+    /* The following should suffice but Safari's regex is b0rken
+       (doesn't support callback substitutions)
+       return "\"" + s.replace(/([^\u0020-\u007f]|[\\\"])/g,
+       escapeJSONChar) + "\"";
+    */
+
+    /* Rather inefficient way to do it */
+    var parts = s.split("");
+    for(var i=0; i < parts.length; i++) {
+       var c =parts[i];
+       if(c == '"' ||
+          c == '\\' ||
+          c.charCodeAt(0) < 32 ||
+          c.charCodeAt(0) >= 128)
+           parts[i] = escapeJSONChar(parts[i]);
+    }
+    return "\"" + parts.join("") + "\"";
+};
+
+
+/* Marshall objects to JSON format */
+
+toJSON = function toJSON(o)
+{
+    if(o == null) {
+       return "null";
+    } else if(o.constructor == String) {
+       return escapeJSONString(o);
+    } else if(o.constructor == Number) {
+       return o.toString();
+    } else if(o.constructor == Boolean) {
+       return o.toString();
+    } else if(o.constructor == Date) {
+       return '{javaClass: "java.util.Date", time: ' + o.valueOf() +'}';
+    } else if(o.constructor == Array) {
+       var v = [];
+       for(var i = 0; i < o.length; i++) v.push(toJSON(o[i]));
+       return "[" + v.join(", ") + "]";
+    } else {
+       var v = [];
+       for(attr in o) {
+           if(o[attr] == null) v.push("\"" + attr + "\": null");
+           else if(typeof o[attr] == "function"); /* skip */
+           else v.push(escapeJSONString(attr) + ": " + toJSON(o[attr]));
+       }
+       return "{" + v.join(", ") + "}";
+    }
+};
+
+
+/* JSONRpcClient constructor */
+
+JSONRpcClient =
+function JSONRpcClient_ctor(serverURL, user, pass, objectID)
+{
+    this.serverURL = serverURL;
+    this.user = user;
+    this.pass = pass;
+    this.objectID = objectID;
+
+    /* Add standard methods */
+    if(this.objectID) {
+       this._addMethods(["listMethods"]);
+       var req = this._makeRequest("listMethods", []);
+    } else {
+       this._addMethods(["system.listMethods"]);
+       var req = this._makeRequest("system.listMethods", []);
+    }
+    var m = this._sendRequest(req);
+    this._addMethods(m);
+};
+
+
+/* JSONRpcCLient.Exception */
+
+JSONRpcClient.Exception =
+function JSONRpcClient_Exception_ctor(code, message, javaStack)
+{
+    this.code = code;
+    var name;
+    if(javaStack) {
+       this.javaStack = javaStack;
+       var m = javaStack.match(/^([^:]*)/);
+       if(m) name = m[0];
+    }
+    if(name) this.name = name;
+    else this.name = "JSONRpcClientException";
+    this.message = message;
+};
+
+JSONRpcClient.Exception.CODE_REMOTE_EXCEPTION = 490;
+JSONRpcClient.Exception.CODE_ERR_CLIENT = 550;
+JSONRpcClient.Exception.CODE_ERR_PARSE = 590;
+JSONRpcClient.Exception.CODE_ERR_NOMETHOD = 591;
+JSONRpcClient.Exception.CODE_ERR_UNMARSHALL = 592;
+JSONRpcClient.Exception.CODE_ERR_MARSHALL = 593;
+
+JSONRpcClient.Exception.prototype = new Error();
+
+JSONRpcClient.Exception.prototype.toString =
+function JSONRpcClient_Exception_toString(code, msg)
+{
+    return this.name + ": " + this.message;
+};
+
+
+/* Default top level exception handler */
+
+JSONRpcClient.default_ex_handler =
+function JSONRpcClient_default_ex_handler(e) { alert(e); };
+
+
+/* Client settable variables */
+
+JSONRpcClient.toplevel_ex_handler = JSONRpcClient.default_ex_handler;
+JSONRpcClient.profile_async = false;
+JSONRpcClient.max_req_active = 1;
+JSONRpcClient.requestId = 1;
+
+
+/* JSONRpcClient implementation */
+
+JSONRpcClient.prototype._createMethod =
+function JSONRpcClient_createMethod(methodName)
+{
+    var fn=function()
+    {
+       var args = [];
+       var callback = null;
+       for(var i=0;i<arguments.length;i++) args.push(arguments[i]);
+
+/*     TUSCANY change callback to be last arg instead of first to match 
binding.ajax
+       if(typeof args[0] == "function") callback = args.shift();
+*/
+       if(typeof args[arguments.length-1] == "function") callback = args.pop();
+
+       var req = fn.client._makeRequest.call(fn.client, fn.methodName,
+                                             args, callback);
+       if(callback == null) {
+           return fn.client._sendRequest.call(fn.client, req);
+       } else {
+           JSONRpcClient.async_requests.push(req);
+           JSONRpcClient.kick_async();
+           return req.requestId;
+       }
+    };
+    fn.client = this;
+    fn.methodName = methodName;
+    return fn;
+};
+
+JSONRpcClient.prototype._addMethods =
+function JSONRpcClient_addMethods(methodNames)
+{
+    for(var i=0; i<methodNames.length; i++) {
+       var obj = this;
+       var names = methodNames[i].split(".");
+       for(var n=0; n<names.length-1; n++) {
+           var name = names[n];
+           if(obj[name]) {
+               obj = obj[name];
+           } else {
+               obj[name]  = new Object();
+               obj = obj[name];
+           }
+       }
+       var name = names[names.length-1];
+       if(!obj[name]) {
+           var method = this._createMethod(methodNames[i]);
+           obj[name] = method;
+       }
+    }
+};
+
+JSONRpcClient._getCharsetFromHeaders =
+function JSONRpcClient_getCharsetFromHeaders(http)
+{
+    try {
+       var contentType = http.getResponseHeader("Content-type");
+       var parts = contentType.split(/\s*;\s*/);
+       for(var i =0; i < parts.length; i++) {
+           if(parts[i].substring(0, 8) == "charset=")
+               return parts[i].substring(8, parts[i].length);
+       }
+    } catch (e) {}
+    return "UTF-8"; /* default */
+};
+
+/* Async queue globals */
+JSONRpcClient.async_requests = [];
+JSONRpcClient.async_inflight = {};
+JSONRpcClient.async_responses = [];
+JSONRpcClient.async_timeout = null;
+JSONRpcClient.num_req_active = 0;
+
+JSONRpcClient._async_handler =
+function JSONRpcClient_async_handler()
+{
+    JSONRpcClient.async_timeout = null;
+
+    while(JSONRpcClient.async_responses.length > 0) {
+       var res = JSONRpcClient.async_responses.shift();
+       if(res.canceled) continue;
+       if(res.profile) res.profile.dispatch = new Date();
+       try {
+           res.cb(res.result, res.ex, res.profile);
+       } catch(e) {
+           JSONRpcClient.toplevel_ex_handler(e);
+       }
+    }
+
+    while(JSONRpcClient.async_requests.length > 0 &&
+         JSONRpcClient.num_req_active < JSONRpcClient.max_req_active) {
+       var req = JSONRpcClient.async_requests.shift();
+       if(req.canceled) continue;
+       req.client._sendRequest.call(req.client, req);
+    }
+};
+
+JSONRpcClient.kick_async =
+function JSONRpcClient_kick_async()
+{
+    if(JSONRpcClient.async_timeout == null)
+       JSONRpcClient.async_timeout =
+           setTimeout(JSONRpcClient._async_handler, 0);
+};
+
+JSONRpcClient.cancelRequest =
+function JSONRpcClient_cancelRequest(requestId)
+{
+    /* If it is in flight then mark it as canceled in the inflight map
+       and the XMLHttpRequest callback will discard the reply. */
+    if(JSONRpcClient.async_inflight[requestId]) {
+       JSONRpcClient.async_inflight[requestId].canceled = true;
+       return true;
+    }
+
+    /* If its not in flight yet then we can just mark it as canceled in
+       the the request queue and it will get discarded before being sent. */
+    for(var i in JSONRpcClient.async_requests) {
+       if(JSONRpcClient.async_requests[i].requestId == requestId) {
+           JSONRpcClient.async_requests[i].canceled = true;
+           return true;
+       }
+    }
+
+    /* It may have returned from the network and be waiting for its callback
+       to be dispatched, so mark it as canceled in the response queue
+       and the response will get discarded before calling the callback. */
+    for(var i in JSONRpcClient.async_responses) {
+       if(JSONRpcClient.async_responses[i].requestId == requestId) {
+           JSONRpcClient.async_responses[i].canceled = true;
+           return true;
+       }
+    }
+
+    return false;
+};
+
+JSONRpcClient.prototype._makeRequest =
+function JSONRpcClient_makeRequest(methodName, args, cb)
+{
+    var req = {};
+    req.client = this;
+    req.requestId = JSONRpcClient.requestId++;
+
+    var obj = {};
+    obj.id = req.requestId;
+    if (this.objectID)
+       obj.method = ".obj#" + this.objectID + "." + methodName;
+    else
+       obj.method = methodName;
+    obj.params = args;
+
+    if (cb) req.cb = cb;
+    if (JSONRpcClient.profile_async)
+       req.profile = { "submit": new Date() };
+    req.data = toJSON(obj);
+
+    return req;
+};
+
+JSONRpcClient.prototype._sendRequest =
+function JSONRpcClient_sendRequest(req)
+{
+    if(req.profile) req.profile.start = new Date();
+
+    /* Get free http object from the pool */
+    var http = JSONRpcClient.poolGetHTTPRequest();
+    JSONRpcClient.num_req_active++;
+
+    /* Send the request */
+    if (typeof(this.user) == "undefined") {
+       http.open("POST", this.serverURL, (req.cb != null));
+    } else {
+       http.open("POST", this.serverURL, (req.cb != null), this.user, 
this.pass);
+    }
+
+    /* setRequestHeader is missing in Opera 8 Beta */
+    try { http.setRequestHeader("Content-type", "text/plain"); } catch(e) {}
+
+    /* Construct call back if we have one */
+    if(req.cb) {
+       var self = this;
+       http.onreadystatechange = function() {
+           if(http.readyState == 4) {
+               http.onreadystatechange = function () {};
+               var res = { "cb": req.cb, "result": null, "ex": null};
+               if (req.profile) {
+                   res.profile = req.profile;
+                   res.profile.end = new Date();
+               }
+               try { res.result = self._handleResponse(http); }
+               catch(e) { res.ex = e; }
+               if(!JSONRpcClient.async_inflight[req.requestId].canceled)
+                   JSONRpcClient.async_responses.push(res);
+               delete JSONRpcClient.async_inflight[req.requestId];
+               JSONRpcClient.kick_async();
+           }
+       };
+    } else {
+       http.onreadystatechange = function() {};
+    }
+
+    JSONRpcClient.async_inflight[req.requestId] = req;
+       
+    try {
+       http.send(req.data);
+    } catch(e) {
+       JSONRpcClient.poolReturnHTTPRequest(http);
+       JSONRpcClient.num_req_active--;
+       throw new JSONRpcClient.Exception
+           (JSONRpcClient.Exception.CODE_ERR_CLIENT, "Connection failed");
+    }
+
+    if(!req.cb) return this._handleResponse(http);
+};
+
+JSONRpcClient.prototype._handleResponse =
+function JSONRpcClient_handleResponse(http)
+{
+    /* Get the charset */
+    if(!this.charset) {
+       this.charset = JSONRpcClient._getCharsetFromHeaders(http);
+    }
+
+    /* Get request results */
+    var status, statusText, data;
+    try {
+       status = http.status;
+       statusText = http.statusText;
+       data = http.responseText;
+    } catch(e) {
+       JSONRpcClient.poolReturnHTTPRequest(http);
+       JSONRpcClient.num_req_active--;
+       JSONRpcClient.kick_async();
+       throw new JSONRpcClient.Exception
+           (JSONRpcClient.Exception.CODE_ERR_CLIENT, "Connection failed");
+    }
+
+    /* Return http object to the pool; */
+    JSONRpcClient.poolReturnHTTPRequest(http);
+    JSONRpcClient.num_req_active--;
+
+    /* Unmarshall the response */
+    if(status != 200) {
+       throw new JSONRpcClient.Exception(status, statusText);
+    }
+    var obj;
+    try {
+       eval("obj = " + data);
+    } catch(e) {
+       throw new JSONRpcClient.Exception(550, "error parsing result");
+    }
+    if(obj.error)
+       throw new JSONRpcClient.Exception(obj.error.code, obj.error.msg,
+                                         obj.error.trace);
+    var res = obj.result;
+
+    /* Handle CallableProxy */
+    if(res && res.objectID && res.JSONRPCType == "CallableReference")
+       return new JSONRpcClient(this.serverURL, this.user,
+                                this.pass, res.objectID);
+
+    return res;
+};
+
+
+/* XMLHttpRequest wrapper code */
+
+/* XMLHttpRequest pool globals */
+JSONRpcClient.http_spare = [];
+JSONRpcClient.http_max_spare = 8;
+
+JSONRpcClient.poolGetHTTPRequest =
+function JSONRpcClient_pool_getHTTPRequest()
+{
+    if(JSONRpcClient.http_spare.length > 0) {
+       return JSONRpcClient.http_spare.pop();
+    }
+    return JSONRpcClient.getHTTPRequest();
+};
+
+JSONRpcClient.poolReturnHTTPRequest =
+function JSONRpcClient_poolReturnHTTPRequest(http)
+{
+    if(JSONRpcClient.http_spare.length >= JSONRpcClient.http_max_spare)
+       delete http;
+    else
+       JSONRpcClient.http_spare.push(http);
+};
+
+JSONRpcClient.msxmlNames = [ "MSXML2.XMLHTTP.5.0",
+                            "MSXML2.XMLHTTP.4.0",
+                            "MSXML2.XMLHTTP.3.0",
+                            "MSXML2.XMLHTTP",
+                            "Microsoft.XMLHTTP" ];
+
+JSONRpcClient.getHTTPRequest =
+function JSONRpcClient_getHTTPRequest()
+{
+    /* Mozilla XMLHttpRequest */
+    try {
+       JSONRpcClient.httpObjectName = "XMLHttpRequest";
+       return new XMLHttpRequest();
+    } catch(e) {}
+
+    /* Microsoft MSXML ActiveX */
+    for (var i=0;i < JSONRpcClient.msxmlNames.length; i++) {
+       try {
+           JSONRpcClient.httpObjectName = JSONRpcClient.msxmlNames[i];
+           return new ActiveXObject(JSONRpcClient.msxmlNames[i]);
+       } catch (e) {}
+    }
+
+    /* None found */
+    JSONRpcClient.httpObjectName = null;
+    throw new JSONRpcClient.Exception(0, "Can't create XMLHttpRequest object");
+};
+
+
+/*
+ * 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.    
+ */
+       
+function AtomClient(uri) {
+
+       this.msxmlNames = [ "MSXML2.XMLHTTP.5.0",
+                        "MSXML2.XMLHTTP.4.0",
+                        "MSXML2.XMLHTTP.3.0",
+                        "MSXML2.XMLHTTP",
+                        "Microsoft.XMLHTTP" ];
+                                   
+       this.uri=uri;
+       
+       this.get = function(id, responseFunction) {
+               var xhr = this.createXMLHttpRequest();
+               xhr.onreadystatechange = function() {
+                       if (xhr.readyState == 4) {
+                               if (xhr.status == 200) {
+                                   var strDocument = xhr.responseText;
+                                   var xmlDocument = xhr.responseXML;
+                                   if(!xmlDocument || 
xmlDocument.childNodes.length==0){ 
+                        xmlDocument = (new 
DOMParser()).parseFromString(strDocument, "text/xml");
+                    } 
+                    if (responseFunction != null) 
responseFunction(xmlDocument);
+                               } else {
+                    alert("get - Error getting data from the server");
+                               }
+                       }
+               }
+               xhr.open("GET", uri + '/' + id, true);
+               xhr.send(null);
+       }       
+
+       this.post = function (entry, responseFunction) {
+               var xhr = this.createXMLHttpRequest();
+               xhr.onreadystatechange = function() {
+                       if (xhr.readyState == 4) {
+                               if (xhr.status == 201) {
+                                   var strDocument = xhr.responseText;
+                                   var xmlDocument = xhr.responseXML;
+                                   if(!xmlDocument || 
xmlDocument.childNodes.length==0){ 
+                        xmlDocument = (new 
DOMParser()).parseFromString(strDocument, "text/xml");
+                    } 
+                                       if (responseFunction != null) 
responseFunction(xmlDocument);
+                               } else {
+                                       alert("post - Error getting data from 
the server");
+                               }
+                       }
+               }
+               xhr.open("POST", uri, true);
+               xhr.setRequestHeader("Content-Type", "application/atom+xml");
+               xhr.send(entry);
+       }       
+
+       this.put = function (id, entry, responseFunction) {
+               var xhr = this.createXMLHttpRequest();
+               xhr.onreadystatechange = function() {
+                       if (xhr.readyState == 4) {
+                               if (xhr.status == 200) {
+                                   var strDocument = xhr.responseText;
+                                   var xmlDocument = xhr.responseXML;
+                                   if(!xmlDocument || 
xmlDocument.childNodes.length==0){ 
+                        xmlDocument = (new 
DOMParser()).parseFromString(strDocument, "text/xml");
+                    } 
+                                       if (responseFunction != null) 
responseFunction(xmlDocument);
+                               } else {
+                                       alert("put - Error getting data from 
the server");
+                               }
+                       }
+               }
+               xhr.open("PUT", uri + '/' + id, true);
+               xhr.setRequestHeader("Content-Type", "application/atom+xml");
+               xhr.send(entry);
+       }       
+
+       this.del = function (id, responseFunction) {       
+               var xhr = this.createXMLHttpRequest();
+               xhr.onreadystatechange = function() {
+                       if (xhr.readyState == 4) {
+                               if (xhr.status == 200) {
+                                       if (responseFunction != null) 
responseFunction();
+                               } else {
+                                       alert("delete - Error getting data from 
the server");
+                               }
+                       }
+               }
+               xhr.open("DELETE", uri + '/' + id, true);               
+               xhr.send(null);
+       }
+       this.createXMLHttpRequest = function () {
+        /* Mozilla XMLHttpRequest */
+        try {return new XMLHttpRequest();} catch(e) {}      
+               
+        /* Microsoft MSXML ActiveX */
+        for (var i=0;i < this.msxmlNames.length; i++) {
+            try {return new ActiveXObject(this.msxmlNames[i]);} catch (e) {}
+        }
+        alert("XML http request not supported");
+        return null;
+       }
+       if (typeof DOMParser == "undefined") {
+          DOMParser = function () {}
+       
+          DOMParser.prototype.parseFromString = function (str, contentType) {
+             if (typeof ActiveXObject != "undefined") {
+                var d = new ActiveXObject("MSXML.DomDocument");
+                d.loadXML(str);
+                return d;
+             } else if (typeof XMLHttpRequest != "undefined") {
+                var req = new XMLHttpRequest;
+                req.open("GET", "data:" + (contentType || "application/xml") +
+                                ";charset=utf-8," + encodeURIComponent(str), 
false);
+                if (req.overrideMimeType) {
+                   req.overrideMimeType(contentType);
+                }
+                req.send(null);
+                return req.responseXML;
+             }
+      }
+   }
+}
+
+
+alert(window.top);
+alert(window.parent);
+alert(window.top.document.referenceMap);
+window.top.document.referenceMap.shoppingCart = new 
AtomClient("http://localhost:8200/ShoppingCart/Cart";);
+window.top.document.referenceMap.shoppingTotal = new 
JSONRpcClient("http://localhost:8200/ShoppingCart/Total";).Service;
+
+alert('finished loading store.js from nodeB');
+
+/** End of Apache Tuscany SCA Widget */
+

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/content/store.js
------------------------------------------------------------------------------
    svn:eol-style = native

Modified: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/store.composite
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/store.composite?rev=685726&r1=685724&r2=685726&view=diff
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/store.composite
 (original)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeB/store.composite
 Wed Aug 13 16:17:32 2008
@@ -31,5 +31,13 @@
                        <t:binding.jsonrpc/>
                </service>      
        </component>
+       
+       <!-- http://localhost:8200/store/nodeB/store.js -->
+       <component name="jsNodeB">
+               <t:implementation.resource location="content"/>
+               <service name="Resource">
+               <t:binding.http uri="/store/nodeB"/>
+       </service>
+       </component>    
 
 </composite>

Added: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js?rev=685726&view=auto
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js
 (added)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js
 Wed Aug 13 16:17:32 2008
@@ -0,0 +1,66 @@
+/*-----------------------------------------------------------------------------+
+| Product:  index.js - Ajile's default auto-loader for shared dependencies.
+|+-----------------------------------------------------------------------------+
+| Author:   Michael A. I. Lee [ http://ajile.iskitz.com/ ]
+|
+| Created:  Friday,    November   2, 2006    [2006.06.02 - 19:44:40 EDT]
+| Modified: Saturday   December  16, 2006    [2006.12.16 - 13:00:00 EST]
+|+-----------------------------------------------------------------------------+
+|
+| README:
+|
+| If you need a way to import/load a common set of scripts for every page on
+| your site or in your web application, this is the file you should use.
+|
+| This index.js file can be used to define scripting dependencies for a page,
+| site, or application in a single place for use in many places.
+|
+| As of Ajile 0.6.5, Ajile automatically loads the index.js file found in its
+| directory. To disable this behavior, use the "mvcshareoff" load-time option
+| in the src parameter of the script tag used to load Ajile.
+|
+| Placing your top-level Namespace, Import, and Load directives in this file
+| allows Ajile to automatically load, import, and initialize all required
+| modules at startup for every page that uses Ajile.
+|
+| By using this file as described, all scripting logic can be controlled from
+| a single point separate from the page, site or application's display logic.
+|
+| When used within web pages (e.g. HTML, XHTML, HTA, JSP, ASP, PHP, CGI, etc.)
+| only 1 SCRIPT tag is required. That SCRIPT tag must identify the location of
+| the Ajile module. For example:
+| 
+| <script type="text/javascript" src="__Ajile's_Path__"></script>
+|
+| Visit http://ajile.iskitz.com/ to start creating "Smart scripts that play 
nice!"
+|+----------------------------------------------------------------------------*/
+
+// You may copy this file into your own projects and use it to define your
+// shared dependencies. This file must reside in the same location as the Ajile
+// module. The logic below demonstrates how this file can be used to define an
+// auto-loader. You'll most-likely use index.js to auto-load common or shared
+// functionality.
+
+/*
+
+   // Example options setting...
+   Ajile.EnableCloak(false);
+   Ajile.EnableDebug();
+   Ajile.EnableOverride(false);
+   
+   // Define your namespace.
+   Namespace ("your.namespace");
+   
+   // Import a versioned namespace.
+   Import ("some.namespace.*.0.6", "some/path/");
+   
+   // Import a module's public members.
+   Import ("some.other.Module.*");
+   
+   // Define a new module.
+   your.namespace.NewModule = new function()
+   {
+      // Your implementation here...
+   };
+
+//*/
\ No newline at end of file

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/index.js
------------------------------------------------------------------------------
    svn:eol-style = native

Added: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html?rev=685726&view=auto
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
 (added)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
 Wed Aug 13 16:17:32 2008
@@ -0,0 +1,114 @@
+<!--
+    * 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>
+<script type="text/javascript" 
src="http://luck.ibm.com:8400/store/nodeC/store.js";></script>
+
+<script language="JavaScript">
+
+var propertyMap = new Object();
+function Property(name) {
+    return propertyMap[name];
+}
+var referenceMap = new Object();
+function Reference(name) {
+    return referenceMap[name];
+}
+
+alert("PropertyMap : " + propertyMap);
+alert("ReferenceMap: " + referenceMap);
+
+//dhtmlLoadScript("http://luck.ibm.com:8100/store/nodeA/store.js";);
+staticLoadScript("http://luck.ibm.com:8100/store/nodeA/store.js";);
+
+referenceMap.catalog = referenceMapA.catalog;
+</script>
+
+</head>
+
+<body>
+<h1>Store</h1>
+
+  <input type="button" onClick="init()" value"Initialize">
+  
+  <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>
+
+
+
+<script language="JavaScript">
+
+       //@Reference
+       var catalog = new Reference("catalog");
+       
+       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].price;
+                               catalog += '<input name="items" type="checkbox" 
value="' + 
+                                                       item + '">' + item + ' 
<br>';
+                       }
+                       document.getElementById('catalog').innerHTML=catalog;
+                       catalogItems = items;
+       }
+       
+       function init() {
+
+                       alert(Reference("catalog"));
+                  try  {
+                               catalog.get(catalog_getResponse);
+                       }
+                       catch(e){
+                               alert(e);
+                       }
+               }
+       
+       init();
+</script>
+
+</html>

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
------------------------------------------------------------------------------
    svn:keywords = Rev Date

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.html
------------------------------------------------------------------------------
    svn:mime-type = text/html

Added: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js?rev=685726&view=auto
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js
 (added)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js
 Wed Aug 13 16:17:32 2008
@@ -0,0 +1,39 @@
+
+function dhtmlLoadScript(url) {
+       var script = document.createElement('script');
+       script.type = 'text/javascript';
+       script.src = url;
+       document.getElementsByTagName('head')[0].appendChild(script);  
+}
+
+function dhtmlLoadScriptIFrame(iframeId, url) {
+       var iframe = document.createElement("IFRAME");
+       iframe.style.display="none";
+       iframe.name = iframeId;
+    iframe.id = iframeId;
+       iframe.src = url;
+       document.body.appendChild(iframe);
+       
+       //var iframeDocument = window.frames[iframeId].document;
+       //iframeDocument.write('<script src="', url, '" 
type="text/JavaScript"><\/script>');
+}
+
+
+function staticLoadScript(url)
+{
+   document.write('<script src="', url, '" type="text/JavaScript"><\/script>');
+}
+
+
+function initialize() {
+
+
+  //alert('will load sotre.js from nodeA');
+  //dhtmlLoadScriptIFrame("iframe", 
"http://localhost:8100/store/nodeA/store.html";);
+
+  //alert('will load sotre.js from nodeB');
+  
//dhtmlLoadScriptIFrame("iframe2","http://localhost:8200/store/nodeB/store.html";);
   
+}
+
+/** End of Apache Tuscany SCA Widget */
+

Propchange: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/content/store.js
------------------------------------------------------------------------------
    svn:eol-style = native

Modified: 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/store.composite
URL: 
http://svn.apache.org/viewvc/tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/store.composite?rev=685726&r1=685724&r2=685726&view=diff
==============================================================================
--- 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/store.composite
 (original)
+++ 
tuscany/sandbox/lresende/sca/samples/store-distributed/src/main/resources/nodeC/store.composite
 Wed Aug 13 16:17:32 2008
@@ -23,7 +23,7 @@
                name="storeC">
                
     <component name="Store">
-        <t:implementation.widget location="uiservices/store.html"/>
+        <t:implementation.widget location="content/store.html"/>
         <service name="Widget">
                <t:binding.http uri="/store"/>
         </service>
@@ -37,5 +37,14 @@
                        <t:binding.jsonrpc/>
                 </reference>
     </component>
+    
+    <!-- http://localhost:8400/store/nodeA/store.js -->
+       <component name="jsNodeC">
+               <t:implementation.resource location="content"/>
+               <service name="Resource">
+               <t:binding.http uri="/store/nodeC"/>
+       </service>
+       </component>      
+     
 </composite>
 


Reply via email to