Comment refondre un legacy sans cris et sans larmes - Retour d'expérience et bonnes pratiques

Un legacy de plusieurs années fait toujours peur : du vieux code PHP 4, pas de template, pas de POO, beaucoup de mauvaises pratiques... Alors quand on décide de refondre tout ça, c'est la panique.

Dans cette conférence, je vous propose de partager le retour d'expérience d'une refonte d'un intranet BtoB. Outillage, bonnes pratiques, architecture logicielle, monitoring, documentation, et formation. Je vous explique tout ce qui nous a permis de réaliser une refonte sans cris et sans larmes.

Démystifions les pratiques du Software craftsmanship !

Vous êtes-vous déjà senti·e bête devant quelqu'un qui parlait d’une pratique comme l'Hexagonale architecture ou le Test Driven Development ?

Avez-vous déjà entendu une phrase comme "Si vous ne faites pas de TDD, vous êtes un·e mauvais·e développeur·euse !" ?

Toutes ces questions, je me les suis posées pendant longtemps, j'ai ressenti ce poids, et aujourd'hui en tant que mentor, je le ressens aussi qui pèse sur les futur·e·s développeur·euse·s.

Alors ensemble, j'ai envie que l'on casse les codes, que l'on parle de gatekeeping, que l'on se pose quelques instants ensemble pour comprendre l'essence du Craft et d'en démystifier les pratiques. Si comme moi, vous ressentez le poids du dogme autour du Software Craftsmanship et que vous en avez marre, ce talk devrait vous plaire !

Monades : paradigme unique pour la programmation (a)synchrone

La programmation asynchrone se fait de plus en plus présente grâce aux Fibers mais, actuellement, passer de la programmation synchrone à asynchrone demande un changement important de la façon de programmer nos applications. Or passer à l'asynchrone est un besoin technique de performance et ne devrait avoir qu'un impact minimum sur nos applications (au même titre qu'ajouter du cache). Et à ce titre cela devrait être de la responsabilité des abstractions de gérer ça correctement, et non aux devs de savoir comment gérer l'asynchrone au mieux.

La programmation fonctionnelle avec le pattern Monad nous permet d'avoir un paradigme unique de programmer qui permet de passer du synchrone à l'asynchrone de manière transparente.

Cette conférence présentera des cas d'usage pour montrer concrètement d'un point de vue utilisateur comment cela est possible.

Tirer parti du composant ExpressionLanguage de Symfony, laissez les utilisateurs finaux être créatifs !

Le composant ExpressionLanguage de Symfony est un composant non seulement ancien mais aussi très utile. Et pour cause, beaucoup de fameux projets - comme OroCRM, Sylius, ou Symfony lui-même - s'en servent.

Cette sandbox PHP est la plupart du temps utilisée pour paramétrer une application tout en permettant une configuration avec une logique complexe. Cependant, ce composant peut aussi être utilisé comme un moteur de règles métier. En effet, en utilisant ce composant de cette manière, il est possible de laisser les utilisateurs finaux écrire de la configuration d'une manière à la fois compréhensible, sécurisée et dynamique.

Or, ce point est très intéressant, et c'est ce que nous voulons présenter.

Durant ce talk, nous redécouvrirons l'ExpressionLanguage en ayant un aperçu de la manière classique dont il est utilisé. Puis, au travers d'un exemple concret, nous révélerons le potentiel réel de ce composant. Nous nous placerons dans un contexte e-commerce, et créerons un système permettant à des administrateurs d'écrire des règles métier pour appliquer des promotions de manière dynamique.

À la fin du talk, nous saurons utiliser le composant ExpressionLanguage de manière à déléguer la gestion de règles métier aux utilisateurs finaux.

Les instruments des devs augmenté·e·s

"Nous sommes en l'an 2023… une développeuse ouvre son IDE, elle commence à taper pour signaler son intention, et le code s'écrit tout seul…"

Franchement on m'aurait dit ça il y a 10 ans je n'y aurais pas cru, mais à l'époque on débuguait encore des sites sous IE6. Aujourd'hui pour avoir utilisé Github Copilot depuis la version beta, je peux vous dire sans mentir que j'aurais beaucoup de mal à revenir en arrière, comme de repasser de Cypress à Selenium.

Des cartes perforées à la réalité virtuelle : les innovations arrivent vite, de plus en plus vite, mais ce n'est pas nouveau, sous les projecteurs comme Github Copilot, mais aussi plein de petits outils plus discrets qui améliorent notre quotidien, et vous êtes surement passé·e à côté de certains d'entre eux.

Je vous propose de faire le tour de quelques trouvailles que l'on utilise et qui ont amélioré, un peu ou beaucoup, ce qu'on appelle la DX, ou "Developer Experience".

Et dans un futur proche, on pourra faire du "pair programmind", directement de cerveau à cerveau.

Mentors : super-héros ou super-vilains ?

Développeuse junior, j’ai eu du mal à trouver ma place et faire mes preuves. Étudiante, vous m’aviez dit : “Deviens PO ou chef de projet !”. Je ne voulais pas d’un métier fonctionnel. Je me suis fixée un but, réussir là où vous, profs et maîtres de stage, ne vouliez pas que j’aille.

Des rencontres, cauchemardesques comme merveilleuses, tout au long de mon apprentissage, m’ont aidée à confirmer mon choix professionnel : être développeuse !

Comment mes mentors m’ont-ils guidée? Je partagerai des actions et des comportements qui m’ont incitée à lutter pour atteindre mes objectifs. Vous aussi, vous avez le pouvoir de changer une vie !

Transformer efficacement du JSON en structure PHP fortement typée

Dans un monde PHP où l'adoption d'un typage fort est de plus en plus fréquente, les outils autour de ce typage se multiplient ; on retrouve notamment des analyseurs statiques comme PHPStan et Psalm, qui améliorent la robustesse de nos applications.

Mais qu'en est-il des données qui proviennent de l'extérieur lors du runtime, qui ne peuvent pas être analysées de manière statique ? Par exemple, il est important de valider la structure d'une requête JSON avant de l'utiliser dans l'application ; cependant, traiter chaque valeur manuellement devient vite rébarbatif.

Découvrons Valinor, une bibliothèque (made in Lyon !) qui permet de valider et transformer facilement n'importe quelle source en une structure fortement typée. Generics, shaped arrays, integer range et bien d'autres : si vous connaissez ces types avancés de PHPStan et Psalm, vous découvrirez comment en tirer parti au runtime.

Le Zéro Downtime Deployment en pratique

Le Zéro Downtime Deployment, appelé communément ZDD, est une pratique permettant de faire des mises en production sans interruption du système ni de maintenance programmée : finies les MEP à 7h00 du matin ou durant la pause déjeuner !

La mise en place du ZDD permet de déployer tous les jours sereinement sans interruption et à n'importe quel moment de la journée.

Dans ce talk je vous propose un retour d'expérience sur cette pratique, les cas pratiques et les pièges à éviter afin de pouvoir mettre en production sereinement.

Que vous changiez votre schéma de base de données, modifiez vos consumer asynchrones ou vos contrats d'APIs, je vous propose de voir comment nous faisons concrètement côté code applicatif pour déployer à toute heure sans casser la prod.

Le travail invisible en entreprise : le cas du glue work

Le glue work est une notion popularisée récemment et qui repose sur la constatation que certains types de tâches, qui ne sont pas du développement pur, sont insuffisamment valorisés dans notre univers professionnel. Le glue work est pourtant essentiel pour ‘lier’ une équipe, la rendre réactive, soudée, plus productive, d’où le nom de ‘glue’ pour 'colle'.

La personne faisant beaucoup de glue work peut être cette personne qui a à coeur de maintenir à jour la documentation d’un projet, les process et outils de l’équipe, qui va prendre de son temps pour onboarder et répondre aux questions des nouveaux et nouvelles. Elle peut aussi organiser des temps informels pour créer du lien dans l’équipe, tout comme systématiquement rédiger et diffuser des comptes-rendus après des réunions.

Je ferai un parallèle et une comparaison avec les notions plus anciennes, mais néanmoins proches et riches, que sont travail invisible et travail du care, en général travail réservé aux femmes.

Vous comprendrez que cette conférence sera aussi un manifeste pour une meilleure intégration et valorisation des femmes et des tâches qu’elles doivent bien souvent faire de façon plus importantes que leurs collègues masculins, volontairement ou non.

Après cette conférence, j’espère que vous aurez des outils pour identifier plus facilement quelles personnes font du glue work dans votre entreprise, et ce que vous pouvez faire pour vous partager plus égalitairement ces tâches, tout en les valorisant davantage

Keynote d'ouverture

Bienvenue à l'AFUP Day 2023 Lyon, pour le retour de l'événement en ville !

Keynote de clôture

Rendez-vous lors de nos prochains meetups, et bien sûr au Forum PHP 2023 !

En poursuivant votre navigation sur ce site, vous acceptez l’utilisation des cookies pour améliorer votre navigation. plus d'infos

1. Qu’est-ce qu’un cookie?

Un Cookie est un petit fichier texte enregistré sur votre terminal (ordinateur, tablette, smartphone, etc.), à l’occasion de la consultation d’un service en ligne grâce à votre logiciel de navigation. Il permet à son émetteur d’identifier le terminal dans lequel il est enregistré, pendant la durée de validité ou d’enregistrement du Cookie. Lors de la consultation de notre site Internet, des informations relatives à la navigation de votre terminal sont susceptibles d'être enregistrées dans ces fichiers dits "Cookies". Ces derniers sont installés sur votre terminal, sous réserve des choix que vous auriez exprimés concernant les Cookies et que vous pouvez modifier à tout moment.

2. A quoi servent les cookies émis sur notre site ?

Seul l’émetteur d’un cookie est susceptible de lire ou de modifier les informations qui y sont contenues.
Les cookies utilisés sur notre site permettent :

3. Vos choix concernant les cookies

Vous disposez de différents moyens pour gérer les cookies. Tout paramétrage que vous pouvez entreprendre sera susceptible de modifier votre navigation sur notre site et sur Internet en général et vos conditions d'accès à certains services de notre site nécessitant l'utilisation de cookies. Vous pouvez à tout moment exprimer et modifier vos souhaits en matière de cookies, par les moyens décrits ci-dessous. L'accord sur les cookies L'enregistrement d'un cookie dans un terminal est essentiellement subordonné à la volonté de l'utilisateur du terminal, que celui-ci peut exprimer et modifier à tout moment et gratuitement à travers les choix qui lui sont offerts par son logiciel de navigation. Si vous avez accepté dans votre logiciel de navigation l'enregistrement de cookies dans votre terminal, les cookies intégrés dans les pages et contenus que vous avez consultés pourront être stockés temporairement dans un espace dédié de votre terminal. Ils y seront lisibles uniquement par leur émetteur.

Le refus des cookies Si vous refusez l'enregistrement de cookies dans votre terminal, ou si vous supprimez ceux qui y sont enregistrés, vous ne pourrez plus bénéficier d'un certain nombre de fonctionnalités qui sont néanmoins nécessaires pour naviguer dans certains espaces de notre site. Tel serait le cas si vous tentiez d'accéder à votre compte ou à votre abonnement qui nécessite de vous identifier. Tel serait également le cas lorsque nous, ou nos prestataires, ne pourrions pas reconnaître, à des fins de compatibilité technique, le type de navigateur utilisé par votre terminal, ses paramètres de langue et d'affichage ou le pays depuis lequel votre terminal semble connecté à Internet. Le cas échéant, nous déclinons toute responsabilité pour les conséquences liées au fonctionnement dégradé de nos services résultant de l'impossibilité pour nous d'enregistrer ou de consulter les cookies nécessaires à leur fonctionnement et que vous auriez refusés ou supprimés. Les choix offerts par votre logiciel de navigation Vous pouvez configurer votre logiciel de navigation de manière à ce que des cookies soient enregistrés dans votre terminal ou, au contraire, qu'ils soient rejetés, soit systématiquement, soit selon leur émetteur. Vous pouvez également configurer votre logiciel de navigation de manière à ce que l'acceptation ou le refus des cookies vous soient proposés ponctuellement, avant qu'un cookie soit susceptible d'être enregistré dans votre terminal. Pour la gestion des cookies et de vos choix, la configuration de chaque navigateur est différente. Elle est décrite dans le menu d'aide de votre navigateur, qui vous permettra de savoir de quelle manière modifier vos souhaits en matière de cookies. Selon votre navigateur, consultez le lien ci-dessous pour configurer votre navigateur et refuser les cookies :