Files
orderPRO/.paul/STATE.md
Jacek Pyziak 3443879f59 feat(127): polkurier integration foundation
Single-instance globalna konfiguracja polkurier.pl jako alternatywa
dla Apaczki: szyfrowany login + Token API, karta w hubie integracji
i realny test polaczenia przez apimetod=test_auth_api zweryfikowany
na zywym koncie operatora (Autoryzacja: 1).

ShipmentProviderRegistry netkniety - PolkurierShipmentService/
TrackingService w kolejnych fazach.

Kluczowe ustalenia kontraktu API (z SDK polkurier-sdk):
- POST https://api.polkurier.pl/ (jeden endpoint)
- JSON body: {authorization:{login,token}, apimetod, data}
- Sukces: top-level status === 'success' (nie 'ok')
- Blad: tresc w polu 'response' envelope'a
- Content-Type: application/json (strict, bez charset suffix)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-14 11:43:11 +02:00

6.2 KiB

Project State

Project Reference

See: .paul/PROJECT.md (updated 2026-05-07)

Core value: Sprzedawca moze obslugiwac zamowienia ze wszystkich kanalow sprzedazy i nadawac przesylki bez przelaczania sie miedzy platformami. Current focus: v3.7 Invoices + operational integrations - Phase 127 polkurier foundation UNIFY zakonczony, transition (commit + ROADMAP/PROJECT update) pending.

Current Position

Milestone: v3.7 Invoices (Fakturownia integration) - In progress Phase: 127 of TBD (polkurier Integration Foundation) - Complete Plan: 127-01 complete (SUMMARY.md created); live API verified (Autoryzacja: 1) Status: UNIFY complete, transition pending (git commit + decisions in PROJECT.md) Last activity: 2026-05-14 - Phase 127-01 UNIFY zakonczony, SUMMARY + changelog utworzone

