var Phenix = function () {
Troll du Web depuis 1996

Laravel

Utiliser la session Laravel avec les route/api

Je cherchais une solution pour utiliser les routes « api » de Laravel avec la session « web » classique.
Installer Passport est complexe et souvent inutile pour pas mal de projet. Il existe la solution de passer par un champ api_token dans la base de donnée, mais niveau sécurité, je trouve cela moyen.

Cependant, il est possible d’utiliser le driver de session classique :

Dans config/auth.php, il faut modifier les guards pour replacer token par session en dessous d’API :

  1.     'guards' => [
  2.         'web' => [
  3.             'driver' => 'session',
  4.             'provider' => 'users',
  5.         ],
  6.  
  7.         'api' => [
  8.             'driver' => 'session',
  9.             'provider' => 'users',
  10.             'hash' => false,
  11.         ],
  12.     ],

Ensuite dans app/Http/Kernel.php, il faut modifier le middlewareGroups « api » :

  1.         'api' => [
  2.             'throttle:60,1',
  3.             \App\Http\Middleware\EncryptCookies::class,
  4.             \Illuminate\Session\Middleware\StartSession::class,
  5.             'bindings',
  6.         ],

Tester avec un projet Laravel 6 sans soucis !


Laravel : utiliser un trait php pour purifier le HTML d’un champ

Lorsque l’ont stock du HTML dans le champ d’une base de donnée, il ne faut jamais le stocker sans le filtrer. C’est une mauvaise pratique bien connue, cela attire les failles XSS et personne n’aime en avoir.

Bref, voici une méthode sympa pour protéger un champ.

Dans un premier temps il faut installer HTMLPurifier :

  1. composer require ezyang/htmlpurifier

Cette librairie permet de filtrer le html correctement. N’utilisez pas strip_tags, cette fonction n’est pas faite pour la sécurité.

Ma base de donnée contient assez bien de champs « description », ils risquent tous de contenir du HTML, car ils sont remplis par un CKeditor.

Cela affecte tous ces champs, j’ai envie de les protéger facilement.
J’ai donc créé un fichier ./app/traits/purify.php

On va mixer le pouvoir des mutators de Laravel et

  1. <?php
  2.  
  3. namespace App;
  4.  
  5. use HTMLPurifier_Config;
  6. use HTMLPurifier;
  7.  
  8. trait Purify
  9. {
  10.     /**
  11.      * @property $allowed allowed html inside description field
  12.      */
  13.     private $allowed = 'p, strong, h2, h3, a[href], ul, ol, li, i';
  14.  
  15.     /**
  16.      * Laravel mutator.
  17.      * Filter all unauthorized HTML from the description field
  18.      * @param $value
  19.      */
  20.     public function setDescriptionAttribute($value)
  21.     {
  22.         $config = HTMLPurifier_Config::createDefault();
  23.         $config->set('HTML.Allowed', $this->allowed);
  24.         $purifier = new HTMLPurifier($config);
  25.         $this->attributes['description'] = $purifier->purify($value);
  26.     }
  27. }

Il suffit alors d’utiliser ce trait dans un modèle Laravel pour que les champs description soit automatiquement filtrés avant d’être insérés dans la base de donnée !

  1. <?php
  2.  
  3. namespace App;
  4.  
  5. use Illuminate\Database\Eloquent\Model;
  6.  
  7. class MyModel extends Model
  8. {
  9.     use Purify;
  10. }

Laravel et PHP sont des outils vraiment formidables quand on comprend ce genre d’astuce !


Laravel + Foundation 6

Laraval vient par défaut avec Boostrap. Personnellement, en matière de Framework frontend, je préfère largement Foundation.

Heureusement, il existe un preset pour changer cela proprement dans Laravel. Les autres Tuto ou tout était fait à la main était quand même barbant.

Installer le preset :

Facile, on demande à composer :

  1. composer require laravel-frontend-presets/zurb-foundation

Activé le preset :

Soit on veut juste activer foundation :

  1. php artisan preset foundation

Soit on veut aussi que les templates de base de Laravel soit adapté :

  1. php artisan preset foundation-auth

Il ne reste plus qu’à installer :

  1. npm install && npm run dev
Voir en ligne : Zurb Foundation 6 Preset For Laravel 5.5