Split the INC-only loader into a dataset-agnostic engine (pipeline.py, renamed from import_tickets.py) parameterized by a Dataset config, with thin per-type entrypoints inc/import_inc.py and crq/import_crq.py. CRQ shares INC's identical 32-column source schema and CDC change stream, so the engine is fully shared. - pipeline.py: Dataset config (name/table/prefixes/key_regex/post_apply); INC keeps the capture_history post-apply hook, CRQ has none yet. geocode_locations now unions tickets.crq (geocoding is cross-dataset: one gazetteer/budget). - crq/import_crq.py: drains automations/crq/changes/ from isptickets into tickets.crq (data layer + map; SLA/dashboard/history deferred). - migrations/13_crq_columns.sql: CRQ mirror of 03 — typed STORED generated columns + indexes on tickets.crq (reuses tickets.eat_ts()). - Deployment: Dockerfile/run_ingest.sh run both via `python -m`; pyproject packages inc/crq. Docs (README, implementation, deployment-and-operations, n8n export ref, phase-1) updated for the split + the one-time CRQ seed runbook. tickets.crq already exists (mig 01, LIKE tickets.inc) and is unioned into reporting.fn_tickets_for_map + resolve_ticket_geoms, so CRQ appears on the existing Tickets map once seeded. Verified locally: ruff-clean new files, engine lists/parses both streams against live S3 (crq=52 files, inc unaffected). Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
17 lines
804 B
Text
17 lines
804 B
Text
# fleettickets — copy to .env and fill in. NEVER commit the real .env.
|
|
|
|
# Shared database (the `tickets` schema lives in tracksolid_db; internal Docker host)
|
|
DATABASE_URL=postgresql://tracksolid_owner:<password>@timescale_db:5432/tracksolid_db
|
|
|
|
# S3 — source ticket CDC streams (isptickets bucket, automations/{inc,crq}/changes/<EAT-ts>.csv)
|
|
RUSTFS_ENDPOINT=https://s3.rahamafresh.com
|
|
RUSTFS_ACCESS_KEY=isptickets
|
|
RUSTFS_SECRET_KEY=<secret>
|
|
RUSTFS_REGION=us-east-1
|
|
TICKETS_BUCKET=isptickets
|
|
|
|
# Geocoder (keyed — public Nominatim rate-limits bulk)
|
|
GEOCODER_PROVIDER=locationiq # locationiq | opencage
|
|
GEOCODER_API_KEY=<key>
|
|
GEOCODER_MIN_INTERVAL_S=1.1 # throttle to provider TOS
|
|
GEOCODER_MAX_KM=25 # reject a location geocode this far from its cluster centroid
|