Progress:

  • Milestone v3.7: [##########] ~99% (Phase 113-127 complete; transition pending)
  • Phase 127: [##########] 100%

Loop Position

Current loop state:

PLAN -> APPLY -> UNIFY
  done      done       done   [Loop complete - transition pending]

Session Continuity

Last session: 2026-05-14 Stopped at: Phase 127-01 UNIFY closed; SUMMARY.md created Next action: Phase transition (git commit feat(127): polkurier integration foundation + Decisions w PROJECT.md), potem wybor kolejnego kandydata v3.7 (np. PolkurierShipmentService albo invoice.created event) Resume file: .paul/ROADMAP.md

Pending parallel work

  • None — Phase 118, 121, 122 wszystkie zacommitowane (8f14851, 360eef1).

Git State

Last phase commit: c758ec7 feat(126): invoice GUS field mapping fix (JDG/KRS heuristic) Previous: 2ab461a feat(125): invoice_requested import fix + drop legacy is_invoice column Branch: main (5 commits ahead of origin/main)

Pending Actions

  • Manualne testy AC-1..AC-7 dla Phase 112 na zywej bazie (XAMPP online).
  • Backfill zamowienia #882 - operator robi recznie po wdrozeniu (poza zakresem planu).
  • Uruchom migracje gdy XAMPP online: php bin/migrate.php (delivery_statuses).
  • Recznie odtworzyc istniejace reguly automatyzacji z grupowymi kluczami (BREAKING z 108-02).
  • HostedSMS inbound replies: requires DCS/HostedSMS activation before implementation.
  • Phase 117 follow-up: run migration when XAMPP MySQL is online and manually test real SMSPLANET sends for Bearer token and key + password.
  • Phase 119 follow-up: composer install + vendor/bin/phpunit tests/Unit/OrderImportRepositoryTest.php to run the 3 new tests; manual smoke test re-syncing order #976 from shoppro to confirm total_paid=91.00 persists across re-import.
  • Phase 121 follow-up: manually verify SMSPLANET settings/test send, inbound webhook insertion, order SMS tab, and notification polling/browser notification.
  • Phase 121 transition note: git commit was not created during UNIFY because the worktree contains unrelated Phase 118/local dirty files; prepare a scoped commit manually.
  • Phase 122 follow-up: manually verify settings save/reload and real SMSPLANET test/order sends with non-empty and empty footer; manually trigger over-limit final body rejection in UI.
  • Phase 123 follow-up: wystaw nowy paragon i potwierdz items_json zawiera vat per pozycja; eksport XLSX z paragonem multi-rate (np. mix 23% + 8%) — sprawdz osobne wiersze; eksport "wybrane paragony" zachowuje breakdown.
  • Phase 123 deferred: RECEIPT-NET-FIX (ReceiptService::issue() zapisuje total_net=total_gross) — udokumentowane w .paul/codebase/todo.md.
  • Phase 124 follow-up: php bin/migrate.php (XAMPP MySQL online) — utworzy sms_templates. Operator nastepnie tworzy szablony manualnie z /settings/sms-templates.
  • Phase 124 follow-up: real smoke wysylki SMS z szablonu (zamowienie z paczka + skonfigurowana stopka SMSPLANET) — sprawdzic ze sms_messages.body ma stopke raz, finalna tresc <= 918 znakow.
  • Phase 124 follow-up: regresja Email — wyslij e-mail z istniejacym szablonem aby potwierdzic ze refaktor Email\VariableResolver na fasade nie zlamal EmailSendingService.
  • Phase 125 follow-up: uruchom php bin/migrate.php (XAMPP MySQL online) — backfill 7 zamowien + DROP COLUMN orders.is_invoice. Weryfikacja: SELECT id, invoice_requested FROM orders WHERE id=1089; -> 1; SHOW COLUMNS FROM orders LIKE 'is_invoice'; -> empty.
  • Phase 125 follow-up: ponowne uruchomienie migracji powinno byc no-op (ALTER TABLE orders COMMENT = 'phase-125 backfill no-op').
  • Phase 125 follow-up: zaimportuj nowe zamowienie shopPRO z firm_nip (bez kluczy w 5-elementowej liscie wczesniejszej heurystyki) -> potwierdz ze UI w zakladce Platnosci pokazuje zaznaczony checkbox „Klient prosi o fakture" i widoczny przycisk „Wystaw fakture".
  • Phase 121 transition note (rozwiązane): commit 360eef1 obejmuje Phase 121 i Phase 122 razem; per-faza hunk-split nie wykonany ze względu na nakładkowe modyfikacje plików.
  • Phase 126 follow-up: manual smoke /orders/1090/invoice/create (JDG, NIP 5170167517) -> "Imie i nazwisko"="JACEK PYZIAK", "Nazwa firmy"="Project-Pro Pyziak Jacek" niezmieniona; drugi smoke na zamowieniu spolki z aktywnym KRS; curl /api/nip/lookup?nip=5170167517 -> data.is_jdg=true.
  • Phase 127 follow-up: zaplanowac kolejna faze polkurier — PolkurierShipmentService (CreateOrder + GetLabel + OrderValuationV2 + AvailableCarriers mapping + UI mapowan metod dostawy + presety przesylek) — fundament + zweryfikowany kontrakt API gotowy.
  • Phase 127 follow-up: drugi krok — PolkurierTrackingService + wpisy w delivery_status_mappings (provider='polkurier').
  • Phase 127 follow-up: po polkurier shipment service rozwazyc fazy paczkomaty (InpostParcelMachines / PocztexPostOffices / Kurier48PostOffices API juz dostepne w SDK polkuriera).

Deferred to Next Milestones

  • Phase 68 - Code Deduplication Refactor (0/2 Planning, nigdy nie rozpoczety).
  • STAT-NET - netto shopPRO z API lub z order_items.tax_rate (.paul/TODO.md).
  • Mobile Orders List / Mobile Order Details / Mobile Settings.
  • INDEX-106-01 - indeksy DB dla query customer_returned_count: order_addresses(order_id, address_type), shipment_packages(order_id, delivery_status) (gdy dataset >50k wierszy).

Skill Requirements

  • sonar-scanner required after APPLY; Phase 116, Phase 117, Phase 121 and Phase 122 gaps documented because CLI was not available in PATH.