{"id":47777085,"url":"https://github.com/ulsklyc/oikos","last_synced_at":"2026-05-23T10:04:56.037Z","repository":{"id":346653472,"uuid":"1190598050","full_name":"ulsklyc/oikos","owner":"ulsklyc","description":"Self-hosted family planner - tasks, calendars, shopping, meals, budget. Your data, your server.  ","archived":false,"fork":false,"pushed_at":"2026-04-18T20:24:09.000Z","size":20508,"stargazers_count":332,"open_issues_count":7,"forks_count":10,"subscribers_count":2,"default_branch":"main","last_synced_at":"2026-04-18T22:33:12.794Z","etag":null,"topics":["docker","family","family-planner","home-automation","open-source","planner-app","privacy-first","progressive-web-app","pwa","self-hosted","selfhosted","selfhosted-apps"],"latest_commit_sha":null,"homepage":"https://ulsklyc.github.io/oikos/","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ulsklyc.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-03-24T12:46:14.000Z","updated_at":"2026-04-18T22:09:09.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/ulsklyc/oikos","commit_stats":null,"previous_names":["ulsklyc/oikos"],"tags_count":101,"template":false,"template_full_name":null,"purl":"pkg:github/ulsklyc/oikos","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ulsklyc%2Foikos","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ulsklyc%2Foikos/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ulsklyc%2Foikos/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ulsklyc%2Foikos/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ulsklyc","download_url":"https://codeload.github.com/ulsklyc/oikos/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ulsklyc%2Foikos/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32095160,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-21T11:25:29.218Z","status":"ssl_error","status_checked_at":"2026-04-21T11:25:28.499Z","response_time":128,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","family","family-planner","home-automation","open-source","planner-app","privacy-first","progressive-web-app","pwa","self-hosted","selfhosted","selfhosted-apps"],"created_at":"2026-04-03T12:03:31.362Z","updated_at":"2026-05-23T10:04:56.031Z","avatar_url":"https://github.com/ulsklyc.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"docs/logo.svg\" alt=\"Oikos\" width=\"120\" /\u003e\n  \u003ch1\u003eOikos\u003c/h1\u003e\n  \u003cp\u003e\u003cstrong\u003eSelf-hosted family planner for small households\u003c/strong\u003e\u003c/p\u003e\n\n  \u003ca href=\"LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/badge/license-MIT-blue?style=flat-square\" alt=\"MIT License\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/ulsklyc/oikos/releases\"\u003e\u003cimg src=\"https://img.shields.io/github/v/release/ulsklyc/oikos?style=flat-square\u0026color=007AFF\u0026label=release\" alt=\"Latest Release\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/ulsklyc/oikos/pkgs/container/oikos\"\u003e\u003cimg src=\"https://img.shields.io/badge/ghcr.io-oikos-2496ED?style=flat-square\u0026logo=docker\u0026logoColor=white\" alt=\"Docker Image\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://nodejs.org\"\u003e\u003cimg src=\"https://img.shields.io/badge/node-%E2%89%A522-339933?style=flat-square\u0026logo=node.js\u0026logoColor=white\" alt=\"Node.js\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/ulsklyc/oikos/pulls\"\u003e\u003cimg src=\"https://img.shields.io/badge/PRs-welcome-brightgreen?style=flat-square\" alt=\"PRs Welcome\"\u003e\u003c/a\u003e\n\u003c/div\u003e\n\n\u003cbr\u003e\n\n\u003ctable\u003e\n  \u003ctr\u003e\n    \u003ctd align=\"center\" width=\"50%\"\u003e\n      \u003cpicture\u003e\n        \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"docs/screenshots/01-mobile-dark.png\"\u003e\n        \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"docs/screenshots/01-mobile-light.png\"\u003e\n        \u003cimg src=\"docs/screenshots/01-mobile-light.png\" alt=\"Mobile Dashboard\" width=\"280\"\u003e\n      \u003c/picture\u003e\n      \u003cbr\u003e\n      \u003csub\u003eMobile Dashboard\u003c/sub\u003e\n    \u003c/td\u003e\n    \u003ctd align=\"center\" width=\"50%\"\u003e\n      \u003cpicture\u003e\n        \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"docs/screenshots/01-web-dark.png\"\u003e\n        \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"docs/screenshots/01-web-light.png\"\u003e\n        \u003cimg src=\"docs/screenshots/01-web-light.png\" alt=\"Desktop Dashboard\" width=\"480\"\u003e\n      \u003c/picture\u003e\n      \u003cbr\u003e\n      \u003csub\u003eDesktop Dashboard\u003c/sub\u003e\n    \u003c/td\u003e\n  \u003c/tr\u003e\n\u003c/table\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003csub\u003eToggle GitHub light/dark mode to see both themes • \u003ca href=\"https://ulsklyc.github.io/oikos/\"\u003eView all screenshots\u003c/a\u003e\u003c/sub\u003e\n\u003c/p\u003e\n\nOikos is a self-hosted web app for families who want to organize their everyday life in one place — without cloud accounts, subscriptions, or data leaving the house. It runs as a Docker container on any home server or NAS, is accessible from every device in the household, and can be installed as a PWA on phones and tablets.\n\nThe goal is a single, private place for everything that keeps a household running: shared tasks, grocery lists, meal plans, a family calendar, budgets, and more. Each module is independent — use what fits, ignore what doesn't.\n\n## Features\n\n| Module | Description |\n|---|---|\n| **Tasks** | Shared tasks with deadlines, priorities, subtasks, and recurring schedules. Assign to multiple family members simultaneously with stacked avatar display. Kanban board with touch-friendly one-tap status buttons. Archive completed tasks to keep lists clean. Inline reminder presets (15 min to 2 weeks before due). Schedule tasks with a future start date — future tasks are hidden by default and revealed via a \"Show scheduled\" toggle. |\n| **Shopping Lists** | Collaborative lists organized by aisle. Import ingredients from meal plans in one click. |\n| **Meal Planning** | Weekly drag-and-drop planner. Export ingredient lists directly to your shopping list. |\n| **Recipes** | Create, duplicate, and scale reusable recipes. Pre-fill meal slots from a recipe or save any meal as a recipe. |\n| **Calendar** | Two-way sync with Google Calendar (OAuth) and multiple CalDAV accounts (iCloud, Nextcloud, Radicale, Baikal). Per-account calendar selection with checkboxes. Subscribe to any public ICS/webcal URL with per-subscription color and visibility. Recurring events support daily, weekly, monthly, and yearly frequencies. Overlapping timed events render side-by-side. Events support file attachments (images, PDFs, Office documents). |\n| **Documents** | Upload and manage family files (PDF, images, Office documents up to 5 MB). Organize into custom folders with a sidebar browser. Grid/list view, drag-and-drop upload, 14 category tags (medical, school, identity, finance, and more), per-document visibility (family, selected members, private), archive and download. |\n| **Budget** | Track income and expenses with recurring entries, monthly trends, and CSV export. 35 predefined categories plus custom ones. Supports 15 currencies. Loans tab for instalment-based loan tracking. **Split Expenses** tab for shared costs within groups — equal, percentage, exact-amount, and shares split methods, multi-currency support, immutable ledger, automatic debt simplification, and recurring expenses. |\n| **Housekeeping** | Manage household staff workflows. Staff profiles with daily rate, calendar color, and payment schedule. Work session check-in/check-out with automatic calendar event creation and optional payment task. Recurring chore tracking with urgency decay indicators. Supply requests linked to shopping lists. Monthly visit log with payment summaries. |\n| **Notes \u0026 Contacts** | Colored sticky notes with Markdown support. Contact directory with multi-account CardDAV sync (Nextcloud, iCloud, Radicale, Baikal), multiple phones/emails/addresses per contact, and vCard import/export. |\n| **Birthdays** | Birthday tracker with automatic annual calendar events, age display, profile photos, and customizable reminder offsets (preset or fully custom interval). |\n| **Reminders** | Time-based reminders on tasks and calendar events. In-app notification badge. |\n| **Family** | Assign family roles, profile pictures, phone, email, and birthday per member. Family details are automatically synced to Contacts and Birthdays. |\n| **API Tokens** | Named Bearer / X-API-Key tokens for external integrations. SHA-256-hashed at rest, with optional expiry. OpenAPI 3.0 spec at `/api/v1/openapi.json`. |\n| **Backup** | Admin-only database backup and restore via the Settings UI. Download a snapshot or restore from a file upload with an automatic pre-restore rollback copy. Automatic scheduled backups (configurable schedule, rotation, retention). |\n\n## Design \u0026 Technology\n\n- **Liquid Glass UI** — translucent surfaces, backdrop blur, module-tinted overlays, spring animations — inspired by Apple's Liquid Glass, built in pure CSS\n- **PWA** — installable on any device, works offline, dark mode, responsive from phone to desktop\n- **Privacy First** — SQLCipher AES-256 encrypted database, fully self-hosted, zero telemetry\n- **Zero Build Step** — pure ES modules, no bundler, no transpiler, no framework\n- **Multilingual** — 16 languages with automatic locale detection (de, en, es, fr, it, sv, el, ru, tr, zh, ja, ar, hi, pt, uk, pl)\n\n## Quick Start\n\n**Option A — Web Installer (recommended)**\n\n```bash\ngit clone https://github.com/ulsklyc/oikos.git \u0026\u0026 cd oikos\nnode tools/installer/install-server.js\n```\n\nOpen **http://localhost:8090** in your browser. The wizard configures your `.env`, starts Docker, and creates your admin account. Requires Node.js 18+ on the host.\n\n**Option B — Pre-built image (no clone required)**\n\n```bash\ncurl -O https://raw.githubusercontent.com/ulsklyc/oikos/main/docker-compose.yml\ncurl -O https://raw.githubusercontent.com/ulsklyc/oikos/main/.env.example\ncp .env.example .env          # set SESSION_SECRET and DB_ENCRYPTION_KEY\ndocker compose up -d\ndocker compose exec oikos node setup.js\n```\n\n**Option C — Build from source**\n\n```bash\ngit clone https://github.com/ulsklyc/oikos.git \u0026\u0026 cd oikos\ncp .env.example .env          # set SESSION_SECRET and DB_ENCRYPTION_KEY\ndocker compose up -d --build\ndocker compose exec oikos node setup.js\n```\n\nOpen `http://localhost:3000` and sign in with the admin credentials you created above.\n\n\u003e **New to Docker?** The **[Installation Guide](docs/installation.md)** covers Docker setup, HTTPS, backups, and troubleshooting step by step.\n\n## Tech Stack\n\n\u003cp\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Express-000000?style=flat-square\u0026logo=express\u0026logoColor=white\" alt=\"Express\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/SQLite%20%2F%20SQLCipher-003B57?style=flat-square\u0026logo=sqlite\u0026logoColor=white\" alt=\"SQLite\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Vanilla_JS_(ES_Modules)-F7DF1E?style=flat-square\u0026logo=javascript\u0026logoColor=black\" alt=\"Vanilla JS\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Plain_CSS-1572B6?style=flat-square\u0026logo=css3\u0026logoColor=white\" alt=\"CSS\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Docker-2496ED?style=flat-square\u0026logo=docker\u0026logoColor=white\" alt=\"Docker\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/PWA-5A0FC8?style=flat-square\u0026logo=pwa\u0026logoColor=white\" alt=\"PWA\"\u003e\n\u003c/p\u003e\n\n## Documentation\n\n| [Installation](docs/installation.md) | [Spec \u0026 Data Model](docs/SPEC.md) | [Contributing](CONTRIBUTING.md) | [Security](SECURITY.md) | [Changelog](CHANGELOG.md) | [Backlog](BACKLOG.md) |\n|---|---|---|---|---|---|\n\n## License\n\n\u003ca href=\"LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/badge/license-MIT-blue?style=flat-square\" alt=\"MIT License\"\u003e\u003c/a\u003e\n\n\u003cdiv align=\"center\"\u003e\n  \u003csub\u003eBuilt with care for families who value privacy and simplicity.\u003c/sub\u003e\n\u003c/div\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fulsklyc%2Foikos","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fulsklyc%2Foikos","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fulsklyc%2Foikos/lists"}