Backend: - service_auto module complet: router, service, schemas, 5 teste suites (22/22 passed) - 5 endpoints: GET /ping, /firme, /tip-deviz, /masini, POST /comenzi - SP_CREEAZA_COMANDA_PROTOTIP creat în MARIUSM_AUTO (VALID, 5.9ms) - oracle_pool.py: session_callback backward-compat patch - ROA_WEB user: grants SP-only confirmate (H3), mariusm_test pool switchat - pyproject.toml: integration pytest marker înregistrat Frontend: - ComandaNoua.vue: date reale din Oracle (firme/tip-deviz/masini), nu hardcodate - src/modules/service-auto/services/api.js: axios service cu Bearer token - src/router/index.js: rută /service-auto/comanda-noua Docs: - decision-log.md: verdict MERGE, toate 6 ipoteze CONFIRMED - learnings.md: 7 patterns reutilizabile - grants-audit.md: arhitectura multi-tenant + proxy auth analysis + V_NOM_FIRME loop - template-modul-oracle.md: rețetă completă pentru module Oracle noi - TODO-phase2.md: 7 items concrete Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
8.6 KiB
Săpt 1 Notes — Oracle POC
Date: 2026-04-11
Conectivitate
- Server:
central(10.0.20.121:1521/ROA, CONTAFIN_ORACLE) — PORT OPEN, direct (no tunnel needed) - Sync connect: 33ms | Queries: 0.6-3.3ms ✅
- Async connect_async: 22ms | Queries: 0.2-0.3ms ✅
Gate Correction 9 — Decizie
Decizie: sync-facade pattern (consistent cu oracle_pool.py existent)
Motivare: oracle_pool.py folosește deja oracledb.create_pool() (sync) + pool.acquire() (sync) + with cursor (sync) în async def. Serviciile service_auto vor urma același pattern pentru consistență arhitecturală. connect_async funcționează dar nu aduce beneficii față de sync-facade la latențele măsurate.
Schema Access
MARIUSM_AUTO.DEV_ORDL— acces OKMARIUSM_AUTO.DEV_TIP_DEVIZ— enum confirmat (7 tipuri, inch_validare corect)
Next Steps (Săpt 3)
- Audit grants
ROA_WEBpeMARIUSM_AUTO.* - Creare SP
SP_CREEAZA_COMANDA_PROTOTIPîn MARIUSM_AUTO (template în tabele-service-auto.md §12.2) - Auth path: adaugă
MARIUSM_AUTOcompany în.env+ test login JWT end-to-end
Săpt 3 — Execution Log
Task #1 — Grants audit (2026-04-11, oracle-agent)
ROA_WEBuser nu există în instanțaROA(toate cele 4 dicționare — DBA_USERS, DBA_TAB_PRIVS, DBA_SYS_PRIVS, DBA_ROLE_PRIVS — întorc 0 rânduri).CONTAFIN_ORACLEareDBArole → acces la MARIUSM_AUTO e viaSELECT/INSERT/UPDATE/DELETE/EXECUTE ANY ..., fără grants explicite. Asta explică de ce Săpt 1 a funcționat fără DBA work.- Decizie: fază A (Săpt 3) folosește CONTAFIN_ORACLE direct — nu e nevoie de DBA. Fază B (Săpt 4+) va crea ROA_WEB cu grants scope-limited pentru a proba ipoteza #3 (access blocat direct, permis doar via SP).
- Findings complete + script creare ROA_WEB:
docs/service-auto/grants-audit.md.
Task #3 — SP_CREEAZA_COMANDA_PROTOTIP (2026-04-11, oracle-agent)
SP source
- Locație:
docs/service-auto/SP_CREEAZA_COMANDA_PROTOTIP.sql - Signature:
(p_tip IN, p_id_masiniclient IN, p_solicitari IN VARCHAR2, p_id_firma IN, p_id_ordl OUT, p_nrord OUT) - Nrord generation:
SEQ_NR_LUCRARE.NEXTVAL(existing, unused —last_number=1) + prefixP<id_firma>-<seq>→ primul prototype produceP01-1. - Body: duplicate-check (paritate cu
pack_auto) + INSERT NOM_LUCRARI (id_mod=1200, id_lucrare auto viaTRG_NOM_LUCRARI_BEFOINS+SEQ_NOM_LUCRARI) + INSERT DEV_ORDL (coloane NOT NULL + client link). - Coloane sărite conștient:
id_inspector,id_asigurator,nr_dosar,kmint,termen,proc_tvav,id_part_ref,observatii,defectiuni— toate nullable, OK pentru prototype.
Execution
CREATE OR REPLACE PROCEDUREviacursor.execute(body)(trailing/stripped în Python pentru a nu fi trimis ca SQL statement invalid) → VALID fără compile errors.- Test call:
tip=1 (POST GARANTIE), id_masiniclient=2, solicitari="Prototype test — rollback imediat după verificare.", id_firma=1 → OUT p_id_ordl=411, p_nrord='P01-1' → verificare pre-rollback: rând în DEV_ORDL + NOM_LUCRARI cu id_lucrare=721, id_mod=1200, an=2026, luna=4 → conn.rollback() → post-rollback: 0 rows în ambele tabele ✅ - Confirmă: ipoteza #1 (oracledb → OUT NUMBER + OUT VARCHAR2 prin
cursor.var()), ipoteza #2 (SP cu RETURNING INTO peste două INSERT-uri cu trigger-uri BEFOINS), tranzacționalitate completă.
Note
SEQ_NR_LUCRAREnu se roll-back-uie (standard Oracle) — următorul test va produceP01-2,P01-3, etc. Util pentru cleanup: prototype rows sunt ușor de identificat prin prefixP.DBMS_LOB.SUBSTRfolosit în verificare pentru a citi CLOB-ulsolicitari_client— implicit VARCHAR2→CLOB conversion la INSERT a mers fără probleme (inclusiv diacritice).
Test #2 — Confirmare (2026-04-11, oracle-agent, săpt 3 exec)
tip=3 (REGIE, inch_validare=1), id_masiniclient=200 (CT-85-ROD), p_id_firma=1
→ SP call: 5.9ms ✅
→ OUT p_id_ordl=412, p_nrord='P01-2'
→ NOM_LUCRARI: id_lucrare=722, nrord='P01-2', id_mod=1200 ✅
→ DEV_ORDL: id_ordl=412, id_lucrare=722, id_tip=3, luna=4, an=2026 ✅
→ conn.rollback() → post-rollback: 0 rows ✅
Ipoteze confirmate Săpt 3:
- H1 ✅ —
oracledb.cursor.callproc()+cursor.var(NUMBER)/cursor.var(STRING)pentru OUT params - H2 ✅ — SP cu dual INSERT (NOM_LUCRARI → DEV_ORDL) + trigger BEFOINS RETURNING + tranzacționalitate completă
- H3 ⏳ — amânat Săpt 4 (necesită creare ROA_WEB via DBA; script ready în
grants-audit.md)
Task #5 — MARIUSM_AUTO în backend/.env (2026-04-11, oracle-agent)
Modificări .env
Adăugat entry mariusm_test în ORACLE_SERVERS JSON în toate cele 3 fișiere env:
backend/.env— activ imediatbackend/.env.prod— pentru viitoarea producțiebackend/.env.test— pentru runul de test
{"id":"mariusm_test","name":"MARIUSM AUTO (service-auto prototype)",
"host":"10.0.20.121","port":1521,
"user":"CONTAFIN_ORACLE","service_name":"ROA"}
Reasoning (fază A): mariusm_test are aceleași parametri de conectare ca și central (același server Oracle, același user DBA), dar ID distinct pentru:
- Pool separat per modul service_auto (pool sizing independent)
- Swap atomic la faza B: schimbăm
mariusm_test→ user=ROA_WEB, fără modificări cod
Parola: backend/secrets/mariusm_test.oracle_pass (copie din central.oracle_pass)
Verificare conectivitate via config
Config parsed: 4 servers (romfast, central, mariusm_test, vending) ✅
mariusm_test: password loaded (len=11) ✅
Direct connect: 22.1ms ✅
DEV_TIP_DEVIZ count=7 ✅
SP_CREEAZA_COMANDA_PROTOTIP STATUS=VALID ✅
Test JWT login — backend offline
Backend nu rulează (verificat via curl http://localhost:8000/health).
Pentru a testa login JWT end-to-end:
# 1. Pornește backend în mod test
./start.sh test
# 2. Testează login JWT cu credențialele de test (din CLAUDE.md)
curl -s -X POST http://localhost:8000/api/auth/login \
-H 'Content-Type: application/json' \
-d '{"username":"MARIUS M","password":"123","company_id":1}' | jq .
# 3. Verifică că token-ul JWT are câmpul companies[] cu MARIUSM_AUTO
# 4. Fă un request autentificat la viitorul endpoint service_auto:
# GET /api/service-auto/comenzi sau POST /api/service-auto/comanda
# 5. Oprește backend
./start.sh test stop
Blocat de: backend offline + task #4 stubs în progres (router/service TODO NotImplementedError) Next step Săpt 3+: după ce backend-agent completează Task #4 (router live), rulează secvența de mai sus.
Verificare Oracle-side a path-ului de login (oracle-agent, 2026-04-11)
Independent de backend, am mirror-at exact cele 3 interogări din
backend/modules/telegram/routers/auth_codes.py:292-349 direct pe Oracle
central pentru a de-risca testul JWT pending:
Step 1 — pack_drepturi.verificautilizator('MARIUS M', '123')
→ return: 803 (≠ -1 → autentificare validă, session id)
Step 2 — SELECT id_util, utilizator FROM UTILIZATORI WHERE UPPER(utilizator)='MARIUS M'
→ id_util=8, utilizator='MARIUS M'
Step 3 — SELECT ID_FIRMA,FIRMA,SCHEMA FROM V_NOM_FIRME
WHERE ID_FIRMA IN (SELECT ID_FIRMA FROM VDEF_UTIL_FIRME WHERE ID_UTIL=8 AND ID_PROGRAM=2)
→ 6 rows:
238 AXN schema=ACN
237 DANUBE GRAIN SERVICES schema=DANUBE
251 EMS schema=EMS
110 MARIUSM AUTO schema=MARIUSM_AUTO ← TARGET
167 MARIUSM AUTO SUC 1 ... schema=MARIUSM_AUTO
169 MARIUSM AUTO SUC 2 schema=MARIUSM_AUTO
3 rânduri în V_NOM_FIRME au schema='MARIUSM_AUTO' pentru MARIUS M, toate
cu cod_fiscal='RO1879855' (același CUI, rapoarte separate):
| id_firma | firma | rel |
|---|---|---|
| 110 | MARIUSM AUTO | parent (mama, id_mama=null) |
| 167 | MARIUSM AUTO SUC 1 ... | sucursală (id_mama=110) |
| 169 | MARIUSM AUTO SUC 2 | sucursală (id_mama=110) |
Concluzie: path-ul Oracle pentru login este 100% funcțional înainte de
pornirea backend-ului. Prototype-ul poate folosi default id_firma=110 în
frontend. Testul JWT HTTP (listat mai sus) e singurul pas care necesită backend
pornit; toate dependențele Oracle sunt verificate.
Decizie separată — pool mariusm_test vs. central: cel care a adăugat
entry-ul mariusm_test în ORACLE_SERVERS a ales izolare pool per-modul + swap
atomic la ROA_WEB în fază B. E compatibil cu path-ul de login: service_auto
folosește mariusm_test pool pentru queries/SP către schema MARIUSM_AUTO, în
timp ce login-ul rămâne pe central (sau pe mariusm_test, echivalent — same
credențiale în fază A).