Le LowCode a son dossier complet dans « programmez » ! [NDLR : Cette tribune a, à l’origine été rédigée pour le magazine] Doit-on parler d’ironie, de simple curiosité, ou observe-t-on les prémisses d’un véritable changement de mentalité dans le monde de l’IT ? De mon côté, qui manque sûrement un peu d’objectivité, j’aurai tendance à pencher pour la dernière solution, car même si le chemin est encore long, nous assistons à d’importantes évolutions, que ce soit auprès des directions IT, que des métiers.

Dans un monde où tout doit toujours aller plus vite, où les utilisateurs souhaitent être de plus en plus autonomes pour des raisons d’agilité et de flexibilité, les promesses des plateformes lowcode résonnent favorablement. Cependant, (loin de moi les généralités) les développeurs professionnels ont tendance à conspuer ces outils et plateformes pour des raisons qui ont pu être réelles à un moment passé, mais qui méritent actualisation et une pincée d’objectivité ! Donc tentons de démystifier l’usage de telles plateformes et de mettre fin à quelques préjugés qui ont la dent dure ! Tâche sûrement un peu rude que je vais tenter de relever.

Enterprise Class Application

J’ai souvent entendu : « le lowcode, ce n’est pas fait pour mettre en place des applications critiques », « c’est très bien pour le maquettage, mais pas plus », « nous on doit délivrer du web desktop et du mobile natif ! ».

Si on peut entendre ces remarques pour des plateformes NoCode, je m’inscris complètement en faux pour des plateformes LowCode dont le terrain de jeu est vraiment les applications critiques, innovantes et pourquoi pas customer facing. Les cas clients doivent parler d’eux-mêmes et montrent l’étendue des possibles et la variété des applications envisageables peu importe les domaines fonctionnels (applications RH, finance, métier, industrie…), les types d’applications (innovantes, de modernisation du legacy, d’efficacité opérationnelle ou de digitalisation de l’UX) ou les usages (Web Desktop, mobile natif ou hybride – PWA).

Les outils LowCode permettent de personnaliser fortement les applications et de les tuner finement afin de les intégrer dans un existant applicatif, et de répondre à des contraintes tangibles, sans pour autant économiser sur les bénéfices de rapidité de mise en place.

Techniquement, les plateformes LowCode n’imposent rien et l’intégration avec des briques existantes est proposée, aussi bien d’un point de vue organisation, que gouvernance ou sécurité. En revanche elles fournissent nativement des outils pour les clients qui ne sont pas équipés ou partiellement (gestionnaire de sources, de build, de suivi projet). Ce, afin de coller au plus près aux contraintes fortes qui peuvent être imposées par les clients, de s’inscrire dans des pratiques DevOps standard, et autoriser une chaîne d’intégration et de livraison continue.

Gestion des sources avec Mendix

Capacités techniques et rapidité de delivery

« Je ne peux pas faire exactement ce que je veux », « je vais être limité et contraint » et « je me suis construit un framework de dev qui me permet d’être très rapide ».

Une partie de la boîte à outils d'intégration et d'injection de code du concepteur

On ne peut pas nier que les plateformes LowCode vont imposer un cadre mais elles font preuve d’ouverture avec la possibilité d’invoquer des services de tout type à tout moment, d’injecter du code serveur ou client, de créer des extensions pour des intégrations ou pour de la présentation… on ne sera donc jamais limité (ci-contre : la boîte à outils d’actions Mendix). Alors certes, si je dois injecter du code en permanence, je perds l’intérêt d’une telle plateforme… mais sincèrement, en de nombreuses années d’expérience (nombre que je tairai par pure coquetterie), je n’ai jamais été confronté à un tel besoin par un client.

Supposons qu’il soit nécessaire d’injecter du code sur chacune des pages de mon application. Une plateforme LowCode va (doit) me permettre de créer aisément un modèle de page qui embarque ce besoin afin que je puisse l’industrialiser et le réutiliser dans mes projets suivants sans avoir à faire à nouveau cet effort… Les concepts de la programmation objet sont donc repris en force et étendus au sein d’une telle plateforme.

Quant à la rapidité d’implémentation, si vous avez commencé à développer un framework d’accélération, c’est que vous êtes dans une dynamique LowCode. Les plateformes LowCode vont avoir l’avantage de reposer sur un historique et une R&D plus conséquents, il y a donc des chances qu’elles aient quelques longueurs d’avance sur vous. Et de prime abord, un développeur professionnel aura également tendance à sous-estimer la charge liée à de nombreuses fonctionnalités annexes qui composent toute application (interfaces d’administration fonctionnelle, gestion des traces, des permissions, les relances…).

La gouvernance des données

« Je n’ai aucune maîtrise sur mes données ».

Sujet sensible et critique pour les outils LowCode en mode SaaS et qui mérite des précisions. La question ne se pose pas lorsque la plateforme ou les applications sont déployées on-premise. Cependant peu importe le mode de déploiement, un outil LowCode proposera toujours le choix dans le système qui persistera les données métier.

Par défaut, les données métier vont être hébergées au sein de la base de données sous-jacente au fonctionnement de la plateforme (et donc en ligne), mais le concepteur, grâce aux différents connecteurs pourra décider d’externaliser cet enregistrement vers des systèmes de gestion de données dont vous êtes complètement administrateur. Cela peut se faire grâce à des webservices si votre système en expose ou au travers de connecteurs SGBD via des intégrations SQL directes. Dans un souci de gouvernance, l’outil de conception va proposer des visualisations graphiques des connexions et usages des différentes sources.

