Skip to main content

CRM Markdown synchronisé depuis CardDAV (Baikal), publié en site statique Hugo.

Project description

jeff

jeff

Your contacts live in CardDAV. Your CRM lives in Markdown.

PyPI version Python versions License: MIT Build Publish codecov Docstring coverage Quality Gate Status Maintainability Rating Reliability Rating Security Rating Bugs Vulnerabilities Code Smells Technical Debt

jeff syncs contacts from a Baikal CardDAV server into clean Markdown files with YAML frontmatter, then publishes a static HTML site. No database, no SaaS, no vendor lock-in — just files, Git, and a fast static site.

Quick start

pip install jeff-contacts
jeff init                # creates .jeff config file
# Edit .jeff with your CardDAV credentials
jeff sync                # fetch contacts
jeff publish             # build HTML site
open public/index.html

Workflow

Le workflow jeff se fait en 5 étapes. Les 4 premières sont à faire une fois lors de la mise en place, la dernière tourne quotidiennement.

1. jeff sync — Récupérer les contacts

jeff sync           # sync incrémental (seuls les changements)
jeff sync --full    # force un re-sync complet

Connecte le serveur CardDAV (Baikal), détecte les contacts modifiés via ctag/etag, télécharge les vCards et les transforme en fichiers Markdown avec frontmatter YAML. Chaque contact devient un fichier .md dans content/contacts/.

Le sync est incrémental : seuls les contacts ajoutés, modifiés ou supprimés depuis le dernier sync sont traités. Un --full force la régénération de tous les fichiers.

2. jeff triage — Trier les contacts

jeff triage
  [1/559] ──────────────────────────────────────────
  Jean Dupont
    tags: ami, ski, photo
    note: Photographe amateur
    addr: Avenue des Alpes 109, Geneve, Suisse
    email: jean@example.com
    phone: +41791234567

  > a a h H    # actif, ami, haute priorité, homme
  ✓ Jean Dupont → actif

Passe en revue chaque contact non trié et permet de décider rapidement :

  • a = actif (garder dans le CRM) avec relation, priorité et genre
  • r = archivé (masqué du dashboard mais conservé)
  • s = skip (on décide plus tard)
  • q = quitter (reprend où on s'est arrêté la prochaine fois)

Relations : a=ami, c=collègue, f=famille, k=connaissance. Priorités : h=haute, m=moyenne, b=basse. Genre : H=homme, F=femme.

3. jeff genre — Assigner le genre

jeff genre
  [1/204] Jean Dupont: h
  [2/204] Marie Martin: f
  [3/204] Acme Corp: n

Passe rapidement sur tous les contacts sans genre. Utile pour :

  • Les liens familiaux (distinguer père/mère automatiquement)
  • L'affichage dans le dashboard (♂️/♀️)
  • Le writeback vers CardDAV (X-GENDER)

Codes : H=homme, F=femme, N=none (entreprise), Enter=skip, q=quit.

4. jeff famille — Liens familiaux

jeff famille              # tous les contacts famille
jeff famille dupont       # filtrer par nom
jeff famille --check      # vérifier la cohérence
── [1/54] Jacques Dupont (homme) ──
    ↳ (aucun lien)

    1. Anne Dupont (femme)
    2. Jean Dupont (homme)
    3. Luc Dupont (homme)

    f=père m=mère w=conjoint c=enfant b=frère/sœur
    ?texte=chercher  Enter=skip  q=quit

  > 1w 2c 3c
  ✓ Jacques Dupont: conjoint=anne-dupont enfants=[jean-dupont, luc-dupont]
  ↔ Anne Dupont: conjoint=jacques-dupont
  ↔ Jean Dupont: pere=jacques-dupont
  ↔ Luc Dupont: pere=jacques-dupont

Pour chaque contact famille, affiche les membres du même nom de famille numérotés. On tape les numéros avec le code de relation. Les liens sont écrits réciproquement — assigner un père ajoute automatiquement l'enfant chez le père, et le genre détermine si c'est père ou mère.

jeff famille --check vérifie que tous les liens sont bidirectionnels et propose de corriger les incohérences.

5. jeff cron — Automatisation quotidienne

jeff cron
── Sync ──
Discovering addressbooks...
Addressbook: Contacts
Already up to date.

── Birthdays ──
  🎂 Jean Dupont (recorded)

── Publish ──
Published 204 contact(s) to public/

Enchaîne automatiquement : syncdétection des anniversairespublication du site HTML. Conçu pour tourner dans un crontab :

0 7 * * * cd /path/to/project && jeff cron

Le site publié inclut :

  • Dashboard avec contacts groupés par relation et triés par priorité
  • Section anniversaires du jour avec bouton WhatsApp pré-rempli
  • Arbre généalogique (Graphviz SVG)
  • Fiches contact avec coordonnées, liens familiaux et signe astrologique

Autres commandes

Commande Description
jeff delete Marquer des contacts archivés pour suppression du CardDAV
jeff check Détecter et nettoyer les doublons (même UID)
jeff export Exporter au format SquirrelMail (.abook)
jeff birthday-mail Envoyer un rappel anniversaire par email
jeff sync --writeback-gender Pousser le genre vers CardDAV (X-GENDER)
jeff sync --writeback-famille Pousser les liens familiaux vers CardDAV (RELATED)

Architecture

src/jeff/
  cli.py                  CLI commands (click)
  domain/                 Business objects
    carddav.py            CardDAV client
    config.py             Configuration (.jeff file)
    transform.py          vCard → Markdown
    urlback.py            vCard injection (URL, gender, RELATED)
  services/               Business logic
    sync.py               Sync orchestration
    publish.py            Static site builder
    triage.py             Contact triage
    famille.py            Family link management
    genealogy.py          Family tree (Graphviz)
    birthday.py           Birthday detection
    birthday_mail.py      Email reminders
    genre.py              Gender assignment
    duplicates.py         Duplicate detection
    export.py             Address book export

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jeff_contacts-0.1.8.tar.gz (241.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jeff_contacts-0.1.8-py3-none-any.whl (228.3 kB view details)

Uploaded Python 3

File details

Details for the file jeff_contacts-0.1.8.tar.gz.

File metadata

  • Download URL: jeff_contacts-0.1.8.tar.gz
  • Upload date:
  • Size: 241.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.26.9 CPython/3.14.4 Linux/7.0.3-arch1-1

File hashes

Hashes for jeff_contacts-0.1.8.tar.gz
Algorithm Hash digest
SHA256 afc5da7e0e7ba5a2c5109050305e119d352c26b1225b4c83bdacde90bd57059d
MD5 28dc6bb5ca813e4d3013d77f53a2825e
BLAKE2b-256 da76ccd00ad3ae4dacae8e77fe3d4f6f3cb6002f735636da71dbc793cce346d0

See more details on using hashes here.

File details

Details for the file jeff_contacts-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: jeff_contacts-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 228.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.26.9 CPython/3.14.4 Linux/7.0.3-arch1-1

File hashes

Hashes for jeff_contacts-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 7d997fdacaa0fa8e5e86e4524ceb4d18b7869da8eaa275dfe01aebe08b11b375
MD5 dfdf7103b1594fa1d8c4cfafa3c3d33f
BLAKE2b-256 3d200b302705e63eec3b2d101030a3e176ddabb2f032831289346a30ccd968bf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page