-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy pathExternalLogoutController.cs
More file actions
60 lines (53 loc) · 2.28 KB
/
ExternalLogoutController.cs
File metadata and controls
60 lines (53 loc) · 2.28 KB
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
namespace Umbraco_OpenIdConnect_Example.Core.Controllers
{
using Microsoft.AspNetCore.Mvc;
using Umbraco.Cms.Core.Cache;
using Umbraco.Cms.Core.Logging;
using Umbraco.Cms.Core.Routing;
using Umbraco.Cms.Core.Services;
using Umbraco.Cms.Core.Web;
using Umbraco.Cms.Infrastructure.Persistence;
using Umbraco.Cms.Web.Common.Filters;
using Umbraco.Cms.Web.Common.Security;
using Umbraco.Cms.Web.Website.Controllers;
using Microsoft.AspNetCore.Authentication;
using Umbraco.Cms.Web.Common.Models;
public class ExternalLogoutController : SurfaceController
{
private readonly IMemberSignInManager _signInManager;
public ExternalLogoutController(
IUmbracoContextAccessor umbracoContextAccessor,
IUmbracoDatabaseFactory databaseFactory,
ServiceContext services,
AppCaches appCaches,
IProfilingLogger profilingLogger,
IPublishedUrlProvider publishedUrlProvider,
IMemberSignInManager signInManager)
: base(umbracoContextAccessor, databaseFactory, services, appCaches, profilingLogger, publishedUrlProvider)
{
_signInManager = signInManager;
}
[HttpPost]
[ValidateAntiForgeryToken]
[ValidateUmbracoFormRouteString]
public async Task<IActionResult> HandleLogout([Bind(Prefix = "logoutModel")]PostRedirectModel model)
{
if (ModelState.IsValid == false)
{
return CurrentUmbracoPage();
}
var isLoggedIn = HttpContext.User?.Identity?.IsAuthenticated ?? false;
if (isLoggedIn)
{
// Trigger logout on the external login provider.
await this.HttpContext.SignOutAsync("UmbracoMembers.OpenIdConnect");
// Trigger logout on this website.
await _signInManager.SignOutAsync();
}
// Don't return RedirectToCurrentUmbracoPage.
// That will override the location header which is set by the external login provider logout.
// So by returning EmptyResult() this will still redirect to the external login provider to logout there.
return new EmptyResult();
}
}
}