Le datahub, outil (entre-autres) de gouvernance des données utilisées

Si d’un point de vue architecture applicative, on ne souhaite pas multiplier les systèmes de gestion de données et profiter de cet espace de stockage inclus avec la plateforme, les données persistées dans cette base sous-jacente sont nativement cryptées au repos et en transit ; et pour des données hyper sensibles, le concepteur peut même appliquer ses propres clés d’encryptage avant leur sauvegarde.

N’oublions pas également qu’une plateforme LowCode se doit de laisser la propriété intellectuelle des applications et des données à ses clients et devra donc leur fournir des outils qui permettent de les extraire quand ils le souhaitent.

Réversibilité et verrouillage fournisseur

« Une fois que j’ai mis le pieds dans la plateforme LowCode, je suis bloqué et ne peux plus en changer ».

Soyons réalistes, on ne peut pas nier qu’il y a du vrai dans cette affirmation, mais elle est à nuancer. Une bonne plateforme de LowCode doit proposer des options de sortie à son client, et cela peut se situer à plusieurs niveaux.  

Tout d’abord, le besoin de réversibilité n’est pas toujours lié à l’outils en tant que tel mais peut-être lié à l’hébergement des applications. Une organisation peut éprouver le besoin de basculer tout ce qui est hébergé dans un cloud public vers un autre « hébergeur ». Une plateforme LowCode Cloud Native est intrinsèquement prête à cela, car elle n’est pas liée à un seul est unique fournisseur cloud. Elle permettra donc la bascule d’un type de hosting à l’autre (qu’il s’agisse de cloud public ou de cloud privé ou de cloud virtuel) de manière très simple grâce à son architecture conteneurisée.

Ensuite, il peut bien évidemment s’agir de changer d’outil, dans ce cas-là, une telle plateforme doit proposer des outils qui vont permettre d’extraire les modélisations, des classes et les données afin de pouvoir les ré-importer dans un autre outil. Ce n’est pas magique non plus, les développements récupérés nécessiteront sûrement une phase de compréhension et surement d’adaptation, mais cela a le mérite d’être mis à disposition.

Ensuite, il peut bien évidemment s’agir de changer d’outil, dans ce cas-là, une telle plateforme doit proposer des outils qui vont permettre d’extraire les modélisations, des classes et les données afin de pouvoir les ré-importer dans un autre outil. Ce n’est pas magique non plus, les développements récupérés nécessiteront sûrement une phase de compréhension et vraisemblablement d’adaptation, mais cela a le mérite d’être mis à disposition.

Cependant, n’oublions pas que le challenge attaché à la réversibilité n’est pas lié aux plateformes LowCode, c’est le cas pour tout, et je ne parle pas que d’outils. Une application développée avec un framework datant de quelques années, lorsqu’elle aura droit à son refactoring…. Il y a de grandes chances que l’équipe de développement préfère repartir de 0, d’un point de vue technique j’entends (car les connaissances fonctionnelles resteront acquises, ce qui est également vrai pour les plateformes LowCode).

Plus besoin des services IT

« Avec le LowCode, les services IT ne serviront plus à rien, je vais faire quoi ? »

L’objection est ici différente car on est conscient de la valeur et de l’intérêt d’une plateforme LowCode, mais si nous n’avons plus besoins d’être développeur professionnel pour mettre en place des applications d’entreprise, que vont faire ces derniers ?

Dans un premier temps, il est important de noter que les services IT conservent toute leur importance. Il y aura besoin de leurs compétences sur les parties les plus techniques d’une application (l’intégration avec un nouvel outil, la création d’une extension…). Cela leur permet donc de se concentrer sur des tâches à fort intérêt technique.

Studio, l’un des outils de conception Mendix

Ensuite, la tendance est à la croissance exponentielle des besoins métier et à leur évolution permanente. En permettant à des concepteurs moins expérimentés de participer à la création d’applications d’entreprise et en accélérant la livraison, cela permet aussi de mettre fin aux goulets d’étranglement des ressources IT et de palier à la pénurie de ces profils sur le marché.

Enfin, n’oublions pas que ces plateformes permettent à des équipes aux profils différents de communiquer autour d’un même univers. Cela permet donc de fluidifier les échanges, de se rapprocher d’un langage commun… et la réconciliation métier/IT n’a pas de prix.

Conclusion

L’évolution des langages de programmation

Et si le LowCode n’était pas, tout simplement, un nouveau standard de développement. La jeune histoire des langages de programmation a été le réceptacle de nombreuses (r)évolutions, de la carte perforée, au langage objet, en passant par le binaire, l’assembleur et les langages procéduraux… le LowCode ou la programmation « graphique » n’en serait-il pas la prochaine étape ? Les arguments en faveur des passages de l’une à l’autre de ces évolutions ont toujours été : abstraction plus forte, compréhension plus aisée, environnements plus accessibles, démocratisation du processus de développement et amélioration de la rapidité de mise en place… Vous remarquez ? Nous sommes en plein dedans avec le LowCode.

L’implémentation graphique d’une fonction Mendix (à droite… à gauche son équivalent procédural)

Laisser un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *

Ce site utilise Akismet pour réduire les indésirables. En savoir plus sur comment les données de vos commentaires sont utilisées.