IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Symfony PHP Discussion :

Créer une contrainte pour empêcher une réservation le mardi


Sujet :

Symfony PHP

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Journaliste - formateur web
    Inscrit en
    Octobre 2017
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Journaliste - formateur web
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2017
    Messages : 35
    Points : 37
    Points
    37
    Par défaut Créer une contrainte pour empêcher une réservation le mardi
    Bonjour à tous,

    Je me permets de vous adresser ce courrier car je peine dans l'écriture d'une contrainte dans mon projet Symfony.
    Dans le cadre de la création d'une billetterie en ligne, je dois créer une contrainte sur le mardi. Objectif : faire en sorte que l'on ne puisse pas réserver sur cette date là en ligne. J'ai déjà activé cette possibilité dans le datepicker en JS. Mais je souhaiterais également créer cette contrainte en PHP au cas où le JS n'est pas actif.

    Dans mon entité visit, à l'attribut $visitDate, j'ai donné une valeur à ma contrainte : 2 pour mardi.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
         * Assert\NoReservationOnThisDay(day="2")
         *
         */
        private $visitDate;
    Dans ma classe NoReservationOnThisDay, j'ai créé un attribut $day et j'ai indiqué mon message d'erreur :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    class NoReservationOnThisDay extends Constraint
    {
        public $day;
     
        public $message = "Il n\'est pas possible de réserver un billet en ligne pour des visites le mardi.";
    Et dans le validator, j'ai écrit ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    class NoReservationOnThisDayValidator extends ConstraintValidator
    {
        /**
         * @param mixed $value
         * @param Constraint $constraint
         */
        public function validate($value, Constraint $constraint)
        {
            $day = date('w');
     
            $value = date('w');
     
            if($day == $value && $day = $constraint->day)
            {
                $this->context->addViolation($constraint->message);
            }
        }
    }
    C'est là que je peine. Car, en écrivant ceci, cela n'empêche pas les résa le mardi. Cela bloque tous les réservations le jour où $value = $day. Il y a une erreur dans mon if mais je ne vois pas du tout comment écrire cet algorithme.

    Si vous avez une idée, je suis preneuse.
    Merci d'avance,
    Vanessa

  2. #2
    Membre extrêmement actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2018
    Messages
    537
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Avril 2018
    Messages : 537
    Points : 634
    Points
    634
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
            if($day == $value && $day == $constraint->day)
            {
                $this->context->addViolation($constraint->message);
            }

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Journaliste - formateur web
    Inscrit en
    Octobre 2017
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Journaliste - formateur web
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2017
    Messages : 35
    Points : 37
    Points
    37
    Par défaut
    C'est bien cela. Mon erreur vient de ce code.
    J'ai changé par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if($value == 2 && $day = $constraint->day)
            {
                $this->context->buildViolation($constraint->message)->addViolation();
     
            }
    Mais cela ne change rien.

  4. #4
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Connais pas symfony.
    Mais si tu mets le trigger en SQL dans ta base, j'imagine que symfony le répercutera automatiquement avec un refactor ?
    Si ça t'intéresse, on peut faire ça. Non testé...
    Tu n'as qu'à modifier db_name, table_name et field_name...
    exécuter ce code dans ton phpmyadmin... et tester enfin en tentant un insert ou update de mardi dans ton phpmyadmin...

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    USE db_name ;
    DROP TRIGGER IF EXISTS `insert_erreur`;
    DELIMITER $$
    CREATE TRIGGER `insert_erreur` BEFORE INSERT ON `table_name` FOR EACH ROW BEGIN
      DECLARE _msg  varchar(255);
     
      if (WEEKDAY(new.field_name,2)=2) then
            set _msg = 'Saisir un mardi est interdit !';
         SIGNAL SQLSTATE VALUE '08888' SET MESSAGE_TEXT = _msg, MYSQL_ERRNO = 8888;
      end if;
    END
    $$
    DELIMITER ;
    DROP TRIGGER IF EXISTS `update_erreur`;
    DELIMITER $$
    CREATE TRIGGER `update_erreur` BEFORE UPDATE ON `table_name` FOR EACH ROW BEGIN
      DECLARE _msg  varchar(255);
     
      if (WEEKDAY(new.field_name,2)=2) then
            set _msg = 'Saisir un mardi est interdit !';
         SIGNAL SQLSTATE VALUE '08888' SET MESSAGE_TEXT = _msg, MYSQL_ERRNO = 8888;
      end if;
    END
    $$
    DELIMITER ;
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  5. #5
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2012
    Messages
    631
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2012
    Messages : 631
    Points : 1 220
    Points
    1 220
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if($value == 2 && $day == $constraint->day)
            {
                $this->context->buildViolation($constraint->message)->addViolation();
     
            }
    Attention $value est un objet de type DateTime. Donc pour comparer $value avec 2 il faut invoquer la méthode format:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
        /**
         *
         * @param Constraint $constraint The constraint for the validation
         * @param DateTime $value
         */
        public function validate(  $value, Constraint $constraint) {
            if( $value->format('w') == 2 ){
                $this->context->buildViolation($constraint->message)
                    ->addViolation();
            }
    }
    Autre approche : constraints Callback.html

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    //entity class
     
    use Symfony\Component\Validator\Constraints as Assert;
    use Symfony\Component\Validator\Context\ExecutionContextInterface;
     
        /**
         * @Assert\Callback
         */
        public function validate(ExecutionContextInterface $context, $payload)  {
            if( $this->getVisitDate()->format('w') == 2 ) {
                $context->buildViolation("Il n'est pas possible de réserver un billet en ligne pour des visites le mardi.")
                    ->atPath('visitDate')
                    ->addViolation();
            }
     
        }

  6. #6
    Nouveau membre du Club
    Femme Profil pro
    Journaliste - formateur web
    Inscrit en
    Octobre 2017
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Journaliste - formateur web
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2017
    Messages : 35
    Points : 37
    Points
    37
    Par défaut
    Finalement, j'ai résolu le souci en utilisant un boléen.
    Merci pour votre aide !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 18/04/2017, 22h57
  2. Lien dans un frame d'une cadre pour ouvrir une autre page sur une même fenêtre
    Par maelislah dans le forum Général Conception Web
    Réponses: 0
    Dernier message: 27/06/2015, 20h39
  3. Simuler une activité pour empêcher une déconnection
    Par docjfnoel dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 28/05/2007, 10h05
  4. Créer une contraintes pour une suppression
    Par subzero82 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 04/10/2005, 17h36
  5. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo