Switch user

Une des fonctionnalités de Symfony que j’utilise dans tous mes projets est la possibilité d’être connecté à la place d’un autre utilisateur (ou de « impersonate a User » selon le terme de Symfony).

Très utile quand vous avez le client au bout du fil qui vous dit que ça ne fonctionne pas alors que chez vous ça fonctionne (un petit « switch user » plus tard, vous vous rendrez compte qu’il y a bien un bug spécifique à son profil)

On va repartir du source sur github « userdemo2018″ que nous avons écrit pour l’article http://blog.dev-web.io/2018/10/30/symfony-4-gestion-utilisateurs-sans-fosuserbundle-v2018-chapitre-1/

Pour ça il n’y a pas besoin de package particulier, il faut juste modifier la config pour activer cette fonctionnalité, ça se passe dans le fichier security.yaml, il faut ajouter un switch_user à true :

Il faut maintenant affecter le rôle ROLE_ALLOWED_TO_SWITCH aux utilisateurs qui auront la possibilités de switcher sur un autre user, pour ça on va tout simplement modifier nos fixtures :

Et ne pas oublier de les relancer après la modif :

On peut tout de suite tester en se rendant à n’importe quelle adresse de votre site et ajouter à la fin de l’URL : ?_switch_user=userdemo5@example.com

Pour être sûr que ça a fonctionné il suffit de jeter un oeil à la debug toolbar, vous devriez voir l’adresse de l’utiliser switché s’afficher, et pour sortir du mode « switch » et revenir à votre profile, il faut cliquer sur « Exit Impersonation »

On va aller un peu plus loin afin de faire quelque chose d’un peu plus sexy et faire un tableau des utilisateurs avec un lien pour switcher et un lien pour sortir du « switch », tout va se passer dans la vue twig :

Plusieurs remarques :
L’utilisateur à l’origine du switch a un nouveau rôle : ROLE_PREVIOUS_ADMIN, ce qui nous permet de tester si on est en train de switch ou pas
Pour sortir d’un « switch » il suffit d’ajouter _switch_user=_exit à la fin de l’URL
Vous ne pouvez pas switcher sur un autre utilisateur si vous avec déjà un switche en cours, il faut d’abord en sortir.

A vous de jouer ! Pour ma part je fais mon baluchon pour Paris et la Symfony Live qui va se dérouler jeudi et vendredi !

Test de la distro Linux Elementary

Ca faisait pas mal de temps que je suivais Elementary, je l’avais testé à plusieurs reprises mais elle n’était pas encore assez mature pour que j’en fasse ma distro de travail.

Un peu influencé par le fait qu’elle soit dans le top 5 de distrowatch et avec la sortie de la version 5.0 (Juno) j’ai décidé de me lancer et de l’utiliser à plein temps.

Et après quelques semaines d’utilisation je dois dire que je suis assez déçu, il y a pas mal de détail assez énervant, dont voici quelques exemples :

  • Il y a très peu d’applications fournies avec, et même pas un pauvre éditeur de texte
  • Un bug qui fait que les fenêtre de certaines applications sont « doublés » (bug connu)
  • Il faut bidouiller pour désactiver l’économiseur d’écran (en passant par le menu paramètres ça ne fonctionne pas : bug connu)
  • Et surtout, le copier coller entre le terminal et une appli externe (genre navigateur) ne fonctionne pas !

Pas mal de petits détails qui au quotidien rends la distro très agaçante, je vais donc me tourner vers la MX Linux, ou sinon je reviendrai à l’incontournable Linux Mint.

Utiliser Symfony dans docker

Dans ce tutorial nous allons voir comment développer un site Symfony à l’aide d’une stack docker.

On part du principe qu’il n’y a rien d’installé sur votre poste de travail, à part docker et docker-compose (et que vous êtes sous linux!) Vous trouverez le tutorial d’installation de docker sur le site officiel (par exemple si vous êtes sous Debian : https://docs.docker.com/install/linux/docker-ce/debian/)

Continuer la lecture

Utiliser docker pour le développement web

Dans ma vie de développeur j’ai connu 2 révolutions qui ont changé ma façon de développer :

  • En 2000, Le développement sous Linux
  • En 2012, la découverte de Symfony

Avec docker je vais ajouter une 3eme ligne à cette liste.

Voici quelques avantages d’utiliser docker (pour l’utilisation que j’en ai) :

  • Tester votre site dans plusieurs version de php, apache, mysql, …. et tout ça en ne changeant que le port du http
  • Plus besoin d’installer php/apache/mysql en local sur votre poste, vous avez toujours un poste propre
  • Des tonnes d’images disponibles sur le net (par exemple voir plus bas, maildev)
  • Vous êtes sûrs que votre stack est dans la même version que celle de vos collègues et/ou la prod

J’ai mis à dispo ma stack sur mon github :

https://github.com/gponty/docker-mysql-apache-php

Il est fait pour mes besoins personnels donc très spécifiques, c’est à dire :

  • Utilisation des dernières versions de PHP 7.1 et 7.2
  • Utilisation d’apache
  • Utilisation de mysql
  • Utilisation de maildev qui permet de rediriger tous les envois smtp vers une boite locale (un must-have)
  • Installation des drivers PHP pour sql server
  • Installation de wkhtml2pdf
  • Installation de phploy (déploiement du code sur un serveur)
  • Installation de composer
  • Installation de Xdebug

Toutes ces commandes se trouvent dans le fichier Dockerfile qui se trouve dans les répertoires PHP (pour une raison x j’avais besoin de 2 fichiers, mais je pense que je pourrai en regrouper une grosse partie dans 1 seul fichier et ainsi éviter la duplication de code) Même si ça peut paraître compliqué, pris ligne à ligne c’est assez simple à comprendre.

Si vous n’avez pas encore passé le cap, je vous recommande donc chaudement d’essayer docker, ça demande un petit investissement afin de bien comprendre comment cela fonctionne, mais au final ça vous fera gagner du temps très précieux.

Symfony 4 : Gestion utilisateurs sans FOSUserBundle v2018 : Chapitre 3

Cet article est écrit en 3 parties :

Dans ce chapitre nous allons voir comment s’enregistrer et récupérer son mot de passe lors d’un oubli.

Continuer la lecture

Symfony 4 : Gestion utilisateurs sans FOSUserBundle v2018 : Chapitre 2

Cet article est écrit en 3 parties :

Au chapitre précédent on a mis en place notre base de données et l’avons alimenté de quelques users, maintenant il va bien falloir qu’ils se connectent !

Continuer la lecture

Symfony 4 : Gestion utilisateurs sans FOSUserBundle v2018 : Chapitre 1

Cet article est écrit en 3 parties : J’avais écrit l’année dernière une série d’articles sur comment gérer les utilisateurs sans FOSUserBundle, il me restait encore à publier « comment modifier son mot de passe et comment faire un « J’ai oublié mon mot de passe ». Vu que les choses ont pas mal bougé en 1 an j’ai décidé de repartir de 0 (mais en reprenant les grandes lignes de l’ancien article). Mon environnement :
  • Linux Mint 19
  • Php 7.2.10
  • MariadB 10.2.18
  • Symfony 4.1.6
Continuer la lecture

Appli de gestion de mot de passe en Symfony et Vue.js (Partie 3)

Dernier chapitre de notre développement, où nous allons ajouter, modifier et supprimer des mots de passe.

Cet article est écrit en 3 parties :

Vous pouvez retrouver le projet complet ici : https://github.com/gponty/gespassvuejs

Continuer la lecture

Appli de gestion de mot de passe en Symfony et Vue.js (Partie 2)

Suite de notre développement !

Dans le chapitre précédent on a pu mettre en place tout notre environnement ainsi que notre première page.

Cet article est écrit en 3 parties :

Vous pouvez retrouver le projet complet ici : https://github.com/gponty/gespassvuejs

Continuer la lecture

Appli de gestion de mot de passe en Symfony et Vue.js (Partie 1)

Le tutorial du jour va être de développer une application qui servira à stocker vos nombreux mots de passe. (site internet, numéro CB, code PIN, etc…)
Elle portera le doux nom de Gespass.
Cette application servira uniquement d’exercice, je ne vous conseille pas de l’utiliser en production sans en améliorer la sécurité (par exemple au moins ajouter une authentification .htaccess)

Mon environnement de dev actuel :

  • Mint 19 xfce
  • php 7.2.5
  • mariadb 10.1.29
  • symfony 4.1.1
  • server web de symfony
  • vue.js 2.5.16

Cet article sera écrit en 3 parties :

Vous pouvez retrouver le projet complet ici : https://github.com/gponty/gespassvuejs

Continuer la lecture