Added Game and Deck models

This commit is contained in:
2025-12-29 21:54:26 -06:00
parent 4e1d7e6992
commit a59604becd
2 changed files with 92 additions and 0 deletions

View File

@@ -0,0 +1,73 @@
using Dapper;
using Npgsql;
namespace SDG_Backend_Barracuda.Models;
public record Game(int Id, string Name, string URL);
public record GameInformation(string Name, string URL);
public interface IGameModel : IDatabaseModel<Game, GameInformation>
{
}
public class GameModel(NpgsqlDataSource dataSource) : IGameModel, IEndpointRouteHandler
{
public static void MapEndpoints(IEndpointRouteBuilder router)
{
var gameEndpoint = router.MapGroup("/game");
gameEndpoint.MapPost("/", async (GameInformation input, IGameModel model) =>
{
var newGame = await model.Create(input);
return Results.Created($"/game/{newGame.Id}", newGame);
});
gameEndpoint.MapGet("/", async (IGameModel model) =>
Results.Ok(await model.GetAll()));
gameEndpoint.MapGet("/{id}", async (int id, IGameModel model) =>
await model.GetById(id) is { } g ? Results.Ok(g) : Results.NotFound());
gameEndpoint.MapPut("/{id}", async (int id, GameInformation input, IGameModel model) =>
await model.Update(id, input) is { } g ? Results.Ok(g) : Results.NotFound());
gameEndpoint.MapDelete("/{id}", async (int id, IGameModel model) =>
await model.Delete(id) ? Results.NoContent() : Results.NotFound());
}
public async Task<IEnumerable<Game>> GetAll()
{
await using var connection = await dataSource.OpenConnectionAsync();
var sql = """SELECT * FROM "Game";""";
return await connection.QueryAsync<Game>(sql);
}
public async Task<Game?> GetById(int id)
{
await using var connection = await dataSource.OpenConnectionAsync();
var sql = """SELECT * FROM "Game" WHERE "Id" = @Id;""";
return await connection.QueryFirstOrDefaultAsync<Game>(sql, new { Id = id });
}
public async Task<Game> Create(GameInformation input)
{
await using var connection = await dataSource.OpenConnectionAsync();
var sql = """INSERT INTO "Game" ("Name", "URL") VALUES (@Name, @URL) RETURNING "Id", "Name", "URL";""";
return await connection.QuerySingleAsync<Game>(sql, input);
}
public async Task<Game?> Update(int id, GameInformation input)
{
await using var connection = await dataSource.OpenConnectionAsync();
var sql = """UPDATE "Game" SET "Name" = @Name, "URL" = @URL WHERE "Id" = @Id RETURNING "Id", "Name", "URL";""";
return await connection.QueryFirstOrDefaultAsync<Game>(sql, new { Id = id, input.Name, input.URL });
}
public async Task<bool> Delete(int id)
{
await using var connection = await dataSource.OpenConnectionAsync();
var sql = """DELETE FROM "Game" WHERE "Id" = @Id;""";
var rowsAffected = await connection.ExecuteAsync(sql, new { Id = id });
return rowsAffected > 0;
}
}

View File

@@ -15,6 +15,8 @@ builder.Services.AddNpgsqlDataSource(connectionString!);
// Register Data Tables // Register Data Tables
builder.Services.AddScoped<ICardModel, CardModel>(); builder.Services.AddScoped<ICardModel, CardModel>();
builder.Services.AddScoped<ICardListModel, CardListModel>(); builder.Services.AddScoped<ICardListModel, CardListModel>();
builder.Services.AddScoped<IGameModel, GameModel>();
builder.Services.AddScoped<IDeckModel, DeckModel>();
var app = builder.Build(); var app = builder.Build();
@@ -40,6 +42,21 @@ using (var scope = app.Services.CreateScope())
""CardListId"" INTEGER NOT NULL REFERENCES ""CardList""(""Id"") ON DELETE CASCADE, ""CardListId"" INTEGER NOT NULL REFERENCES ""CardList""(""Id"") ON DELETE CASCADE,
""SubCardListId"" INTEGER NOT NULL REFERENCES ""CardList""(""Id"") ON DELETE CASCADE, ""SubCardListId"" INTEGER NOT NULL REFERENCES ""CardList""(""Id"") ON DELETE CASCADE,
PRIMARY KEY (""CardListId"", ""SubCardListId"") PRIMARY KEY (""CardListId"", ""SubCardListId"")
);
CREATE TABLE IF NOT EXISTS ""Game"" (
""Id"" SERIAL PRIMARY KEY,
""Name"" VARCHAR(64) NOT NULL,
""URL"" TEXT NOT NULL
);
CREATE TABLE IF NOT EXISTS ""Deck"" (
""Id"" SERIAL PRIMARY KEY,
""Name"" TEXT NOT NULL,
""CardListId"" INTEGER NOT NULL REFERENCES ""CardList""(""Id"") ON DELETE CASCADE
);
CREATE TABLE IF NOT EXISTS ""DeckGame"" (
""DeckId"" INTEGER NOT NULL REFERENCES ""Deck""(""Id"") ON DELETE CASCADE,
""GameId"" INTEGER NOT NULL REFERENCES ""Game""(""Id"") ON DELETE CASCADE,
PRIMARY KEY (""DeckId"", ""GameId"")
);"); );");
} }
@@ -53,5 +70,7 @@ app.UseHttpsRedirection();
CardModel.MapEndpoints(app); CardModel.MapEndpoints(app);
CardListModel.MapEndpoints(app); CardListModel.MapEndpoints(app);
GameModel.MapEndpoints(app);
DeckModel.MapEndpoints(app);
app.Run(); app.Run();