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.Base.Data.Responses;
|
||||||
using OwnChar.Model;
|
|
||||||
using OwnChar.Server.Data.Model;
|
using OwnChar.Server.Data.Model;
|
||||||
|
|
||||||
namespace OwnChar.ServerNew.Api.Endpoint.Implementations;
|
namespace OwnChar.ServerNew.Api.Endpoint.Implementations;
|
||||||
@@ -9,24 +8,34 @@ internal class LoginApi(ServerContext server) : IApiEndpoint
|
|||||||
{
|
{
|
||||||
public void Initialize(IApiBuilder builder)
|
public void Initialize(IApiBuilder builder)
|
||||||
{
|
{
|
||||||
builder.Map("/auth/login/{username}", Login);
|
builder.Map("/auth/login/{request}", Login);
|
||||||
builder.Map("/auth/logout/{secret}", Logout);
|
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)
|
LoginResponse? result;
|
||||||
return TypedResults.Ok(new LoginResponse
|
|
||||||
|
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),
|
ErrorCode = Base.Data.OwnCharResponseError.NotAuthorized
|
||||||
UserAccount = account,
|
};
|
||||||
});
|
}
|
||||||
return TypedResults.Unauthorized();
|
|
||||||
|
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();
|
return TypedResults.Ok();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using OwnChar.Model;
|
using OwnChar.Base.Data.Model;
|
||||||
using Pilz.Configuration;
|
using Pilz.Configuration;
|
||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using ILogger = Castle.Core.Logging.ILogger;
|
using ILogger = Castle.Core.Logging.ILogger;
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
using Castle.Core.Logging;
|
using Castle.Core.Logging;
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using OwnChar.Base.Data.Model;
|
||||||
using OwnChar.Data;
|
using OwnChar.Data;
|
||||||
using OwnChar.Model;
|
using OwnChar.Model;
|
||||||
using OwnChar.Server;
|
using OwnChar.Server;
|
||||||
|
|||||||
Reference in New Issue
Block a user