feat: WIP connections query endpoint

This commit is contained in:
2024-12-26 14:41:24 +01:00
parent 63bbf80ced
commit 9f5099c819
7 changed files with 81 additions and 32 deletions

View File

@@ -7,7 +7,7 @@ public class PuzzleRepository(ConnectionsContext _db)
{
private readonly ConnectionsContext _db = _db;
public async Task<ConnectionsPuzzle?> GetPuzzleByDateAsync(string printDate, bool includeSolutions = true)
public async Task<ConnectionsPuzzle?> GetConnectionsByDateAsync(string printDate, bool includeSolutions = true)
{
// query for the puzzle
var query = _db.ConnectionsPuzzles.AsNoTracking();
@@ -27,12 +27,12 @@ public class PuzzleRepository(ConnectionsContext _db)
return null;
}
await EnhancePuzzleWithDatesAsync(puzzle);
await EnhanceConnectionsWithDatesAsync(puzzle);
return puzzle;
}
public async Task<IEnumerable<ConnectionsPuzzle>> GetAllPuzzlesAsync(bool includeSolutions = true)
public async Task<IEnumerable<ConnectionsPuzzle>> GetAllConnectionsAsync(bool includeSolutions = true)
{
// query all, ordered by print date
var query = _db.ConnectionsPuzzles
@@ -49,13 +49,13 @@ public class PuzzleRepository(ConnectionsContext _db)
foreach (var puzzle in result)
{
await EnhancePuzzleWithDatesAsync(puzzle);
await EnhanceConnectionsWithDatesAsync(puzzle);
}
return result;
}
private async Task EnhancePuzzleWithDatesAsync(ConnectionsPuzzle puzzle)
private async Task EnhanceConnectionsWithDatesAsync(ConnectionsPuzzle puzzle)
{
string? previousPuzzleDate = await _db.ConnectionsPuzzles.AsNoTracking()
.Where(x => x.PrintDate.CompareTo(puzzle.PrintDate) < 0)

View File

@@ -17,7 +17,7 @@ public class GetConnectionsEndpoint(PuzzleRepository _puzzleRepo) : Endpoint<Get
bool hideSolutions = Query<bool>("hideSolutions", isRequired: false);
// query for the puzzle
var puzzle = await _puzzleRepo.GetPuzzleByDateAsync(req.PrintDate, includeSolutions: !hideSolutions);
var puzzle = await _puzzleRepo.GetConnectionsByDateAsync(req.PrintDate, includeSolutions: !hideSolutions);
// if not found, done here
if (puzzle == null)

View File

@@ -0,0 +1,17 @@
using ConnectionsAPI.Models.Request;
using ConnectionsAPI.Models.Response;
namespace ConnectionsAPI.Features.Connections.Query;
public class Endpoint : Endpoint<QueryPuzzlesRequest, PagedDataResponse<ConnectionsPuzzleDTO>>
{
public override void Configure()
{
Get("query");
}
public override Task HandleAsync(QueryPuzzlesRequest req, CancellationToken ct)
{
return base.HandleAsync(req, ct);
}
}

View File

@@ -1,40 +1,38 @@

using System.Text;
namespace ConnectionsAPI.Features.Version.Get
namespace ConnectionsAPI.Features.Version.Get;
public class GetVersionEndpoint : EndpointWithoutRequest<string>
{
public class GetVersionEndpoint : EndpointWithoutRequest<string>
private static readonly int START_YEAR = 2024;
public override void Configure()
{
private static readonly int START_YEAR = 2024;
Get("/version");
AllowAnonymous();
}
public override void Configure()
public override async Task HandleAsync(CancellationToken ct)
{
StringBuilder responseBuilder = new();
responseBuilder.Append("ConnectionsAPI ©");
if (DateTime.UtcNow.Year != START_YEAR)
{
Get("/version");
AllowAnonymous();
responseBuilder.AppendFormat("{0} - {1}; ", START_YEAR, DateTime.UtcNow.Year);
}
else
{
responseBuilder.AppendFormat("{0}; ", DateTime.UtcNow.Year);
}
public override async Task HandleAsync(CancellationToken ct)
{
StringBuilder responseBuilder = new();
responseBuilder.Append("by Mate Farkas; ");
responseBuilder.Append("ConnectionsAPI ©");
if (DateTime.UtcNow.Year != START_YEAR)
{
responseBuilder.AppendFormat("{0} - {1}; ", START_YEAR, DateTime.UtcNow.Year);
}
else
{
responseBuilder.AppendFormat("{0}; ", DateTime.UtcNow.Year);
}
var currentAsm = System.Reflection.Assembly.GetExecutingAssembly();
string asmVersion = currentAsm.GetName()?.Version?.ToString() ?? string.Empty;
responseBuilder.Append("by Mate Farkas; ");
responseBuilder.AppendFormat("v{0};", asmVersion);
var currentAsm = System.Reflection.Assembly.GetExecutingAssembly();
string asmVersion = currentAsm.GetName()?.Version?.ToString() ?? string.Empty;
responseBuilder.AppendFormat("v{0};", asmVersion);
await SendStringAsync(responseBuilder.ToString(), cancellation: ct);
}
await SendStringAsync(responseBuilder.ToString(), cancellation: ct);
}
}

View File

@@ -0,0 +1,7 @@
namespace ConnectionsAPI.Models.Request;
public class QueryPuzzlesRequest
{
[QueryParam] public int Page { get; set; }
[QueryParam] public int Count { get; set; }
}

View File

@@ -0,0 +1,8 @@
namespace ConnectionsAPI.Models.Response;
public record PagedDataResponse<T>(
int Page,
int Count,
int MaxCount,
ICollection<T> Data
);

View File

@@ -0,0 +1,19 @@
using System;
using ConnectionsAPI.Models.Request;
using FluentValidation;
namespace ConnectionsAPI.Validators;
public class QueryPuzzlesRequestValidator : Validator<QueryPuzzlesRequest>
{
public QueryPuzzlesRequestValidator()
{
RuleFor(x => x.Page)
.Must(x => x > 0)
.WithMessage("Page number must be a positive integer");
RuleFor(x => x.Count)
.Must(x => x > 0)
.WithMessage(x => "Item count must be a positive integer");
}
}