==================================== Gestion des adhésions de Nos oignons ==================================== Voici une collection de scripts et de bouts de code qui permettent de gérer les adhésions de Nos oignons conformément aux statuts de l'association. Base des membres ================ La base des membres est pensée pour être stockés dans le wiki du conseil d'administration. Elle est formée sous forme d'une série de pages, une par membre. Cela donne l'aboresence suivante : Membres ├── 000000.mdwn ├── 000001.mdwn ├── 000002.mdwn ├── 000003.mdwn ├── 000004.mdwn … └── 000042.mdwn Chaque page doit ressembler à : --- name: Violette Dupuis address: | 42 rue du Fleuve 12042 Essaiville email: violette@example.org joined_on: 2013-05-25 membership_fee_paid_on: 2013-05-25 --- Violette sait programmer en Ruby, on peut lui demander si on a besoin de coup de main. Le début de chaque page est un morceau de [YAML]. Il doit contenir les entrées suivantes : =`name`= Le nom (complet) du membre. =`address`= L'adresse postale du membre. =`email`= L'adresse email du membre. C'est à cette adresse que seront envoyés les messages de l'assemblée générale et les rappels de cotisation. =`joined_on`= Date d'adhésion à l'association. =`membership_fee_paid_on`= Date du paiement de la dernière cotisation. Le reste de la page peut servir à noter ce qu'on veut. [YAML]: http://yaml.org/ Scripts ======= Voici le détail des scripts utilisés. On peut se faire une idée de leurs fonctionalités respectives en lisant les cas d'utilisation dans les fichiers `features/*.feature`. Le chemin vers la racine du clone du wiki du conseil d'amnisitration est spécifié par la variable d'environnement `NOS_OIGNONS_BOARD_WIKI_PATH`. Si cette dernière n'est pas spécifié, les scripts cherchent un répertoire `Membres` à la racine du Git courant, et si ce n'est pas le cas, dans le répertoire `wiki-ca` du répertoire parent du Git courant. `list-email` ------------ Affiche sur la sortie standard les adresses emails des membres à jour de cotisation. `pre-commit-hook` ----------------- `pre-commit` hook pour Git. Ce dernier est avant tout là pour éviter de pouvoir enregistrer des informations invalides dans la base des membres depuis Ikiwiki. Il est nécessaire de le configurer à chaque fois qu'on clone le dépôt du wiki du C.A. (en faisant un lien symbolique dans `.git/hooks/pre-commit`). `pre-receive-hook` ------------------ `pre-commit` hook pour Git. Ce dernier est là pour éviter de pouvoir enregistrer des informations invalides dans la base des membres. Il doit être configuré dans le dépôt central du wiki du C.A. (via un lien symbolique dans `.git/hooks/pre-receive`). `update-ag-subscribers` ----------------------- Met à jour la liste des emails inscrites à la liste ag@ par rapport aux membres à jour de cotisation. À exécuter à travers un *cron*. A besoin de pouvoir lancer les commandes `list_members`, `add_members` et `remove_members` via `sudo` sur le compte `list`. `send-membership-reminders` --------------------------- Préviens les membres qu'il faut renouveller leur cotisation. Le fichier utiliser pour garder la liste des envois déjà effectués est soit celui indiqué par la variable d'environnement `NOS_OIGNONS_REMINDER_DB`, ou le fichier si elle est vide `var/reminders.yaml`. `send-member-emails-to-advisors` -------------------------------- Envoie la liste des emails des membres à jour de cotisation au comité de déontologie. Ce script a vocation a être executé tous les mois afin que le comité puisse convoquer une assemblée générale extraordinaire, même en cas de défaillance du conseil d'administration. Développement ============= L'essentiel du code est en Ruby. Les dépendences sont gérés avec Bundler. Les tests d'intégrations sont fait avec Cucumber. Installer les paquets Debian qui vont bien (sur Wheezy) : apt-get install ruby1.9.1 bundler Pour récupérer les dépendences : ruby1.9.1 /usr/bin/bundle install --path=vendor/bundle Déploiement =========== Installer les paquets Debian qui vont bien (sur Wheezy) : apt-get install ruby1.9.1 bundler Installer les dépendences : ruby1.9.1 /usr/bin/bundle install --deployment \ --without=development \ --path=vendor/bundle chmod -R o+rX vendor/bundle Il faut donner les droits d'écriture à `wiki-ca` sur le répertoire `var`. Pour rendre facilement accessible `list-members-emails`, on peut ajouter dans `/usr/local/bin` un mini script tel que celui-ci : #!/bin/sh NOS_OIGNONS_BOARD_WIKI_PATH=/srv/ikiwiki/wiki-ca/src \ /srv/ikiwiki/wiki-ca/gestion-adh/bin/list-emails Ne pas oublier de le rendre exécutable. Pour permettre au script `update-ag-subscribers` de fonctionner, il est nécessaire de l'autoriser à exécuter certaines commandes de Mailman. Pour cela, on va créer un fichier dans `/etc/sudoers.d` : Defaults:wiki-ca !requiretty Cmnd_Alias AG_MANAGEMENT = /usr/sbin/list_members ag,\ /usr/sbin/add_members -r - ag,\ /usr/sbin/remove_members -f - ag wiki-ca ALL = (list) NOPASSWD: AG_MANAGEMENT Ensuite, pour exécuter régulièrement les scripts via le *crontab* du compte `wiki-ca`, il faut y ajouter : 42 * * * * BUNDLE_GEMFILE=/srv/ikiwiki/wiki-ca/gestion-adh/Gemfile NOS_OIGNONS_BOARD_WIKI_PATH=/srv/ikiwiki/wiki-ca/src ruby1.9.1 /srv/ikiwiki/wiki-ca/gestion-adh/bin/update-ag-subscribers 42 6 * * * BUNDLE_GEMFILE=/srv/ikiwiki/wiki-ca/gestion-adh/Gemfile NOS_OIGNONS_BOARD_WIKI_PATH=/srv/ikiwiki/wiki-ca/src ruby1.9.1 /srv/ikiwiki/wiki-ca/gestion-adh/bin/send-membership-reminders 21 0 1 * * BUNDLE_GEMFILE=/srv/ikiwiki/wiki-ca/gestion-adh/Gemfile NOS_OIGNONS_BOARD_WIKI_PATH=/srv/ikiwiki/wiki-ca/src ruby1.9.1 /srv/ikiwiki/wiki-ca/gestion-adh/bin/send-member-emails-to-advisors Pour installer le `pre-commit` *hook* sur le dépôt utilisé par Ikiwiki, on met dans `/srv/ikiwiki/wiki-ca/src/.git/hooks/pre-commit` : if ! BUNDLE_GEMFILE=/srv/ikiwiki/wiki-ca/gestion-adh/Gemfile ruby1.9.1 /srv/ikiwiki/wiki-ca/gestion-adh/bin/pre-commit-hook; then # Reset changes that do not pass the pre-commit hook to prevent # wrong changes to lay in the Ikiwiki source directory. git reset --hard exit 1 fi Ne pas oublier de le rendre exécutable. Pour installer le `pre-receive` *hook* sur le dépôt central, on met dans `/srv/git/.gitolite/hooks/wiki-ca/hooks/pre-receive` : #!/bin/sh BUNDLE_GEMFILE=/srv/ikiwiki/wiki-ca/gestion-adh/Gemfile ruby1.9.1 /srv/ikiwiki/wiki-ca/gestion-adh/bin/pre-receive-hook Ne pas oublier de le rendre exécutable. Il faut ensuite faire un lien symbolique : ln -s ../../../.gitolite/hooks/wiki-ca/pre-receive /srv/git/repositories/wiki-ca.git/hooks/pre-receive