66 lines
2.4 KiB
C#
66 lines
2.4 KiB
C#
using Bootstrap.Admin.Models;
|
|
using Bootstrap.DataAccess;
|
|
using Bootstrap.Security;
|
|
using Longbow.Web;
|
|
using Microsoft.AspNetCore.Authentication;
|
|
using Microsoft.AspNetCore.Authentication.Cookies;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using System.Security.Claims;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace Bootstrap.Admin.Controllers
|
|
{
|
|
/// <summary>
|
|
/// Account controller.
|
|
/// </summary>
|
|
[AllowAnonymous]
|
|
public class AccountController : Controller
|
|
{
|
|
/// <summary>
|
|
/// Login the specified userName, password and remember.
|
|
/// </summary>
|
|
/// <returns>The login.</returns>
|
|
/// <param name="userName">User name.</param>
|
|
/// <param name="password">Password.</param>
|
|
/// <param name="remember">Remember.</param>
|
|
public async Task<IActionResult> Login(string userName, string password, string remember)
|
|
{
|
|
if (!string.IsNullOrEmpty(userName) && BootstrapUser.Authenticate(userName, password))
|
|
{
|
|
var identity = new ClaimsIdentity(CookieAuthenticationDefaults.AuthenticationScheme);
|
|
identity.AddClaim(new Claim(ClaimTypes.Name, userName));
|
|
await HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, new ClaimsPrincipal(identity), new AuthenticationProperties() { IsPersistent = remember == "true" });
|
|
return Redirect("~/");
|
|
}
|
|
var mobile = Request.IsMobileDevice();
|
|
var model = Request.IPad();
|
|
return mobile && !model ? View("Loginm", new ModelBase()) : View("Login", new ModelBase());
|
|
}
|
|
/// <summary>
|
|
/// Logout this instance.
|
|
/// </summary>
|
|
/// <returns>The logout.</returns>
|
|
public async Task<IActionResult> Logout()
|
|
{
|
|
await HttpContext.SignOutAsync(CookieAuthenticationDefaults.AuthenticationScheme);
|
|
return Redirect("~" + CookieAuthenticationDefaults.LoginPath);
|
|
}
|
|
/// <summary>
|
|
/// Accesses the denied.
|
|
/// </summary>
|
|
/// <returns>The denied.</returns>
|
|
public ActionResult AccessDenied()
|
|
{
|
|
return View();
|
|
}
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public ActionResult Mobile()
|
|
{
|
|
return View();
|
|
}
|
|
}
|
|
} |