admin user

This commit is contained in:
Tizian.Breuch
2025-07-25 11:22:13 +02:00
parent a51be188d9
commit 407a3d731b
5 changed files with 88 additions and 18 deletions

View File

@@ -15,9 +15,9 @@ namespace Webshop.Api.Controllers.Admin
[Authorize(Roles = "Admin")] [Authorize(Roles = "Admin")]
public class AdminUsersController : ControllerBase public class AdminUsersController : ControllerBase
{ {
private readonly AdminUserService _adminUserService; private readonly IAdminUserService _adminUserService;
public AdminUsersController(AdminUserService adminUserService) public AdminUsersController(IAdminUserService adminUserService)
{ {
_adminUserService = adminUserService; _adminUserService = adminUserService;
} }

View File

@@ -13,6 +13,7 @@ using Microsoft.AspNetCore.HttpOverrides; // For UseForwardedHeaders
using Microsoft.Extensions.Logging; // For ILogger using Microsoft.Extensions.Logging; // For ILogger
using Microsoft.OpenApi.Models; // For Swagger OpenAPI models using Microsoft.OpenApi.Models; // For Swagger OpenAPI models
using Webshop.Api.SwaggerFilters; // For AuthorizeOperationFilter using Webshop.Api.SwaggerFilters; // For AuthorizeOperationFilter
using Webshop.Domain.Entities;
var builder = WebApplication.CreateBuilder(args); var builder = WebApplication.CreateBuilder(args);
@@ -24,8 +25,11 @@ builder.Services.AddDbContext<ApplicationDbContext>(options =>
); );
// 2. ASP.NET Core Identity f<>r Benutzerverwaltung registrieren // 2. ASP.NET Core Identity f<>r Benutzerverwaltung registrieren
builder.Services.AddIdentity<IdentityUser, IdentityRole>() builder.Services.AddIdentity<ApplicationUser, IdentityRole>(options =>
.AddEntityFrameworkStores<ApplicationDbContext>() {
options.SignIn.RequireConfirmedAccount = true;
})
.AddEntityFrameworkStores<ApplicationDbContext>() // Stellen Sie sicher, dass Ihr DbContext-Name hier korrekt ist
.AddDefaultTokenProviders(); .AddDefaultTokenProviders();
// Optional: Passe die Anforderungen f<>r Passw<73>rter f<>r die Entwicklung an // Optional: Passe die Anforderungen f<>r Passw<73>rter f<>r die Entwicklung an

View File

@@ -1,26 +1,65 @@
// Auto-generiert von CreateWebshopFiles.ps1 // src/Webshop.Application/Services/Admin/AdminUserService.cs
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Webshop.Application.DTOs.Users;
using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.Identity;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Webshop.Application.DTOs.Users;
using Webshop.Domain.Entities; // Wichtiges using für ApplicationUser
namespace Webshop.Application.Services.Admin namespace Webshop.Application.Services.Admin
{ {
public class AdminUserService : IAdminUserService public class AdminUserService : IAdminUserService
{ {
private readonly UserManager<IdentityUser> _userManager; // Wir verwenden nun den UserManager mit unserer neuen ApplicationUser-Klasse
private readonly UserManager<ApplicationUser> _userManager;
public AdminUserService(UserManager<IdentityUser> userManager) public AdminUserService(UserManager<ApplicationUser> userManager)
{ {
_userManager = userManager; _userManager = userManager;
} }
// HIER KOMMT DER VORHERIGE ADMINUSERSERVICE CODE HIN (GetAllUsersAsync, GetUserByIdAsync etc.) public async Task<IEnumerable<UserDto>> GetAllUsersAsync()
// Hier sind Platzhalter-Implementierungen, die Sie durch den vollständigen Code ersetzen müssen: {
public async Task<IEnumerable<UserDto>> GetAllUsersAsync() { return new List<UserDto>(); } // Alle Benutzer aus der Datenbank laden
public async Task<UserDto?> GetUserByIdAsync(string userId) { return null; } var users = await _userManager.Users.ToListAsync();
var userDtos = new List<UserDto>();
// Für jeden Benutzer ein DTO erstellen und die Daten mappen
foreach (var user in users)
{
userDtos.Add(new UserDto
{
Id = user.Id,
Email = user.Email ?? string.Empty,
UserName = user.UserName ?? string.Empty,
CreatedDate = user.CreatedDate, // Dieses Feld ist jetzt verfügbar!
EmailConfirmed = user.EmailConfirmed,
Roles = (await _userManager.GetRolesAsync(user)).ToList() // Rollen des Benutzers abrufen
});
}
return userDtos;
}
public async Task<UserDto?> GetUserByIdAsync(string userId)
{
var user = await _userManager.FindByIdAsync(userId);
if (user == null)
{
return null;
}
// Den gefundenen Benutzer in ein DTO umwandeln
return new UserDto
{
Id = user.Id,
Email = user.Email ?? string.Empty,
UserName = user.UserName ?? string.Empty,
CreatedDate = user.CreatedDate,
EmailConfirmed = user.EmailConfirmed,
Roles = (await _userManager.GetRolesAsync(user)).ToList()
};
}
} }
} }

View File

@@ -0,0 +1,22 @@
using Microsoft.AspNetCore.Identity;
using System;
namespace Webshop.Domain.Entities
{
/// <summary>
/// Erweitert die Standard-Identity-Klasse, um anwendungsspezifische
/// Eigenschaften für einen Benutzer zu speichern.
/// </summary>
public class ApplicationUser : IdentityUser
{
// Hinzugefügtes Feld, das in der Standard-IdentityUser-Klasse fehlt.
// Wird benötigt, um die Anforderung Ihrer UserDto zu erfüllen.
public DateTimeOffset CreatedDate { get; set; }
// BEISPIELE FÜR WEITERE NÜTZLICHE FELDER (können bei Bedarf einkommentiert werden):
// public string? FirstName { get; set; }
// public string? LastName { get; set; }
// public byte[]? ProfilePicture { get; set; }
// public DateTimeOffset? LastLoginDate { get; set; }
}
}

View File

@@ -6,4 +6,9 @@
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
</PropertyGroup> </PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.Identity.EntityFrameworkCore" Version="8.0.4" />
<!-- Die Version kann leicht abweichen -->
</ItemGroup>
</Project> </Project>