- apply_push now uses PRAGMA table_info() to get valid column names per
table and filters incoming data to only known columns, preventing
"no such column" SQLite errors from frontend-only fields like oracle_id
- Wrap each operation in try/except so one bad op doesn't abort the
whole batch; errors are returned in the conflicts list instead of 500
- Add server_default to all NOT NULL float/int columns so raw SQL
INSERT OR REPLACE without those fields still succeeds
- Align DB models with frontend schema.js:
- orders: add nr_comanda, client_nume, client_telefon, nr_auto,
marca_denumire, model_denumire, created_by
- order_lines: add norma_id, mecanic_id, ordine
- vehicles: add serie_sasiu, client_cod_fiscal (keep vin, client_cui
for REST API compat)
- catalog_*: rename nume → denumire to match frontend schema
- catalog_norme: align fields (cod, denumire, ore_normate)
- invoices: add serie_factura, modalitate_plata, client_cod_fiscal,
nr_auto, total_fara_tva, tva, total_general; keep total for compat
- appointments: add client_nume, client_telefon, data_ora, durata_minute,
status, order_id
- mecanici: add user_id, prenume, activ
- Fix seed.py to use denumire= instead of nome= after catalog rename
- Add 3 new sync push tests covering order insert with frontend fields,
unknown column filtering, and order_line with norma_id/mecanic_id/ordine
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
26 lines
1.3 KiB
Python
26 lines
1.3 KiB
Python
from sqlalchemy import Integer, String, Text
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
|
|
from app.db.base import Base, UUIDMixin, TenantMixin, TimestampMixin
|
|
|
|
|
|
class Vehicle(Base, UUIDMixin, TenantMixin, TimestampMixin):
|
|
__tablename__ = "vehicles"
|
|
nr_inmatriculare: Mapped[str] = mapped_column(String(20))
|
|
marca_id: Mapped[str | None] = mapped_column(String(36))
|
|
model_id: Mapped[str | None] = mapped_column(String(36))
|
|
an_fabricatie: Mapped[int | None] = mapped_column(Integer)
|
|
# VIN / serie sasiu (vin kept for REST API compat, serie_sasiu for frontend sync)
|
|
vin: Mapped[str | None] = mapped_column(String(17))
|
|
serie_sasiu: Mapped[str | None] = mapped_column(String(50))
|
|
tip_motor_id: Mapped[str | None] = mapped_column(String(36))
|
|
capacitate_motor: Mapped[str | None] = mapped_column(String(20))
|
|
putere_kw: Mapped[str | None] = mapped_column(String(20))
|
|
client_nume: Mapped[str | None] = mapped_column(String(200))
|
|
client_telefon: Mapped[str | None] = mapped_column(String(20))
|
|
client_email: Mapped[str | None] = mapped_column(String(200))
|
|
# client_cod_fiscal used by frontend; client_cui kept for REST API compat
|
|
client_cod_fiscal: Mapped[str | None] = mapped_column(String(20))
|
|
client_cui: Mapped[str | None] = mapped_column(String(20))
|
|
client_adresa: Mapped[str | None] = mapped_column(Text)
|