| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841 |
- //
- // System.Web.HttpRequest
- //
- // Author:
- // Patrik Torstensson ([email protected])
- //
- using System;
- using System.Collections;
- using System.Collections.Specialized;
- using System.IO;
- using System.Text;
- namespace System.Web {
- //-- Methods from HttpRequest not implemented
- // public HttpFileCollection Files {get;}
- // public HttpBrowserCapabilities Browser {get; set;}
- // public HttpClientCertificate ClientCertificate {get;}
- // public string ApplicationPath {get;}
- // public HttpCookieCollection Cookies {get;}
- // public Stream Filter {get; set;}
- // public string MapPath(string virtualPath, string baseVirtualDir, bool allowCrossAppMapping);
- // public string MapPath(string virtualPath);
- // public int [] MapImageCoordinates(string imageFieldName);
- // public string FilePath {get;}
- // public Uri UrlReferrer
- [MonoTODO("Review security in all path access function")]
- public class HttpRequest {
- private string [] _arrAcceptTypes;
- private string [] _arrUserLanguages;
- private byte [] _arrRawContent;
- private int _iContentLength;
- private string _sContentType;
- private string _sHttpMethod;
- private string _sRawUrl;
- private string _sUserAgent;
- private string _sUserHostAddress;
- private string _sUserHostName;
- private string _sPath;
- private string _sPathInfo;
- private string _sFilePath;
- private string _sPathTranslated;
- private string _sQueryStringRaw;
- private string _sRequestType;
- private string _sRequestRootVirtualDir;
- private Encoding _oContentEncoding;
- private Uri _oUriReferrer;
- private Uri _oUrl;
- private int _iTotalBytes;
- private HttpContext _oContext;
- private HttpWorkerRequest _WorkerRequest;
- private HttpRequestStream _oInputStream;
- private HttpValueCollection _oServerVariables;
- private HttpValueCollection _oHeaders;
- private HttpValueCollection _oQueryString;
- private HttpValueCollection _oFormData;
- private HttpValueCollection _oParams;
- public HttpRequest(string Filename, string Url, string Querystring) {
- _iContentLength = -1;
- _iTotalBytes = -1;
- _WorkerRequest = null;
- _sPathTranslated = Filename;
- _sRequestType = "GET";
- _sHttpMethod = "GET";
- _oUrl = new Uri(Url);
- _sPath = _oUrl.AbsolutePath;
- _sQueryStringRaw = Querystring;
- _oQueryString = new HttpValueCollection(Querystring, true, Encoding.Default);
- }
- internal HttpRequest(HttpWorkerRequest WorkRequest, HttpContext Context) {
- _WorkerRequest = WorkRequest;
- _oContext = Context;
- _iContentLength = -1;
- _iTotalBytes = -1;
- }
- static private string MakeServerVariableFromHeader(string header) {
- return "HTTP_" + header.ToUpper().Replace("-", "_");
- }
- [MonoTODO("Need to support non-raw mode also..")]
- private string GetAllHeaders(bool Raw) {
- StringBuilder oData;
- if (null == _WorkerRequest) {
- return null;
- }
- oData = new StringBuilder(512);
- string sHeaderValue;
- string sHeaderName;
- int iCount = 0;
- // Add all know headers
- for (; iCount != 40; iCount++) {
- sHeaderValue = _WorkerRequest.GetKnownRequestHeader(iCount);
- if (null != sHeaderValue && sHeaderValue.Length > 0) {
- sHeaderName = _WorkerRequest.GetKnownRequestHeader(iCount);
- if (null != sHeaderName && sHeaderName.Length > 0) {
- oData.Append(sHeaderName);
- oData.Append(": ");
- oData.Append(sHeaderValue);
- oData.Append("\r\n");
- }
- }
- }
- // Get all other headers
- string [][] arrUnknownHeaders = _WorkerRequest.GetUnknownRequestHeaders();
- if (null != arrUnknownHeaders) {
- for (iCount = 0; iCount != arrUnknownHeaders.Length; iCount++) {
- oData.Append(arrUnknownHeaders[iCount][0]);
- oData.Append(": ");
- oData.Append(arrUnknownHeaders[iCount][1]);
- oData.Append("\r\n");
- }
- }
- return oData.ToString();
- }
-
- [MonoTODO("We need to handly 'dynamic' variables like AUTH_USER, that can be changed during runtime... special collection")]
- private void ParseServerVariables() {
- if (null == _WorkerRequest) {
- return;
- }
- if (_oServerVariables == null) {
- string sTmp;
- _oServerVariables = new HttpValueCollection();
-
- _oServerVariables.Add("ALL_HTTP", GetAllHeaders(false));
- _oServerVariables.Add("ALL_RAW", GetAllHeaders(true));
- _oServerVariables.Add("APPL_MD_PATH", _WorkerRequest.GetServerVariable("APPL_MD_PATH"));
- _oServerVariables.Add("AUTH_PASSWORD", _WorkerRequest.GetServerVariable("AUTH_PASSWORD"));
- _oServerVariables.Add("CERT_COOKIE", _WorkerRequest.GetServerVariable("CERT_COOKIE"));
- _oServerVariables.Add("CERT_FLAGS", _WorkerRequest.GetServerVariable("CERT_FLAGS"));
- _oServerVariables.Add("CERT_ISSUER", _WorkerRequest.GetServerVariable("CERT_ISSUER"));
- _oServerVariables.Add("CERT_KEYSIZE", _WorkerRequest.GetServerVariable("CERT_KEYSIZE"));
- _oServerVariables.Add("CERT_SECRETKEYSIZE", _WorkerRequest.GetServerVariable("CERT_SECRETKEYSIZE"));
- _oServerVariables.Add("CERT_SERIALNUMBER", _WorkerRequest.GetServerVariable("CERT_SERIALNUMBER"));
- _oServerVariables.Add("CERT_SERVER_ISSUER", _WorkerRequest.GetServerVariable("CERT_SERVER_ISSUER"));
- _oServerVariables.Add("CERT_SERVER_SUBJECT", _WorkerRequest.GetServerVariable("CERT_SERVER_SUBJECT"));
- _oServerVariables.Add("CERT_SUBJECT", _WorkerRequest.GetServerVariable("CERT_SUBJECT"));
- _oServerVariables.Add("GATEWAY_INTERFACE", _WorkerRequest.GetServerVariable("GATEWAY_INTERFACE"));
- _oServerVariables.Add("HTTPS", _WorkerRequest.GetServerVariable("HTTPS"));
- _oServerVariables.Add("HTTPS_KEYSIZE", _WorkerRequest.GetServerVariable("HTTPS_KEYSIZE"));
- _oServerVariables.Add("HTTPS_SECRETKEYSIZE", _WorkerRequest.GetServerVariable("HTTPS_SECRETKEYSIZE"));
- _oServerVariables.Add("CONTENT_TYPE", ContentType);
- _oServerVariables.Add("HTTPS_SERVER_ISSUER", _WorkerRequest.GetServerVariable("HTTPS_SERVER_ISSUER"));
- _oServerVariables.Add("HTTPS_SERVER_SUBJECT", _WorkerRequest.GetServerVariable("HTTPS_SERVER_SUBJECT"));
- _oServerVariables.Add("INSTANCE_ID", _WorkerRequest.GetServerVariable("INSTANCE_ID"));
- _oServerVariables.Add("INSTANCE_META_PATH", _WorkerRequest.GetServerVariable("INSTANCE_META_PATH"));
- _oServerVariables.Add("LOCAL_ADDR", _WorkerRequest.GetLocalAddress());
- _oServerVariables.Add("REMOTE_ADDR", UserHostAddress);
- _oServerVariables.Add("REMOTE_HOST", UserHostName);
- _oServerVariables.Add("REQUEST_METHOD", HttpMethod);
- _oServerVariables.Add("SERVER_NAME", _WorkerRequest.GetServerName());
- _oServerVariables.Add("SERVER_PORT", _WorkerRequest.GetLocalPort().ToString());
- _oServerVariables.Add("SERVER_PROTOCOL", _WorkerRequest.GetHttpVersion());
- _oServerVariables.Add("SERVER_SOFTWARE", _WorkerRequest.GetServerVariable("SERVER_SOFTWARE"));
- if (_WorkerRequest.IsSecure()) {
- _oServerVariables.Add("SERVER_PORT_SECURE", "1");
- } else {
- _oServerVariables.Add("SERVER_PORT_SECURE", "0");
- }
- sTmp = _WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderContentLength);
- if (null != sTmp) {
- _oServerVariables.Add("CONTENT_LENGTH", sTmp);
- }
- // TODO: Should be dynamic
- if (null != _oContext.User && _oContext.User.Identity.IsAuthenticated) {
- _oServerVariables.Add("AUTH_TYPE", _oContext.User.Identity.AuthenticationType);
- _oServerVariables.Add("AUTH_USER", _oContext.User.Identity.Name);
- } else {
- _oServerVariables.Add("AUTH_TYPE", "");
- _oServerVariables.Add("AUTH_USER", "");
- }
- _oServerVariables.Add("PATH_INFO", PathInfo);
- _oServerVariables.Add("PATH_TRANSLATED", PhysicalPath);
- _oServerVariables.Add("QUERY_STRING", QueryStringRaw);
- _oServerVariables.Add("SCRIPT_NAME", FilePath);
- // end dynamic
-
- _oServerVariables.MakeReadOnly();
- }
- }
- [MonoTODO("Handle Multipart data also, content-encoding check")]
- private void ParseFormData() {
- if (_oFormData == null) {
- byte [] arrData = GetRawContent();
- _oFormData = new HttpValueCollection(ContentEncoding.GetString(arrData), true, ContentEncoding);
- }
- }
- void Dispose() {
-
- }
- [MonoTODO("Handle Multipart data, max content length?")]
- private byte [] GetRawContent() {
- if (null == _arrRawContent) {
- if (null == _WorkerRequest) {
- return null;
- }
- // TODO: Check max length?
- _arrRawContent = _WorkerRequest.GetPreloadedEntityBody();
- if (!_WorkerRequest.IsEntireEntityBodyIsPreloaded()) {
- byte [] arrTemp;
- byte [] arrBuffer;
-
- arrBuffer = new byte[16384];
- int iLoaded = 16384;
- while (iLoaded == arrBuffer.Length) {
- iLoaded = _WorkerRequest.ReadEntityBody(arrBuffer, arrBuffer.Length);
-
- // Save data
- arrTemp = new byte[_arrRawContent.Length + iLoaded];
-
- Array.Copy(_arrRawContent, 0, arrTemp, 0, _arrRawContent.Length);
- Array.Copy(arrBuffer, 0, arrTemp, _arrRawContent.Length, iLoaded);
- _arrRawContent = arrTemp;
- }
- }
- }
- return _arrRawContent;
- }
- public string [] AcceptTypes {
- get {
- if (null == _arrAcceptTypes && null != _WorkerRequest) {
- _arrAcceptTypes = HttpHelper.ParseMultiValueHeader(_WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderAccept));
- }
- return _arrAcceptTypes;
-
- }
- }
- public string ApplicationPath {
- get {
- if (null != _WorkerRequest) {
- return _WorkerRequest.GetAppPath();
- }
- return null;
- }
- }
- [MonoTODO()]
- public HttpBrowserCapabilites Browser {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- [MonoTODO()]
- public HttpClientCertificate ClientCertificate {
- get {
- throw new NotImplementedException();
- }
- }
- [MonoTODO("Get content encoding from Syste.Web.Configuration namespace")]
- public Encoding ContentEncoding {
- get {
- if (_oContentEncoding == null) {
- // TODO: Get from config what is the default encoding
- // TODO: Should we get encoding from HttpHeaders? Just get charset from ContentType and the get encoding..
- _oContentEncoding = Encoding.Default;
- }
- return _oContentEncoding;
- }
- set {
- _oContentEncoding = value;
- }
- }
- public int ContentLength {
- get {
- if (_iContentLength == -1 && null != _WorkerRequest) {
- string sLength = _WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderContentLength);
- if (sLength != null) {
- try {
- _iContentLength = Int32.Parse(sLength);
- }
- catch(Exception) {
- }
- }
- }
- if (_iContentLength < 0) {
- _iContentLength = 0;
- }
- return _iContentLength;
- }
- }
- public string ContentType {
- get {
- if (null == _sContentType) {
- if (null != _WorkerRequest) {
- _sContentType = _WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderContentType);
- }
- if (null == _sContentType) {
- _sContentType = string.Empty;
- }
- }
- return _sContentType;
- }
- }
- [MonoTODO()]
- public HttpCookieCollection Cookies {
- get {
- throw new NotImplementedException();
- }
- }
- [MonoTODO()]
- public string CurrentExecutionFilePath {
- get {
- throw new NotImplementedException();
- }
- }
- public string FilePath {
- get {
- if (null == _sFilePath && null != _WorkerRequest) {
- _sFilePath = _WorkerRequest.GetFilePath();
- }
- return _sFilePath;
- }
- }
- [MonoTODO()]
- public HttpFileCollection Files {
- get {
- throw new NotImplementedException();
- }
- }
- [MonoTODO("Use stream filter in the request stream")]
- public Stream Filter {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- public NameValueCollection Form {
- get {
- ParseFormData();
- return (NameValueCollection) _oFormData;
- }
- }
- public NameValueCollection Headers {
- get {
- if (_oHeaders == null) {
- _oHeaders = new HttpValueCollection();
- if (null != _WorkerRequest) {
- string sHeaderValue;
- string sHeaderName;
- int iCount = 0;
- // Add all know headers
- for (; iCount != 40; iCount++) {
- sHeaderValue = _WorkerRequest.GetKnownRequestHeader(iCount);
- if (null != sHeaderValue && sHeaderValue.Length > 0) {
- sHeaderName = _WorkerRequest.GetKnownRequestHeader(iCount);
- if (null != sHeaderName && sHeaderName.Length > 0) {
- _oHeaders.Add(sHeaderName, sHeaderValue);
- }
- }
- }
- // Get all other headers
- string [][] arrUnknownHeaders = _WorkerRequest.GetUnknownRequestHeaders();
- if (null != arrUnknownHeaders) {
- for (iCount = 0; iCount != arrUnknownHeaders.Length; iCount++) {
- _oHeaders.Add(arrUnknownHeaders[iCount][0], arrUnknownHeaders[iCount][1]);
- }
- }
- }
- // Make headers read-only
- _oHeaders.MakeReadOnly();
- }
- return (NameValueCollection) _oHeaders;
- }
- }
- public string HttpMethod {
- get {
- if (null == _sHttpMethod) {
- if (null != _WorkerRequest) {
- _sHttpMethod = _WorkerRequest.GetHttpVerbName().ToUpper();
- }
-
- if (_sHttpMethod == null) {
- _sHttpMethod = "GET";
- }
- }
- return _sHttpMethod;
- }
- }
- public Stream InputStream {
- get {
- if (_oInputStream == null) {
- byte [] arrInputData = GetRawContent();
- if (null != arrInputData) {
- _oInputStream = new HttpRequestStream(arrInputData, 0, arrInputData.Length);
- } else {
- _oInputStream = new HttpRequestStream(null, 0, 0);
- }
- }
- return _oInputStream;
- }
- }
- public bool IsAuthenticated {
- get {
- if (_oContext != null && _oContext.User != null && _oContext.User.Identity != null) {
- return _oContext.User.Identity.IsAuthenticated;
- }
- return false;
- }
- }
- public bool IsSecureConnection {
- get {
- if (null != _WorkerRequest) {
- return _WorkerRequest.IsSecure();
- }
- return false;
- }
- }
- [MonoTODO("Call item in querystring, form, cookie and servervariables")]
- public string this [string sKey] {
- get {
- throw new NotImplementedException();
- }
- }
- [MonoTODO("Add cookie collection to our Params collection via merge")]
- public NameValueCollection Params {
- get {
- if (_oParams == null) {
- _oParams = new HttpValueCollection();
-
- _oParams.Merge(QueryString);
- _oParams.Merge(Form);
- _oParams.Merge(ServerVariables);
- // TODO: Cookie
- _oParams.MakeReadOnly();
- }
- return (NameValueCollection) _oParams;
- }
- }
-
- public string Path {
- get {
- if (_sPath == null) {
- if (null != _WorkerRequest) {
- _sPath = _WorkerRequest.GetUriPath();
- }
- if (_sPath == null) {
- _sPath = string.Empty;
- }
- }
- return _sPath;
- }
- }
-
- public string PathInfo {
- get {
- if (_sPathInfo == null) {
- if (null != _WorkerRequest) {
- _sPathInfo = _WorkerRequest.GetPathInfo();
- }
- if (_sPathInfo == null) {
- _sPathInfo = string.Empty;
- }
- }
-
- return _sPathInfo;
- }
- }
- public string PhysicalApplicationPath {
- get {
- if (null != _WorkerRequest) {
- return _WorkerRequest.GetAppPathTranslated();
- }
- return null;
- }
- }
- public string PhysicalPath {
- get {
- if (null != _WorkerRequest) {
- _sPathTranslated = _WorkerRequest.GetFilePathTranslated();
- if (null == _sPathTranslated) {
- _sPathTranslated = _WorkerRequest.MapPath(FilePath);
- }
- }
- return _sPathTranslated;
- }
- }
- public NameValueCollection QueryString {
- get {
- if (_oQueryString == null) {
- _oQueryString = new HttpValueCollection(QueryStringRaw, true, Encoding.UTF8);
- }
- return _oQueryString;
- }
- }
- // Used to parse the querystring
- internal string QueryStringRaw {
- get {
- if (_sQueryStringRaw == null && null != _WorkerRequest) {
- byte [] arrQuerystringBytes = _WorkerRequest.GetQueryStringRawBytes();
- if (null != arrQuerystringBytes && arrQuerystringBytes.Length > 0) {
- _sQueryStringRaw = ContentEncoding.GetString(arrQuerystringBytes);
- } else {
- _sQueryStringRaw = _WorkerRequest.GetQueryString();
- }
- }
- if (_sQueryStringRaw == null) {
- _sQueryStringRaw = string.Empty;
- }
- return _sQueryStringRaw;
- }
- }
- public string RawUrl {
- get {
- if (null == _sRawUrl) {
- if (null != _WorkerRequest) {
- _sRawUrl = _WorkerRequest.GetRawUrl();
- } else {
- _sRawUrl = Path;
- if (QueryStringRaw != null && QueryStringRaw.Length > 0) {
- _sRawUrl = _sRawUrl + "?" + QueryStringRaw;
- }
- }
- }
- return _sRawUrl;
- }
- }
- public string RequestType {
- get {
- if (null == _sRequestType) {
- return HttpMethod;
- }
-
- return _sRequestType;
- }
- }
-
-
- public NameValueCollection ServerVariables {
- get {
- ParseServerVariables();
- return (NameValueCollection) _oServerVariables;
- }
- }
- public int TotalBytes {
- get {
- if (_iTotalBytes == -1) {
- if (null != InputStream) {
- _iTotalBytes = (int) InputStream.Length;
- } else {
- _iTotalBytes = 0;
- }
- }
- return _iTotalBytes;
- }
- }
- public Uri Url {
- get {
- if (null == _oUrl) {
- _oUrl = new Uri(RawUrl);
- }
- return _oUrl;
- }
- }
- public Uri UrlReferrer {
- get {
- if (null == _oUriReferrer && null != _WorkerRequest) {
- string sReferrer = _WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderReferer);
- if (null != sReferrer && sReferrer.Length > 0) {
- try {
- if (sReferrer.IndexOf("://") >= 0) {
- _oUriReferrer = new Uri(sReferrer);
- } else {
- _oUriReferrer = new Uri(this.Url, sReferrer);
- }
- }
- catch (Exception) {
- }
- }
- }
- return _oUriReferrer;
- }
- }
- public string UserAgent {
- get {
- if (_sUserAgent == null && _WorkerRequest != null) {
- _sUserAgent = _WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderUserAgent);
- }
- if (_sUserAgent == null) {
- _sUserAgent = string.Empty;
- }
- return _sUserAgent;
- }
- }
- public string UserHostAddress {
- get {
- if (_sUserHostAddress == null && null != _WorkerRequest) {
- _sUserHostAddress = _WorkerRequest.GetRemoteAddress();
- }
- if (_sUserHostAddress == null || _sUserHostAddress.Length == 0) {
- _sUserHostAddress = "127.0.0.1";
- }
- return _sUserHostAddress;
- }
- }
-
- public string UserHostName {
- get {
- if (_sUserHostName == null && null != _WorkerRequest) {
- _sUserHostName = _WorkerRequest.GetRemoteName();
- }
- if (_sUserHostName == null || _sUserHostName.Length == 0) {
- _sUserHostName = UserHostAddress;
- }
- return _sUserHostName;
- }
- }
-
- public string [] UserLanguages {
- get {
- if (_arrUserLanguages == null && null != _WorkerRequest) {
- _arrUserLanguages = HttpHelper.ParseMultiValueHeader(_WorkerRequest.GetKnownRequestHeader(HttpWorkerRequest.HeaderAcceptLanguage));
- }
- return _arrUserLanguages;
- }
- }
- public byte [] BinaryRead(int count) {
- int iSize = TotalBytes;
- if (iSize == 0) {
- throw new ArgumentException();
- }
- byte [] arrData = new byte[iSize];
-
- int iRetSize = InputStream.Read(arrData, 0, iSize);
- if (iRetSize != iSize) {
- byte [] tmpData = new byte[iRetSize];
- if (iRetSize > 0) {
- Array.Copy(arrData, 0, tmpData, 0, iRetSize);
- }
- arrData = tmpData;
- }
- return arrData;
- }
- public int [] MapImageCoordinates(string ImageFieldName) {
- NameValueCollection oItems;
- if (HttpMethod == "GET" || HttpMethod == "HEAD") {
- oItems = QueryString;
- } else if (HttpMethod == "POST") {
- oItems = Form;
- } else {
- return null;
- }
- int [] arrRet = null;
- try {
- string sX = oItems.Get(ImageFieldName + ".x");
- string sY = oItems.Get(ImageFieldName + ".y");
- if (null != sX && null != sY) {
- int [] arrTmp = new Int32[2];
- arrRet[0] = Int32.Parse(sX);
- arrRet[1] = Int32.Parse(sY);
- arrRet = arrTmp;
- }
- }
- catch (Exception) {
- }
- return arrRet;
- }
- public string MapPath(string VirtualPath) {
- if (null == _sRequestRootVirtualDir) {
- if (null == FilePath || FilePath.Length == 0) {
- throw new ArgumentException("Filepath can't be empty");
- }
- if (FilePath[0] != '/') {
- throw new ArgumentException("Filepath must be a root");
- }
- _sRequestRootVirtualDir = FilePath.Substring(0, FilePath.LastIndexOf('/'));
- if (_sRequestRootVirtualDir.Length == 0) {
- _sRequestRootVirtualDir = "/";
- }
- }
- return MapPath(VirtualPath, _sRequestRootVirtualDir, true);
- }
- [MonoTODO("Build a path to send to MapPath in the workerrequest")]
- public string MapPath(string virtualPath, string baseVirtualDir, bool allowCrossAppMapping) {
- throw new NotImplementedException();
- }
- public void SaveAs(string filename, bool includeHeaders) {
- FileStream oFile;
- TextWriter oWriter;
- HttpRequestStream oData;
- oFile = new FileStream(filename, FileMode.CreateNew);
- if (includeHeaders) {
- oWriter = new StreamWriter(oFile);
- oWriter.Write(HttpMethod + " " + Path);
- if (QueryStringRaw != null && QueryStringRaw.Length > 0)
- oWriter.Write("?" + QueryStringRaw);
- if (_WorkerRequest != null) {
- oWriter.Write(" " + _WorkerRequest.GetHttpVersion() + "\r\n");
- oWriter.Write(GetAllHeaders(true));
- } else {
- oWriter.Write("\r\n");
- }
- oWriter.Write("\r\n");
- oWriter.Flush();
- }
- oData = (HttpRequestStream) InputStream;
- if (oData.DataLength > 0) {
- oFile.Write(oData.Data, oData.DataOffset, oData.DataLength);
- }
- oFile.Flush();
- oFile.Close();
- }
- }
- }
|