Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTO/CreateOrderDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTO
{
public class CreateOrderDto
{
public int CustomerId { get; set; }
public int PizzaId { get; set; }
public List<int> ToppingIds { get; set; }
}
}
14 changes: 14 additions & 0 deletions exercise.pizzashopapi/DTO/CreatedOrderDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
namespace exercise.pizzashopapi.DTO
{
public class CreatedOrderDto
{
public string Customer { get; set; }
public string Pizza { get; set; }
public IEnumerable<ToppingDto> Toppings { get; set; }
public decimal Price { get; set; }
public bool IsDelivered { get; set; }
public DateTime OrderedAt { get; set; }
public int EstimatedDelivery { get; set; }

} }

7 changes: 7 additions & 0 deletions exercise.pizzashopapi/DTO/CustomerDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
namespace exercise.pizzashopapi.DTO
{
public class CustomerDto
{
public string Name { get; set; }
}
}
12 changes: 12 additions & 0 deletions exercise.pizzashopapi/DTO/OrderDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
namespace exercise.pizzashopapi.DTO
{
public class OrderDto
{
public string Customer { get; set; }
public string Pizza { get; set; }
public decimal Price { get; set; }
public DateTime OrderedAt { get; set; }
public string Stage { get; set; }
public int EstimatedDelivery { get; set; }
}
}
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTO/PizzaDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTO
{
public class PizzaDto
{
public string Name { get; set; }
public decimal Price { get; set; }

}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTO/ToppingDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTO
{
public class ToppingDto
{
public string Name { get; set; }
public decimal Price { get; set; }
}
}
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTO/UpdateOrderDto.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTO
{
public class UpdateOrderDto
{
public bool IsDelivered { get; set; }
public decimal Price { get; set; }

}
}
21 changes: 16 additions & 5 deletions exercise.pizzashopapi/Data/DataContext.cs
Original file line number Diff line number Diff line change
Expand Up @@ -11,18 +11,29 @@ public DataContext()
var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();
connectionString = configuration.GetValue<string>("ConnectionStrings:DefaultConnectionString");

}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Pizza>().HasKey(p => p.Id);
modelBuilder.Entity<Customer>().HasKey(c => c.Id);

modelBuilder.Entity<Order>().HasKey(o => new { o.PizzaId, o.CustomerId });
modelBuilder.Entity<Order>().HasKey(o => o.Id);
modelBuilder.Entity<Topping>().HasKey(t => t.Id);
modelBuilder.Entity<OrderToppings>().HasKey(ot => new { ot.OrderId, ot.ToppingId });
modelBuilder.Entity<OrderToppings>().HasKey(o => o.Id);
modelBuilder.Entity<DeliveryDriver>().HasKey(d => d.Id);

}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseNpgsql(connectionString);

//set primary of order?

//seed data?

}
public DbSet<Pizza> Pizzas { get; set; }
public DbSet<Customer> Customers { get; set; }
public DbSet<Order> Orders { get; set; }
public DbSet<Topping> Toppings { get; set; }
public DbSet<OrderToppings> OrderToppings { get; set; }
public DbSet<DeliveryDriver> DeliveryDrivers { get; set; }
}
}
47 changes: 40 additions & 7 deletions exercise.pizzashopapi/Data/Seeder.cs
Original file line number Diff line number Diff line change
Expand Up @@ -6,28 +6,61 @@ public static class Seeder
{
public async static void SeedPizzaShopApi(this WebApplication app)
{
using(var db = new DataContext())
using (var db = new DataContext())
{
if(!db.Customers.Any())
if (!db.Customers.Any())
{
db.Add(new Customer() { Name="Nigel" });
db.Add(new Customer() { Name = "Dave" });
db.Add(new Customer() { Name = "Nigel" });
db.Add(new Customer() { Name = "Andreas" });
await db.SaveChangesAsync();
}
if(!db.Pizzas.Any())
if (!db.Pizzas.Any())
{
db.Add(new Pizza() { Name = "Cheese & Pineapple" });
db.Add(new Pizza() { Name = "Vegan Cheese Tastic" });
db.Add(new Pizza() { Name = "Cheese & Pineapple", Price = 10 });
db.Add(new Pizza() { Name = "Vegan Cheese Tastic", Price = 15 });
db.Add(new Pizza() { Name = "Mushrooms & Onion", Price = 8 });
await db.SaveChangesAsync();

}
if (!db.DeliveryDrivers.Any())
{
db.Add(new DeliveryDriver() { Name = "Donald Driver" });
db.Add(new DeliveryDriver() { Name = "Daisy Driver" });
db.Add(new DeliveryDriver() { Name = "Daffy Driver" });
db.Add(new DeliveryDriver() { Name = "Dennis Driver" });
await db.SaveChangesAsync();
}

//order data
if(1==1)
if (!db.Orders.Any())
{
db.Add(new Order() { CustomerId = 1, PizzaId = 1, OrderedAt = new DateTime(2025, 1, 20, 8, 30, 0, DateTimeKind.Utc), Price = 10,DeliveryDriverId = 1 });
db.Add(new Order() { CustomerId = 2, PizzaId = 2, OrderedAt = new DateTime(2025, 1, 23, 19, 10, 0, DateTimeKind.Utc), Price = 15, DeliveryDriverId = 2 });
db.Add(new Order() { CustomerId = 3, PizzaId = 3, OrderedAt = new DateTime(2025, 1, 26, 16, 45, 0, DateTimeKind.Utc), Price = 8, DeliveryDriverId = 3 });
await db.SaveChangesAsync();
}

if (!db.Toppings.Any())
{
db.Add(new Topping() { Name = "Bacon", Price = 3 });
db.Add(new Topping() { Name = "Pineapple", Price = 2 });
db.Add(new Topping() { Name = "Vegan Cheese", Price = 1 });
db.Add(new Topping() { Name = "Mushrooms", Price = 1 });
db.Add(new Topping() { Name = "Onion", Price = 1 });
await db.SaveChangesAsync();
}

if (!db.OrderToppings.Any())
{
db.Add(new OrderToppings() { OrderId = 1, ToppingId = 2 });
db.Add(new OrderToppings() { OrderId = 2, ToppingId = 3 });
db.Add(new OrderToppings() { OrderId = 3, ToppingId = 4 });
db.Add(new OrderToppings() { OrderId = 3, ToppingId = 5 });
await db.SaveChangesAsync();
}


}
}
}
Expand Down
Loading