serialize multiple calls to a javascript agent method
[contrib/cloudeebus.git] / doc / agent / server.html
1 <!DOCTYPE html>
2 <html>
3     <head>
4         <script src="../../lib/autobahn.min.js"></script>
5         <script src="../../cloudeebus/cloudeebus.js"></script>
6         <script type="text/javascript">
7                 function evalScript() {
8                         eval(
9                                 "var lambda = function() {" +
10                                         document.getElementById('script').value +
11                                 "};" + 
12                                 "lambda();"
13                         );
14                 }
15         </script>
16     </head>
17    <body>
18         <center><h1>cloudeebus</h1></center>
19         <br>
20                 <textarea style="width:80%" rows="32" id="script">var sampleXml= '<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN"\n"http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">\n<node><interface name="org.cloudeebus.Sample"><method name="Release"></method><method name="Add"><arg type="i" name="arg1"/><arg type="i" name="arg2"/><arg type="i" name="result" direction="out"/></method></interface></node>';
21 cloudeebus.log = function(msg) {
22   document.getElementById("log").innerHTML += msg + "\n";
23 }
24
25 function logCB(result) {
26   cloudeebus.log(JSON.stringify(result));
27 }
28
29 function errorCB(error) {
30   cloudeebus.log(error.desc ? error.desc : error);
31 }
32
33 function addCalled(args) {
34   var methodId = arguments[0];
35   var callDict = JSON.parse(arguments[1]);
36   cloudeebus.log("Method called: " + methodId);
37   cloudeebus.log("Add: " + callDict.args[0] + " + " + callDict.args[1] + " = " + (callDict.args[0] + callDict.args[1]));
38   cloudeebus.SessionBus().service.returnMethod(methodId, callDict.callIndex, true, callDict.args[0] + callDict.args[1]);
39 }
40
41 function releaseCalled() {
42   var methodId = arguments[0];
43   var callDict = JSON.parse(arguments[1]);
44   cloudeebus.log("Method called: " + methodId);
45   cloudeebus.SessionBus().service.returnMethod(methodId, 0, true, null);
46   cloudeebus.SessionBus().service.wampSession.unsubscribe(methodId);  
47   cloudeebus.SessionBus().service.delAgent("/org/cloudeebus/Sample", logCB, errorCB);
48   cloudeebus.SessionBus().service.remove(logCB, errorCB);
49 }
50
51 function serviceAdded(servName) {
52   cloudeebus.SessionBus().service.registerMethod("org.cloudeebus.Sample#/org/cloudeebus/Sample#Add",addCalled);
53   cloudeebus.SessionBus().service.registerMethod("org.cloudeebus.Sample#/org/cloudeebus/Sample#Release",releaseCalled);
54   cloudeebus.SessionBus().service.addAgent("/org/cloudeebus/Sample", sampleXml, logCB, errorCB);
55 }
56
57 function connectSuccess() {
58   cloudeebus.SessionBus().addService("org.cloudeebus.Sample", serviceAdded, errorCB);
59 }
60
61 cloudeebus.connect("ws://localhost:9003", null, connectSuccess, errorCB);
62 </textarea>
63                 <br>
64                 <input type="button" value="run script" onclick="evalScript()"/>
65                 <input type="button" value="clear log" onclick="document.getElementById('log').innerHTML='';"/>
66                 <br>
67                 <pre id="log" style="height: 20em; overflow-x: auto; overflow-y: auto; background-color: #faa;"></pre>
68    </body>
69 </html>