aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework/WebUtil.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Framework/WebUtil.cs')
-rw-r--r--OpenSim/Framework/WebUtil.cs63
1 files changed, 53 insertions, 10 deletions
diff --git a/OpenSim/Framework/WebUtil.cs b/OpenSim/Framework/WebUtil.cs
index b180c8a..3436984 100644
--- a/OpenSim/Framework/WebUtil.cs
+++ b/OpenSim/Framework/WebUtil.cs
@@ -233,6 +233,9 @@ namespace OpenSim.Framework
233 string errorMessage = "unknown error"; 233 string errorMessage = "unknown error";
234 int tickstart = Util.EnvironmentTickCount(); 234 int tickstart = Util.EnvironmentTickCount();
235 int tickdata = 0; 235 int tickdata = 0;
236 int tickcompressdata = 0;
237 int tickJsondata = 0;
238 int compsize = 0;
236 string strBuffer = null; 239 string strBuffer = null;
237 240
238 try 241 try
@@ -250,6 +253,8 @@ namespace OpenSim.Framework
250 { 253 {
251 strBuffer = OSDParser.SerializeJsonString(data); 254 strBuffer = OSDParser.SerializeJsonString(data);
252 255
256 tickJsondata = Util.EnvironmentTickCountSubtract(tickstart);
257
253 if (DebugLevel >= 5) 258 if (DebugLevel >= 5)
254 LogOutgoingDetail("SEND", reqnum, strBuffer); 259 LogOutgoingDetail("SEND", reqnum, strBuffer);
255 260
@@ -271,13 +276,20 @@ namespace OpenSim.Framework
271 // gets written on the stream upon Dispose() 276 // gets written on the stream upon Dispose()
272 } 277 }
273 byte[] buf = ms.ToArray(); 278 byte[] buf = ms.ToArray();
279
280 tickcompressdata = Util.EnvironmentTickCountSubtract(tickstart);
281
274 request.ContentLength = buf.Length; //Count bytes to send 282 request.ContentLength = buf.Length; //Count bytes to send
283 compsize = buf.Length;
275 using (Stream requestStream = request.GetRequestStream()) 284 using (Stream requestStream = request.GetRequestStream())
276 requestStream.Write(buf, 0, (int)buf.Length); 285 requestStream.Write(buf, 0, (int)buf.Length);
277 } 286 }
278 } 287 }
279 else 288 else
280 { 289 {
290 tickcompressdata = tickJsondata;
291 compsize = buffer.Length;
292
281 request.ContentLength = buffer.Length; //Count bytes to send 293 request.ContentLength = buffer.Length; //Count bytes to send
282 using (Stream requestStream = request.GetRequestStream()) 294 using (Stream requestStream = request.GetRequestStream())
283 requestStream.Write(buffer, 0, buffer.Length); //Send it 295 requestStream.Write(buffer, 0, buffer.Length); //Send it
@@ -314,6 +326,7 @@ namespace OpenSim.Framework
314 catch (Exception ex) 326 catch (Exception ex)
315 { 327 {
316 errorMessage = ex.Message; 328 errorMessage = ex.Message;
329 m_log.Debug("[WEB UTIL]: Exception making request: " + ex.ToString());
317 } 330 }
318 finally 331 finally
319 { 332 {
@@ -321,8 +334,17 @@ namespace OpenSim.Framework
321 if (tickdiff > LongCallTime) 334 if (tickdiff > LongCallTime)
322 { 335 {
323 m_log.InfoFormat( 336 m_log.InfoFormat(
324 "[LOGHTTP]: Slow JSON-RPC request {0} {1} to {2} took {3}ms, {4}ms writing, {5}", 337 "[WEB UTIL]: Slow ServiceOSD request {0} {1} {2} took {3}ms, {4}ms writing({5} at Json; {6} at comp), {7} bytes ({8} uncomp): {9}",
325 reqnum, method, url, tickdiff, tickdata, 338 reqnum,
339 method,
340 url,
341 tickdiff,
342 tickdata,
343 tickJsondata,
344 tickcompressdata,
345 compsize,
346 strBuffer != null ? strBuffer.Length : 0,
347
326 strBuffer != null 348 strBuffer != null
327 ? (strBuffer.Length > MaxRequestDiagLength ? strBuffer.Remove(MaxRequestDiagLength) : strBuffer) 349 ? (strBuffer.Length > MaxRequestDiagLength ? strBuffer.Remove(MaxRequestDiagLength) : strBuffer)
328 : ""); 350 : "");
@@ -396,7 +418,7 @@ namespace OpenSim.Framework
396 /// </summary> 418 /// </summary>
397 public static OSDMap PostToService(string url, NameValueCollection data) 419 public static OSDMap PostToService(string url, NameValueCollection data)
398 { 420 {
399 return ServiceFormRequest(url,data,10000); 421 return ServiceFormRequest(url,data, 30000);
400 } 422 }
401 423
402 public static OSDMap ServiceFormRequest(string url, NameValueCollection data, int timeout) 424 public static OSDMap ServiceFormRequest(string url, NameValueCollection data, int timeout)
@@ -779,6 +801,20 @@ namespace OpenSim.Framework
779 MakeRequest<TRequest, TResponse>(verb, requestUrl, obj, action, maxConnections, null); 801 MakeRequest<TRequest, TResponse>(verb, requestUrl, obj, action, maxConnections, null);
780 } 802 }
781 803
804 /// <summary>
805 /// Perform a synchronous REST request.
806 /// </summary>
807 /// <param name="verb"></param>
808 /// <param name="requestUrl"></param>
809 /// <param name="obj"></param>
810 /// <param name="pTimeout">
811 /// Request timeout in seconds. Timeout.Infinite indicates no timeout. If 0 is passed then the default HttpWebRequest timeout is used (100 seconds)
812 /// </param>
813 /// <param name="maxConnections"></param>
814 /// <returns>
815 /// The response. If there was an internal exception or the request timed out,
816 /// then the default(TResponse) is returned.
817 /// </returns>
782 public static void MakeRequest<TRequest, TResponse>(string verb, 818 public static void MakeRequest<TRequest, TResponse>(string verb,
783 string requestUrl, TRequest obj, Action<TResponse> action, 819 string requestUrl, TRequest obj, Action<TResponse> action,
784 int maxConnections, IServiceAuth auth) 820 int maxConnections, IServiceAuth auth)
@@ -791,6 +827,7 @@ namespace OpenSim.Framework
791 827
792 int tickstart = Util.EnvironmentTickCount(); 828 int tickstart = Util.EnvironmentTickCount();
793 int tickdata = 0; 829 int tickdata = 0;
830 int tickdiff = 0;
794 831
795 Type type = typeof(TRequest); 832 Type type = typeof(TRequest);
796 833
@@ -936,7 +973,7 @@ namespace OpenSim.Framework
936 }, null); 973 }, null);
937 } 974 }
938 975
939 int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); 976 tickdiff = Util.EnvironmentTickCountSubtract(tickstart);
940 if (tickdiff > WebUtil.LongCallTime) 977 if (tickdiff > WebUtil.LongCallTime)
941 { 978 {
942 string originalRequest = null; 979 string originalRequest = null;
@@ -948,8 +985,7 @@ namespace OpenSim.Framework
948 if (originalRequest.Length > WebUtil.MaxRequestDiagLength) 985 if (originalRequest.Length > WebUtil.MaxRequestDiagLength)
949 originalRequest = originalRequest.Remove(WebUtil.MaxRequestDiagLength); 986 originalRequest = originalRequest.Remove(WebUtil.MaxRequestDiagLength);
950 } 987 }
951 988 m_log.InfoFormat(
952 m_log.InfoFormat(
953 "[LOGHTTP]: Slow AsynchronousRequestObject request {0} {1} to {2} took {3}ms, {4}ms writing, {5}", 989 "[LOGHTTP]: Slow AsynchronousRequestObject request {0} {1} to {2} took {3}ms, {4}ms writing, {5}",
954 reqnum, verb, requestUrl, tickdiff, tickdata, 990 reqnum, verb, requestUrl, tickdiff, tickdata,
955 originalRequest); 991 originalRequest);
@@ -957,6 +993,7 @@ namespace OpenSim.Framework
957 else if (WebUtil.DebugLevel >= 4) 993 else if (WebUtil.DebugLevel >= 4)
958 { 994 {
959 m_log.DebugFormat("[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", 995 m_log.DebugFormat("[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing",
996
960 reqnum, tickdiff, tickdata); 997 reqnum, tickdiff, tickdata);
961 } 998 }
962 } 999 }
@@ -1004,6 +1041,8 @@ namespace OpenSim.Framework
1004 1041
1005 string respstring = String.Empty; 1042 string respstring = String.Empty;
1006 1043
1044 int tickset = Util.EnvironmentTickCountSubtract(tickstart);
1045
1007 using (MemoryStream buffer = new MemoryStream()) 1046 using (MemoryStream buffer = new MemoryStream())
1008 { 1047 {
1009 if ((verb == "POST") || (verb == "PUT")) 1048 if ((verb == "POST") || (verb == "PUT"))
@@ -1070,8 +1109,13 @@ namespace OpenSim.Framework
1070 if (tickdiff > WebUtil.LongCallTime) 1109 if (tickdiff > WebUtil.LongCallTime)
1071 { 1110 {
1072 m_log.InfoFormat( 1111 m_log.InfoFormat(
1073 "[LOGHTTP]: Slow SynchronousRestForms request {0} {1} to {2} took {3}ms, {4}ms writing, {5}", 1112 "[FORMS]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}",
1074 reqnum, verb, requestUrl, tickdiff, tickdata, 1113 reqnum,
1114 verb,
1115 requestUrl,
1116 tickdiff,
1117 tickset,
1118 tickdata,
1075 obj.Length > WebUtil.MaxRequestDiagLength ? obj.Remove(WebUtil.MaxRequestDiagLength) : obj); 1119 obj.Length > WebUtil.MaxRequestDiagLength ? obj.Remove(WebUtil.MaxRequestDiagLength) : obj);
1076 } 1120 }
1077 else if (WebUtil.DebugLevel >= 4) 1121 else if (WebUtil.DebugLevel >= 4)
@@ -1202,7 +1246,7 @@ namespace OpenSim.Framework
1202 auth.AddAuthorization(ht.Headers); 1246 auth.AddAuthorization(ht.Headers);
1203 1247
1204 if (pTimeout != 0) 1248 if (pTimeout != 0)
1205 ht.Timeout = pTimeout; 1249 request.Timeout = pTimeout;
1206 1250
1207 if (maxConnections > 0 && ht.ServicePoint.ConnectionLimit < maxConnections) 1251 if (maxConnections > 0 && ht.ServicePoint.ConnectionLimit < maxConnections)
1208 ht.ServicePoint.ConnectionLimit = maxConnections; 1252 ht.ServicePoint.ConnectionLimit = maxConnections;
@@ -1343,7 +1387,6 @@ namespace OpenSim.Framework
1343 1387
1344 return deserial; 1388 return deserial;
1345 } 1389 }
1346
1347 1390
1348 public static class XMLResponseHelper 1391 public static class XMLResponseHelper
1349 { 1392 {