Difference between revisions of "LSL HTTP server"
Jump to navigation
Jump to search
m (→LSL) |
Kelly Linden (talk | contribs) |
||
Line 46: | Line 46: | ||
* Get statistics on # of XMLRPC connections, [[llHTTPRequest]]s and [[llEmail]]s per unit of time per region to set expectations for level of usage. | * Get statistics on # of XMLRPC connections, [[llHTTPRequest]]s and [[llEmail]]s per unit of time per region to set expectations for level of usage. | ||
** XMLRPC: We can handle ~200 concurrent requests per server, we have seen peaks at ~300 concurrent requests (lower now). | ** XMLRPC: We can handle ~200 concurrent requests per server, we have seen peaks at ~300 concurrent requests (lower now). | ||
== Security Impact == | == Security Impact == |
Revision as of 13:41, 13 May 2008
Goals
Create an alternative to the XMLRPC server for communication with LSL scripts initiated from outside Second Life that is easy to use and scalable.
Design
LSL
- llRequestHTTPServerURL()
- An asynchronous event with no return data.
- This will create a capability on the cap server that maps to an internal simulator url.
- An http_event will be triggered with type 'SERVER_URL' and a body of the cap url created.
- If a cap already exists for this object, the existing URL will be passed to the http_event
- One server/url per prim.
- Example public url: https://sim123.agni.lindenlab.com/cap/f23b4b94-012d-44f2-bd0c-16c328321221
- llClearHTTPServerURL()
- This will clear or invalidate the cap for this lsl http server.
- Calling llRegisterHTTPServer again after this should generate a new cap URL.
- Triggers an http_event with success/fail. (or just always with 'success' if it is not possible to fail)
- Automatically called on object/script death/return/deletion. (what about script state being set to 'not running'?) Timeless Prototype
- http_server(string method, list meta, string body)
- Event triggered when an URL is hit.
- method is GET/POST/PUT/DELETE
- meta is a list of meta data about the request.
- Initially this is only REQUESTING_HOST which is the IP of the request. This can be extended later as needed.
- body is the body of the request
- http_event(integer type, string body)
- Triggered for specific events relating to the HTTP server
- SERVER_URL: body will be the cap url that maps to this scripts http server
- URL_LOST: no body, triggered whenever a cap is lost or cleared
- urls will be lost if the object changes regions or the region restarts
Questions / Issues
- Should these caps time out?
- Can we make the cap server pass along everything after the cap itself to the simulator and the script?
- This idea has been revisited several times in the last year and devs. keep deciding that data on the URL after the cap should be dropped. It makes for the most certain security. Zero Linden 14:37, 16 November 2007 (PST)
- If we decide we can do this later we can pass the remainder of the url in with the meta data - Kelly
- Define mime-handling
- I believe that we should, like the llHTTPRequest() call, be very clear in our handling of bodies and mime-types. In particular, accept only text/* mime types, and be sure to do proper charset handling and conversion into the UTF-8 that LSL strings use. (The code should all be cullable from the llHTTPRequest() implementation.) Zero Linden 14:37, 16 November 2007 (PST)
Performance Requirements
This should add no database, assetserver or viewer load.
Simulator:
- In general load should be no higher than existing alternatives (xmlrpc, llEmail and llHTTPRequest) for any single action.
- Connections need to be throttled.
- It would be nice if this could happen before the simulator on a per-cap basis, but throttling in the simulator handler would probably work as well.
TODO:
- Get statistics on # of XMLRPC connections, llHTTPRequests and llEmails per unit of time per region to set expectations for level of usage.
- XMLRPC: We can handle ~200 concurrent requests per server, we have seen peaks at ~300 concurrent requests (lower now).
Security Impact
Creating a server accessible in any way from outside needs to be done with care. The cap server already does this, and security concerns should already be handled here. This isn't something to take for granted though.
- Scripts should be blocked from using llHTTPRequest to contact the cap server, since this could be seen as an internal request to the cap server.
- Residents would really like them to be able to, but allowing access to our hosts from resident run content within our network is not a good idea. - Kelly
- Really? The caps invoking address is an external IP address, which is a different IP and port from the internal caps control address. The caps invoking IP and port is open to the Internet, surely llHTTPRequest() offers no more danger? The only trick I see is that we have to make sure that llHTTPRequest() ends up going out the external IP and back in again, rather than routing via localhost or the internal IP. Zero Linden 14:37, 16 November 2007 (PST)
- It sounds like this isn't as scary as I first feared. We need to make sure that we still can't make requests against local host, or anything except the public IP, or anything not the cap server - these rules should already be in place. Kelly
Limitations
- Size of the body of the requests will need to be limited. At least to something that will fit within script memory - 2k is probably right.
- Why not have this user configurable via function? One size does not fit all. - Strife Onizuka
- Incoming requests will need to be throttled at some rate. Script event queuing acts as a throttle for what connections the script will be able to handle, but that probably isn't enough. I would guess that near the rate of llHTTPRequest throttling is probably good - ~1 / second / object.
- Can we throttle before we reach the sim? - Kelly
Interactions
- Relies on capabilities and the cap server
- Effects LSL development including MONO