public async Task <IActionResult> AddressAndPayment([FromServices] DrinkStoreContext dbContext, [FromForm] Order order, CancellationToken requestAborted) { if (!ModelState.IsValid) { return(View(order)); } var formCollection = await HttpContext.Request.ReadFormAsync(); try { if (string.Equals(formCollection["PromoCode"].FirstOrDefault(), PromoCode, StringComparison.OrdinalIgnoreCase) == false) { return(View(order)); } else { order.UserName = HttpContext.User.Identity.Name; order.OrderDate = DateTime.Now; //Add the Order dbContext.Orders.Add(order); //Process the order var cart = ShoppingCart.GetCart(dbContext, HttpContext); await cart.CreateOrder(order); _logger.LogInformation("User {userName} started checkout of {orderId}.", order.UserName, order.OrderId); // Save all changes await dbContext.SaveChangesAsync(requestAborted); return(RedirectToAction("Complete", new { id = order.OrderId })); } } catch { //Invalid - redisplay with errors return(View(order)); } }
// GET: /Checkout/Complete public async Task <IActionResult> Complete([FromServices] DrinkStoreContext dbContext, int id) { var userName = HttpContext.User.Identity.Name; // Validate customer owns this order bool isValid = await dbContext.Orders.AnyAsync( o => o.OrderId == id && o.UserName == userName); if (isValid) { _logger.LogInformation("User {userName} completed checkout on order {orderId}.", userName, id); return(View(id)); } else { _logger.LogError( "User {userName} tried to checkout with an order ({orderId}) that doesn't belong to them.", userName, id); return(View("Error")); } }
public StoreManagerController(DrinkStoreContext context) { _context = context; }
public CartInfoComponent(DrinkStoreContext dbContext) { DbContext = dbContext; }
public ShoppingCartController(DrinkStoreContext context, ILogger <ShoppingCartController> logger) { _context = context; _logger = logger; }
public StyleMenuComponent(DrinkStoreContext dbContext) { DbContext = dbContext; }
public DrinksController(DrinkStoreContext context) { _context = context; }