public Task ProcessRequestAsync(HttpContextPipelineHandlerContext context) { var body = "<no body>"; if (context.HttpContext.Request.Body != null) { using (var streamReader = new StreamReader(context.HttpContext.Request.Body, Encoding.UTF8, false, 1024, true)) { body = streamReader.ReadToEnd(); } context.HttpContext.Request.Body.Position = 0; } HttpNetTrace.Verbose(nameof(TraceHandler), context.HttpContext.Request.Method + " " + context.HttpContext.Request.Uri + " " + body); return(Task.FromResult(0)); }
public async Task ProcessAsync() { RawHttpRequest httpRequest; try { httpRequest = await RequestReader.ReadAsync(_clientSession.CancellationToken).ConfigureAwait(false); } catch (OperationCanceledException) { _clientSession.Close(); return; } catch (Exception exception) { HttpNetTrace.Error(nameof(HttpSessionHandler), exception, "Unhandled exceptio while processing HTTP request."); _clientSession.Close(); return; } var httpResponse = new RawHttpResponse { Version = httpRequest.Version, Headers = new Dictionary <string, string>(), StatusCode = (int)HttpStatusCode.OK }; var httpContext = new HttpContext(httpRequest, httpResponse, _clientSession, this); await _clientSession.HandleHttpRequestAsync(httpContext); if (httpContext.Response != null) { await ResponseWriter.WriteAsync(httpContext.Response, _clientSession.CancellationToken); HttpNetTrace.Verbose(nameof(HttpSessionHandler), "Response '{0}' sent to '{1}'.", httpContext.Response.StatusCode, _clientSession.Client.Identifier); } if (httpContext.CloseConnection) { _clientSession.Close(); } }
public Task ProcessResponseAsync(HttpContextPipelineHandlerContext context) { HttpNetTrace.Verbose(nameof(TraceHandler), context.HttpContext.Response.StatusCode + " " + context.HttpContext.Response.ReasonPhrase); return(Task.FromResult(0)); }