summaryrefslogtreecommitdiffstats
path: root/samples/OpenIdOfflineProvider/Controllers/ProviderController.cs
diff options
context:
space:
mode:
authorAndrew Arnott <andrewarnott@gmail.com>2013-03-26 11:19:06 -0700
committerAndrew Arnott <andrewarnott@gmail.com>2013-03-26 11:19:06 -0700
commit3d37ff45cab6838d80b22e6b782a0b9b4c2f4aeb (patch)
treec15816c3d7f6e74334553f2ff98605ce1c22c538 /samples/OpenIdOfflineProvider/Controllers/ProviderController.cs
parent5e9014f36b2d53b8e419918675df636540ea24e2 (diff)
parente6f7409f4caceb7bc2a5b4ddbcb1a4097af340f2 (diff)
downloadDotNetOpenAuth-3d37ff45cab6838d80b22e6b782a0b9b4c2f4aeb.zip
DotNetOpenAuth-3d37ff45cab6838d80b22e6b782a0b9b4c2f4aeb.tar.gz
DotNetOpenAuth-3d37ff45cab6838d80b22e6b782a0b9b4c2f4aeb.tar.bz2
Move to HttpClient throughout library.
Diffstat (limited to 'samples/OpenIdOfflineProvider/Controllers/ProviderController.cs')
-rw-r--r--samples/OpenIdOfflineProvider/Controllers/ProviderController.cs81
1 files changed, 81 insertions, 0 deletions
diff --git a/samples/OpenIdOfflineProvider/Controllers/ProviderController.cs b/samples/OpenIdOfflineProvider/Controllers/ProviderController.cs
new file mode 100644
index 0000000..b0d243b
--- /dev/null
+++ b/samples/OpenIdOfflineProvider/Controllers/ProviderController.cs
@@ -0,0 +1,81 @@
+namespace DotNetOpenAuth.OpenIdOfflineProvider.Controllers {
+ using System;
+ using System.Collections.Generic;
+ using System.Linq;
+ using System.Net;
+ using System.Net.Http;
+ using System.Text;
+ using System.Threading;
+ using System.Threading.Tasks;
+ using System.Web.Http;
+
+ using DotNetOpenAuth.OpenId;
+ using DotNetOpenAuth.OpenId.Provider;
+
+ public class ProviderController : ApiController {
+ private static readonly IOpenIdApplicationStore store = new StandardProviderApplicationStore();
+
+ private MainWindow MainWindow {
+ get { return MainWindow.Instance; }
+ }
+
+ public Task<HttpResponseMessage> Get() {
+ return this.HandleAsync();
+ }
+
+ public Task<HttpResponseMessage> Post() {
+ return this.HandleAsync();
+ }
+
+ private async Task<HttpResponseMessage> HandleAsync() {
+ var provider = new OpenIdProvider(store);
+ IRequest request = await provider.GetRequestAsync(this.Request);
+ if (request == null) {
+ App.Logger.Error("A request came in that did not carry an OpenID message.");
+ return new HttpResponseMessage(HttpStatusCode.BadRequest) {
+ Content = new StringContent("<html><body>This is an OpenID Provider endpoint.</body></html>", Encoding.UTF8, "text/html"),
+ };
+ }
+
+ return await await this.MainWindow.Dispatcher.InvokeAsync(async delegate {
+ if (!request.IsResponseReady) {
+ var authRequest = request as IAuthenticationRequest;
+ if (authRequest != null) {
+ string userIdentityPageBase = this.Url.Link("default", new { controller = "user" }) + "/";
+ var userIdentityPageBaseUri = new Uri(userIdentityPageBase);
+ switch (this.MainWindow.checkidRequestList.SelectedIndex) {
+ case 0:
+ if (authRequest.IsDirectedIdentity) {
+ if (this.MainWindow.capitalizedHostName.IsChecked.Value) {
+ userIdentityPageBase = (userIdentityPageBaseUri.Scheme + Uri.SchemeDelimiter + userIdentityPageBaseUri.Authority).ToUpperInvariant() + userIdentityPageBaseUri.PathAndQuery;
+ }
+ string leafPath = "directedidentity";
+ if (this.MainWindow.directedIdentityTrailingPeriodsCheckbox.IsChecked.Value) {
+ leafPath += ".";
+ }
+ authRequest.ClaimedIdentifier = Identifier.Parse(userIdentityPageBase + leafPath, true);
+ authRequest.LocalIdentifier = authRequest.ClaimedIdentifier;
+ }
+ authRequest.IsAuthenticated = true;
+ break;
+ case 1:
+ authRequest.IsAuthenticated = false;
+ break;
+ case 2:
+ IntPtr oldForegroundWindow = NativeMethods.GetForegroundWindow();
+ bool stoleFocus = NativeMethods.SetForegroundWindow(this.MainWindow);
+ await CheckIdWindow.ProcessAuthenticationAsync(userIdentityPageBaseUri, authRequest, CancellationToken.None);
+ if (stoleFocus) {
+ NativeMethods.SetForegroundWindow(oldForegroundWindow);
+ }
+ break;
+ }
+ }
+ }
+
+ var responseMessage = await provider.PrepareResponseAsync(request);
+ return responseMessage;
+ });
+ }
+ }
+}