Create HTTP REST API for Game Library
This commit is contained in:
69
Controllers/GamesController.cs
Normal file
69
Controllers/GamesController.cs
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
using GameLibrary.Models;
|
||||||
|
using GameLibrary.Repositories;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace GameLibrary.Controllers
|
||||||
|
{
|
||||||
|
[Route("api/[controller]")]
|
||||||
|
[ApiController]
|
||||||
|
public class GamesController : ControllerBase
|
||||||
|
{
|
||||||
|
private readonly IGameRepository _gameRepository;
|
||||||
|
|
||||||
|
public GamesController(IGameRepository gameRepository)
|
||||||
|
{
|
||||||
|
_gameRepository = gameRepository;
|
||||||
|
}
|
||||||
|
|
||||||
|
// GET: api/games
|
||||||
|
[HttpGet]
|
||||||
|
public async Task<ActionResult<IEnumerable<Game>>> GetGames(string genre = null)
|
||||||
|
{
|
||||||
|
var games = await _gameRepository.GetAllGames(genre);
|
||||||
|
return Ok(games);
|
||||||
|
}
|
||||||
|
|
||||||
|
// GET: api/games/{id}
|
||||||
|
[HttpGet("{id}")]
|
||||||
|
public async Task<ActionResult<Game>> GetGame(int id)
|
||||||
|
{
|
||||||
|
var game = await _gameRepository.GetGameById(id);
|
||||||
|
if (game == null)
|
||||||
|
{
|
||||||
|
return NotFound();
|
||||||
|
}
|
||||||
|
return Ok(game);
|
||||||
|
}
|
||||||
|
|
||||||
|
// POST: api/games
|
||||||
|
[HttpPost]
|
||||||
|
public async Task<ActionResult<Game>> CreateGame(Game game)
|
||||||
|
{
|
||||||
|
await _gameRepository.CreateGame(game);
|
||||||
|
return CreatedAtAction(nameof(GetGame), new { id = game.Id }, game);
|
||||||
|
}
|
||||||
|
|
||||||
|
// PUT: api/games/{id}
|
||||||
|
[HttpPut("{id}")]
|
||||||
|
public async Task<IActionResult> UpdateGame(int id, Game game)
|
||||||
|
{
|
||||||
|
if (id != game.Id)
|
||||||
|
{
|
||||||
|
return BadRequest();
|
||||||
|
}
|
||||||
|
|
||||||
|
await _gameRepository.UpdateGame(game);
|
||||||
|
return NoContent();
|
||||||
|
}
|
||||||
|
|
||||||
|
// DELETE: api/games/{id}
|
||||||
|
[HttpDelete("{id}")]
|
||||||
|
public async Task<IActionResult> DeleteGame(int id)
|
||||||
|
{
|
||||||
|
await _gameRepository.DeleteGame(id);
|
||||||
|
return NoContent();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
24
Data/GameContext.cs
Normal file
24
Data/GameContext.cs
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
using Microsoft.Extensions.Configuration;
|
||||||
|
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using GameLibrary.Models;
|
||||||
|
|
||||||
|
namespace GameLibrary.Data
|
||||||
|
{
|
||||||
|
public class GameContext : DbContext
|
||||||
|
{
|
||||||
|
protected readonly IConfiguration Configuration;
|
||||||
|
public GameContext(IConfiguration configuration)
|
||||||
|
{
|
||||||
|
Configuration = configuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnConfiguring(DbContextOptionsBuilder options)
|
||||||
|
{
|
||||||
|
// connect to sqlite database
|
||||||
|
options.UseSqlite(Configuration.GetConnectionString("DefaultConnection"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public DbSet<Game> Games { get; set; }
|
||||||
|
}
|
||||||
|
}
|
13
GameLibrary.csproj
Normal file
13
GameLibrary.csproj
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net8.0</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<ImplicitUsings>disable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="8.0.8" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
25
GameLibrary.sln
Normal file
25
GameLibrary.sln
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 17
|
||||||
|
VisualStudioVersion = 17.11.35312.102
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "GameLibrary", "GameLibrary.csproj", "{A4C8B6FE-20B5-4304-A80F-E098461F1138}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{A4C8B6FE-20B5-4304-A80F-E098461F1138}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{A4C8B6FE-20B5-4304-A80F-E098461F1138}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{A4C8B6FE-20B5-4304-A80F-E098461F1138}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{A4C8B6FE-20B5-4304-A80F-E098461F1138}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {5429A3BB-08B5-4F88-90AF-B686275A5080}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
12
Models/Game.cs
Normal file
12
Models/Game.cs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace GameLibrary.Models
|
||||||
|
{
|
||||||
|
public class Game
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string Title { get; set; }
|
||||||
|
public string Developer { get; set; }
|
||||||
|
public List<string> Genres { get; set; }
|
||||||
|
}
|
||||||
|
}
|
49
Program.cs
Normal file
49
Program.cs
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
using Microsoft.AspNetCore.Builder;
|
||||||
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
|
||||||
|
using GameLibrary.Data;
|
||||||
|
using GameLibrary.Repositories;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
|
||||||
|
namespace GameLibrary
|
||||||
|
{
|
||||||
|
public class Program
|
||||||
|
{
|
||||||
|
public static void Main(string[] args)
|
||||||
|
{
|
||||||
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
|
builder.Services.AddDbContext<GameContext>();
|
||||||
|
|
||||||
|
builder.Services.AddScoped<IGameRepository, GameRepository>();
|
||||||
|
|
||||||
|
builder.Services.AddControllers();
|
||||||
|
builder.Services.AddCors(options =>
|
||||||
|
{
|
||||||
|
options.AddPolicy("AllowAllOrigins",
|
||||||
|
builder =>
|
||||||
|
{
|
||||||
|
builder.AllowAnyOrigin()
|
||||||
|
.AllowAnyMethod()
|
||||||
|
.AllowAnyHeader();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
var app = builder.Build();
|
||||||
|
|
||||||
|
app.UseCors("AllowAllOrigins");
|
||||||
|
|
||||||
|
app.UseHttpsRedirection();
|
||||||
|
app.UseAuthorization();
|
||||||
|
app.MapControllers();
|
||||||
|
|
||||||
|
using (var scope = app.Services.CreateScope())
|
||||||
|
{
|
||||||
|
var dbContext = scope.ServiceProvider.GetRequiredService<GameContext>();
|
||||||
|
dbContext.Database.EnsureCreated();
|
||||||
|
}
|
||||||
|
|
||||||
|
app.Run();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
58
Repositories/GameRepository.cs
Normal file
58
Repositories/GameRepository.cs
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
using GameLibrary.Data;
|
||||||
|
using GameLibrary.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace GameLibrary.Repositories
|
||||||
|
{
|
||||||
|
public class GameRepository : IGameRepository
|
||||||
|
{
|
||||||
|
private readonly GameContext _context;
|
||||||
|
|
||||||
|
public GameRepository(GameContext context)
|
||||||
|
{
|
||||||
|
_context = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<IEnumerable<Game>> GetAllGames(string genre = null)
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(genre))
|
||||||
|
{
|
||||||
|
return await _context.Games.ToListAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
return await _context.Games
|
||||||
|
.Where(g => g.Genres.Contains(genre))
|
||||||
|
.ToListAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<Game> GetGameById(int id)
|
||||||
|
{
|
||||||
|
return await _context.Games.FindAsync(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task CreateGame(Game game)
|
||||||
|
{
|
||||||
|
_context.Games.Add(game);
|
||||||
|
await _context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task UpdateGame(Game game)
|
||||||
|
{
|
||||||
|
_context.Entry(game).State = EntityState.Modified;
|
||||||
|
await _context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task DeleteGame(int id)
|
||||||
|
{
|
||||||
|
var game = await _context.Games.FindAsync(id);
|
||||||
|
if (game != null)
|
||||||
|
{
|
||||||
|
_context.Games.Remove(game);
|
||||||
|
await _context.SaveChangesAsync();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
15
Repositories/IGameRepository.cs
Normal file
15
Repositories/IGameRepository.cs
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
using GameLibrary.Models;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace GameLibrary.Repositories
|
||||||
|
{
|
||||||
|
public interface IGameRepository
|
||||||
|
{
|
||||||
|
Task<IEnumerable<Game>> GetAllGames(string genre = null);
|
||||||
|
Task<Game> GetGameById(int id);
|
||||||
|
Task CreateGame(Game game);
|
||||||
|
Task UpdateGame(Game game);
|
||||||
|
Task DeleteGame(int id);
|
||||||
|
}
|
||||||
|
}
|
8
appsettings.Development.json
Normal file
8
appsettings.Development.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
12
appsettings.json
Normal file
12
appsettings.json
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"ConnectionStrings": {
|
||||||
|
"DefaultConnection": "Data Source=GameLibrary.db"
|
||||||
|
},
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"AllowedHosts": "*"
|
||||||
|
}
|
Reference in New Issue
Block a user