Free shopping assistant
A fast and simple app for managing your shopping list together
Koffan is a lightweight web application for managing shopping lists, designed for couples and families. It allows real-time synchronization between multiple devices, so everyone knows what to buy and what's already in the cart.
The app works in any browser on both mobile and desktop. Just one password to log in - no complicated registration required.
I needed an app that would let me and my wife create a shopping list together and do grocery shopping quickly and efficiently. I tested various solutions, but none of them were simple and fast enough.
I built the first version in Next.js, but it turned out to be very resource-heavy. I have a lot of other things running on my server, so I decided to optimize. I rewrote the app in Go and now it uses only ~2.5 MB RAM instead of hundreds of megabytes!
- Ultra-lightweight - ~16 MB on disk, ~2.5 MB RAM
- Multiple lists - Create separate lists for different stores or purposes, with custom icons
- PWA - Install on your phone like a native app
- Offline mode - Add, edit, check/uncheck products without internet (auto-sync when back online)
- Auto-completion - Fuzzy search suggestions from your history, remembers sections
- Organize products into sections (e.g., Dairy, Vegetables, Cleaning)
- Mark products as purchased
- Mark products as "uncertain" (can't find it in the store)
- Real-time synchronization (WebSocket)
- Responsive interface (mobile-first)
- Dark mode - Automatic theme based on system preferences
- Multi-language support (PL, EN, DE, ES, FR, PT, UK, NO, LT, EL, SK)
- Simple login system
- Rate limiting protection against brute-force attacks
- REST API - Programmatic access for integrations and migrations (docs)
- Backend: Go 1.21 + Fiber
- Frontend: HTMX + Alpine.js + Tailwind CSS
- Database: SQLite
You can run Koffan directly on your machine using Go. This works on any system (macOS, Linux, Windows).
macOS (Homebrew):
brew install goLinux (Debian/Ubuntu):
sudo apt install golang-goWindows: Download from go.dev/dl
git clone https://github.com/PanSalut/Koffan.git
cd Koffan
go run main.goApp available at http://localhost:3000
Default password: shopping123
To set a custom password:
APP_PASSWORD=yourpassword go run main.godocker run -d -p 3000:80 -e APP_PASSWORD=yourpassword -v koffan-data:/data ghcr.io/pansalut/koffan:latestApp available at http://localhost:3000
docker-compose up -d
# App available at http://localhost:80| Variable | Default | Description |
|---|---|---|
APP_ENV |
development |
Set to production for secure cookies |
APP_PASSWORD |
shopping123 |
Login password |
DISABLE_AUTH |
false |
Set to true to disable authentication (for reverse proxy setups) |
PORT |
80 (Docker) / 3000 (local) |
Server port |
DB_PATH |
./shopping.db |
Database file path |
DEFAULT_LANG |
en |
Default UI language (pl, en, de, es, fr, pt, uk, no, lt, el, sk) |
LOGIN_MAX_ATTEMPTS |
5 |
Max login attempts before lockout |
LOGIN_WINDOW_MINUTES |
15 |
Time window for counting attempts |
LOGIN_LOCKOUT_MINUTES |
30 |
Lockout duration after exceeding limit |
API_TOKEN |
(disabled) | Enable REST API with this token (docs) |
git clone https://github.com/PanSalut/Koffan.git
cd Koffan
docker build -t koffan .
docker run -d -p 80:80 -e APP_PASSWORD=your-password -v koffan-data:/data koffan- Add new resource → Docker Compose → Select your Git repository or use
https://github.com/PanSalut/Koffan - Set domain in Domains section
- Enable Connect to Predefined Network in Advanced settings
- Add environment variable
APP_PASSWORDwith your password - Deploy
Data is stored in /data/shopping.db. The volume ensures your data persists across deployments.
For more information, check the Wiki:
- REST API - Programmatic access, migrations, integrations
- Multiple Instances - Running separate instances for different households
Have an idea? Check open feature requests and vote with 👍 on the ones you want most.
Want to suggest something new? Create an issue.
I love and admire the open source philosophy. That's why I created Koffan - to give back to the community that has given me so much over the years.
If you find this project useful and want to support my work (completely optional!), you can become a sponsor:
I'm incredibly grateful to these amazing people for supporting Koffan:
MIT License with Commons Clause.
You are free to use, modify, and share this software for any purpose, including commercial use within your organization. However, you may not sell the software or offer it as a paid service.

