-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProgram.cs
More file actions
50 lines (40 loc) · 1.5 KB
/
Program.cs
File metadata and controls
50 lines (40 loc) · 1.5 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
using Microsoft.EntityFrameworkCore;
using ShiftsLoggerAPI.Models;
var builder = WebApplication.CreateBuilder(args);
var connString = builder.Configuration.GetConnectionString("ShiftsLoggerDbConnection");
builder.Services.AddDbContext<ShiftsContext>(opt => opt.UseSqlServer(connString));
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
var app = builder.Build();
app.UseSwagger();
app.UseSwaggerUI();
app.MapGet("/shifts", async (ShiftsContext db) =>
await db.Shifts.ToListAsync());
app.MapGet("/shifts/employee={id}", async (int id, ShiftsContext db) =>
await db.Shifts.Where(t => t.EmployeeId == id).ToListAsync());
app.MapPost("/shifts", async (Shift shift, ShiftsContext db) =>
{
db.Shifts.Add(shift);
await db.SaveChangesAsync();
return Results.Created($"/shifts/{shift.Id}", shift);
});
app.MapPut("/shifts/{id}", async (int id, Shift inputShift, ShiftsContext db) =>
{
var shift = await db.Shifts.FindAsync(id);
if (shift == null) return Results.NotFound();
shift.StartTime = inputShift.StartTime;
shift.EndTime = inputShift.EndTime;
shift.Date = inputShift.Date;
shift.EmployeeId = inputShift.EmployeeId;
await db.SaveChangesAsync();
return Results.NoContent();
});
app.MapDelete("/shifts/{id}", async (int id, ShiftsContext db) =>
{
var shift = await db.Shifts.FindAsync(id);
if (shift == null) return Results.NotFound();
db.Shifts.Remove(shift);
await db.SaveChangesAsync();
return Results.NoContent();
});
app.Run();