Home
Softono
OpenHabitTracker

OpenHabitTracker

Open source Docker
249
Stars
19
Forks
2
Issues
4
Watchers
2 weeks
Last Commit

About OpenHabitTracker

Track habits, tasks and notes with time tracking, calendar view and completion statistics.

Platforms

Web Self-hosted Docker Linux Windows macOS iOS Android

Languages

Docker

OpenHabitTracker

https://openhabittracker.net

App:

https://pwa.openhabittracker.net

Take Markdown notes, plan tasks, track habits

  • Free and Ad-free
  • Open Source
  • Privacy Focused: All user data is stored locally on your device
  • Available on Windows, Linux, Android, iOS, macOS, and as a web app
  • Localized to English, German, Spanish, Slovenian, French, Portuguese, Italian, Japanese, Chinese, Korean, Dutch, Danish, Norwegian, Swedish, Finnish, Polish, Czech, Slovak, Croatian, Serbian

Key Features:

  • Markdown support for notes
  • Use categories and priorities to organize your notes, tasks, and habits
  • Advanced Search, Filter, and Sort
  • Data Export/Import: JSON, YAML, TSV, Markdown
  • Import your notes from Google Keep
  • Available in 26 themes with Dark and Light modes

Stores:

Windows:

Linux - Flathub:

Linux - Snap Store:

Android:

iOS:

macOS:

Android - APKPure:

Docker image contains a Blazor Server app for one user

https://hub.docker.com/r/jinjinov/openhabittracker

https://github.com/Jinjinov/OpenHabitTracker/pkgs/container/openhabittracker

Set your username and password with environment variables:

.env

APPSETTINGS_USERNAME=admin
[email protected]
APPSETTINGS_PASSWORD=admin
APPSETTINGS_JWT_SECRET=your-extremely-strong-secret-key

Replace your-extremely-strong-secret-key in Windows terminal:

[System.Convert]::ToBase64String([System.Security.Cryptography.RandomNumberGenerator]::GetBytes(32))

Replace your-extremely-strong-secret-key in Linux / macOS terminal:

openssl rand -base64 32

docker-compose.yml

services:
  openhabittracker:
    image: jinjinov/openhabittracker:latest
    ports:
      - "5050:8080"
    environment:
      - AppSettings__UserName=${APPSETTINGS_USERNAME}
      - AppSettings__Email=${APPSETTINGS_EMAIL}
      - AppSettings__Password=${APPSETTINGS_PASSWORD}
      - AppSettings__JwtSecret=${APPSETTINGS_JWT_SECRET}
    volumes:
      - ./.OpenHabitTracker:/app/.OpenHabitTracker

The default port is 5050. You can change it to 80 to avoid typing the port in the address, or to any other free port if 5050 is already in use - update the port in docker-compose.yml accordingly.

After you login at http://localhost:5050/login you can use the same browser tab to access:

Sync desktop or mobile app with Docker

Run the Docker container

Choose the platform where you want to host the OpenHabitTracker server:

Docker Desktop

  1. Open Docker Desktop and make sure it shows Engine running
  2. Open a terminal in the folder containing your .env and docker-compose.yml
  3. Run: docker-compose up -d
  4. Open http://localhost:5050/login in a browser to confirm the server is running
  5. Find this machine's IP address:
    • Windows: ipconfig
    • Mac / Linux: ifconfig

Linux server

  1. SSH into your server
  2. Install Docker: sudo apt update && sudo apt install -y docker.io docker-compose
  3. Open a terminal in the folder containing your .env and docker-compose.yml
  4. Run: docker-compose up -d
  5. Find the server IP: ifconfig

Synology NAS

  1. Open Package Center and install Container Manager
  2. Open Container ManagerProjectCreate
  3. Set the project name to openhabittracker
  4. Paste the docker-compose.yml content, replacing ${APPSETTINGS_...} placeholders with your actual values
  5. Click NextDone — the container starts automatically
  6. Find your NAS IP: Control PanelNetworkNetwork Interface

Enable sync in OpenHabitTracker

  1. Open OpenHabitTracker on your device
  2. Open the menu and click Data
  3. Scroll down to Online sync
  4. Enter the Address: http:// + the IP from your scenario above + :5050 or whichever port you chose (omit the port entirely if you chose 80)
  5. Enter your Username and Password from .env
  6. Check Remember me to stay logged in across app restarts
  7. Click Log in

Made with:

Runs with:

Desktop videos:

Notes, Tasks, Habits

Search, Settings

Desktop screenshots:

Phone screenshots: