Mirror of github.com/Memo-2023/mana-monorepo
Find a file
Till JS af92720a62 feat(mana/web): encryption phase 5 — rollout to chat/dreams/memoro/contacts/cycles/finance
Six modules join the notes pilot (Phase 4) on the encrypted-at-rest path.
Every user-typed text and PII field listed below is now wrapped via
AES-GCM-256 with the per-user master key before any write hits Dexie,
and decrypted on every liveQuery read coming back through the public
queries module.

Tables flipped to enabled:true in the registry
  - chat.messages          messageText
  - chat.conversations     title
  - chat.chatTemplates     name + description + systemPrompt + initialQuestion
  - dreams.dreams          title + content + transcript + interpretation
                           + aiInterpretation + location
  - dreams.dreamSymbols    meaning   (name stays plaintext — used as
                                       indexed lookup key in touchSymbols /
                                       updateSymbol via where('name'))
  - memoro.memos           title + intro + transcript
  - memoro.memories        title + content
  - contacts.contacts      firstName + lastName + email + phone + mobile
                           + birthday + street + city + postalCode
                           + country + notes + website + linkedin
                           + twitter + instagram + github
  - cycles.cycles          notes
  - cycles.cycleDayLogs    notes + mood   (symptoms stays plaintext —
                                            standardised label array
                                            consumed by symptomsStore.touchSymptoms
                                            via Set diffs in dayLogsStore.logDay)
  - finance.transactions   description + note   (the schema uses
                                                  `note` singular,
                                                  not `notes` or `merchant`
                                                  as my earlier draft had it)

Tables intentionally left disabled
  - questions / answers — direct db.table().update() call sites in
    DetailView.svelte instead of going through a store. Need a store
    extraction first; registry entry stays in place so the flip is a
    one-line change once the store exists.
  - tasks, events, calendar.events, plants, meals, slides, presiDecks,
    cards, links, etc. — fall through to a future Phase 6 once the
    chat/dreams/memoro/contacts pilots are validated in real use.

Per-module changes
  Each store now follows the same pattern the notes pilot established:
    1. Build the LocalRecord with plaintext fields
    2. Snapshot it via toX() for the optimistic UI return value
    3. await encryptRecord(tableName, record)   // mutates in place
    4. await table.add(record)                   // ciphertext lands on disk

  For updates the diff is encrypted in place before the update() call
  so partial updates only encrypt the modified fields.

  The transcribeBlob flows in dreams + memoro decrypt the existing
  record first (to read the user-typed `content`), then build a
  diff and re-encrypt it. Same for contactsStore.ensureSelfContact
  which compares against decrypted-existing values to decide whether
  the profile-sync needs an update.

Per-module query changes
  Each public liveQuery now filters on plaintext metadata (deletedAt,
  isArchived, etc.) FIRST, then runs decryptRecords on the visible
  set, then maps to the public type. Cost stays bounded by what the
  view actually renders, not the total table size.

  cross-app-queries.ts useFavoriteContacts decrypts firstName before
  the localeCompare sort.

Test fixes
  - aes.test.ts: the "registry returns null for disabled tables"
    assertion now picks tasks + events as the disabled examples
    (messages + contacts both flipped on in this commit).
  - cycles.integration.test.ts:
    1. beforeEach installs a fresh MemoryKeyProvider with a real
       Web Crypto key so dayLogsStore.logDay can encrypt mood/notes
    2. The "no duplicate" upsert test decrypts the raw rows it reads
       directly from the table before asserting on the mood field
  - module-registry.test.ts (drive-by, unrelated): adds eventItems
    to the events appId snapshot to match the parallel module-registry
    refactor.

Verified: 20 test files, 262/262 tests passing.

