Si vous lisez ce fichier, c'est que vous pensez pouvoir nous aider d’une manière ou d’une autre, et nous vous en remercions d'ores et déjà ! :)
Notre objectif est évidemment d’élargir l’étendue des aides simulées en une seule fois. Pour dépasser la limite de nos ressources, nous cherchons à ouvrir au maximum cet outil à la contribution. Ainsi, tout le code du moteur de calcul comme de l’interface utilisateur est sous licence libre, et toute forme de contribution peut aider à l’intégration de nouvelles aides : recherche législative préalable et rédaction des règles à implémenter, ajout de tests pour valider le calcul de prestations…
Pour suggérer l'ajout d'aides supplémentaires, créez une issue pour chacune d'entre elles, avec la référence la plus officielle possible vers le descriptif de l'aide. Nous cherchons les conditions d'attributions et les modalités de calcul.
Pour faciliter le suivi des demandes, chaque aide demandée est représentée par une issue identifiée par le tag « nouvelle aide », afin que toute personne se sentant concernée puisse appuyer la demande, et en suivre l'évolution.
Par souci de lisibilité pour les partenaires, notamment administratifs, la langue utilisée pour la description et le suivi de fonctionnalités est le français.
En revanche, pour éviter le coût du changement de contexte, les discussions techniques peuvent se faire en anglais, la langue la plus utilisée dans le cadre du développement logiciel.
Toutes les évolutions de l'outil, espérées, planifiées ou réalisées, sont représentées par des issues GitHub. L'ensemble des issues sur tous les dépôts composant les différents modules de l'application mes-aides est donc la seule source de vérité sur ses évolutions.
L'état d'avancement de la fonctionnalité représentée par l'issue est donné par un tag.
Pour faciliter la lecture du processus et regrouper les issues ouvertes sur tous les différents dépôts, nous utilisons Waffle.
Le passage d'une étape du processus est rendu possible par la validation des conditions suivantes.
Décision informelle sur la base de l'analyse des besoins des usagers, des partenaires, des opportunités et contraintes techniques.
- Validation de la définition de l'issue par le demandeur.
- Validation de la définition de l'issue par l'équipe technique.
- Création d'un test invalide (selon la modalité la plus indiquée : unitaire pour l'API, via Ludwig pour une prestation, d'intégration pour l'interface…).
- Passage du (ou des) test(s) associé(s) à la définition.
- Aucune régression n'est détectée par les tests.
- Pour les forks de dépôts externes (notamment OpenFisca), une pull request proposant nos modifications a été ouverte.
- Une revue de code a été faite sur les modifications.
- Aucune régression n'est détectée sur les tests applicables en production (Ludwig, test d'intégration pour le moment manuel).
- Le wiki a été mis à jour pour notifier de l'implémentation.
- Si la fonctionnalité touche les utilisateurs, un tweet l'a annoncée.
Vous êtes un organisme liquidateur ? Lisez plutôt comment intégrer une nouvelle aide dans Mes Aides. La documentation ci-dessous est technique.
- Décrire l'organisme liquidateur et l'aide à ajouter dans
app/js/constants/droits.js
(voir plus bas). - Copier ces informations dans
lib/config/ludwig.js
du modulemes-aides-api
. - Décrire le type de données dans
lib/simulation/openfisca/prestations.js
du modulemes-aides-api
. - Mettre à jour les données de réponse attendue dans
test/openfisca/mapping/reverse.coffee
du modulemes-aides-api
. - Coder l'aide dans OpenFisca.
Une aide est décrite dans app/js/constants/droits.js
par les champs suivants :
label
: nom de l'aide. Utiliser le plus officiel possible, sinon, celui validé par l'organisme ; attention aux majuscules.shortLabel
: acronyme de l'aide. Bien vérifier les majuscules et les minuscules.description
: présentation des objectifs et enjeux de l'aide. Entre 280 et 420 caractères (entre 2 et 3 tweets) ; la description commence par le nom de l'aide en sujet d'une phrase active ; ne pas citer Mes Aides ; préférer la 3e personne ; neutralité de genre.link
: URL d'une description de l'aide. Préférer un lien versservice-public.fr
pour la stabilité. À défaut, vers le site officiel de l'organisme attributeur.
Et l'un des champs suivants :
form
: URL d'un formulaire téléchargeable et imprimable. Préférer un lien versservice-public.fr
pour la stabilité. À défaut, vers le site officiel de l'organisme attributeur.teleservice
: URL d'un téléservice permettant la demande de l'aide.
Tous ces champs sont obligatoires.