Files
abzarasadi/Pages/Admin/Login.cshtml.cs
T
Soroush Asadi f97f891d67
CI/CD / CI — dotnet build (push) Successful in 44s
CI/CD / Deploy — docker compose (push) Failing after 1s
Initial commit — AsadiTools v1.0
Full ASP.NET Core 10 Razor Pages app for آساد ابزار tool repair shop
in Karaj, Iran (official DeWalt representative).

Features:
- Homepage, Services, DeWalt page, Shop (pagination + images)
- 10 brand SEO pages (/brands/*) with rich Persian content + FAQ schema
- Blog engine with admin management (/blog, /Admin/Blog)
- Cart, Checkout, Contact (OpenStreetMap embed)
- Admin panel: Products CRUD, Orders, Blog, Change Password
- Jalali date formatting, product images, SiteData centralised contact
- Docker + docker-compose with healthcheck
- Gitea CI/CD via .gitea/workflows/ci-cd.yml (NuGet through Nexus mirror)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-06-01 22:08:43 +03:30

52 lines
1.6 KiB
C#

using AsadiTools.Data;
using Microsoft.AspNetCore.Authentication;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using System.ComponentModel.DataAnnotations;
using System.Security.Claims;
namespace AsadiTools.Pages.Admin;
public class LoginModel(AppDbContext db) : PageModel
{
[BindProperty]
public InputModel Input { get; set; } = new();
public string? ErrorMessage { get; private set; }
public class InputModel
{
[Required] public string Username { get; set; } = string.Empty;
[Required] public string Password { get; set; } = string.Empty;
}
public IActionResult OnGet()
{
if (User.Identity?.IsAuthenticated == true)
return RedirectToPage("/Admin/Index");
return Page();
}
public async Task<IActionResult> OnPostAsync()
{
if (!ModelState.IsValid) return Page();
var user = db.AdminUsers.FirstOrDefault(u => u.Username == Input.Username);
if (user is null || !BCrypt.Net.BCrypt.Verify(Input.Password, user.PasswordHash))
{
ErrorMessage = "نام کاربری یا رمز اشتباه است";
return Page();
}
var claims = new List<Claim>
{
new(ClaimTypes.Name, user.Username),
new(ClaimTypes.NameIdentifier, user.Id.ToString()),
};
var identity = new ClaimsIdentity(claims, "AdminCookie");
var principal = new ClaimsPrincipal(identity);
await HttpContext.SignInAsync("AdminCookie", principal);
return RedirectToPage("/Admin/Index");
}
}