CLI tool for managing bug tasks from the command line, supporting both Lark Suite and Kanban (Outline) backends.
pip install boring-cliboring setup| Backend | Description | Setup Steps |
|---|---|---|
| Lark | Lark Suite task management | Lark Setup |
| Kanban | Outline Kanban board integration | Kanban Setup |
You'll be prompted for the following settings:
Server URL [https://boring.omelet.tech/api]: (press Enter to use default)
Bugs output directory [/tmp/bugs]: /path/to/your/project/bugs
Backend type (lark, kanban) []: lark
Tasklist GUID (from Lark) []: 9a31701d-fd0e-4417-b00d-e040afe2b234
In-progress Section GUID []: e2c8e412-fbae-41ea-9daa-c2b58efc1b87
Solved Section GUID []: 76a74fd6-79d8-4f74-a358-e78c688ee5ef
Default GUIDs for Bugs list:
| Setting | GUID |
|---|---|
| Tasklist GUID | 9a31701d-fd0e-4417-b00d-e040afe2b234 |
| In-progress Section (Inprogress - Bình) | e2c8e412-fbae-41ea-9daa-c2b58efc1b87 |
| Solved Section | 76a74fd6-79d8-4f74-a358-e78c688ee5ef |
- A browser window will open for Lark login
- Login with your Lark account
- After login, you'll see a JSON response like:
{"user":{...},"token":{"access_token":"eyJhbGciOiJ...",...}}- Copy the
access_tokenvalue (the long string starting witheyJ...) - Paste it in the terminal when prompted
Paste your access_token here: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
Login successful! Setup complete!
## Kanban Setup
### Step 2: Configure Settings (Kanban)
You'll be prompted for the following settings:
Server URL [https://boring.omelet.tech/api]: (press Enter to use default) Bugs output directory [/tmp/bugs]: /path/to/your/project/bugs Backend type (lark, kanban) []: kanban Kanban API Base URL [https://local.outline.dev:3000]: https://local.outline.dev:3000 Kanban API Key [*****]: Fetching available boards...
Available Boards:
- Kanban (b55c24c4-cbad-422a-b42e-56a9692a2e10)
Kanban Board ID [b55c24c4-cbad-422a-b42e-56a9692a2e10]: Fetching board details...
Available Lists (Columns):
- In Progress (c5286835-b3c9-4a99-9a17-66217a7d0ef9)
- To Do (c85e17e1-3190-4f5c-b2c0-bbe3a862f575)
- Done (f03c2aef-c3b3-4789-8b32-b4180cc6d927)
In-progress List ID [c5286835-b3c9-4a99-9a17-66217a7d0ef9]: Tasklist GUID (from Lark) []: 9a31701d-fd0e-4417-b00d-e040afe2b234 Solved/Done List ID [f03c2aef-c3b3-4789-8b32-b4180cc6d927]:
Kanban configuration updated!
**Default GUIDs for Bugs list:**
| Setting | GUID |
|---------|------|
| Tasklist GUID | `9a31701d-fd0e-4417-b00d-e040afe2b234` |
| In-progress Section (Inprogress - Bình) | `e2c8e412-fbae-41ea-9daa-c2b58efc1b87` |
| Solved Section | `76a74fd6-79d8-4f74-a358-e78c688ee5ef` |
### Step 3: Login with Lark (for Kanban)
If your Kanban board is linked to Lark authentication, follow the same login process:
1. A browser window will open for Lark login
2. Login with your Lark account
3. After login, you'll see a JSON response like:
```json
{"user":{...},"token":{"access_token":"eyJhbGciOiJ...",...}}
- Copy the
access_tokenvalue (the long string starting witheyJ...) - Paste it in the terminal when prompted
Paste your access_token here: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
Login successful!
Setup complete!
Download all tasks from your configured section:
boring downloadDownload to a specific directory:
boring download --dir /path/to/your/project/bugsDownload from a specific section:
boring download --section e2c8e412-fbae-41ea-9daa-c2b58efc1b87List all tasklists and sections to find GUIDs:
boring sections| Command | Description |
|---|---|
boring setup |
Configure CLI and login to Lark |
boring download |
Download tasks to local folder |
boring download --section GUID |
Download from specific section |
boring download --dir PATH |
Download to specific directory |
boring download --labels "Critical,High" |
Filter by labels |
boring sections |
List all tasklists and sections |
boring solve |
Move tasks to Solved section |
boring solve --keep |
Solve but keep local folders |
boring status |
Show current configuration |
boring --version |
Show version |
boring --help |
Show help |
Configuration is stored in ~/.boring-agents/config.yaml:
server_url: https://boring.omelet.tech/api
jwt_token: eyJhbGc...
bugs_dir: /path/to/your/project/bugs
tasklist_guid: 9a31701d-fd0e-4417-b00d-e040afe2b234
section_guid: e2c8e412-fbae-41ea-9daa-c2b58efc1b87
solved_section_guid: 76a74fd6-79d8-4f74-a358-e78c688ee5efIf you see authentication errors, run boring setup again to get a new token.
Run boring sections to list all available tasklists and their sections with GUIDs.
- Python 3.9+
MIT