/* * 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.Collections.Specialized; using System.Net; using System.IO; using System.Text; using HttpServer; namespace OpenSim.Framework.Servers { public class OSHttpRequest { /// /// soon to be deprecated /// private string[] _acceptTypes; private Encoding _contentEncoding; private long _contentLength64; private string _contentType; // private CookieCollection _cookies; private NameValueCollection _headers; private string _httpMethod; private Stream _inputStream; // private bool _isSecureConnection; // private bool _isAuthenticated; private bool _keepAlive; private bool _hasbody; private string _rawUrl; private Uri _url; private NameValueCollection _queryString; private string _userAgent; private HttpRequest _request; // private HttpClientContext _context; public string[] AcceptTypes { get { return _acceptTypes; } } public Encoding ContentEncoding { get { return _contentEncoding; } } public long ContentLength { get { return _contentLength64; } } public long ContentLength64 { get { return ContentLength; } } public string ContentType { get { return _contentType; } } // public CookieCollection Cookies // { // get { return _cookies; } // } public NameValueCollection Headers { get { return _headers; } } public string HttpMethod { get { return _httpMethod; } } public Stream InputStream { get { return _inputStream; } } // public bool IsSecureConnection // { // get { return _isSecureConnection; } // } // public bool IsAuthenticated // { // get { return _isAuthenticated; } // } public bool HasEntityBody { get { return _hasbody; } } public bool KeepAlive { get { return _keepAlive; } } public string RawUrl { get { return _rawUrl; } } public Uri Url { get { return _url; } } public string UserAgent { get { return _userAgent; } } public NameValueCollection QueryString { get { return _queryString; } } public HttpRequest HttpRequest { get { return _request; } } public OSHttpRequest() { } public OSHttpRequest(HttpListenerRequest req) { _acceptTypes = req.AcceptTypes; _contentEncoding = req.ContentEncoding; _contentLength64 = req.ContentLength64; _contentType = req.ContentType; // _cookies = req.Cookies; _headers = req.Headers; _httpMethod = req.HttpMethod; _hasbody = req.HasEntityBody; _inputStream = req.InputStream; // _isSecureConnection = req.IsSecureConnection; // _isAuthenticated = req.IsAuthenticated; _keepAlive = req.KeepAlive; _rawUrl = req.RawUrl; _url = req.Url; _queryString = req.QueryString; _userAgent = req.UserAgent; } public OSHttpRequest(HttpClientContext context, HttpRequest req) { // _context = context; _request = req; _acceptTypes = req.AcceptTypes; if (null != req.Headers["content-encoding"]) _contentEncoding = Encoding.GetEncoding(_request.Headers["content-encoding"]); _contentLength64 = req.ContentLength; if (null != req.Headers["content-type"]) _contentType = _request.Headers["content-type"]; // _cookies = req.Cookies; _headers = req.Headers; _httpMethod = req.Method; _hasbody = req.ContentLength != 0; _inputStream = req.Body; // _isSecureConnection = req.IsSecureConnection; // _isAuthenticated = req.IsAuthenticated; _keepAlive = ConnectionType.KeepAlive == req.Connection; _rawUrl = req.Uri.AbsolutePath; _url = req.Uri; if (null != req.Headers["user-agent"]) _userAgent = req.Headers["user-agent"]; _queryString = new NameValueCollection(); foreach (KeyValuePair q in req.QueryString) { _queryString.Add(q.Key, q.Value.Value); } } } }