A tool to sync GitHub issues and PRs to Todoist tasks.
Project description
GitHub Todoist Sync
A Python tool that synchronizes your GitHub issues and pull requests (PRs) with Todoist tasks. It creates Todoist tasks for issues and PRs assigned to you, created by you, or where you're mentioned, and updates tasks when items are closed on GitHub.
Features
- Sync GitHub Issues and PRs: Automatically create Todoist tasks for GitHub issues and PRs that are relevant to you.
- Repository to Project Mapping: Map specific GitHub repositories to Todoist projects for organized task management.
- Automatic Labeling: Add labels to tasks based on item type (
issue
orpr
) and your relation (assigned
,mentioned
,created
,review
). - Closed Item Tracking: When an issue or PR is closed on GitHub, the corresponding Todoist task is updated with a
"Closed"
label. - Cross-Platform Configuration: Uses a configuration directory in the user's home folder, compatible with Windows, Linux, and macOS.
Installation
Prerequisites
- Python 3.6 or higher installed on your system.
- GitHub Personal Access Token:
- Go to your GitHub account settings.
- Navigate to Developer settings > Personal access tokens.
- Generate a new token with the
repo
scope to access repository issues and PRs.
- Todoist API Token:
- Log in to your Todoist account.
- Go to Settings > Integrations.
- Copy your API token.
Install via pip
pip install github-todoist-sync
Configuration
Initialize Configuration
After installation, run the following command to create the default configuration files:
github-todoist-sync-init
This command creates the configuration directory and default config files in your home directory:
- Windows:
C:\Users\YourUsername\AppData\Roaming\github_todoist_sync\
- Linux/macOS:
/home/yourusername/.config/github_todoist_sync/
Update config.json
Navigate to the configuration directory and open config.json
. Update it with your actual GitHub and Todoist API tokens, GitHub username, and repository-to-project mappings.
Example config.json
:
{
"GITHUB_TOKEN": "your_actual_github_token",
"TODOIST_TOKEN": "your_actual_todoist_token",
"USERNAME": "your_github_username",
"REPO_PROJECT_MAPPING": {
"owner1/repo1": "Todoist Project 1",
"owner2/repo2": "Todoist Project 2"
}
}
GITHUB_TOKEN
: Your GitHub personal access token.TODOIST_TOKEN
: Your Todoist API token.USERNAME
: Your GitHub username.REPO_PROJECT_MAPPING
: A mapping of GitHub repositories to Todoist project names.
Permissions
Ensure that the configuration files are secure:
-
On Unix systems, you can set the config file permissions to be readable and writable only by you:
chmod 600 config.json
Usage
After configuring the tool, you can run the synchronization script:
github-todoist-sync
- The script fetches your GitHub issues and PRs.
- Creates Todoist tasks for new items.
- Updates tasks for closed items by adding a
"Closed"
label. - Tasks are added to the specified Todoist projects and labeled accordingly.
Labels Added to Tasks
- For Issues:
issue:assigned
issue:mentioned
issue:created
- For Pull Requests:
pr:assigned
pr:mentioned
pr:created
pr:review
- When Closed:
Closed
Project Structure
github_todoist_sync/
├── github_todoist_sync/
│ ├── __init__.py
│ └── sync.py
├── pyproject.toml
└── README.md
Contributing
Contributions are welcome! Please follow these steps:
-
Fork the repository on GitHub.
-
Clone your fork:
git clone https://github.com/yourusername/github-todoist-sync.git
-
Create a new branch for your feature or bugfix:
git checkout -b feature-or-bugfix-name
-
Make your changes and commit them:
git commit -am "Description of changes"
-
Push to your fork:
git push origin feature-or-bugfix-name
-
Submit a pull request to the main repository.
Troubleshooting
-
Authentication Errors:
- Ensure your API tokens are correct and have the necessary permissions.
- Double-check that you copied the entire token without extra spaces.
-
Permission Issues:
- If the script can't read or write configuration files, check the file permissions.
- Ensure the config directory is writable by your user account.
-
Label or Project Not Found:
- Verify that the Todoist project names in
REPO_PROJECT_MAPPING
match exactly with those in your Todoist account. - Labels are created automatically; ensure your Todoist account allows label creation.
- Verify that the Todoist project names in
-
API Rate Limits:
- Be aware of GitHub and Todoist API rate limits.
- If you encounter rate limit issues, consider running the script less frequently.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Contact
For any questions or support, please open an issue on the GitHub repository.
Acknowledgements
- PyGithub - A Python library to access the GitHub API.
- Todoist API Python - Official Todoist Python SDK.
Happy task management!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file github_todoist_sync-0.1.0.tar.gz
.
File metadata
- Download URL: github_todoist_sync-0.1.0.tar.gz
- Upload date:
- Size: 5.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 92278f6eb48f14dd7eea350003cc66d7b4551cffa72c74124f74e37104696f6a |
|
MD5 | 59211c51e30cba3cad693b6cdba817f7 |
|
BLAKE2b-256 | 6e7ae7adbdd89c642723ffe0a6d05f6481f738919e87b249a701c6740b3c0749 |
Provenance
The following attestation bundles were made for github_todoist_sync-0.1.0.tar.gz
:
Publisher:
release.yml
on 1337-42/Github2Todoist
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
github_todoist_sync-0.1.0.tar.gz
- Subject digest:
92278f6eb48f14dd7eea350003cc66d7b4551cffa72c74124f74e37104696f6a
- Sigstore transparency entry: 147599346
- Sigstore integration time:
- Predicate type:
File details
Details for the file github_todoist_sync-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: github_todoist_sync-0.1.0-py3-none-any.whl
- Upload date:
- Size: 6.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | da64052cba7ee59610b4cf9cb2a77a877880ba6dc922fdfac2ccc7bb97ae6fe8 |
|
MD5 | 509f00156e7dcbb7c2e568d73c557672 |
|
BLAKE2b-256 | 25e024e8713c7689f023a02d1c02a69989a87849437f98259f88204ff19849d0 |
Provenance
The following attestation bundles were made for github_todoist_sync-0.1.0-py3-none-any.whl
:
Publisher:
release.yml
on 1337-42/Github2Todoist
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
github_todoist_sync-0.1.0-py3-none-any.whl
- Subject digest:
da64052cba7ee59610b4cf9cb2a77a877880ba6dc922fdfac2ccc7bb97ae6fe8
- Sigstore transparency entry: 147599348
- Sigstore integration time:
- Predicate type: