UtilisateursController.cs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. using CD67.FicheCollege.Entity;
  2. using CD67.FicheCollege.Factory;
  3. using CD67.FicheCollege.MVC.Models;
  4. using CD67.PIMP.MVC.Internal;
  5. using System.Net;
  6. using System.Web.Mvc;
  7. namespace CD67.FicheCollege.MVC.Controllers
  8. {
  9. [Acces(groupes = "Admin")]
  10. public class UtilisateursController : Controller
  11. {
  12. private Entities db = new Entities();
  13. // GET: ActionEduAxe/Create
  14. public ActionResult Create(int? groupe_id)
  15. {
  16. if (groupe_id == null)
  17. {
  18. return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
  19. }
  20. Utilisateur utilisateur = new Utilisateur();
  21. utilisateur.GroupeId = groupe_id.Value;
  22. GroupeFactory fact = new GroupeFactory(db);
  23. utilisateur.Groupe = fact.getById(groupe_id);
  24. UtilisateurViewModel model = new UtilisateurViewModel(utilisateur, ModeAcces.Creation);
  25. return View("Create", model);
  26. }
  27. // POST: ActionEduAxe/Create
  28. // Afin de déjouer les attaques par sur-validation, activez les propriétés spécifiques que vous voulez lier. Pour
  29. // plus de détails, voir http://go.microsoft.com/fwlink/?LinkId=317598.
  30. [HttpPost]
  31. [ValidateAntiForgeryToken]
  32. public ActionResult Create(Utilisateur utilisateur)
  33. {
  34. if (ModelState.IsValid)
  35. {
  36. UtilisateurFactory fact = new UtilisateurFactory(db);
  37. fact.add(ref utilisateur);
  38. return RedirectToAction("Details", "Groupes", new { Id = utilisateur.GroupeId });
  39. }
  40. GroupeFactory groupe_fact = new GroupeFactory(db);
  41. utilisateur.Groupe = groupe_fact.getById(utilisateur.GroupeId);
  42. UtilisateurViewModel model = new UtilisateurViewModel(utilisateur, ModeAcces.Creation);
  43. return View("Create", model);
  44. }
  45. // GET: ActionEduAxe/Delete/5
  46. public ActionResult Delete(int? id)
  47. {
  48. if (id == null)
  49. {
  50. return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
  51. }
  52. UtilisateurFactory fact = new UtilisateurFactory(db);
  53. Utilisateur utilisateur = fact.getById(id.Value);
  54. if (utilisateur == null)
  55. {
  56. return HttpNotFound();
  57. }
  58. DeleteViewModel model = new DeleteViewModel(utilisateur, "Utilisateur", utilisateur.Login);
  59. return View("~/Views/Shared/_AdminDeleteWarning.cshtml", model);
  60. }
  61. // POST: ActionEduAxe/Delete/5
  62. [HttpPost, ActionName("Delete")]
  63. [ValidateAntiForgeryToken]
  64. public ActionResult DeleteConfirmed(int id)
  65. {
  66. UtilisateurFactory fact = new UtilisateurFactory(db);
  67. Utilisateur utilisateur = fact.getById(id);
  68. fact.delete(ref utilisateur);
  69. return RedirectToAction("Details", "Groupes", new { Id = utilisateur.GroupeId });
  70. }
  71. protected override void Dispose(bool disposing)
  72. {
  73. if (disposing)
  74. {
  75. db.Dispose();
  76. }
  77. base.Dispose(disposing);
  78. }
  79. }
  80. }