Difference between revisions of "LlHTTPResponse"

From Second Life Wiki
Jump to navigation Jump to search
m (~caveat clarification)
Line 10: Line 10:
|spec
|spec
|caveats=* This call must be made by the script containing the [[http_request]] event where the '''request_id''' was received.
|caveats=* This call must be made by the script containing the [[http_request]] event where the '''request_id''' was received.
* If '''body''' content greater than 2048 bytes, sent in response to [[llHTTPRequest]], will be truncated to 2048 bytes by [[http_response]] in the receiving script
* There is no limit, other than script size, to the amount of data that can be sent by this function.
** This limit does not apply to shared media {{HoverText|MOAP|Media On A Prim}}
** [[llHTTPRequest]] can truncate the response length in ''receiving'' scripts. Be aware when using them together for prim-to-prim communications.
* Returns 'content-type: text/plain' by default. Use [[llSetContentType]] to optionally return 'text/html' if being viewed by the object owner within a Second Life client.
* Returns 'content-type: text/plain' by default. Use [[llSetContentType]] to optionally return 'text/html' if being viewed by the object owner within a Second Life client.
|constants
|constants

Revision as of 06:24, 18 July 2012

Summary

Function: llHTTPResponse( key request_id, integer status, string body );
0.0 Forced Delay
10.0 Energy

Responds to request_id with status and body.

• key request_id A valid HTTP request key.
• integer status HTTP Status (200, 400, 404, etc)
• string body Contents of the response.

The response need not be made inside the http_request event but if it does not happen in a timely fashion the request will time out (within 25 seconds).

Caveats

  • This call must be made by the script containing the http_request event where the request_id was received.
  • There is no limit, other than script size, to the amount of data that can be sent by this function.
    • llHTTPRequest can truncate the response length in receiving scripts. Be aware when using them together for prim-to-prim communications.
  • Returns 'content-type: text/plain' by default. Use llSetContentType to optionally return 'text/html' if being viewed by the object owner within a Second Life client.

Examples

<lsl>key url_request;

default {

   state_entry()
   {
       url_request = llRequestURL();
   }
   http_request(key id, string method, string body)
   {
       if (url_request == id)
       {
           url_request = "";
           if (method == URL_REQUEST_GRANTED)
           {
               llOwnerSay("URL: " + body);
           }
           else if (method == URL_REQUEST_DENIED)
           {
               llOwnerSay("Something went wrong, no url. " + body);
           }
       }
       else
       {
           llHTTPResponse(id, 200, body);
       }
   }
}</lsl>

See Also

Events

•  http_request

Functions

•  llGetFreeURLs
•  llRequestURL
•  llRequestSecureURL
•  llReleaseURL
•  llGetHTTPHeader
•  llSetContentType

Articles

•  LSL http server

Deep Notes

History

Signature

function void llHTTPResponse( key request_id, integer status, string body );