TenantAtlas/database/migrations
ahmido 8ae7a7234e feat/040-inventory-core (#43)
Summary

Implements Inventory Core (Spec 040): a tenant-scoped, mutable “last observed” inventory catalog + sync run logging, with deterministic selection hashing and safe derived “missing” semantics.

This establishes the foundation for Inventory UI (041), Dependencies Graph (042), Compare/Promotion (043), and Drift (044).

What’s included
	•	DB schema
	•	inventory_items (unique: tenant_id + policy_type + external_id; indexes; last_seen_at, last_seen_run_id)
	•	inventory_sync_runs (tenant_id, selection_hash/payload, status, started/finished, counts, error_codes, correlation_id)
	•	Selection hashing
	•	Deterministic selection_hash via canonical JSON (sorted keys + sorted arrays) + sha256
	•	Sync semantics
	•	Idempotent upsert (no duplicates)
	•	Updates last_seen_* when observed
	•	Enforces tenant scoping for all reads/writes
	•	Guardrail: inventory sync does not create snapshots/backups
	•	Missing semantics (derived)
	•	“missing” computed relative to latest completed run for same (tenant_id, selection_hash)
	•	Low confidence when latest run is partial/failed or had_errors=true
	•	Selection isolation (runs for other selections don’t affect missing)
	•	deleted is reserved (not produced here)
	•	Safety
	•	meta_jsonb whitelist enforced (unknown keys dropped; never fail sync)
	•	Safe error persistence (no bearer tokens / secrets)
	•	Locking to prevent overlapping runs for same tenant+selection
	•	Concurrency limiter (global + per-tenant) and throttling resilience (429/503 backoff + jitter)

Tests

Added Pest coverage for:
	•	selection_hash determinism (array order invariant)
	•	upsert idempotency + last_seen updates
	•	missing derived semantics + selection isolation
	•	low confidence missing on partial/had_errors
	•	meta whitelist drop (no exception)
	•	lock prevents overlapping runs
	•	no snapshots/backups side effects
	•	safe error persistence (no bearer tokens)

Non-goals
	•	Inventory UI pages/resources (Spec 041)
	•	Dependency graph hydration (Spec 042)
	•	Cross-tenant compare/promotion flows (Spec 043)
	•	Drift analysis dashboards (Spec 044)

Review focus
	•	Data model correctness + indexes/constraints
	•	Selection hash canonicalization (determinism)
	•	Missing semantics (latest completed run + confidence rule)
	•	Guardrails (no snapshot/backups side effects)
	•	Safety: error_code taxonomy + safe persistence/logging

Co-authored-by: Ahmed Darrazi <ahmeddarrazi@adsmac.local>
Reviewed-on: #43
2026-01-07 14:54:24 +00:00
..
0001_01_01_000000_create_users_table.php Initial commit from Specify template 2025-12-10 22:27:21 +01:00
0001_01_01_000001_create_cache_table.php Initial commit from Specify template 2025-12-10 22:27:21 +01:00
0001_01_01_000002_create_jobs_table.php Initial commit from Specify template 2025-12-10 22:27:21 +01:00
2025_12_10_000100_create_tenants_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000110_create_policies_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000120_create_policy_versions_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000130_create_backup_sets_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000140_create_backup_items_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000150_create_restore_runs_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_10_000160_create_audit_logs_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_11_121623_add_app_fields_to_tenants_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_11_122423_create_tenant_permissions_table.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_11_130000_add_soft_deletes_and_status_housekeeping.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_11_192942_add_is_current_to_tenants.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
2025_12_12_150000_add_rbac_fields_to_tenants.php Intune RBAC: graceful unsupported-account handling, health-check fixes, tests and docs updates 2025-12-13 01:25:06 +01:00
2025_12_12_151000_add_rbac_status_fields_to_tenants.php Intune RBAC: graceful unsupported-account handling, health-check fixes, tests and docs updates 2025-12-13 01:25:06 +01:00
2025_12_12_160000_add_rbac_summary_to_tenants.php Intune RBAC: graceful unsupported-account handling, health-check fixes, tests and docs updates 2025-12-13 01:25:06 +01:00
2025_12_12_170500_add_rbac_role_definition_columns_to_tenants.php Intune RBAC: graceful unsupported-account handling, health-check fixes, tests and docs updates 2025-12-13 01:25:06 +01:00
2025_12_13_212126_create_settings_catalog_definitions_table.php feat: merge 001-filament-json 2025-12-14 20:23:18 +01:00
2025_12_20_221547_create_settings_catalog_categories_table.php dev-merges/c709b36 (#3) 2025-12-21 23:15:12 +00:00
2025_12_22_004948_add_assignments_to_backup_items.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
2025_12_22_004957_add_group_mapping_to_restore_runs.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
2025_12_22_171525_add_assignments_to_policy_versions.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
2025_12_22_171545_add_policy_version_id_to_backup_items.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
2025_12_23_215901_create_bulk_operation_runs_table.php feat/005-bulk-operations (#5) 2025-12-25 13:32:36 +00:00
2025_12_23_215905_add_ignored_at_to_policies_table.php feat/005-bulk-operations (#5) 2025-12-25 13:32:36 +00:00
2025_12_24_002001_create_notifications_table.php feat/005-bulk-operations (#5) 2025-12-25 13:32:36 +00:00
2025_12_24_005055_increase_bulk_operation_runs_status_length.php feat/005-bulk-operations (#5) 2025-12-25 13:32:36 +00:00
2026_01_04_135956_add_environment_to_tenants_table.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
2026_01_04_135957_create_tenant_user_table.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
2026_01_04_135957_create_user_tenant_preferences_table.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
2026_01_05_011014_create_backup_schedules_table.php feat/032-backup-scheduling-mvp (#34) 2026-01-05 04:22:13 +00:00
2026_01_05_011034_create_backup_schedule_runs_table.php feat/032-backup-scheduling-mvp (#34) 2026-01-05 04:22:13 +00:00
2026_01_06_211013_add_user_id_to_backup_schedule_runs_table.php feat/032-backup-scheduling-mvp (#36) 2026-01-07 01:12:12 +00:00
2026_01_07_142719_create_inventory_items_table.php feat/040-inventory-core (#43) 2026-01-07 14:54:24 +00:00
2026_01_07_142719_create_inventory_sync_runs_table.php feat/040-inventory-core (#43) 2026-01-07 14:54:24 +00:00
2026_01_07_142720_create_inventory_items_table.php feat/040-inventory-core (#43) 2026-01-07 14:54:24 +00:00