Ejemplo n.º 1
0
 public ActionResult ManageSubscriptions(string id)
 {
     if (!id.HasValue())
         return Content("bad link");
     ManageSubsModel m;
     var td = TempData["PeopleId"];
     if (td != null)
         m = new ManageSubsModel(td.ToInt(), id.ToInt());
     else
     {
         var guid = id.ToGuid();
         if (guid == null)
             return Content("invalid link");
         var ot = DbUtil.Db.OneTimeLinks.SingleOrDefault(oo => oo.Id == guid.Value);
         if (ot == null)
             return Content("invalid link");
         if (ot.Used)
             return Content("link used");
         if (ot.Expires.HasValue && ot.Expires < DateTime.Now)
             return Content("link expired");
         var a = ot.Querystring.Split(',');
         m = new ManageSubsModel(a[1].ToInt(), a[0].ToInt());
         id = a[0];
         ot.Used = true;
         DbUtil.Db.SubmitChanges();
     }
     m.Log("Start");
     SetHeaders(id.ToInt());
     return View("ManageSubscriptions/Choose", m);
 }
Ejemplo n.º 2
0
        public ActionResult ConfirmSubscriptions(ManageSubsModel m)
        {
            m.UpdateSubscriptions();

            var Staff = DbUtil.Db.StaffPeopleForOrg(m.masterorgid);

            var msg = DbUtil.Db.ContentHtml("ConfirmSubscriptions", Resource1.ConfirmSubscriptions);
            var orgname = m.Description();
            msg = msg.Replace("{org}", orgname).Replace("{details}", m.Summary);
            DbUtil.Db.Email(Staff.First().FromEmail, m.person, "Subscription Confirmation", msg);

            DbUtil.Db.Email(m.person.FromEmail, Staff, "Subscriptions managed",
                $@"{m.person.Name} managed subscriptions to {m.Description()}<br/>{m.Summary}");

            SetHeaders(m.masterorgid);
            m.Log("Confirm");
            return View("ManageSubscriptions/Confirm", m);
        }