aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
authorBlueWall2015-03-04 14:02:35 -0500
committerBlueWall2015-03-04 14:02:35 -0500
commit369ccaf1eb0f2cf235108b6534d4207cfbf520e9 (patch)
treec916dd429b9a9b494b27fe87563ef31d399c9403 /OpenSim/Region
parentOne more migration fix (diff)
parentMake private services forbid llHTTPRequest() calls by rejecting those that ha... (diff)
downloadopensim-SC-369ccaf1eb0f2cf235108b6534d4207cfbf520e9.zip
opensim-SC-369ccaf1eb0f2cf235108b6534d4207cfbf520e9.tar.gz
opensim-SC-369ccaf1eb0f2cf235108b6534d4207cfbf520e9.tar.bz2
opensim-SC-369ccaf1eb0f2cf235108b6534d4207cfbf520e9.tar.xz
Merge branch 'master' of ssh://opensimulator.org/var/git/opensim
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/CoreModules/Scripting/HttpRequest/ScriptsHttpRequests.cs124
-rw-r--r--OpenSim/Region/CoreModules/Scripting/HttpRequest/Tests/ScriptsHttpRequestsTests.cs4
-rw-r--r--OpenSim/Region/CoreModules/Scripting/LoadImageURL/LoadImageURLModule.cs53
-rw-r--r--OpenSim/Region/Framework/Interfaces/IHttpRequests.cs37
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs6
5 files changed, 195 insertions, 29 deletions
diff --git a/OpenSim/Region/CoreModules/Scripting/HttpRequest/ScriptsHttpRequests.cs b/OpenSim/Region/CoreModules/Scripting/HttpRequest/ScriptsHttpRequests.cs
index a7237ea..8f6aa55 100644
--- a/OpenSim/Region/CoreModules/Scripting/HttpRequest/ScriptsHttpRequests.cs
+++ b/OpenSim/Region/CoreModules/Scripting/HttpRequest/ScriptsHttpRequests.cs
@@ -40,6 +40,7 @@ using log4net;
40using Nini.Config; 40using Nini.Config;
41using OpenMetaverse; 41using OpenMetaverse;
42using OpenSim.Framework; 42using OpenSim.Framework;
43using OpenSim.Framework.Communications;
43using OpenSim.Framework.Servers; 44using OpenSim.Framework.Servers;
44using OpenSim.Framework.Servers.HttpServer; 45using OpenSim.Framework.Servers.HttpServer;
45using OpenSim.Region.Framework.Interfaces; 46using OpenSim.Region.Framework.Interfaces;
@@ -94,10 +95,13 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
94 [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "HttpRequestModule")] 95 [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "HttpRequestModule")]
95 public class HttpRequestModule : ISharedRegionModule, IHttpRequestModule 96 public class HttpRequestModule : ISharedRegionModule, IHttpRequestModule
96 { 97 {
98// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
99
97 private object HttpListLock = new object(); 100 private object HttpListLock = new object();
98 private int httpTimeout = 30000; 101 private int httpTimeout = 30000;
99 private string m_name = "HttpScriptRequests"; 102 private string m_name = "HttpScriptRequests";
100 103
104 private OutboundUrlFilter m_outboundUrlFilter;
101 private string m_proxyurl = ""; 105 private string m_proxyurl = "";
102 private string m_proxyexcepts = ""; 106 private string m_proxyexcepts = "";
103 107
@@ -156,7 +160,9 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
156 return UUID.Zero; 160 return UUID.Zero;
157 } 161 }
158 162
159 public UUID StartHttpRequest(uint localID, UUID itemID, string url, List<string> parameters, Dictionary<string, string> headers, string body) 163 public UUID StartHttpRequest(
164 uint localID, UUID itemID, string url, List<string> parameters, Dictionary<string, string> headers, string body,
165 out HttpInitialRequestStatus status)
160 { 166 {
161 UUID reqID = UUID.Random(); 167 UUID reqID = UUID.Random();
162 HttpRequestClass htc = new HttpRequestClass(); 168 HttpRequestClass htc = new HttpRequestClass();
@@ -232,7 +238,8 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
232 } 238 }
233 } 239 }
234 } 240 }
235 241
242 htc.RequestModule = this;
236 htc.LocalID = localID; 243 htc.LocalID = localID;
237 htc.ItemID = itemID; 244 htc.ItemID = itemID;
238 htc.Url = url; 245 htc.Url = url;
@@ -243,14 +250,43 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
243 htc.proxyurl = m_proxyurl; 250 htc.proxyurl = m_proxyurl;
244 htc.proxyexcepts = m_proxyexcepts; 251 htc.proxyexcepts = m_proxyexcepts;
245 252
253 // Same number as default HttpWebRequest.MaximumAutomaticRedirections
254 htc.MaxRedirects = 50;
255
256 if (StartHttpRequest(htc))
257 {
258 status = HttpInitialRequestStatus.OK;
259 return htc.ReqID;
260 }
261 else
262 {
263 status = HttpInitialRequestStatus.DISALLOWED_BY_FILTER;
264 return UUID.Zero;
265 }
266 }
267
268 /// <summary>
269 /// Would a caller to this module be allowed to make a request to the given URL?
270 /// </summary>
271 /// <returns></returns>
272 public bool CheckAllowed(Uri url)
273 {
274 return m_outboundUrlFilter.CheckAllowed(url);
275 }
276
277 public bool StartHttpRequest(HttpRequestClass req)
278 {
279 if (!CheckAllowed(new Uri(req.Url)))
280 return false;
281
246 lock (HttpListLock) 282 lock (HttpListLock)
247 { 283 {
248 m_pendingRequests.Add(reqID, htc); 284 m_pendingRequests.Add(req.ReqID, req);
249 } 285 }
250 286
251 htc.Process(); 287 req.Process();
252 288
253 return reqID; 289 return true;
254 } 290 }
255 291
256 public void StopHttpRequestsForScript(UUID id) 292 public void StopHttpRequestsForScript(UUID id)
@@ -326,6 +362,8 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
326 m_proxyurl = config.Configs["Startup"].GetString("HttpProxy"); 362 m_proxyurl = config.Configs["Startup"].GetString("HttpProxy");
327 m_proxyexcepts = config.Configs["Startup"].GetString("HttpProxyExceptions"); 363 m_proxyexcepts = config.Configs["Startup"].GetString("HttpProxyExceptions");
328 364
365 m_outboundUrlFilter = new OutboundUrlFilter("Script HTTP request module", config);
366
329 m_pendingRequests = new Dictionary<UUID, HttpRequestClass>(); 367 m_pendingRequests = new Dictionary<UUID, HttpRequestClass>();
330 } 368 }
331 369
@@ -368,7 +406,7 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
368 #endregion 406 #endregion
369 } 407 }
370 408
371 public class HttpRequestClass: IServiceRequest 409 public class HttpRequestClass : IServiceRequest
372 { 410 {
373// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 411// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
374 412
@@ -380,6 +418,12 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
380 // public const int HTTP_VERBOSE_THROTTLE = 4; 418 // public const int HTTP_VERBOSE_THROTTLE = 4;
381 // public const int HTTP_CUSTOM_HEADER = 5; 419 // public const int HTTP_CUSTOM_HEADER = 5;
382 // public const int HTTP_PRAGMA_NO_CACHE = 6; 420 // public const int HTTP_PRAGMA_NO_CACHE = 6;
421
422 /// <summary>
423 /// Module that made this request.
424 /// </summary>
425 public HttpRequestModule RequestModule { get; set; }
426
383 private bool _finished; 427 private bool _finished;
384 public bool Finished 428 public bool Finished
385 { 429 {
@@ -412,6 +456,17 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
412 public DateTime Next; 456 public DateTime Next;
413 public string proxyurl; 457 public string proxyurl;
414 public string proxyexcepts; 458 public string proxyexcepts;
459
460 /// <summary>
461 /// Number of HTTP redirects that this request has been through.
462 /// </summary>
463 public int Redirects { get; private set; }
464
465 /// <summary>
466 /// Maximum number of HTTP redirects allowed for this request.
467 /// </summary>
468 public int MaxRedirects { get; set; }
469
415 public string OutboundBody; 470 public string OutboundBody;
416 private UUID _reqID; 471 private UUID _reqID;
417 public UUID ReqID 472 public UUID ReqID
@@ -419,7 +474,7 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
419 get { return _reqID; } 474 get { return _reqID; }
420 set { _reqID = value; } 475 set { _reqID = value; }
421 } 476 }
422 public WebRequest Request; 477 public HttpWebRequest Request;
423 public string ResponseBody; 478 public string ResponseBody;
424 public List<string> ResponseMetadata; 479 public List<string> ResponseMetadata;
425 public Dictionary<string, string> ResponseHeaders; 480 public Dictionary<string, string> ResponseHeaders;
@@ -435,7 +490,8 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
435 { 490 {
436 try 491 try
437 { 492 {
438 Request = WebRequest.Create(Url); 493 Request = (HttpWebRequest)WebRequest.Create(Url);
494 Request.AllowAutoRedirect = false;
439 Request.Method = HttpMethod; 495 Request.Method = HttpMethod;
440 Request.ContentType = HttpMIMEType; 496 Request.ContentType = HttpMIMEType;
441 497
@@ -450,16 +506,19 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
450// { 506// {
451// Request.ConnectionGroupName="Verify"; 507// Request.ConnectionGroupName="Verify";
452// } 508// }
509
453 if (!HttpPragmaNoCache) 510 if (!HttpPragmaNoCache)
454 { 511 {
455 Request.Headers.Add("Pragma", "no-cache"); 512 Request.Headers.Add("Pragma", "no-cache");
456 } 513 }
514
457 if (HttpCustomHeaders != null) 515 if (HttpCustomHeaders != null)
458 { 516 {
459 for (int i = 0; i < HttpCustomHeaders.Count; i += 2) 517 for (int i = 0; i < HttpCustomHeaders.Count; i += 2)
460 Request.Headers.Add(HttpCustomHeaders[i], 518 Request.Headers.Add(HttpCustomHeaders[i],
461 HttpCustomHeaders[i+1]); 519 HttpCustomHeaders[i+1]);
462 } 520 }
521
463 if (!string.IsNullOrEmpty(proxyurl)) 522 if (!string.IsNullOrEmpty(proxyurl))
464 { 523 {
465 if (!string.IsNullOrEmpty(proxyexcepts)) 524 if (!string.IsNullOrEmpty(proxyexcepts))
@@ -565,7 +624,52 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
565 if (response != null) 624 if (response != null)
566 response.Close(); 625 response.Close();
567 626
568 _finished = true; 627 // We need to resubmit
628 if (
629 (Status == (int)HttpStatusCode.MovedPermanently
630 || Status == (int)HttpStatusCode.Found
631 || Status == (int)HttpStatusCode.SeeOther
632 || Status == (int)HttpStatusCode.TemporaryRedirect))
633 {
634 if (Redirects >= MaxRedirects)
635 {
636 Status = (int)OSHttpStatusCode.ClientErrorJoker;
637 ResponseBody = "Number of redirects exceeded max redirects";
638 _finished = true;
639 }
640 else
641 {
642 string location = response.Headers["Location"];
643
644 if (location == null)
645 {
646 Status = (int)OSHttpStatusCode.ClientErrorJoker;
647 ResponseBody = "HTTP redirect code but no location header";
648 _finished = true;
649 }
650 else if (!RequestModule.CheckAllowed(new Uri(location)))
651 {
652 Status = (int)OSHttpStatusCode.ClientErrorJoker;
653 ResponseBody = "URL from HTTP redirect blocked: " + location;
654 _finished = true;
655 }
656 else
657 {
658 Status = 0;
659 Url = response.Headers["Location"];
660 Redirects++;
661 ResponseBody = null;
662
663// m_log.DebugFormat("Redirecting to [{0}]", Url);
664
665 Process();
666 }
667 }
668 }
669 else
670 {
671 _finished = true;
672 }
569 } 673 }
570 } 674 }
571 675
@@ -583,4 +687,4 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest
583 Request.Abort(); 687 Request.Abort();
584 } 688 }
585 } 689 }
586} 690} \ No newline at end of file
diff --git a/OpenSim/Region/CoreModules/Scripting/HttpRequest/Tests/ScriptsHttpRequestsTests.cs b/OpenSim/Region/CoreModules/Scripting/HttpRequest/Tests/ScriptsHttpRequestsTests.cs
index 4d8b591..28fd495 100644
--- a/OpenSim/Region/CoreModules/Scripting/HttpRequest/Tests/ScriptsHttpRequestsTests.cs
+++ b/OpenSim/Region/CoreModules/Scripting/HttpRequest/Tests/ScriptsHttpRequestsTests.cs
@@ -146,11 +146,11 @@ namespace OpenSim.Region.CoreModules.Scripting.HttpRequest.Tests
146 /// <summary> 146 /// <summary>
147 /// Test what happens when we get a 404 response from a call. 147 /// Test what happens when we get a 404 response from a call.
148 /// </summary> 148 /// </summary>
149 [Test] 149// [Test]
150 public void Test404Response() 150 public void Test404Response()
151 { 151 {
152 TestHelpers.InMethod(); 152 TestHelpers.InMethod();
153// TestHelpers.EnableLogging(); 153 TestHelpers.EnableLogging();
154 154
155 if (!Util.IsPlatformMono) 155 if (!Util.IsPlatformMono)
156 Assert.Ignore("Ignoring test since can only currently run on Mono"); 156 Assert.Ignore("Ignoring test since can only currently run on Mono");
diff --git a/OpenSim/Region/CoreModules/Scripting/LoadImageURL/LoadImageURLModule.cs b/OpenSim/Region/CoreModules/Scripting/LoadImageURL/LoadImageURLModule.cs
index baf9f2f..7462ebd 100644
--- a/OpenSim/Region/CoreModules/Scripting/LoadImageURL/LoadImageURLModule.cs
+++ b/OpenSim/Region/CoreModules/Scripting/LoadImageURL/LoadImageURLModule.cs
@@ -32,6 +32,7 @@ using System.Net;
32using Nini.Config; 32using Nini.Config;
33using OpenMetaverse; 33using OpenMetaverse;
34using OpenMetaverse.Imaging; 34using OpenMetaverse.Imaging;
35using OpenSim.Framework.Communications;
35using OpenSim.Region.CoreModules.Scripting.DynamicTexture; 36using OpenSim.Region.CoreModules.Scripting.DynamicTexture;
36using OpenSim.Region.Framework.Interfaces; 37using OpenSim.Region.Framework.Interfaces;
37using OpenSim.Region.Framework.Scenes; 38using OpenSim.Region.Framework.Scenes;
@@ -50,6 +51,7 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
50 private Scene m_scene; 51 private Scene m_scene;
51 private IDynamicTextureManager m_textureManager; 52 private IDynamicTextureManager m_textureManager;
52 53
54 private OutboundUrlFilter m_outboundUrlFilter;
53 private string m_proxyurl = ""; 55 private string m_proxyurl = "";
54 private string m_proxyexcepts = ""; 56 private string m_proxyexcepts = "";
55 57
@@ -88,8 +90,7 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
88 90
89 public bool AsyncConvertUrl(UUID id, string url, string extraParams) 91 public bool AsyncConvertUrl(UUID id, string url, string extraParams)
90 { 92 {
91 MakeHttpRequest(url, id); 93 return MakeHttpRequest(url, id);
92 return true;
93 } 94 }
94 95
95 public bool AsyncConvertData(UUID id, string bodyData, string extraParams) 96 public bool AsyncConvertData(UUID id, string bodyData, string extraParams)
@@ -110,6 +111,7 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
110 111
111 public void Initialise(IConfigSource config) 112 public void Initialise(IConfigSource config)
112 { 113 {
114 m_outboundUrlFilter = new OutboundUrlFilter("Script dynamic texture image module", config);
113 m_proxyurl = config.Configs["Startup"].GetString("HttpProxy"); 115 m_proxyurl = config.Configs["Startup"].GetString("HttpProxy");
114 m_proxyexcepts = config.Configs["Startup"].GetString("HttpProxyExceptions"); 116 m_proxyexcepts = config.Configs["Startup"].GetString("HttpProxyExceptions");
115 } 117 }
@@ -157,9 +159,13 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
157 159
158 #endregion 160 #endregion
159 161
160 private void MakeHttpRequest(string url, UUID requestID) 162 private bool MakeHttpRequest(string url, UUID requestID)
161 { 163 {
162 WebRequest request = HttpWebRequest.Create(url); 164 if (!m_outboundUrlFilter.CheckAllowed(new Uri(url)))
165 return false;
166
167 HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
168 request.AllowAutoRedirect = false;
163 169
164 if (!string.IsNullOrEmpty(m_proxyurl)) 170 if (!string.IsNullOrEmpty(m_proxyurl))
165 { 171 {
@@ -174,12 +180,14 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
174 } 180 }
175 } 181 }
176 182
177 RequestState state = new RequestState((HttpWebRequest) request, requestID); 183 RequestState state = new RequestState(request, requestID);
178 // IAsyncResult result = request.BeginGetResponse(new AsyncCallback(HttpRequestReturn), state); 184 // IAsyncResult result = request.BeginGetResponse(new AsyncCallback(HttpRequestReturn), state);
179 request.BeginGetResponse(new AsyncCallback(HttpRequestReturn), state); 185 request.BeginGetResponse(new AsyncCallback(HttpRequestReturn), state);
180 186
181 TimeSpan t = (DateTime.UtcNow - new DateTime(1970, 1, 1)); 187 TimeSpan t = (DateTime.UtcNow - new DateTime(1970, 1, 1));
182 state.TimeOfRequest = (int) t.TotalSeconds; 188 state.TimeOfRequest = (int) t.TotalSeconds;
189
190 return true;
183 } 191 }
184 192
185 private void HttpRequestReturn(IAsyncResult result) 193 private void HttpRequestReturn(IAsyncResult result)
@@ -195,10 +203,11 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
195 Stream stream = null; 203 Stream stream = null;
196 byte[] imageJ2000 = new byte[0]; 204 byte[] imageJ2000 = new byte[0];
197 Size newSize = new Size(0, 0); 205 Size newSize = new Size(0, 0);
206 HttpWebResponse response = null;
198 207
199 try 208 try
200 { 209 {
201 HttpWebResponse response = (HttpWebResponse)request.EndGetResponse(result); 210 response = (HttpWebResponse)request.EndGetResponse(result);
202 if (response != null && response.StatusCode == HttpStatusCode.OK) 211 if (response != null && response.StatusCode == HttpStatusCode.OK)
203 { 212 {
204 stream = response.GetResponseStream(); 213 stream = response.GetResponseStream();
@@ -262,18 +271,32 @@ namespace OpenSim.Region.CoreModules.Scripting.LoadImageURL
262 finally 271 finally
263 { 272 {
264 if (stream != null) 273 if (stream != null)
265 {
266 stream.Close(); 274 stream.Close();
267 }
268 }
269 275
270 m_log.DebugFormat("[LOADIMAGEURLMODULE]: Returning {0} bytes of image data for request {1}", 276 if (response != null)
271 imageJ2000.Length, state.RequestID); 277 response.Close();
272 278
273 m_textureManager.ReturnData( 279 if (
274 state.RequestID, 280 response.StatusCode == HttpStatusCode.MovedPermanently
275 new OpenSim.Region.CoreModules.Scripting.DynamicTexture.DynamicTexture( 281 || response.StatusCode == HttpStatusCode.Found
276 request.RequestUri, null, imageJ2000, newSize, false)); 282 || response.StatusCode == HttpStatusCode.SeeOther
283 || response.StatusCode == HttpStatusCode.TemporaryRedirect)
284 {
285 string redirectedUrl = response.Headers["Location"];
286
287 MakeHttpRequest(redirectedUrl, state.RequestID);
288 }
289 else
290 {
291 m_log.DebugFormat("[LOADIMAGEURLMODULE]: Returning {0} bytes of image data for request {1}",
292 imageJ2000.Length, state.RequestID);
293
294 m_textureManager.ReturnData(
295 state.RequestID,
296 new OpenSim.Region.CoreModules.Scripting.DynamicTexture.DynamicTexture(
297 request.RequestUri, null, imageJ2000, newSize, false));
298 }
299 }
277 } 300 }
278 301
279 #region Nested type: RequestState 302 #region Nested type: RequestState
diff --git a/OpenSim/Region/Framework/Interfaces/IHttpRequests.cs b/OpenSim/Region/Framework/Interfaces/IHttpRequests.cs
index 113dcd7..124504c 100644
--- a/OpenSim/Region/Framework/Interfaces/IHttpRequests.cs
+++ b/OpenSim/Region/Framework/Interfaces/IHttpRequests.cs
@@ -25,6 +25,7 @@
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */ 26 */
27 27
28using System;
28using System.Collections.Generic; 29using System.Collections.Generic;
29using OpenMetaverse; 30using OpenMetaverse;
30 31
@@ -41,10 +42,44 @@ namespace OpenSim.Region.Framework.Interfaces
41 HTTP_PRAGMA_NO_CACHE = 6 42 HTTP_PRAGMA_NO_CACHE = 6
42 } 43 }
43 44
45 /// <summary>
46 /// The initial status of the request before it is placed on the wire.
47 /// </summary>
48 /// <remarks>
49 /// The request may still fail later on, in which case the normal HTTP status is set.
50 /// </remarks>
51 [Flags]
52 public enum HttpInitialRequestStatus
53 {
54 OK = 1,
55 DISALLOWED_BY_FILTER = 2
56 }
57
44 public interface IHttpRequestModule 58 public interface IHttpRequestModule
45 { 59 {
46 UUID MakeHttpRequest(string url, string parameters, string body); 60 UUID MakeHttpRequest(string url, string parameters, string body);
47 UUID StartHttpRequest(uint localID, UUID itemID, string url, List<string> parameters, Dictionary<string, string> headers, string body); 61
62 /// <summary>
63 /// Starts the http request.
64 /// </summary>
65 /// <remarks>
66 /// This is carried out asynchronously unless it fails initial checks. Results are fetched by the script engine
67 /// HTTP requests module to be distributed back to scripts via a script event.
68 /// </remarks>
69 /// <returns>The ID of the request. If the requested could not be performed then this is UUID.Zero</returns>
70 /// <param name="localID">Local ID of the object containing the script making the request.</param>
71 /// <param name="itemID">Item ID of the script making the request.</param>
72 /// <param name="url">Url to request.</param>
73 /// <param name="parameters">LSL parameters for the request.</param>
74 /// <param name="headers">Extra headers for the request.</param>
75 /// <param name="body">Body of the request.</param>
76 /// <param name="status">
77 /// Initial status of the request. If OK then the request is actually made to the URL. Subsequent status is
78 /// then returned via IServiceRequest when the response is asynchronously fetched.
79 /// </param>
80 UUID StartHttpRequest(
81 uint localID, UUID itemID, string url, List<string> parameters, Dictionary<string, string> headers, string body,
82 out HttpInitialRequestStatus status);
48 83
49 /// <summary> 84 /// <summary>
50 /// Stop and remove all http requests for the given script. 85 /// Stop and remove all http requests for the given script.
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index d0a0b03..61756af 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -12240,8 +12240,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
12240 } 12240 }
12241 } 12241 }
12242 12242
12243 HttpInitialRequestStatus status;
12243 UUID reqID 12244 UUID reqID
12244 = httpScriptMod.StartHttpRequest(m_host.LocalId, m_item.ItemID, url, param, httpHeaders, body); 12245 = httpScriptMod.StartHttpRequest(m_host.LocalId, m_item.ItemID, url, param, httpHeaders, body, out status);
12246
12247 if (status == HttpInitialRequestStatus.DISALLOWED_BY_FILTER)
12248 Error("llHttpRequest", string.Format("Request to {0} disallowed by filter", url));
12245 12249
12246 if (reqID != UUID.Zero) 12250 if (reqID != UUID.Zero)
12247 return reqID.ToString(); 12251 return reqID.ToString();