blob: 0f69bf57057fbf72b7db53ab2b8295d2cc199cf5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Security.Authentication;
using System.Threading;
using System.Threading.Tasks;
using System.Web;
using System.Web.Http;
using System.Web.Http.Controllers;
using Tango.Logging;
using Tango.Transport.Web;
using Tango.Web.Security;
namespace Tango.Web.Controllers
{
public class TangoController : ApiController
{
protected LogManager LogManager { get; private set; }
public TangoController()
{
LogManager = LogManager.Default;
}
public override async Task<HttpResponseMessage> ExecuteAsync(HttpControllerContext context, CancellationToken cancellationToken)
{
string controllerName = String.Empty;
string actionName = String.Empty;
try
{
var routeData = HttpContext.Current.Request.RequestContext.RouteData;
actionName = routeData.Values["action"].ToString();
controllerName = routeData.Values["controller"].ToString();
}
catch { }
try
{
String request = String.Empty;
try
{
request = context.Request.Content.ReadAsStringAsync().Result;
}
catch { }
LogManager.Log($"Request Received on {controllerName + "/" + actionName}: \n{request}");
OnRequestArrived(context.Request);
var result = await base.ExecuteAsync(context, cancellationToken);
return result;
}
catch (Exception ex)
{
LogManager.Log(ex, $"An error occurred while processing the request message on {controllerName + "/" + actionName}.");
HttpStatusCode code = HttpStatusCode.InternalServerError;
HttpResponseException httpException = null;
if (ex is ArgumentException || ex is InvalidDataException)
{
code = HttpStatusCode.BadRequest;
}
else if (ex is AuthenticationException || ex is TokenExpiredException)
{
code = HttpStatusCode.Unauthorized;
}
else if (ex is KeyNotFoundException)
{
code = HttpStatusCode.NotFound;
}
else if (ex is HttpResponseException httpResponseException)
{
httpException = httpResponseException;
}
else
{
httpException = new HttpResponseException(Request.CreateErrorResponse(code, ex.FlattenMessage(), ex));
}
#if DEBUG
throw httpException;
#else
//Remove Stack trace
var expandedException = httpException.Response.Content as System.Net.Http.ObjectContent<System.Web.Http.HttpError>;
if (expandedException != null)
{
var expandedExceptionValues = expandedException.Value as HttpError;
if (expandedExceptionValues != null)
{
expandedExceptionValues["StackTrace"] = "";
}
}
#endif
throw httpException;
}
}
protected virtual void OnRequestArrived(HttpRequestMessage request)
{
//Do nothing.
}
}
public class TangoController<T> : TangoController where T : class
{
public WebToken<T> RequestToken { get; set; }
protected override void OnRequestArrived(HttpRequestMessage request)
{
base.OnRequestArrived(request);
var authorizationHeader = request.Headers.Authorization;
if (authorizationHeader != null)
{
try
{
RequestToken = WebToken<T>.FromToken(authorizationHeader.Parameter != null ? authorizationHeader.Parameter : authorizationHeader.ToString());
}
catch (Exception ex)
{
throw new HttpParseException("Could not parse the provided token embedded object.", ex);
}
}
}
}
}
|