bit more work on api endpoint
This commit is contained in:
2
OwnChar
2
OwnChar
Submodule OwnChar updated: 38dc09ab12...db5191b0b8
@@ -1,6 +1,5 @@
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using OwnChar.Base.Data.Requests;
|
||||
using OwnChar.Base.Data.Responses;
|
||||
using OwnChar.Model;
|
||||
using OwnChar.Server.Data.Model;
|
||||
|
||||
namespace OwnChar.ServerNew.Api.Endpoint.Implementations;
|
||||
@@ -9,24 +8,34 @@ internal class LoginApi(ServerContext server) : IApiEndpoint
|
||||
{
|
||||
public void Initialize(IApiBuilder builder)
|
||||
{
|
||||
builder.Map("/auth/login/{username}", Login);
|
||||
builder.Map("/auth/logout/{secret}", Logout);
|
||||
builder.Map("/auth/login/{request}", Login);
|
||||
builder.Map("/auth/logout/{request}", Logout);
|
||||
}
|
||||
|
||||
private IResult Login(string username, [FromHeader(Name = "X-USER-PASSWORD")] string password)
|
||||
private IResult Login(LoginRequest request)
|
||||
{
|
||||
if (server.Data != null && server.Data.Set<UserAccountDb>()?.FirstOrDefault(n => n.Username == username && n.Password == password) is UserAccountBase account)
|
||||
return TypedResults.Ok(new LoginResponse
|
||||
LoginResponse? result;
|
||||
|
||||
if (server.Data != null
|
||||
&& server.Data.Set<UserAccountDb>()?.FirstOrDefault(n => n.Username == request.Username && n.Password == request.Password) is UserAccountDb acc
|
||||
&& acc.Profile != null)
|
||||
{
|
||||
result = new(new(acc), new(acc.Profile), server.Login(acc));
|
||||
}
|
||||
else
|
||||
{
|
||||
result = new(null, null, null)
|
||||
{
|
||||
Secret = server.Login(account),
|
||||
UserAccount = account,
|
||||
});
|
||||
return TypedResults.Unauthorized();
|
||||
ErrorCode = Base.Data.OwnCharResponseError.NotAuthorized
|
||||
};
|
||||
}
|
||||
|
||||
return TypedResults.Ok(result);
|
||||
}
|
||||
|
||||
private IResult Logout([FromHeader(Name = "X-AUTH-SECRET")] string secret)
|
||||
private IResult Logout(LogoutRequest request)
|
||||
{
|
||||
server.Logout(secret);
|
||||
server.Logout(request.AuthSecret);
|
||||
return TypedResults.Ok();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using OwnChar.Model;
|
||||
using OwnChar.Base.Data.Model;
|
||||
using Pilz.Configuration;
|
||||
using System.Diagnostics.CodeAnalysis;
|
||||
using ILogger = Castle.Core.Logging.ILogger;
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
using Castle.Core.Logging;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using OwnChar.Base.Data.Model;
|
||||
using OwnChar.Data;
|
||||
using OwnChar.Model;
|
||||
using OwnChar.Server;
|
||||
|
||||
Reference in New Issue
Block a user