Kresus

Kresus: version 0.8.0

Je viens de publier une nouvelle version de Kresus, le gestionnaire de finances personnelles open-source sur lequel je travaille. Pour rappel, cette application, basée sur Weboob, est disponible dans CozyCloud et vous permet de vous connecter à votre compte bancaire, récupérer vos opérations et les classifier pour savoir où votre argent passe.

Action requise pour les auto-hébergés : installation de Weboob

Avant de passer à la liste détaillée des changements, il y a une procédure de migration qui nécessitera une action de votre part, si vous êtes auto-hébergés (c'est-à-dire si vous n'utilisez pas d'instance bêta sur l'infrastructure de CozyCloud). Si vous êtes utilisateur de l'infrastructure de CozyCloud, le changement devrait avoir été effectué par l'équipe des administrateurs systèmes de Cozy, et vous pouvez passer à la partie suivante.

Si vous êtes auto-hébergés, il vous faudra installer Weboob par vos propres moyens et vous assurer que l'utilisateur qui lance le processus de Kresus ait accès à Weboob. J'ai personnellement effectué une installation globale. Je recommande d'installer la version 1.1 ou supérieure de Weboob, pour être certain que les modules des sites ne soient pas dépassés.

Si vous utilisez l'application cozy_management, il existe maintenant une commande permettant d'effectuer l'installation globale de Weboob telle qu'elle est nécessaire pour que Kresus fonctionne sur votre machine :

cozy_management install_weboob

Un grand merci à nicofrand pour cette fonctionnalité !

Auparavant, Weboob, le système qui se connecte à votre banque pour récupérer la liste des comptes et opérations, était installé par Kresus et cela nécessitait des dépendences externes. Il a été décidé que Weboob devait désormais être installé au préalable par l'administrateur système : Kresus n'essaiera plus de l'installer. Cela simplifie beaucoup de choses, notamment en facilitant la gestion des dépendences nécessaires lors de l'installation.

La version courte

Pour cette version, beaucoup de changements peu visibles pour l'utilisateur : c'est beaucoup de nettoyage et de changements structurels dans le code (séparation du code client en composants logiques et lint complet), qui devraient faciliter la maintenance et l'amélioration du code par le futur. Aussi, beaucoup de problèmes relatifs à la détection des doublons et à la synchronisation automatique des comptes ont été réglés.

Un changement visible et notable : la liste des opérations est désormais beaucoup plus fluide lors du scroll, même si vous avez des tonnes d'opérations.

En cas de problèmes de balances

Si vous rencontrez des problèmes de synchronisation entre Kresus et votre banque, par exemple si Kresus affiche des soldes de comptes qui ne correspondent pas aux montants indiqués sur le site de votre banque, il est conseillé de vérifier les doublons dans la section correspondante et d'essayer de les fusionner à la main.

Si malgré la détection de doublons, vous avez encore des problèmes de montant, laissez un message sur le fil associé du forum de Cozy ! J'aimerais expérimenter des méthodes plus agressives de détection automatique de doublons, et cela nécessite de savoir quelles sont les situations qui posent fréquemment problème.

Les contributions en détail

Un grand merci aux 7 contributeurs de cette nouvelle version, pour un total de 108 commits !

  • @AwYiss, qui avait déjà grandement amélioré l'interface utilisateur, a frappé de nouveau, en intégrant les préférences au niveau design, rendant cette partie plus consistente avec le reste de l'application et très élégante.
  • @nicofrand a corrigé des soucis de style (CSS) lors de l'ajout manuel d'opération.
  • Bezleputh (de la communauté Weboob) a corrigé un bogue qui empêchait l'import d'opérations, si celles-ci présentaient des informations manquantes.
  • @brouberol a ajouté un Dockerfile (ou RecetteÀMarcel pour les puristes de l'OS souverain) afin de pouvoir tester Kresus rapidement en production. J'espère pouvoir écrire un peu plus sur le sujet bientôt.
  • @PandiPanda69 a effectué une revue du code avec la sécurité à l'esprit :
    • Correction de bogue : lors de l'import d'une instance, si le fichier JSON contient des erreurs de syntaxe, ne pas essayer de l'importer.
    • Ajout de la possibilité de chiffrer l'export de son instance Kresus et d'importer une instance chiffrée de Kresus. Avec cette nouvelle méthode d'import, le mot de passe peut être inclus dans le fichier exporté, en toute sécurité ! (cette fonctionnalité n'est pas encore activée car elle nécessite une réflexion et des tests approfondis ainsi qu'une implémentation côté interface)
  • @ZeHiro:
    • Amélioration de la visualisation de la liste des opérations sur interface mobile (en lecture seule pour le moment).
    • Amélioration sensible des traductions : les notifications et textes des emails sont désormais traduits en français ou en anglais, selon la langue choisie dans votre Cozy !
    • Utilisation de la vraie monnaie du compte, avec le symbole monétaire associé, dans toute l'interface utilisateur.
    • Amélioration de la détection manuelle des doublons (deux opérations sont considérées comme des doublons seulement si leurs types sont identiques).
    • Suppression de faux positifs dans la détection automatique des doublons (deux opérations avec la même date, le même montant et le même libellé).
    • Si votre mot de passe expire, Kresus vous enverra désormais un mail une et une seule fois pour vous le signaler, et n'importera plus d'opérations automatiquement jusqu'à la mise à jour du mot de passe (le même comportement est prévu si le mot de passe devient erroné, s'il n'est pas mis à jour dans Kresus).
    • Ajout de la possibilité de supprimer une opération manuellement. N'utilisez cette fonctionnalité qu'en dernier recours et seulement si la détection de doublons n'a pas marché !
    • Fix spécifique à un problème spécifique de plateforme sous raspberry pi.
  • De manière notable, ZeHiro et moi-même avons contribué ensemble à des fonctionnalités majeures :
    • Grâce à une implémentation de l'infinite scrolling dans la liste des opérations, celle-ci est bien plus fluide à s'afficher, même si vous avez beaucoup d'opérations !
    • Découpage du code en modules logiques et refactoring pour que le code client passe le lint (validation statique du style du code). Ce n'est pas visible pour l'utilisateur, mais ça aide grandement les développeurs en leur évitant de se poser plein de questions futiles sur le style du code.
  • votre serviteur:
    • utilisation de Weboob au niveau global (voir paragraphe sur la procédure de migration).
    • meilleure représentation des erreurs. Normalement, les erreurs devraient être plus claires à comprendre, côté client comme ou dans les logs côté serveur, grâce à une meilleure cohérence et à des logs plus détaillés et facultatifs. Un mode de debugging pour Weboob a été également rajouté, ce qui est très utile en cas de problèmes de synchronisation avec votre banque, pour remonter des logs aux développeurs de Weboob !
    • la récupération automatique des opérations ne s'arrête plus en cas d'échec. Si les opérations n'étaient plus récupérées automatiquement toutes les nuits chez vous, c'était peut-être à cause de ce bug.
    • les graphiques des opérations en valeurs négatives pointent désormais vers le haut et non plus vers le bas.

Le mot de la fin

La prochaine version est déjà presque prête et comprend une réécriture presque complète du client avec une autre technologie (redux). Après cette réécriture, on devrait plus facilement pouvoir ajouter de nouveau des grosses fonctionnalités !

Comme d'habitude, si vous avez des remarques ou suggestions, n'hésitez-pas à me le faire savoir, par twitter, sur diaspora ou sur le forum de cozy !