diff options
author | Andrew Arnott <andrewarnott@gmail.com> | 2013-03-01 21:26:10 -0800 |
---|---|---|
committer | Andrew Arnott <andrewarnott@gmail.com> | 2013-03-01 21:26:10 -0800 |
commit | 74b6b4efd2be2680e3067f716829b0c9385ceebe (patch) | |
tree | 5f241db63080c6547d9cc635b0bf36dd587b5354 /samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs | |
parent | 798fa1c5f55058eb241f257d15e2dd630eb3d4fd (diff) | |
download | DotNetOpenAuth-74b6b4efd2be2680e3067f716829b0c9385ceebe.zip DotNetOpenAuth-74b6b4efd2be2680e3067f716829b0c9385ceebe.tar.gz DotNetOpenAuth-74b6b4efd2be2680e3067f716829b0c9385ceebe.tar.bz2 |
Adds a WebAPI sample that is its own authorization server and resource server.
Diffstat (limited to 'samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs')
-rw-r--r-- | samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs b/samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs new file mode 100644 index 0000000..04296b4 --- /dev/null +++ b/samples/OAuth2ProtectedWebApi/Code/BearerTokenHandler.cs @@ -0,0 +1,27 @@ +namespace OAuth2ProtectedWebApi.Code { + using System; + using System.Collections.Generic; + using System.Linq; + using System.Net.Http; + using System.Threading; + using System.Threading.Tasks; + using System.Web; + + using DotNetOpenAuth.OAuth2; + + public class BearerTokenHandler : DelegatingHandler { + protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken) { + if (request.Headers.Authorization != null) { + if (request.Headers.Authorization.Scheme == "Bearer") { + string bearer = request.Headers.Authorization.Parameter; + var resourceServer = new ResourceServer(new StandardAccessTokenAnalyzer(MemoryCryptoKeyStore.Instance)); + var principal = await resourceServer.GetPrincipalAsync(request, cancellationToken); + HttpContext.Current.User = principal; + Thread.CurrentPrincipal = principal; + } + } + + return await base.SendAsync(request, cancellationToken); + } + } +}
\ No newline at end of file |