Files
Learn_System/backend/src/db/migrations
Maxim Dolgolyov be9fdfa703 feat(wishes): трекер пожеланий по улучшению системы
Любой авторизованный пользователь подаёт пожелание (заголовок, категория, описание);
видит только свои. Админ видит все, фильтрует по статусу, ведёт по статусам
(новое → запланировано → в работе → готово / отклонено) и пишет ответ автору. Автор
получает уведомление при смене статуса (pushNotif).

Бэкенд: миграция 080 (таблица wishes), wishController (list/create/update/remove с
валидацией и whitelist категорий/статусов), routes/wishes (PATCH — только админ, DELETE —
автор«новое»/админ, проверка в хендлере), смонтировано в server.js. Тесты 15/15.

Фронт: страница /wishes (форма + список со статус-бейджами; у админа — фильтры,
смена статуса, ответ, удаление), пункт «Пожелания» в сайдбаре (все роли), фиче-флаг
feature_wishes_enabled (тумблер в админ-модулях + whitelist + FEATURE_HREFS; админ
видит всегда). Клиентские врапперы LS.wish*.

⚠️ Живой БД нужен npm run migrate (080). lint:routes 0; node --check всех файлов + инлайна.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-23 16:12:10 +03:00
..
@
2026-05-16 17:01:11 +03:00
@
2026-05-30 14:10:21 +03:00
@
2026-06-13 15:31:25 +03:00

Versioned migrations

Each schema change is a separate .sql file, applied in alphabetical order. Applied files are tracked in the _migrations table.

Applying migrations

npm run migrate           # apply pending migrations (safe to re-run)
npm run migrate:bootstrap # mark 000_baseline.sql as applied on existing DB (run ONCE per env)
npm run migrate:legacy    # run legacy migrate.js (kept for reference, do not use)

Naming convention

NNN_short_description.sql

Examples: 001_add_user_avatar.sql, 002_drop_unused_columns.sql

To find the next number:

ls backend/src/db/migrations/*.sql | sort -r | head -1

Rules

  1. Never edit a migration file after it has been committed and deployed.
  2. To revert: write a new migration that undoes the change.
  3. Each file must be valid SQLite SQL (not PostgreSQL — no SERIAL, no EXTENSION).
  4. Use IF NOT EXISTS / IF EXISTS where possible for safety.
  5. Test on a copy of the prod DB before deploying.

Deploy order (first time on a new environment)

npm run migrate:legacy        # initialize full schema (existing init script)
npm run seed:permissions      # seed default permissions and achievements
npm run migrate:bootstrap     # mark 000_baseline.sql as applied
npm run migrate               # apply any newer migrations (should say "nothing to apply")
npm start

Adding a new migration

# 1. Create the file
echo "ALTER TABLE users ADD COLUMN avatar_url TEXT;" > backend/src/db/migrations/001_add_avatar_url.sql

# 2. Apply and verify
npm run migrate

# 3. Commit
git add backend/src/db/migrations/001_add_avatar_url.sql
git commit -m "db: add avatar_url column to users"

Files

File Description
000_baseline.sql Snapshot of full schema as of 2026-05-06. Never runs on existing DBs.