====== Kresus ======
Attention, copier-coller : [[Kresus|https://kresus.org/fr/]] est un gestionnaire de finances personnelles gratuit et libre qui tourne sur votre serveur. Il récupère automatiquement et quotidiennement toutes vos nouvelles transactions bancaires et vous permet de les catégoriser, étudier via des graphiques, et établir un budget.
Pour se connecter à votre compte et récupérer les opérations bancaires, il utilise le logiciel Woob.
Le gros avantage de Kresus comparé au site de votre banque, c'est qu'il permet de conserver tout l'historique de votre compte (là où les sites de banques ne gardent que 2 ou 3 mois), permet de créer des catégories de dépenses (courses, essences, travaux, EDF, crédit, etc), de les attribuer automatiquement et de centraliser tous vos comptes en un seul site si vous avez des comptes dans plusieurs banques.
Le gros inconvénient c'est que Kresus a besoin de l'identifiant et du mot passe d'accès au site de la banque pour pouvoir fonctionner. Et les deux sont stockés dans la base de données avec le cookie de double authentification de session. Si par malheur une personne malveillante arrive à accéder à la base PostgreSQL de Kresus, il a tout ce qu'il lui faut pour accéder à votre compte en banque.
Vous êtes prévenus.
===== Installation des dépendances =====
Vous allez avoir besoin de plusieurs logiciels pour l'installation :
sudo aptitude install git npm postgresql python3 python3-pdfminer
===== Installation de Kresus =====
On va créer un utilisateur qui exécutera Kresus :
sudo useradd -m kresus
Connectez vous avec cet utilisateur :
sudo -i -u kresus
Lancez l'installation :
npm install --prefix /home/kresus/ kresus
===== Installation de Woob =====
Woob est plus simple à installer. Toujours avec l'utilisateur kresus, lancez la commande suivante :
pip install --user woob
===== Création de la base de données =====
Kresus a besoin d'une base de données Postgresql pour fonctionner.
Connectez-vous avec l'utilisateur postgres :
sudo -i -u postgres
Lancez PostgreSQL :
psql
Créez l'utilisateur :
CREATE ROLE kresus LOGIN PASSWORD 'mot_de_passe';
Créez la base de données :
CREATE DATABASE kresus OWNER kresus;
Quittez PostgreSQL :
exit
Déconnectez-vous de l'utilisateur postgres :
exit
===== Configuration de Kresus =====
Dans le dossier d'installation, vous trouverez un fichier config.ini.
Vous devez modifier, si besoin :
* la ligne "datadir" pour indiquer l'emplacement du dossier data (/home/kresus/database)
* la partie [email] si vous souhaitez activer les alarmes par mail
* la partie [db] pour indiquer les informations de connexion à la base (adresse, nom utilisateur, mot de passe, etc)
===== Configuration d’Apache2 =====
Créez le fichier
/etc/apache2/sites-available/kresus.domaine.fr.conf
Remplacez domaine.fr par votre nom de domaine
Collez les lignes suivantes dedans (en remplaçant de nouveau domaine.fr par votre nom de domaine)
ServerName kresus.domaine.fr
Redirect / https://kresus.domaine.fr/
ServerName kresus.domaine.fr
LogLevel warn
CustomLog ${APACHE_LOG_DIR}/kresus.access.log combined
ErrorLog ${APACHE_LOG_DIR}/kresus.error.log
SSLEngine on
SSLCertificateFile /etc/letsencrypt/live/domaine.fr/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/domaine.fr/privkey.pem
ProxyPass / http://localhost:9876/
ProxyPassReverse http://localhost:9876/
AuthType Digest
AuthName "Kresus"
AuthDigestDomain /home/kresus/kresus/ https://kresus.domaine.fr
AuthDigestProvider file
AuthUserFile /etc/apache2/passwords
Require valid-user
SetEnv R_ENV "/home/kresus/kresus"
Créez le mot de passe d'accès à Kresus (remplacez nomutilisateur) :
sudo htdigest /etc/apache2/passwords Kresus nomutilisateur
Activez le fichier de conf Apache
a2ensite kresus.nomdedomaine.fr.conf
Redémarrez Apache
systemctl restart apache2
===== Lancement de Kresus via Systemd =====
Créez le fichier
/etc/systemd/system/kresus.service
Copiez les lignes suivantes dedans
[Unit]
Description=Personal finance manager
After=network.target postgresql.service
[Service]
WorkingDirectory=/home/kresus/
Environment=NODE_ENV=production
ExecStartPre=/bin/sleep 60
ExecStart=/home/kresus/node_modules/kresus/bin/kresus.js --config /home/kresus/config.ini
Type=simple
Restart=always
User=kresus
StandardOutput=journal
StandardError=inherit
SyslogIdentifier=kresus
[Install]
WantedBy=multi-user.target
Activez le service au démarrage
sudo systemctl enable kresus.service
Démarrez le service
sudo systemctl start kresus.service
Vous pouvez maintenant accéder à Kresus à l'adresse kresus.domaine.fr
===== Mise à jour =====
Lorsqu'une nouvelle version sort, pour mettre à jour Kresus, il vous suffit de relancer les étapes d'installation.
Connectez vous avec l'utilisateur kresus :
sudo -i -u kresus
Lancez l'installation :
npm install --prefix /home/kresus/ kresus
S'il ne vous installe pas la dernière version disponible (voir [[https://www.npmjs.com/package/kresus|ici]] pour les versions), lancez la commande en ajoutant le numéro de la dernière version. Exemple avec la version 0.19.0 :
npm install --prefix /home/kresus/ kresus@0.19.0