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
7 changes: 7 additions & 0 deletions exercise.pizzashopapi/DTOs/request/CustomerPut.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
namespace exercise.pizzashopapi.DTOs.request
{
public class CustomerPut
{
public string Name { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTOs/request/OrderPost.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTOs.request
{
public class OrderPost
{
public int PizzaId { get; set; }
public int CustomerId { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTOs/request/PizzaPost.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTOs.request
{
public class PizzaPost
{
public string Name { get; set; }
public decimal Price { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTOs/response/CustomerDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class CustomerDTO
{
public string Name { get; set; }
public List<OrderCustomerDTO> Orders { get; set; } = new List<OrderCustomerDTO>();
}
}
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTOs/response/OrderCustomerDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class OrderCustomerDTO
{
public int PizzaId { get; set; }
public string PizzaName { get; set; }
public string OrderStatus { get; set; }
}
}
11 changes: 11 additions & 0 deletions exercise.pizzashopapi/DTOs/response/OrderDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class OrderDTO
{
public int PizzaId { get; set; }
public int CustomerId { get; set; }
public string PizzaName { get; set; }
public decimal PizzaPrice { get; set; }
public string CustomerName { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTOs/response/OrderPizzaDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class OrderPizzaDTO
{
public int CustomerId { get; set; }
public string CustomerName { get; set; }
}
}
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTOs/response/OrderToppingDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class OrderToppingDTO
{
public int OrderId { get; set; }
public int ToppingId { get; set; }
public ToppingDTO Topping { get; set; }
}
}
9 changes: 9 additions & 0 deletions exercise.pizzashopapi/DTOs/response/PizzaDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class PizzaDTO
{
public string Name { get; set; }
public decimal Price { get; set; }
public List<OrderPizzaDTO> Orders { get; set; } = new List<OrderPizzaDTO>();
}
}
7 changes: 7 additions & 0 deletions exercise.pizzashopapi/DTOs/response/ToppingDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
namespace exercise.pizzashopapi.DTOs.response
{
public class ToppingDTO
{
public string Name { get; set; }
}
}
21 changes: 20 additions & 1 deletion exercise.pizzashopapi/Data/DataContext.cs
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,25 @@ public DataContext()
{
var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();
connectionString = configuration.GetValue<string>("ConnectionStrings:DefaultConnectionString");

}

//protected override void OnModelCreating(ModelBuilder modelBuilder)
//{
// // Set up composite key for Order (pizzaId+customerId)
// modelBuilder.Entity<Order>()
// .HasKey(o => new { o.PizzaId, o.CustomerId });

// modelBuilder.Entity<Order>()
// .HasOne(o => o.Pizza)
// .WithMany(p => p.Orders)
// .HasForeignKey(o => o.PizzaId);

// modelBuilder.Entity<Order>()
// .HasOne(o => o.Customer)
// .WithMany(p => p.Orders)
// .HasForeignKey(o => o.CustomerId);

//}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseNpgsql(connectionString);
Expand All @@ -21,8 +38,10 @@ protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
//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; }
}
}
22 changes: 18 additions & 4 deletions exercise.pizzashopapi/Data/Seeder.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,20 +12,34 @@ public async static void SeedPizzaShopApi(this WebApplication app)
{
db.Add(new Customer() { Name="Nigel" });
db.Add(new Customer() { Name = "Dave" });
db.Add(new Customer() { Name = "Espen" });
await db.SaveChangesAsync();
}
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 = 123.45M });
db.Add(new Pizza() { Name = "Vegan Cheese Tastic", Price = 124.89M });
db.Add(new Pizza() { Name = "Prosciutto", Price = 131.90M });
await db.SaveChangesAsync();

}

//order data
if(1==1)
if(!db.Orders.Any())
{
db.Add(new Order() { CustomerId = 1, PizzaId = 1, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
db.Add(new Order() { CustomerId = 2, PizzaId = 2, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
db.Add(new Order() { CustomerId = 3, PizzaId = 3, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
db.Add(new Order() { CustomerId = 2, PizzaId = 1, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
db.Add(new Order() { CustomerId = 1, PizzaId = 3, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
db.Add(new Order() { CustomerId = 3, PizzaId = 3, CreatedAt = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Utc) });
await db.SaveChangesAsync();
}

if(!db.Toppings.Any())
{
db.Add(new Topping() { Name = "Pepperoni" });
db.Add(new Topping() { Name = "Ham" });
db.Add(new Topping() { Name = "Chicken" });
await db.SaveChangesAsync();
}
}
Expand Down
Loading