Skip to content

One way Todoist to Habitica sync to allow scoring points for completed tasks.

License

Notifications You must be signed in to change notification settings

radeklat/todoist-habitica-sync

Repository files navigation

☑️⚔️   Todoist ⇒ Habitica Sync   ⚔️☑️

One way synchronisation from Todoist to Habitica

CircleCI Codecov GitHub tag (latest SemVer) Maintenance GitHub last commit Docker Pulls Docker Image Version (latest semver) Docker Image Size (latest semver)

Because if you want to be productive, you should not track tasks in two places. Habitica is great for tracking habits, Todoist for tracking TODOs. Now you can get the best of both.

How it works

Tasks are not added immediately. Only when you finish a task in Todoist, new task will be created in Habitica, finished and immediately deleted. So you won't see any Todoist tasks in Habitica but still get the rewards.

Features

  • Scores points in Habitica when Todoist task is finished.
  • Works for repeated tasks in Todoist, as long as the date string contains every.

Installation

As a script

  1. Open terminal
  2. Make sure git is installed:
    git --version   
    The output should look something like:
    git version 2.25.1
    
  3. Make sure Python 3.12.x is installed:
    python --version
    The output should look something like:
    Python 3.12.0
    
    • If it shows 2.7.x instead, try python3 instead and use it in the rest of the guide.
    • If it shows 3.11.x or lower, use pyenv to install a higher version of Python on your system.
  4. Make sure poetry is installed:
    poetry --version
    The output should look something like:
    Poetry (version 1.7.1)
    
  5. Clone this repository:
    git clone https://github.com/radeklat/todoist-habitica-sync.git
    cd todoist-habitica-sync
  6. Copy the .env.template file into .env file:
    cp .env.template .env
  7. Edit the .env file, fill all missing values and/or change existing ones to suit your needs.
  8. Install all application dependencies:
    poetry install --no-root --without=dev
  9. Run the app:
    poetry run python src/main.py

As a docker container

  1. Open terminal
  2. Make sure docker is installed:
    docker --version   
    The output should look something like:
    Docker version 20.10.5, build 55c4c88
    
  3. Create a base folder structure for the service:
    mkdir -p todoist-habitica-sync/.sync_cache
    cd todoist-habitica-sync
    chmod 0777 .sync_cache
    # Download .env file template
    curl https://raw.githubusercontent.com/radeklat/todoist-habitica-sync/master/.env.template --output .env
  4. Edit the .env file and fill the missing details.
  5. Run the container:
    docker run \
       --pull always --rm --name todoist-habitica-sync \
       --env-file=.env \
       -v $(pwd)/.sync_cache:/usr/src/app/.sync_cache \
       radeklat/todoist-habitica-sync:latest
    This configuration will run the service in the foreground (you need to keep the terminal open) and always use the latest version.
    • Change latest to a specific version if you don't always want the latest version or remove the --pull always flag to not update.

Add --detach flag to run in the background. You can close the terminal, but it will not start on system start up.

  • To see the log of the service running in the background, run docker logs todoist-habitica-sync
  • To stop the service, run docker container stop todoist-habitica-sync

As a service

You can use the above mentioned docker image to run the sync as a service on server or even your local machine. The simples way is to use docker compose:

  1. Make sure you have docker installed:
    docker --version
    docker compose version
    The output should look something like:
    Docker version 23.0.2, build 569dd73
    Docker Compose version v2.17.2
    
  2. Download the example compose file:
    mkdir -p todoist-habitica-sync/.sync_cache
    cd todoist-habitica-sync
    chmod 0777 .sync_cache
  3. Download a compose file and an example .env file:
    BASE_URL=https://raw.githubusercontent.com/radeklat/todoist-habitica-sync/master
    curl $BASE_URL/.env.template --output .env
    curl $BASE_URL/docker-compose.yml -O
  4. Edit the .env file and fill the missing details.
  5. Run the service:
    docker compose up
    This command will run the service in the foreground (you need to keep the terminal open) and always use the latest version.

Add --detach flag to run in the background. You can close the terminal. The service should start on system start up.

  • To see the log of the service running in the background, run docker-compose logs todoist-habitica-sync
  • To stop the service, run docker-compose stop todoist-habitica-sync

Update

As a script

  1. Open terminal

  2. Navigate to the project repository:

    cd todoist-habitica-sync
  3. Update the source code:

    git pull
  4. Update application dependencies:

    poetry install --no-dev
  5. Run the application again.

From docker-compose

If you used the latest tag, run:

docker compose stop  # stop the container
docker compose pull todoist-habitica-sync  # pull a new image
docker compose up -d --force-recreate  # re-create container with the new image
docker image prune -f  # clean up unused images

Environment variables

TODOIST_USER_ID

Optional, default value: None

See "user_id" mentioned in a link under "Calendar Subscription URL" at https://todoist.com/prefs/integrations. Needed only for shared projects to score points for tasks owned by you.

TODOIST_API_KEY

Required

See https://todoist.com/prefs/integrations under "API token".

HABITICA_USER_ID

Required

See https://habitica.com/user/settings/api under "User ID".

HABITICA_API_KEY

Required

See https://habitica.com/user/settings/api under "API Token", the "Show API Token" button.

SYNC_DELAY_MINUTES

Optional, default value: 1

Repeat sync automatically after N minutes.

DATABASE_FILE

Optional, default value: .sync_cache/sync_cache.json

Where to store synchronisation details. No need to change.

PRIORITY_TO_DIFFICULTY

Optional, default value: {'P1': 'HARD', 'P2': 'MEDIUM', 'P3': 'EASY', 'P4': 'TRIVIAL'}

Defines how Todoist priorities map to Habitica difficulties. Keys/values are case-insensitive and can be both names or numerical values defines by the APIs. See https://habitica.com/apidoc/#api-Task-CreateUserTasks and https://developer.todoist.com/sync/v9/#items for numerical values definitions.

LABEL_TO_DIFFICULTY

Optional

Defines how Todoist labels map to Habitica difficulties. Keys are case-insensitive. See https://habitica.com/apidoc/#api-Task-CreateUserTasks for difficulty values. If a task has no matching label, the priority_to_difficulty mapping is used. If a task has multiple labels, the highest difficulty is used.

Resetting sync cache

Sometimes certain changes require to reset the sync cache. The cache holds state information only to allow recovery after an unexpected termination of the program. So it is not needed in between restarts and can be safely removed.

To reset the cache:

  1. Stop the application.
  2. Remove the .sync_cache/sync_cache.json file or any other location given in the DATABASE_FILE config option.
  3. Optionally, update the application.
  4. Start to application again.
  5. You should see all existing Todoist tasks loaded again either as HIDDEN (finished tasks) or TODOIST_ACTIVE (not completed yet).

Planned work

  • Synchronise overdue task to cause damage in habitica

About

One way Todoist to Habitica sync to allow scoring points for completed tasks.

Resources

License

Stars

Watchers

Forks

Packages

No packages published