public async Task <ActionResult> Login(LoggedUser pUser) { try { if (ModelState.IsValid) { UserBL wUserBL = new UserBL(); pUser.wDetailUser = ConvertEntityUserTOUserModel.ConvertoUserEntityTOUserModel(await wUserBL.SigIn(pUser.Email, pUser.Password)); Session["CurrentUser"] = pUser; Session["Ruolo"] = pUser.wDetailUser.Ruolo; return(await Index(new SearchProduct())); } else { return(View(pUser)); } } catch (Exception ex) { Log.Error("Errore in fase di Login", ex); ViewBag.ErrorMessage = "Username o Password errati"; return(View(pUser)); } }
public async Task <ActionResult> Create(User collection) { try { if (ModelState.IsValid) { UserBL wDB = new UserBL(); await wDB.InsertUser(ConvertEntityUserTOUserModel.ConvertoUserEntityTOUserModel(collection)); ViewBag.ErrorMessage = "Registrazione avvenuta con successo"; return(RedirectToAction("Login", "Home")); } else { return(View(collection)); } } catch (Exception ex) { Log.Error("Errore in fase di Registrazione", ex); ViewBag.ErrorMessage = "Registrazione non Riuscita. " + ex.Message; return(View(collection)); } }
// GET: Cart/Details/5 public async Task <ActionResult> Details() { wLogUser = (LoggedUser)Session["CurrentUser"]; Cart wCart = ConvertEntityUserTOUserModel.ConvertoCartEntityTOCartModel(await new CartBL().GetCartByUser(wLogUser.wDetailUser.Id)); wCart.UserOwner = wLogUser.wDetailUser; return(View("Details", wCart)); }
public async Task <ActionResult> PaymentWithPaypal(string userId, string Cancel = null) { //getting the apiContext APIContext apiContext = PaypalConfiguration.GetAPIContext(); wLogUser = (LoggedUser)Session["CurrentUser"]; Cart wCart = null; try { //A resource representing a Payer that funds a payment Payment Method as paypal //Payer Id will be returned when payment proceeds or click to pay string payerId = Request.Params["PayerID"]; if (string.IsNullOrEmpty(payerId)) { //this section will be executed first because PayerID doesn't exist //it is returned by the create function call of the payment class // Creating a payment // baseURL is the url on which paypal sendsback the data. string baseURI = Request.Url.Scheme + "://" + Request.Url.Authority + "/Cart/PaymentWithPayPal?"; //here we are generating guid for storing the paymentID received in session //which will be used in the payment execution var guid = Convert.ToString((new Random()).Next(100000)); //CreatePayment function gives us the payment approval url //on which payer is redirected for paypal account payment wCart = ConvertEntityUserTOUserModel.ConvertoCartEntityTOCartModel(await new CartBL().GetCartByUser(wLogUser.wDetailUser.Id)); if (wCart.DetailsCart.Count == 0) { ViewBag.ErrorMessage = "Non sono presenti articoli nel carrello"; wCart.UserOwner = wLogUser.wDetailUser; return(View("Details", wCart)); } wCart.NumOrder = new CartBL().GenerateNumOrder(); Session["NumOrder"] = wCart.NumOrder; var createdPayment = this.CreatePayment(apiContext, baseURI + "guid=" + guid, wCart); //get links returned from paypal in response to Create function call var links = createdPayment.links.GetEnumerator(); string paypalRedirectUrl = null; while (links.MoveNext()) { Links lnk = links.Current; if (lnk.rel.ToLower().Trim().Equals("approval_url")) { //saving the payapalredirect URL to which user will be redirected for payment paypalRedirectUrl = lnk.href; } } // saving the paymentID in the key guid Session.Add(guid, createdPayment.id); return(Redirect(paypalRedirectUrl)); } else { // This function exectues after receving all parameters for the payment var guid = Request.Params["guid"]; var executedPayment = ExecutePayment(apiContext, payerId, Session[guid] as string); //If executed payment failed then we will show payment failure message to user if (executedPayment.state.ToLower() != "approved") { return(View("FailureView")); } } } catch (Exception ex) { return(View("FailureView")); } //on successful payment, show success page to user. wLogUser = (LoggedUser)Session["CurrentUser"]; string wNumOrder = Session["NumOrder"] != null ? Session["NumOrder"].ToString() : ""; //scrittura pdf di conferma acquisto Log.Info("Scrittura PDF per ordine " + wNumOrder); var appSettings = ConfigurationManager.AppSettings; string wUrlPDF = appSettings["UlrPDF"]; FileStream wPFD = ManagementDocument.CreateOrderDocument(wUrlPDF, wNumOrder, await new CartBL().GetCartByUser(wLogUser.wDetailUser.Id), ConvertEntityUserTOUserModel.ConvertoUserEntityTOUserModel(wLogUser.wDetailUser)); //invio Mail try { Log.Info("Tentativo invio mail per ordine " + wNumOrder); MailManagment.SendEmail(wPFD.Name, wLogUser.Email, wLogUser.wDetailUser.Name, wLogUser.wDetailUser.Surname); } catch (Exception ex) { Log.Error("Errore durante l'invio della mail.", ex); } try { //creo lo storico dell'ordine Log.Info("Scrittura Storico per ordine " + wNumOrder + " dell'utente " + wLogUser.Id); await new CartBL().AddHistoryBuy(wLogUser.wDetailUser.Id, wNumOrder); } catch (Exception ex) { Log.Error("Errore durante la scrittura dello storico ordine.", ex); } return(View("SuccessView")); }