further work on the HttpServer stuff. not functional yet. just sharing

what crimes i'm committing.
0.6.0-stable
Dr Scofield 2008-06-25 13:10:12 +00:00
parent b713f4a540
commit daca971bf6
4 changed files with 126 additions and 11 deletions

View File

@ -30,11 +30,15 @@ using System.Collections.Specialized;
using System.Net; using System.Net;
using System.IO; using System.IO;
using System.Text; using System.Text;
using HttpServer;
namespace OpenSim.Framework.Servers namespace OpenSim.Framework.Servers
{ {
public class OSHttpRequest public class OSHttpRequest
{ {
/// <remarks>
/// soon to be deprecated
/// </remarks>
private string[] _acceptTypes; private string[] _acceptTypes;
private Encoding _contentEncoding; private Encoding _contentEncoding;
private long _contentLength64; private long _contentLength64;
@ -52,6 +56,9 @@ namespace OpenSim.Framework.Servers
private NameValueCollection _queryString; private NameValueCollection _queryString;
private string _userAgent; private string _userAgent;
private HttpRequest _request;
private HttpClientContext _context;
public string[] AcceptTypes public string[] AcceptTypes
{ {
get { return _acceptTypes; } get { return _acceptTypes; }
@ -160,5 +167,11 @@ namespace OpenSim.Framework.Servers
_queryString = req.QueryString; _queryString = req.QueryString;
_userAgent = req.UserAgent; _userAgent = req.UserAgent;
} }
public OSHttpRequest(HttpClientContext context, HttpRequest req)
{
_context = context;
_request = req;
}
} }
} }

View File

@ -31,25 +31,28 @@ using HttpServer;
namespace OpenSim.Framework.Servers namespace OpenSim.Framework.Servers
{ {
/// <summary> /// <summary>
/// OSHttpServer provides an HTTP server bound to a specific /// An OSHttpRequestPump fetches incoming OSHttpRequest objects
/// port. When instantiated with just address and port it uses /// from the OSHttpRequestQueue and feeds them to all subscribed
/// normal HTTP, when instantiated with address, port, and X509 /// parties. Each OSHttpRequestPump encapsulates one thread to do
/// certificate, it uses HTTPS. /// the work and there is a fixed number of pumps for each
/// OSHttpServer object.
/// </summary> /// </summary>
public class OSHttpRequestPump public class OSHttpRequestPump
{ {
protected OSHttpServer _httpServer; protected OSHttpServer _server;
protected OSHttpRequestQueue _queue;
public OSHttpRequestPump() public OSHttpRequestPump()
{ {
} }
public static OSHttpRequestPump[] Pumps(OSHttpServer server, int poolSize) public static OSHttpRequestPump[] Pumps(OSHttpServer server, OSHttpRequestQueue queue, int poolSize)
{ {
OSHttpRequestPump[] pumps = new OSHttpRequestPump[poolSize]; OSHttpRequestPump[] pumps = new OSHttpRequestPump[poolSize];
for (int i = 0; i < pumps.Length; i++) for (int i = 0; i < pumps.Length; i++)
{ {
pumps[i]._httpServer = server; pumps[i]._server = server;
pumps[i]._queue = queue;
} }
return pumps; return pumps;

View File

@ -0,0 +1,66 @@
/*
* Copyright (c) Contributors, http://opensimulator.org/
* See CONTRIBUTORS.TXT for a full list of copyright holders.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSim Project nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
using System;
using System.Collections.Generic;
using System.Threading;
using HttpServer;
namespace OpenSim.Framework.Servers
{
/// <summary>
/// OSHttpRequestQueues are used to hand over incoming HTTP
/// requests to OSHttpRequestPump objects.
/// </summary>
public class OSHttpRequestQueue : Queue<OSHttpRequest>
{
new public void Enqueue(OSHttpRequest req)
{
lock (this)
{
base.Enqueue(req);
Monitor.Pulse(this);
}
}
new public OSHttpRequest Dequeue()
{
OSHttpRequest req = null;
lock (this)
{
while (null == req)
{
Monitor.Wait(this);
if (0 != this.Count) req = base.Dequeue();
}
}
return req;
}
}
}

View File

@ -50,8 +50,12 @@ namespace OpenSim.Framework.Servers
// underlying HttpServer.HttpListener // underlying HttpServer.HttpListener
protected HttpListener _listener; protected HttpListener _listener;
// underlying core/engine thread
protected Thread _engine; protected Thread _engine;
// Queue containing (OS)HttpRequests
protected OSHttpRequestQueue _queue;
// OSHttpRequestPumps "pumping" incoming OSHttpRequests // OSHttpRequestPumps "pumping" incoming OSHttpRequests
// upwards // upwards
protected OSHttpRequestPump[] _pumps; protected OSHttpRequestPump[] _pumps;
@ -72,6 +76,11 @@ namespace OpenSim.Framework.Servers
get { return _isSecure; } get { return _isSecure; }
} }
public int QueueSize
{
get { return _pumps.Length; }
}
/// <summary> /// <summary>
/// Instantiate an HTTP server. /// Instantiate an HTTP server.
/// </summary> /// </summary>
@ -80,17 +89,37 @@ namespace OpenSim.Framework.Servers
_engineId = String.Format("OSHttpServer [HTTP:{0}/ps:{1}]", port, poolSize); _engineId = String.Format("OSHttpServer [HTTP:{0}/ps:{1}]", port, poolSize);
_isSecure = false; _isSecure = false;
_pumps = OSHttpRequestPump.Pumps(this, poolSize); _listener = new HttpListener(address, port);
_queue = new OSHttpRequestQueue();
_pumps = OSHttpRequestPump.Pumps(this, _queue, poolSize);
} }
/// <summary> /// <summary>
/// Instantiate an HTTPS server. /// Instantiate an HTTPS server.
/// </summary> /// </summary>
public OSHttpServer(IPAddress address, int port, X509Certificate certificate, int poolSize) : public OSHttpServer(IPAddress address, int port, X509Certificate certificate, int poolSize)
this(address, port, poolSize)
{ {
_engineId = String.Format("OSHttpServer [HTTPS:{0}/ps:{1}]", port, poolSize); _engineId = String.Format("OSHttpServer [HTTPS:{0}/ps:{1}]", port, poolSize);
_isSecure = true; _isSecure = true;
_listener = new HttpListener(address, port, certificate);
_queue = new OSHttpRequestQueue();
_pumps = OSHttpRequestPump.Pumps(this, _queue, poolSize);
}
/// <summary>
/// Turn an HttpRequest into an OSHttpRequestItem and place it
/// in the queue. The OSHttpRequestQueue object will pulse the
/// next available idle pump.
/// </summary>
protected void OnHttpRequest(HttpClientContext client, HttpRequest request)
{
// turn request into OSHttpRequest
OSHttpRequest req = new OSHttpRequest(client, request);
// place OSHttpRequest into _httpRequestQueue, will
// trigger Pulse to idle waiting pumps
_queue.Enqueue(req);
} }
/// <summary> /// <summary>
@ -102,6 +131,7 @@ namespace OpenSim.Framework.Servers
_engine.Name = _engineId; _engine.Name = _engineId;
_engine.IsBackground = true; _engine.IsBackground = true;
_engine.Start(); _engine.Start();
ThreadTracker.Add(_engine); ThreadTracker.Add(_engine);
} }
@ -111,9 +141,12 @@ namespace OpenSim.Framework.Servers
{ {
while (true) while (true)
{ {
// do stuff _listener.RequestHandler += OnHttpRequest;
_listener.Start(QueueSize);
} }
} }
} }
} }