Metadata-Version: 2.1
Name: kenboard
Version: 0.1.42
Summary: Project management dashboard with kanban boards, burndown charts, and category-based organization. Flask API backend with MySQL storage and static HTML generation.
Keywords: kenboard,kanban,project-management,flask,mysql,dashboard
Author: Q
License: MIT
Classifier: Development Status :: 3 - Alpha
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Framework :: Flask
Classifier: Topic :: Office/Business :: Scheduling
Requires-Python: >=3.11
Requires-Dist: flask>=3.1
Requires-Dist: flask-cors>=5.0
Requires-Dist: flask-login>=0.6
Requires-Dist: pymysql[rsa]>=1.1
Requires-Dist: aiosql>=12.0
Requires-Dist: yoyo-migrations>=8.2
Requires-Dist: pydantic>=2.11
Requires-Dist: structlog>=24.0
Requires-Dist: click>=8.1
Requires-Dist: python-dotenv>=1.0
Requires-Dist: jinja2>=3.1
Requires-Dist: argon2-cffi>=25.1.0
Requires-Dist: flask-limiter>=4.1.1
Requires-Dist: authlib>=1.6.9
Requires-Dist: requests>=2.28
Provides-Extra: prod
Requires-Dist: gunicorn>=21.0; extra == "prod"
Description-Content-Type: text/markdown

# KENBOARD

> **Un kanban pour les BOT.**

[![PyPI version](https://img.shields.io/pypi/v/kenboard.svg)](https://pypi.org/project/kenboard/)
[![Python versions](https://img.shields.io/pypi/pyversions/kenboard.svg)](https://pypi.org/project/kenboard/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Build](https://github.com/lduchosal/kenboard/actions/workflows/python-package.yml/badge.svg)](https://github.com/lduchosal/kenboard/actions/workflows/python-package.yml)
[![Publish](https://github.com/lduchosal/kenboard/actions/workflows/publish.yml/badge.svg)](https://github.com/lduchosal/kenboard/actions/workflows/publish.yml)
[![codecov](https://codecov.io/gh/lduchosal/kenboard/branch/main/graph/badge.svg)](https://codecov.io/gh/lduchosal/kenboard)
[![Docstring coverage](./interrogate_badge.svg)](./interrogate_badge.svg)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=sqale_rating)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=reliability_rating)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=security_rating)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Bugs](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=bugs)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Vulnerabilities](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=vulnerabilities)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Code Smells](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=code_smells)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)
[![Technical Debt](https://sonarcloud.io/api/project_badges/measure?project=lduchosal_kenboard&metric=sqale_index)](https://sonarcloud.io/summary/new_code?id=lduchosal_kenboard)

<p align="center">
  <img src="./logo.svg" alt="kenboard logo" width="480">
</p>

## Usage pour les humains

<p align="center">
  <img src="./doc/images/kanban.png" alt="Vue kanban KENBOARD" width="800">
</p>

> Régénérer le screenshot après une évolution UI : `pdm run screenshots`

## Usage pour les BOT

KENBOARD livre `ken`, une CLI pensée pour Claude Code et autres assistants :
output JSON, filtres natifs, exit codes propres.

```sh
# Une fois par dossier : lier le repo à un projet KENBOARD
ken --base-url https://kenboard.example.ch init <project-id>

# Workflow quotidien
ken list --status doing --who Claude       # tâches en cours assignées au bot
ken add "Fix login redirect" --who Claude  # créer
ken move 42 --to review                    # déplacer
ken done 42                                # clôturer
```

Référence complète de la CLI : [`doc/ken-cli.md`](doc/ken-cli.md).
Pour les cas non couverts par `ken` (categories, users, delete), l'API REST
reste disponible : [`doc/api.md`](doc/api.md), [`doc/openapi.yaml`](doc/openapi.yaml).

## Installation

Voir [`INSTALL.md`](INSTALL.md) pour la mise en place complète (MySQL, utilisateurs, migrations, reverse proxy).

## Licence

MIT — voir [`LICENSE`](LICENSE).

