* ResetPassword.txt: Un message pour le mot de passe oublié * style.css: fixe un 404 * UpdatePassword.aspx: Implémente le formulaire de mise à jour du mot de passe, accessible depuis l'e-mail. * Contact.aspx: implémente la page de contact préstataire * UpdatePassword.cs: modèle de la modification de mot de passe au jeton de securité (qui est encore un fake en l'état) * CommandRegistration.cs: un enregistrement de commande * NominativeCommandRegistration.cs: un enregistrement de commande nominative * .gitignore: ignore ma config LuaDebug * NpgsqlMembershipProvider.cs: ne pas crasher à la lecture en base de la question de recupération du mot de passe quand elle est nulle. * BasketController.cs: renvoie l'objet décrivant la prise de commande * Global.asax.cs: ignorer les routes vers App_Data et App_Code * instdbws.sql: passage du type json à jsonb pour les paramètres de la commande * RegistrationMail.txt: un piti message à l'enregistrement * AccountController.cs: Envoi du message du mot de passe oublié, methode de changemnet du mot de passe. * AdminController.cs: xmldoc + refabrication helper Notify * HomeController.cs: * BlogsController.cs: * GoogleController.cs: refabrication helper Notify * FrontOfficeController.cs: Refabrication: Utilisation du nouvel enregistrement de commande. + refabrication helper Notify * YavscHelpers.cs: implémente la methode d'envoi du message de mot de passe oublié + refabrication helper Notify * App.master: Corrige la notification Html * AppAdmin.master: Le lien vers la page de contact était associé à tort à la classe css "thanks" * yavsc.js: message plus parlant en cas de requête Ajax mal formée. * Login.aspx: Implémente le lien vers le formulaire de recupération du mot de passe * UserPost.aspx: . * Booking.aspx: format du code * Performer.ascx: l'e-mail préstataire ne sera jamais fourni par l'application, aussi, on parlera de "prendre contact", d'échanger ... mais pas de donner l'adresse e-mail. L'information "son email" n'est donc pas disponible meme à l'utilisateur autorisé. La prise de contact, ou autre fux de comunication le sont. * Performers.aspx: affiche la notification à l'envoi de la demande de devis * Product.aspx: * Service.aspx: les periodes du catalogue et du calendrier sont fondue. * Contact.aspx: traduction en français * Web.config: * la procédure de recupération du mot de passe est activée * l'e-message envoyé est construit à partir d'un modèle, un fichier texte trouvé dans /App_Data, et indiqué à l'application par le paramêtre applicatif "LostPasswordMessage" * Yavsc.csproj: reference les nouveaux fichiers * Product.cs: utilise la période du calendrier * Commande.cs: renvoie un objet à la prise de commande, indiquant l'identifiant de commande, et les messages envoyés en cas de commande nominative. * GoogleHelpers.cs: icone à la notification mobile * LocalizedText.resx: * LocalizedText.fr.resx: * LocalizedText.Designer.cs: * LocalizedText.fr.Designer.cs: traductions * UserNameBase.cs: fixe la dé-sérialisation * WorkFlowManager.cs: refabrication de la prise de commande * YavscModel.csproj: nouveaux objets du modèle * OtherWebException.aspx: page obsolete * Period.cs: fondre la période: celle du catalogue disparait, au profit de celle du calendrier.
341 lines
9.8 KiB
C#
341 lines
9.8 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Web;
|
|
using System.Web.Mvc;
|
|
using System.Web.Security;
|
|
using Yavsc.Model.RolesAndMembers;
|
|
using Yavsc.Model.Admin;
|
|
using Yavsc.Admin;
|
|
using System.IO;
|
|
using Yavsc.Model;
|
|
using Yavsc.Helpers;
|
|
|
|
namespace Yavsc.Controllers
|
|
{
|
|
/// <summary>
|
|
/// Admin controller.
|
|
/// Only Admin members should be allowed to use it.
|
|
/// </summary>
|
|
public class AdminController : Controller
|
|
{
|
|
/// <summary>
|
|
/// Index this instance.
|
|
/// </summary>
|
|
public ActionResult Index()
|
|
{
|
|
// FIXME do this in a new installation script.
|
|
if (!Roles.RoleExists (_adminRoleName)) {
|
|
Roles.CreateRole (_adminRoleName);
|
|
ViewData.Notify( _adminRoleName + " " + LocalizedText.role_created);
|
|
}
|
|
return View ();
|
|
}
|
|
/// <summary>
|
|
/// Inits the db.
|
|
/// In order this action succeds,
|
|
/// there must not exist any administrator,
|
|
/// nor Admin group.
|
|
/// </summary>
|
|
/// <returns>The db.</returns>
|
|
/// <param name="datac">Datac.</param>
|
|
/// <param name="doInit">Do init.</param>
|
|
public ActionResult InitDb(DataAccess datac, string doInit)
|
|
{
|
|
if (doInit=="on") {
|
|
if (ModelState.IsValid) {
|
|
datac.BackupPrefix = Server.MapPath (datac.BackupPrefix);
|
|
DataManager mgr = new DataManager (datac);
|
|
TaskOutput tcdb = mgr.CreateDb ();
|
|
ViewData ["DbName"] = datac.DbName;
|
|
ViewData ["DbUser"] = datac.DbUser;
|
|
ViewData ["Host"] = datac.Host;
|
|
ViewData ["Port"] = datac.Port;
|
|
return View ("Created", tcdb);
|
|
}
|
|
}
|
|
return View ();
|
|
}
|
|
/// <summary>
|
|
/// Backups the specified model.
|
|
/// </summary>
|
|
/// <param name="model">Model.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult Backups(DataAccess model)
|
|
{
|
|
return View (model);
|
|
}
|
|
/// <summary>
|
|
/// Creates the backup.
|
|
/// </summary>
|
|
/// <returns>The backup.</returns>
|
|
/// <param name="datac">Datac.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult CreateBackup(DataAccess datac)
|
|
{
|
|
if (datac != null) {
|
|
if (ModelState.IsValid) {
|
|
if (string.IsNullOrEmpty (datac.Password))
|
|
ModelState.AddModelError ("Password", "Invalid passord");
|
|
datac.BackupPrefix = Server.MapPath (datac.BackupPrefix);
|
|
DataManager ex = new DataManager (datac);
|
|
Export e = ex.CreateBackup ();
|
|
if (e.ExitCode > 0)
|
|
ModelState.AddModelError ("Password", "Operation Failed");
|
|
return View ("BackupCreated", e);
|
|
}
|
|
} else {
|
|
datac = new DataAccess ();
|
|
}
|
|
return View (datac);
|
|
}
|
|
/// <summary>
|
|
/// Creates the user backup.
|
|
/// </summary>
|
|
/// <returns>The user backup.</returns>
|
|
/// <param name="datac">Datac.</param>
|
|
/// <param name="username">Username.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult CreateUserBackup(DataAccess datac,string username)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
/// <summary>
|
|
/// Upgrade the specified datac.
|
|
/// </summary>
|
|
/// <param name="datac">Datac.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult Upgrade(DataAccess datac) {
|
|
throw new NotImplementedException();
|
|
}
|
|
/// <summary>
|
|
/// Restore the specified datac, backupName and dataOnly.
|
|
/// </summary>
|
|
/// <param name="datac">Datac.</param>
|
|
/// <param name="backupName">Backup name.</param>
|
|
/// <param name="dataOnly">If set to <c>true</c> data only.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult Restore(DataAccess datac,string backupName,bool dataOnly=true)
|
|
{
|
|
ViewData ["BackupName"] = backupName;
|
|
if (ModelState.IsValid) {
|
|
// TODO BETTER
|
|
datac.BackupPrefix = Server.MapPath (datac.BackupPrefix);
|
|
DataManager mgr = new DataManager (datac);
|
|
ViewData ["BackupName"] = backupName;
|
|
ViewData ["DataOnly"] = dataOnly;
|
|
|
|
TaskOutput t = mgr.Restore (
|
|
Path.Combine(new FileInfo(datac.BackupPrefix).DirectoryName,
|
|
backupName),dataOnly);
|
|
return View ("Restored", t);
|
|
}
|
|
BuildBackupList (datac);
|
|
return View (datac);
|
|
}
|
|
|
|
private void BuildBackupList(DataAccess datac)
|
|
{
|
|
// build ViewData ["Backups"];
|
|
string bckd=Server.MapPath (datac.BackupPrefix);
|
|
DirectoryInfo di = new DirectoryInfo (new FileInfo(bckd).DirectoryName);
|
|
List<string> bks = new List<string> ();
|
|
foreach (FileInfo ti in di.GetFiles("*.tar"))
|
|
bks.Add (ti.Name);
|
|
ViewData ["Backups"] = bks.ToArray ();
|
|
}
|
|
/// <summary>
|
|
/// Removes from role.
|
|
/// </summary>
|
|
/// <returns>The from role.</returns>
|
|
/// <param name="username">Username.</param>
|
|
/// <param name="rolename">Rolename.</param>
|
|
/// <param name="returnUrl">Return URL.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult RemoveUserFromRole(string username, string rolename, string returnUrl)
|
|
{
|
|
if (ModelState.IsValid)
|
|
Roles.RemoveUserFromRole(username,rolename);
|
|
return Redirect(returnUrl);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Adds the user to role.
|
|
/// </summary>
|
|
/// <returns>The user to role.</returns>
|
|
/// <param name="username">Username.</param>
|
|
/// <param name="rolename">Rolename.</param>
|
|
/// <param name="returnUrl">Return URL.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult AddUserToRole(string username, string rolename, string returnUrl)
|
|
{
|
|
if (ModelState.IsValid)
|
|
Roles.AddUsersToRole(new string[] { username } ,rolename);
|
|
return Redirect(returnUrl);
|
|
}
|
|
/// <summary>
|
|
/// Removes the user.
|
|
/// </summary>
|
|
/// <returns>The user.</returns>
|
|
/// <param name="username">Username.</param>
|
|
/// <param name="submitbutton">Submitbutton.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult RemoveUser (string username, string submitbutton)
|
|
{
|
|
ViewData ["usertoremove"] = username;
|
|
if (submitbutton == "Supprimer") {
|
|
Membership.DeleteUser (username);
|
|
ViewData.Notify( string.Format("utilisateur \"{0}\" supprimé",username));
|
|
ViewData ["usertoremove"] = null;
|
|
}
|
|
return View ();
|
|
}
|
|
/// <summary>
|
|
/// Removes the role.
|
|
/// </summary>
|
|
/// <returns>The role.</returns>
|
|
/// <param name="rolename">Rolename.</param>
|
|
/// <param name="submitbutton">Submitbutton.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult RemoveRole (string rolename, string submitbutton)
|
|
{
|
|
if (submitbutton == "Supprimer")
|
|
{
|
|
Roles.DeleteRole(rolename);
|
|
}
|
|
return RedirectToAction("RoleList");
|
|
}
|
|
/// <summary>
|
|
/// Removes the role query.
|
|
/// </summary>
|
|
/// <returns>The role query.</returns>
|
|
/// <param name="rolename">Rolename.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult RemoveRoleQuery(string rolename)
|
|
{
|
|
ViewData["roletoremove"] = rolename;
|
|
return View ();
|
|
}
|
|
/// <summary>
|
|
/// Removes the user query.
|
|
/// </summary>
|
|
/// <returns>The user query.</returns>
|
|
/// <param name="username">Username.</param>
|
|
[Authorize(Roles="Admin")]
|
|
public ActionResult RemoveUserQuery(string username)
|
|
{
|
|
ViewData["usertoremove"] = username;
|
|
return UserList();
|
|
}
|
|
|
|
|
|
//TODO no more than pageSize results per page
|
|
/// <summary>
|
|
/// User list.
|
|
/// </summary>
|
|
/// <returns>The list.</returns>
|
|
[Authorize()]
|
|
public ActionResult UserList ()
|
|
{
|
|
MembershipUserCollection c = Membership.GetAllUsers ();
|
|
return View (c);
|
|
}
|
|
[Authorize()]
|
|
public ActionResult UsersInRole (string rolename)
|
|
{
|
|
if (rolename == null)
|
|
rolename = "Admin";
|
|
ViewData ["RoleName"] = rolename;
|
|
ViewData ["Roles"] = Roles.GetAllRoles ();
|
|
ViewData ["UsersInRole"] = Roles.GetUsersInRole (rolename);
|
|
return View ();
|
|
}
|
|
|
|
[Authorize()]
|
|
public ActionResult UserRoles (string username)
|
|
{
|
|
ViewData ["AllRoles"] = Roles.GetAllRoles ();
|
|
if (username == null)
|
|
username = User.Identity.Name;
|
|
ViewData ["UserName"] = username;
|
|
ViewData ["UsersRoles"] = Roles.GetRolesForUser (username);
|
|
return View ();
|
|
}
|
|
/// <summary>
|
|
/// a form to add a role
|
|
/// </summary>
|
|
/// <returns>The role.</returns>
|
|
[Authorize(Roles="Admin"),HttpGet]
|
|
public ActionResult AddRole ()
|
|
{
|
|
return View ();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Add a new role.
|
|
/// </summary>
|
|
/// <returns>The add role.</returns>
|
|
/// <param name="rolename">Rolename.</param>
|
|
[Authorize(Roles="Admin"),HttpPost]
|
|
public ActionResult AddRole (string rolename)
|
|
{
|
|
Roles.CreateRole(rolename);
|
|
ViewData.Notify(LocalizedText.role_created+ " : "+rolename);
|
|
return View ();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Shows the roles list.
|
|
/// </summary>
|
|
/// <returns>The list.</returns>
|
|
[Authorize()]
|
|
public ActionResult RoleList ()
|
|
{
|
|
return View (Roles.GetAllRoles ());
|
|
}
|
|
|
|
private const string _adminRoleName = "Admin";
|
|
|
|
/// <summary>
|
|
/// Assing the Admin role to the specified user in model.
|
|
/// </summary>
|
|
/// <param name="model">Model.</param>
|
|
[Authorize()]
|
|
public ActionResult Admin (NewAdminModel model)
|
|
{
|
|
// ASSERT (Roles.RoleExists (adminRoleName))
|
|
string [] admins = Roles.GetUsersInRole (_adminRoleName);
|
|
string currentUser = Membership.GetUser ().UserName;
|
|
List<SelectListItem> users = new List<SelectListItem> ();
|
|
foreach (MembershipUser u in Membership.GetAllUsers ()) {
|
|
var i = new SelectListItem ();
|
|
i.Text = string.Format ("{0} <{1}>", u.UserName, u.Email);
|
|
i.Value = u.UserName;
|
|
users.Add (i);
|
|
}
|
|
ViewData ["admins"] = admins;
|
|
ViewData ["useritems"] = users;
|
|
if (ModelState.IsValid) {
|
|
Roles.AddUserToRole (model.UserName, _adminRoleName);
|
|
ViewData.Notify(model.UserName + " "+LocalizedText.was_added_to_the_role+" '" + _adminRoleName + "'");
|
|
} else {
|
|
if (admins.Length > 0) {
|
|
if (! admins.Contains (Membership.GetUser ().UserName)) {
|
|
ModelState.Remove("UserName");
|
|
ModelState.AddModelError("UserName",LocalizedText.younotadmin+"!");
|
|
}
|
|
} else {
|
|
// No admin, gives the Admin Role to the current user
|
|
Roles.AddUserToRole (currentUser, _adminRoleName);
|
|
admins = new string[] { currentUser };
|
|
ViewData.Notify( string.Format (
|
|
LocalizedText.was_added_to_the_empty_role,
|
|
currentUser, _adminRoleName));
|
|
}
|
|
}
|
|
return View (model);
|
|
}
|
|
}
|
|
}
|
|
|