aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/docs/common/NGIW.Commands.html
diff options
context:
space:
mode:
authorDavid Walter Seikel2016-02-20 12:31:37 +1000
committerDavid Walter Seikel2016-02-20 12:31:37 +1000
commit080e27a38c508b2370cfe7f0152183f99a17131a (patch)
tree7a153d59ce96915416e4788b73554e1e7739230d /docs/common/NGIW.Commands.html
parentRun the docs through a spell checker. (diff)
downloadSledjHamr-080e27a38c508b2370cfe7f0152183f99a17131a.zip
SledjHamr-080e27a38c508b2370cfe7f0152183f99a17131a.tar.gz
SledjHamr-080e27a38c508b2370cfe7f0152183f99a17131a.tar.bz2
SledjHamr-080e27a38c508b2370cfe7f0152183f99a17131a.tar.xz
Rearrange the docs.
Diffstat (limited to 'docs/common/NGIW.Commands.html')
-rw-r--r--docs/common/NGIW.Commands.html46
1 files changed, 46 insertions, 0 deletions
diff --git a/docs/common/NGIW.Commands.html b/docs/common/NGIW.Commands.html
new file mode 100644
index 0000000..c058a6f
--- /dev/null
+++ b/docs/common/NGIW.Commands.html
@@ -0,0 +1,46 @@
1<html>
2<title>NGIW.Commands</title>
3<head>
4</head>
5<body bgcolor="black" text="white" alink="red" link="blue" vlink="purple">
6<p>In a virtual world there are many places where an actor (either an avatar directed by a human, an avatar directed by a program (bot), or a scripted object) wants to do something to an object. Something other than just directly change a property of the object. The LSL programming model is that scripts react to events. So I propose we unify commands, LSL events and REST by manipulating even queues.</p>
7<p>&nbsp;</p>
8<h2> Proposal </h2>
9<p>If <a href="http://sim.ulat.or/obj/">http://sim.ulat.or/obj/</a><strong>oid</strong> is the url to some object with id <strong>oid</strong>, and we have a http connection to <a href="http://sim.ulat.or">http://sim.ulat.or</a> then</p>
10<ul>
11<li>PUT /obj/<strong>oid</strong>/eq -- adds a new event to the queue (at the end)</li>
12<li>PUT /obj/<strong>oid</strong>/eq/0 -- adds a new event to the queue at the <strong>beginning</strong></li>
13<li>PUT /obj/<strong>oid</strong>/eq/9 -- same behaviour as PUT /obj/<strong>oid</strong>/eq</li>
14<li>GET /obj/<strong>oid</strong>/eq -- returns the full event queue</li>
15<li>PUT /obj/<strong>oid</strong>/eq/<strong>eventid</strong> -- changes the event (or adds one) with id <strong>eventid</strong></li>
16<li>GET /obj/<strong>oid</strong>/eq/<strong>eventid</strong> -- returns the event with id <strong>eventid</strong> or an error</li>
17<li>GET /obj/<strong>oid</strong>/eq/0 -- returns the first event from the queue or an error</li>
18<li>GET /obj/<strong>oid</strong>/eq/9 -- returns the <strong>last</strong> event in the queue</li>
19<li>DELETE /obj/<strong>oid</strong>/eq/<strong>eventid</strong> -- removes an event from the queue and returns it</li>
20<li>DELETE /obj/<strong>oid</strong>/eq/0 -- removes the first event from the queue and returns it, or returns an error</li>
21</ul>
22<p>And maybe</p>
23<ul>
24<li>PUT /obj/<strong>oid</strong>/eq -- add a bunch of events to a queue</li>
25<li>PUT /eq -- add a bunch of events to a bunch of objects?</li>
26</ul>
27<p>&nbsp;</p>
28<h2> What a PUT really sends to the server </h2>
29<p>Supose we are telling the server about the avy touching an object. The actual text that gets sent might look like:</p>
30<pre> PUT /obj/<strong>oid</strong>/eq HTTP/1.1
31 Host: sim.ulat.or
32 Content-Type: application/json
33 Content-Length: xxxx
34
35 {"touch_start":{"force":13,"avy":"uuid","time":1311663233}}
36</pre>
37<p>So you can see it is fairly heavy weight compared to a tuned command language. I will investigate what subsequent requests look like when using the http 1.1 persistent connection features. At the worst the http overhead can be amortised across many commands by using the last two forms of request. The last would look like:</p>
38<pre> PUT /eq HTTP/1.1
39 Host: sim.ulat.or
40 Content-Type: application/json
41 Content-Length: xxxx
42
43 [{command1...},{command2...},...]
44</pre>
45</body>
46</html>