Unified Quote Journal (parts_log) v3

- New unified append-only quote log table parts_log replaces three
  separate log tables (stock_log, partnumber_log_competitors, lot_log)
- Migrations 042-049: extend supplier, create parts_log/import_formats/
  ignore_rules, rework qt_lot_metadata composite PK, add lead_time_weeks
  to pricelist_items, backfill data, migrate ignore rules
- New services: PartsLogBackfillService, ImportFormatService,
  UnifiedImportService; new world pricelist type (all supplier types)
- qt_lot_metadata PK changed to (lot_name, pricelist_type); all queries
  now filter WHERE pricelist_type='estimate'
- Fix pre-existing bug: qt_component_usage_stats column names
  quotes_last30d/quotes_last7d (no underscore) — added explicit gorm tags
- Bible: full table inventory, baseline schema snapshot, updated pricelist/
  data-rules/api/history/architecture docs

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Mikhail Chusavitin
2026-03-21 17:25:54 +03:00
parent f73e3d144d
commit 5f8aec456b
40 changed files with 2294 additions and 124 deletions

View File

@@ -28,6 +28,7 @@ PriceForge is a price and pricelist manager built on top of MariaDB.
| [api.md](api.md) | All API endpoints |
| [operations.md](operations.md) | Config, commands, build, release |
| [history.md](history.md) | Architectural decisions and change log |
| [schema-baseline-2026-03-21.sql](schema-baseline-2026-03-21.sql) | Full DB schema as of 2026-03-21 (before migrations 042049) |
---