* 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.
139 lines
3.8 KiB
C#
139 lines
3.8 KiB
C#
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Web;
|
|
using System.Web.Routing;
|
|
using Yavsc.Formatters;
|
|
using Yavsc.Model.FrontOffice;
|
|
using System.Web.SessionState;
|
|
using System.Web.Mvc;
|
|
using System.Web.Http;
|
|
using System.Web.WebPages.Scope;
|
|
using System.Reflection;
|
|
using System.Web.Configuration;
|
|
|
|
namespace Yavsc
|
|
{
|
|
|
|
/// <summary>
|
|
/// Mvc application.
|
|
/// </summary>
|
|
public class MvcApplication : HttpApplication
|
|
{
|
|
|
|
/// <summary>
|
|
/// Registers the routes.
|
|
/// </summary>
|
|
/// <param name="routes">Routes.</param>
|
|
public static void RegisterRoutes (RouteCollection routes)
|
|
{
|
|
routes.IgnoreRoute ("{resource}.axd/{*pathInfo}"); // not used
|
|
routes.IgnoreRoute ("Scripts/{*pathInfo}"); // web user side scripts
|
|
routes.IgnoreRoute ("App_Theme/{*pathInfo}"); // sites themes
|
|
routes.IgnoreRoute ("App_Data/{*pathInfo}"); // sites themes
|
|
routes.IgnoreRoute ("App_Code/{*pathInfo}"); // sites themes
|
|
routes.IgnoreRoute ("users/{*pathInfo}"); // user's files
|
|
routes.IgnoreRoute ("avatars/{*pathInfo}"); // user's avatar
|
|
routes.IgnoreRoute ("bfiles/{*pathInfo}"); // Blog files
|
|
routes.IgnoreRoute ("xmldoc/{*pathInfo}"); // xml doc
|
|
routes.IgnoreRoute ("htmldoc/{*pathInfo}"); // html doc
|
|
routes.IgnoreRoute ("fonts/{*pathInfo}"); // fonts
|
|
routes.IgnoreRoute ("favicon.ico"); // favorite icon
|
|
routes.IgnoreRoute ("favicon.png"); // favorite icon
|
|
routes.IgnoreRoute ("robots.txt"); // for search engine robots
|
|
|
|
routes.MapRoute (
|
|
"FrontOffice",
|
|
"do/{action}/{MEACode}/{Id}",
|
|
new { controller = "FrontOffice", action = "Index", MEACode = UrlParameter.Optional, Id = UrlParameter.Optional }
|
|
);
|
|
|
|
routes.MapRoute (
|
|
"Titles",
|
|
"title/{title}",
|
|
new { controller = "Blogs", action = "Index",
|
|
title=UrlParameter.Optional }
|
|
);
|
|
routes.MapRoute (
|
|
"Blogs",
|
|
"blog/{user}",
|
|
new { controller = "Blogs",
|
|
action = "UserPosts",
|
|
user= UrlParameter.Optional }
|
|
);
|
|
|
|
routes.MapRoute (
|
|
"BlogByTitle",
|
|
"by/{user}/{title}/{id}",
|
|
new { controller = "Blogs",
|
|
action = "UserPosts",
|
|
user="Paul Schneider",
|
|
title=UrlParameter.Optional,
|
|
id=UrlParameter.Optional }
|
|
);
|
|
routes.MapRoute (
|
|
"BlogById",
|
|
"b/{action}/{postid}",
|
|
new { controller = "Blogs", action = "Index",
|
|
postid=UrlParameter.Optional }
|
|
);
|
|
routes.MapRoute (
|
|
"BackCompat",
|
|
"Blogs/{action}/{user}/{title}",
|
|
new { controller = "Blogs", action = "Index", user = UrlParameter.Optional, title = UrlParameter.Optional }
|
|
);
|
|
|
|
routes.MapRoute (
|
|
"Default",
|
|
"{controller}/{action}/{id}",
|
|
new { controller = "Home", action = "Index", id = UrlParameter.Optional }
|
|
);
|
|
|
|
}
|
|
|
|
/// <summary>
|
|
/// Starts the Application.
|
|
/// </summary>
|
|
protected void Application_Start ()
|
|
{
|
|
AreaRegistration.RegisterAllAreas ();
|
|
WebApiConfig.Register (GlobalConfiguration.Configuration);
|
|
RegisterRoutes (RouteTable.Routes);
|
|
AjaxHelper.GlobalizationScriptPath = "~/Scripts/globalize";
|
|
|
|
}
|
|
|
|
/// <summary>
|
|
/// Applications the post authorize request.
|
|
/// </summary>
|
|
protected void Application_PostAuthorizeRequest()
|
|
{
|
|
if (IsWebApiRequest())
|
|
{
|
|
HttpContext.Current.SetSessionStateBehavior(SessionStateBehavior.Required);
|
|
}
|
|
}
|
|
|
|
private bool IsWebApiRequest()
|
|
{
|
|
return HttpContext.Current.Request.AppRelativeCurrentExecutionFilePath.StartsWith(WebApiConfig.UrlPrefixRelative);
|
|
}
|
|
|
|
/// <summary>
|
|
/// begins a request against this application.
|
|
/// </summary>
|
|
protected void Application_BeginRequest()
|
|
{
|
|
var ob = typeof(
|
|
AspNetRequestScopeStorageProvider).Assembly.GetType(
|
|
"System.Web.WebPages.WebPageHttpModule").GetProperty
|
|
("AppStartExecuteCompleted",
|
|
BindingFlags.NonPublic | BindingFlags.Static);
|
|
ob.SetValue(null, true, null);
|
|
|
|
}
|
|
}
|
|
}
|
|
|