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/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; }
}
}
7 changes: 7 additions & 0 deletions exercise.pizzashopapi/DTO/DeliveryDriverDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
namespace exercise.pizzashopapi.DTO
{
public class DeliveryDriverDTO
{
public string Name { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTO/DeliveryDriverWithOrdersDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTO
{
public class DeliveryDriverWithOrdersDTO
{
public string Name { get; set; }
public IEnumerable<OrderDTO> Orders { 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 DateTime OrderTime { get; set; }
public OrderStatus Status { get; set; }
public PizzaStatus PizzaStatus { get; set; }
public CustomerDTO Customer { get; set; }
public PizzaDTO Pizza { get; set; }
public DeliveryDriverDTO? DeliveryDriver { get; set; }
}
}
8 changes: 8 additions & 0 deletions exercise.pizzashopapi/DTO/PizzaDTO.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace exercise.pizzashopapi.DTO
{
public class PizzaDTO
{
public string Name { get; set; }
public decimal Price { get; set; }
}
}
47 changes: 37 additions & 10 deletions exercise.pizzashopapi/Data/DataContext.cs
Original file line number Diff line number Diff line change
@@ -1,28 +1,55 @@
using exercise.pizzashopapi.Models;
using System.Numerics;
using exercise.pizzashopapi.Models;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Options;

namespace exercise.pizzashopapi.Data
{
public class DataContext : DbContext
{
private string connectionString;
public DataContext()
private readonly IConfiguration _configuration;
public DataContext(DbContextOptions<DataContext> options, IConfiguration configuration) : base(options)
{
var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();
connectionString = configuration.GetValue<string>("ConnectionStrings:DefaultConnectionString");

_configuration = configuration;
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseNpgsql(connectionString);
{
base.OnConfiguring(optionsBuilder);
optionsBuilder.UseNpgsql(_configuration.GetConnectionString("DefaultConnectionString"));
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
Seeder seed = new Seeder();

modelBuilder.Entity<Order>()
.HasOne(o => o.Pizza)
.WithMany()
.HasForeignKey(p => p.PizzaId)
.OnDelete(DeleteBehavior.Cascade);

modelBuilder.Entity<Order>()
.HasOne(o => o.Customer)
.WithMany()
.HasForeignKey(o => o.CustomerId)
.OnDelete(DeleteBehavior.Cascade);
modelBuilder.Entity<Order>()
.HasOne(o => o.DeliveryDriver)
.WithMany(d => d.Orders)
.HasForeignKey(o => o.DeliveryDriverId)
.OnDelete(DeleteBehavior.SetNull);


modelBuilder.Entity<Customer>().HasData(seed.Customers);
modelBuilder.Entity<DeliveryDriver>().HasData(seed.DeliveryDrivers);
modelBuilder.Entity<Order>().HasData(seed.Orders);
modelBuilder.Entity<Pizza>().HasData(seed.Pizzas);

//set primary of order?

//seed data?

}
public DbSet<Pizza> Pizzas { get; set; }
public DbSet<Customer> Customers { get; set; }
public DbSet<DeliveryDriver> DeliveryDrivers { get; set; }
public DbSet<Order> Orders { get; set; }
}
}
102 changes: 76 additions & 26 deletions exercise.pizzashopapi/Data/Seeder.cs
Original file line number Diff line number Diff line change
@@ -1,34 +1,84 @@
using exercise.pizzashopapi.Models;
using System;
using exercise.pizzashopapi.Models;

namespace exercise.pizzashopapi.Data
public class Seeder
{
public static class Seeder
private List<string> _firstnames = new List<string>()
{
public async static void SeedPizzaShopApi(this WebApplication app)
"Audrey", "Donald", "Elvis", "Barack", "Oprah",
"Jimi", "Mick", "Kate", "Charles", "Kate"
};

private List<string> _lastnames = new List<string>()
{
"Hepburn", "Trump", "Presley", "Obama", "Winfrey",
"Hendrix", "Jagger", "Winslet", "Windsor", "Middleton"
};

private List<string> _pizzaNames = new List<string>()
{
"Cheese & Pineapple", "Vegan Cheese Tastic", "Pepperoni", "Margherita", "Hawaiian",
"Vegetarian", "Meat Lovers", "BBQ Chicken", "Buffalo", "Supreme"
};

private List<Customer> _customers = new List<Customer>();
private List<DeliveryDriver> _drivers = new List<DeliveryDriver>();
private List<Pizza> _pizzas = new List<Pizza>();
private List<Order> _orders = new List<Order>();

public Seeder()
{
for (int i = 1; i <= 10; i++)
{
Customer customer = new Customer
{
Id = i,
Name = $"{_firstnames[i % _firstnames.Count]} {_lastnames[i % _lastnames.Count]}"
};
_customers.Add(customer);
}

for (int i = 1; i <= 2; i++)
{
DeliveryDriver driver = new DeliveryDriver
{
Id = i,
Name = $"{_firstnames[i % _firstnames.Count]} {_lastnames[i % _lastnames.Count]}"
};
_drivers.Add(driver);
}

for (int i = 1; i <= 10; i++)
{
using(var db = new DataContext())

Pizza pizza = new Pizza
{
if(!db.Customers.Any())
{
db.Add(new Customer() { Name="Nigel" });
db.Add(new Customer() { Name = "Dave" });
await db.SaveChangesAsync();
}
if(!db.Pizzas.Any())
{
db.Add(new Pizza() { Name = "Cheese & Pineapple" });
db.Add(new Pizza() { Name = "Vegan Cheese Tastic" });
await db.SaveChangesAsync();

}

//order data
if(1==1)
{

await db.SaveChangesAsync();
}
}
Id = i,
Name = _pizzaNames[i % _pizzaNames.Count],
Price = 50,
};
_pizzas.Add(pizza);
}
for (int i = 1; i <= 20; i++)
{
var customer = _customers[i % _customers.Count];
var pizza = _pizzas[i % _pizzas.Count];

Order order = new Order
{
Id = i,
CustomerId = customer.Id,
PizzaId = pizza.Id,
OrderTime = new DateTime(2023, 12, 25).AddDays(i).ToUniversalTime(),
Status = exercise.pizzashopapi.OrderStatus.Complete,
PizzaStatus = exercise.pizzashopapi.PizzaStatus.Finished
};
_orders.Add(order);
}
}

public List<Customer> Customers => _customers;
public List<DeliveryDriver> DeliveryDrivers => _drivers;
public List<Pizza> Pizzas => _pizzas;
public List<Order> Orders => _orders;
}
Loading