La page de reservation par défaut est maintenant la reservation dite simple. Fonctionnalités en cours de développement: 1) la reservation dite simple 2) la notification à la reservation 3) l'activité principale exercée 4) l'integration d'un premier thème clair * MEA.sql: définit la valeur MEA du profile (Main Exerted Activity) dans la base de donnée * Booking.aspx: Imlémente la vue du formulaire de reservation simple, c'etait avant la reservation classique, sur une période plutôt qu'un jour. La reservation classique est renomée `EavyBooking`. * SimpleBookingQuery.cs: Implémente une simple commande de rendez-vous, en tant que commande du workflow. * .gitignore: ignorer les configuration des pré et prod totem. * SkillEntity.cs: * SkillManager.cs: * Skills.aspx: * SkillProvider.cs: * SkillController.cs: * UserSkills.aspx: * NpgsqlSkillProvider.cs: refactorisation (-Skill+SkillEntity) * NpgsqlProfileProvider.cs: Fixe un bug introduit avec l'implementation des profiles anonymes. * FrontOfficeController.cs: definit l'interface de cotation des compétences attendues * UserCard.ascx: Imlémente une carte utilisateur. * Web.config: déclare le code activité principale exercée parmis les valeurs du profile authentifié. * Web.csproj: ajoute les nouveaux formulaire de reservation au projet. * PerformerProfile.cs: S'assure d'avoir une valeur pour le nom d'utilisateur à la création. * LocalizedText.resx: * LocalizedText.Designer.cs: "date préférée" en anglais * LocalizedText.fr.resx: * LocalizedText.fr.Designer.cs: "date préférée" en français * Profile.cs: à la creation d'un profile, on doit avoir un nom d'utilisateur, même dans le cas où le profile est anonyme (dans ce cas, on l'appelle identifiant anonyme). Sinon, on lève une exception. * YavscModel.csproj: * refactorisation: le nom `Skill` est celui de l'espace, celui de la classe devient `SkillEntity`. * Creation de la requête dite simple d'un rendez-vous (pour prestation) à une date donnée (sans heure), concernant simplement une activité. * EavyBooking.aspx: Implémente la reservation lourde
110 lines
3.1 KiB
C#
110 lines
3.1 KiB
C#
//
|
|
// SkillController.cs
|
|
//
|
|
// Author:
|
|
// Paul Schneider <paul@pschneider.fr>
|
|
//
|
|
// Copyright (c) 2015 GNU GPL
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
using System;
|
|
using Yavsc.Model.Skill;
|
|
using System.Web.Http;
|
|
using Yavsc.Model;
|
|
|
|
namespace Yavsc.ApiControllers
|
|
{
|
|
/// <summary>
|
|
/// Skill controller.
|
|
/// </summary>
|
|
public class SkillController : YavscController
|
|
{
|
|
/// <summary>
|
|
/// Create or update the specified Skill.
|
|
/// </summary>
|
|
/// <param name="s">the Skill objet.</param>
|
|
[ValidateAjaxAttribute,Authorize(Roles="Profiler")]
|
|
public long DeclareSkill (SkillEntity s) {
|
|
if (ModelState.IsValid) {
|
|
SkillManager.DeclareSkill (s);
|
|
}
|
|
return s.Id;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Declares the user's skill,
|
|
/// This call should be in charge of
|
|
/// the user himself, it's an user
|
|
/// declaration, and as a result,
|
|
/// this only is a declarative caracterisation of
|
|
/// the user's skills.
|
|
/// </summary>
|
|
/// <returns>The skill.</returns>
|
|
/// <param name="dec">Dec.</param>
|
|
[Authorize()]
|
|
public long DeclareUserSkill (UserSkillDeclaration dec) {
|
|
return SkillManager.DeclareUserSkill(dec);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Rate the specified user's skill.
|
|
/// A way for an effective client to rate
|
|
/// the service or good he should have got.
|
|
/// This is the king's value
|
|
/// </summary>
|
|
/// <param name="rate">The user skill rating.</param>
|
|
[Authorize()]
|
|
public long RateUserSkill (UserSkillRating rate) {
|
|
return SkillManager.RateUserSkill(User.Identity.Name, rate);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Rates the skill.
|
|
/// </summary>
|
|
/// <param name="rate">Skill rating.</param>
|
|
[Authorize()]
|
|
public void RateSkill (SkillRating rate) {
|
|
SkillManager.RateSkill(User.Identity.Name,rate);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Finds the skill identifier.
|
|
/// </summary>
|
|
/// <returns>The skill identifier.</returns>
|
|
/// <param name="pattern">Pattern.</param>
|
|
public SkillEntity [] FindSkill (string pattern){
|
|
return SkillManager.FindSkill(pattern);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Finds the performer.
|
|
/// </summary>
|
|
/// <returns>The performer.</returns>
|
|
/// <param name="skillIds">Skill identifiers.</param>
|
|
public string [] FindPerformer (long []skillIds){
|
|
return SkillManager.FindPerformer(skillIds);
|
|
}
|
|
/// <summary>
|
|
/// Deletes the skill.
|
|
/// </summary>
|
|
/// <param name="skillId">Skill identifier.</param>
|
|
[Authorize(Roles="Moderator")]
|
|
public void DeleteSkill (long skillId)
|
|
{
|
|
SkillManager.DeleteSkill (skillId);
|
|
}
|
|
}
|
|
}
|
|
|