Phase 6 will roll out to the remaining tables (tasks, events, plants,
meals, slides, etc.) and finally light up the settings/security UI
(lock state, manual rotate, recovery code opt-in).

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-07 19:28:26 +02:00
.changeset feat(versioning): add semantic versioning and changesets to all apps 2026-03-19 16:20:18 +01:00
.claude feat(manacore/web): wire TagField, FavoriteButton, ColorPicker into module UIs 2026-04-02 17:20:46 +02:00
.github chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
.husky fix(devtools): fix pre-commit hook - add eslint-config dep, remove type-check 2026-03-17 13:08:51 +01:00
apps feat(mana/web): encryption phase 5 — rollout to chat/dreams/memoro/contacts/cycles/finance 2026-04-07 19:28:26 +02:00
docker feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
docs feat(memoro): voice recording → mana-stt transcription pipeline 2026-04-07 18:48:41 +02:00
games chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
load-tests chore: rename mukke to music in infra, scripts, and CI/CD 2026-04-05 16:47:57 +02:00
NewAppIdeas/Roblox Reimagined chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
packages feat(cycles): add menstrual cycle tracking module 2026-04-07 14:35:33 +02:00
patches fix(traces): configure EAS Build for TestFlight and fix bot-services build 2026-03-17 13:16:38 +01:00
scripts feat(memoro): voice recording → mana-stt transcription pipeline 2026-04-07 18:48:41 +02:00
services test(mana-events): 35 server tests covering routes + sweeper 2026-04-07 19:02:54 +02:00
tests/e2e first implementation 2025-11-27 17:26:18 +01:00
.dockerignore make auth working 2025-11-26 01:31:12 +01:00
.editorconfig feat: add monorepo configuration and shared packages structure 2025-11-22 23:41:52 +01:00
.env.development feat(memoro): voice recording → mana-stt transcription pipeline 2026-04-07 18:48:41 +02:00
.env.macmini.example feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
.gitignore chore: misc fixes, new services, lockfile cleanup 2026-03-28 10:27:35 +01:00
.npmrc fix(monorepo): add .npmrc with node-linker=hoisted for EAS Build compatibility 2026-03-15 08:50:18 +01:00
.nvmrc feat: add monorepo configuration and shared packages structure 2025-11-22 23:41:52 +01:00
.prettierignore chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
.prettierrc.json fix(cicd): docker paths, formatting config, 2025-11-27 18:33:08 +01:00
CLAUDE.md chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
cloudflared-config.yml feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
docker-compose.dev.yml feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
docker-compose.macmini.yml fix(events): production wiring + polling resilience (quick wins) 2026-04-07 18:53:29 +02:00
eslint.config.mjs chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
gift-codes-2026-02-14.txt feat(gifts): add gift code creation script and initial codes 2026-02-14 11:23:08 +01:00
lint-staged.config.js chore: archive 17 standalone app servers (replaced by unified API) 2026-04-02 21:37:45 +02:00
mac-mini-setup.sh feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
package.json feat(events): add mana-events service + public RSVP flow (Phase 1b) 2026-04-07 14:27:48 +02:00
playwright.config.ts style: auto-format codebase with Prettier 2025-11-27 18:33:16 +01:00
pnpm-lock.yaml chore(workspace): unify vitest to ^4.1.2 across all packages 2026-04-07 13:58:29 +02:00
pnpm-workspace.yaml chore: delete 25 web-archived directories, remove stale stubs, clean workspace config 2026-04-03 13:03:49 +02:00
README.md chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
test-chat-auth.sh feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
TROUBLESHOOTING.md chore: complete ManaCore → Mana rename (docs, go modules, plists, images) 2026-04-07 12:26:10 +02:00
turbo.json feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00
vitest.config.ts feat: rename ManaCore to Mana across entire codebase 2026-04-05 20:00:13 +02:00

Mana Monorepo

Monorepo containing all Mana projects — a self-hosted multi-app ecosystem with shared packages and unified tooling.

Projects

Project Description Apps
mana Multi-app ecosystem platform Expo mobile, SvelteKit web
chat AI chat application NestJS backend, Expo mobile, SvelteKit web, Astro landing
todo Task management NestJS backend, SvelteKit web, Astro landing
calendar Calendar & scheduling NestJS backend, SvelteKit web, Astro landing
clock Pomodoro & time tracking NestJS backend, SvelteKit web, Astro landing
contacts Contact management NestJS backend, SvelteKit web
picture AI image generation NestJS backend, Expo mobile, SvelteKit web, Astro landing
cards Card/deck management NestJS backend, Expo mobile, SvelteKit web
zitare Daily inspiration quotes NestJS backend, Expo mobile, SvelteKit web, Astro landing
mukke Music player NestJS backend, SvelteKit web
planta Plant care tracker NestJS backend, SvelteKit web
storage Cloud storage NestJS backend, SvelteKit web
questions Q&A with web search SvelteKit web
skilltree Skill tree visualization NestJS backend, SvelteKit web
nutriphi Nutrition tracking NestJS backend, SvelteKit web
citycorners City guide NestJS backend, SvelteKit web, Astro landing
presi Presentation tool NestJS backend, SvelteKit web
photos Photo management NestJS backend, SvelteKit web

Getting Started

Prerequisites

  • Node.js 20+
  • pnpm 9.15.0+
  • Docker (for PostgreSQL, Redis, MinIO)

Installation

pnpm install

Development

# Start infrastructure (PostgreSQL, Redis, MinIO)
pnpm docker:up

# Start any app with auto DB setup
pnpm dev:chat:full
pnpm dev:todo:full
pnpm dev:calendar:full
pnpm dev:contacts:full

# Build & quality
pnpm run build
pnpm run type-check
pnpm run format

See CLAUDE.md for comprehensive development documentation.

Architecture

mana-monorepo/
├── apps/                    # Product applications
├── services/                # Microservices (auth, search, LLM, bots)
├── packages/                # Shared packages
├── docker/                  # Docker configuration
└── scripts/                 # Development & deployment scripts

Tooling

  • Package Manager: pnpm 9.15.0
  • Build System: Turborepo
  • Formatting: Prettier (tabs, single quotes, 100 char width)
  • Hosting: Mac Mini (self-hosted) via Docker + Cloudflare Tunnel
  • Analytics: Umami (stats.mana.how)

License

Private - All rights reserved