- Implemented ShopproPaymentStatusSyncService to handle payment status synchronization between Shoppro and Orderpro. - Added methods for resolving watched status codes, finding candidate orders, and syncing individual order payments. - Introduced ShopproStatusMappingRepository for managing status mappings between Shoppro and Orderpro. - Created ShopproStatusSyncService to facilitate synchronization of order statuses from Shoppro to Orderpro.
15 KiB
15 KiB
DB Schema
Status
- Projekt po resecie do trybu
users-only. - Aktualizuj ten plik przy kazdej zmianie migracji/schematu.
- 2026-03-02: Przywrocenie UI
Ustawienia > Baza danychnie wprowadza zmian w schemacie. - 2026-03-02: Dodano tabele statusow (grupy + statusy) dla nowej zakladki
Ustawienia > Statusy. - 2026-03-02: Przygotowano draft generycznego schematu zamowien (bez aktywnej migracji) w
database/drafts/20260302_orders_schema_v1.sql. - 2026-03-03: Wdrozono generyczne tabele zamowien na bazie docelowej skryptem
bin/deploy_and_seed_orders.php(bez migratora SQL). - 2026-03-03: Dodano UI
Zamowienia > Lista zamowien- bez zmian schematu (wykorzystuje istniejace tabele domeny zamowien). - 2026-03-03: Dodano UI
Zamowienia > Szczegoly zamowienia(GET /orders/{id}) - bez zmian schematu. - 2026-03-04: Dodano tabele
allegro_integration_settingspod konfiguracje OAuth2 Allegro i tokeny dostepowe. - 2026-03-04: Dodano harmonogram crona
allegro_token_refresh(co 3600s, priorytet 10, max 3 proby). - 2026-03-04: Dodano reczny import pojedynczego zamowienia Allegro - bez zmian schematu (wykorzystuje istniejace tabele domeny zamowien).
- 2026-03-04: Dodano tabele
allegro_order_status_mappingsdo mapowania statusow Allegro na statusy orderPRO. - 2026-03-04: Zmieniono
allegro_order_status_mappings.orderpro_status_codena nullable, aby zapisac statusy pobrane z Allegro przed przypisaniem mapowania. - 2026-03-04: Dodano rozwiazywanie miniatur pozycji zamowien z mapowania produktu orderPRO (
product_channel_map+product_images) - bez zmian schematu. - 2026-03-04: Dodano diagnostyke importu miniatur Allegro (alerty przyczyn brakow) - bez zmian schematu.
- 2026-03-04: Dodano harmonogram
allegro_orders_import(auto-import zamowien Allegro) oraz rozszerzonointegration_order_sync_stateo kolumny kursora sync (last_synced_order_updated_at,last_synced_source_order_id,last_success_at) - migracja20260304_000027_add_allegro_orders_import_schedule.sql. - 2026-03-04: Dodano zakladke
Ustawieniaw integracji Allegro z konfiguracja interwalu importu zamowien; zapis aktualizuje istniejacy rekordcron_schedules(job_type=allegro_orders_import) - bez zmian schematu. - 2026-03-04: Rozszerzono zakladke
Ustawieniaintegracji Allegro o kierunek synchronizacji statusow i interwal synchronizacji statusow; zapis doapp_settings(allegro_status_sync_direction,allegro_status_sync_interval_minutes) - bez zmian schematu. - 2026-03-04: Dodano harmonogram
allegro_status_sync(cron synchronizacji statusow) + defaultyapp_settingsdla kierunku i interwalu status sync - migracja20260304_000028_add_allegro_status_sync_schedule.sql. - 2026-03-04: Import Allegro mapuje forme wysylki do
orders.external_carrier_idiorders.external_carrier_account_id- bez zmian schematu. - 2026-03-05: Dodano tabele
order_activity_log— uniwersalny log aktywnosci zamowien (zmiany statusow, platnosci, przesylki, faktury, wiadomosci itp.). - 2026-03-05: Dodano tabele
apaczka_integration_settingspod konfiguracje klucza API Apaczka. - 2026-03-05: Dodano tabele
inpost_integration_settingspod konfiguracje integracji InPost ShipX. - 2026-03-06: Dodano kolumne
carrierdo tabeliallegro_delivery_method_mappings(default 'allegro') - umozliwia mapowanie na roznych przewoznikow (Allegro, InPost). - 2026-03-06: Wdrozono migracje
20260302_000019_add_internal_order_number_to_orders.sql- kolumnainternal_order_numberVARCHAR(11) UNIQUE w tabeliorders, formatOPXXXXXXXXX(np.OP000000001); backfill istniejacych rekordow; UI: lista i szczegoly zamowien wyswietlaja numer wewnetrzny jako glowny identyfikator. - 2026-03-04: Poprawiono prezentacje daty zamowienia na liscie (
fallback ordered_at -> source_created_at -> source_updated_at -> fetched_at) - bez zmian schematu. - 2026-03-08: Rozpoczeto ujednolicanie integracji - migracja
20260308_000037_unify_integrations_base_links.sql:- dodano
integration_iddo tabelallegro_integration_settings,apaczka_integration_settings,inpost_integration_settings, - dodano FK/UNIQUE 1:1 z tabela
integrations, - dodano/uzupelniono rekordy bazowe providerow (
allegro,apaczka,inpost) wintegrations.
- dodano
- 2026-03-08: Dodano UI i endpointy konfiguracji
shopPRO(wieloinstancyjnie) w oparciu o istniejaca tabeleintegrations(type=shoppro) - bez zmian schematu. - 2026-03-08: Dodano mapowanie statusow dla
shopPRO(zakladkaStatusy) z zapisem do istniejacej tabeliorder_status_mappingsperintegration_id- bez zmian schematu. - 2026-03-08: Dodano migracje naprawcza
20260308_000038_ensure_order_status_mappings_table.sql(uzupelnia brakujaca tabeleorder_status_mappingsw srodowiskach z niepelna historia migracji). - 2026-03-08: Dodano migracje naprawcza
20260308_000039_ensure_integrations_fetch_columns.sql(uzupelnia brakujace kolumnyorders_fetch_enablediorders_fetch_start_datewintegrations). - 2026-03-08: Dodano migracje
20260308_000040_ensure_shoppro_orders_import_schedule.sql(seed/naprawa harmonogramucron_schedulesdla jobashoppro_orders_import) - bez zmian schematu tabel. - 2026-03-08: Dodano migracje
20260308_000041_ensure_shoppro_status_sync_schedule_and_direction.sql(seed/naprawa harmonogramucron_schedulesdla jobashoppro_order_status_syncoraz uzupelnienie kolumnyintegrations.order_status_sync_directionw srodowiskach niezgodnych). - 2026-03-08: Dodano migracje
20260308_000042_ensure_shoppro_payment_sync_schedule_and_columns.sql:- uzupelnienie kolumny
integrations.payment_sync_status_codes_json(JSON) dla konfiguracji statusow objetych kontrola platnosci, - seed/naprawa harmonogramu
cron_schedulesdla jobashoppro_payment_status_sync(domyslnie 600s, priorytet 105).
- uzupelnienie kolumny
- 2026-03-08: Dodano migracje
20260308_000043_create_shoppro_delivery_method_mappings_table.sql:- nowa tabela
shoppro_delivery_method_mappings(mapowanie form dostawy perintegration_id), - tabela przechowuje mapowanie formy shopPRO na usluge Allegro WZA/InPost (
allegro_delivery_method_id,allegro_credentials_id,allegro_carrier_id,allegro_service_name,carrier).
- nowa tabela
- 2026-03-08: Poprawiono mapowanie importu zamowien shopPRO (kwoty i miniatury pozycji) - bez zmian schematu bazy.
- 2026-03-08: Poprawiono mapowanie danych wysylki shopPRO (paczkomat/punkt odbioru + kontakt klienta + koszt transportu) - bez zmian schematu bazy.
Tabele
users
- Uzytkownicy panelu.
- Klucz unikalny:
email.
order_status_groups
- Grupy statusow zamowien zarzadzane z UI.
- Kolumny:
id(PK, int unsigned, AI),name(varchar 120),code(varchar 64, UNIQUE),color_hex(char 7, domyslnie#64748b),sort_order(int, domyslnie0),is_active(tinyint(1), domyslnie1),created_at,updated_at.
- Indeksy:
order_status_groups_code_unique(UNIQUE:code),order_status_groups_sort_order_idx(sort_order).
order_statuses
- Statusy przypisane do grup statusow.
- Kolumny:
id(PK, int unsigned, AI),group_id(FK ->order_status_groups.id),name(varchar 120),code(varchar 64, UNIQUE),sort_order(int, domyslnie0),is_active(tinyint(1), domyslnie1),created_at,updated_at.
- Indeksy:
order_statuses_code_unique(UNIQUE:code),order_statuses_group_sort_idx(group_id,sort_order,id).
- Klucze obce:
order_statuses_group_fk:group_id->order_status_groups.id(ON DELETE CASCADE,ON UPDATE CASCADE).
Domena zamowien (generyczna)
- Wdrozone tabele:
ordersorder_addressesorder_itemsorder_paymentsorder_shipmentsorder_documentsorder_notesorder_status_historyorder_tags_dictorder_tag_linksintegration_order_sync_state
- Charakterystyka:
- schema neutralna wzgledem dostawcy API (pola
source_*,external_*), - kolekcje zamowienia rozdzielone na osobne tabele 1:N,
payload_jsondostepne dla diagnostyki/replay,- historia zmian statusow utrzymywana w
order_status_history.
- schema neutralna wzgledem dostawcy API (pola
integration_order_sync_state
- Kursor synchronizacji importu zamowien dla integracji (uzywany przez cron auto-importu Allegro).
- Kolumny:
integration_id(PK),last_synced_order_updated_at(datetime, nullable) lub historycznielast_synced_external_updated_at,last_synced_source_order_id(varchar, nullable) lub historycznielast_synced_external_order_id,last_run_at(datetime),last_success_at(datetime),last_error(varchar 500),created_at,updated_at.
order_status_mappings
- Mapowanie statusow zamowien shopPRO na statusy orderPRO per instancja integracji.
- Kolumny:
id(PK, int unsigned, AI),integration_id(int unsigned, FK ->integrations.id),shoppro_status_code(varchar 64),shoppro_status_name(varchar 128, nullable),orderpro_status_code(varchar 64),created_at,updated_at.
- Indeksy:
order_status_mappings_integration_shoppro_unique(UNIQUE:integration_id,shoppro_status_code),order_status_mappings_integration_idx(integration_id),order_status_mappings_orderpro_idx(orderpro_status_code).
- Klucze obce:
order_status_mappings_integration_fk:integration_id->integrations.id(ON DELETE CASCADE,ON UPDATE CASCADE).
allegro_integration_settings
- Konfiguracja OAuth i sync dla integracji Allegro per srodowisko (
sandbox|production) zarzadzana zUstawienia > Integracje > Allegro. - Kolumny:
id(PK, tinyint unsigned),integration_id(int unsigned, UNIQUE, FK ->integrations.id),environment(varchar 16,sandbox|production),client_id(varchar 128),client_secret_encrypted(text),redirect_uri(varchar 255),orders_fetch_enabled(tinyint(1), domyslnie0),orders_fetch_start_date(date),access_token_encrypted(mediumtext),refresh_token_encrypted(mediumtext),token_type(varchar 32),token_scope(varchar 255),token_expires_at(datetime),connected_at(datetime),created_at,updated_at.
- Indeksy:
allegro_integration_settings_environment_idx(environment),allegro_integration_settings_token_expires_at_idx(token_expires_at),allegro_integration_settings_integration_unique(integration_id, UNIQUE).
allegro_order_status_mappings
- Mapowanie kodow statusow Allegro na kody statusow orderPRO.
- Kolumny:
id(PK, int unsigned, AI),allegro_status_code(varchar 64, UNIQUE),allegro_status_name(varchar 120),orderpro_status_code(varchar 64),created_at,updated_at.
- Indeksy:
allegro_order_status_mappings_code_unique(UNIQUE:allegro_status_code),allegro_order_status_mappings_orderpro_code_idx(orderpro_status_code).
order_activity_log
- Uniwersalny log aktywnosci zamowienia (zmiany statusow, platnosci, przesylki, faktury, wiadomosci itp.).
- Kolumny:
id(PK, bigint unsigned, AI),order_id(FK ->orders.id, CASCADE),event_type(varchar 32) — typ zdarzenia:status_change,payment,invoice,shipment,message,document,import,note,summary(varchar 255) — czytelny opis zdarzenia,details_json(json, nullable) — dodatkowe dane strukturalne,actor_type(varchar 16, domyslniesystem) —system,user,import,api,sync,actor_name(varchar 128, nullable) — nazwa uzytkownika lub identyfikator systemu,created_at.
- Indeksy:
order_activity_log_order_created_idx(order_id,created_at),order_activity_log_event_type_idx(event_type).
integrations
- Bazowa tabela wszystkich instancji integracji (model docelowy pod wielu providerow i wiele kont per provider).
- Kolumny:
id(PK, int unsigned, AI),type(varchar 32, np.allegro,apaczka,inpost,shoppro),name(varchar 128, unikalne w obrebietype),base_url(varchar 255),api_key_encrypted(text, nullable),timeout_seconds(smallint unsigned),is_active(tinyint(1)),orders_fetch_enabled(tinyint(1)),orders_fetch_start_date(date, nullable),order_status_sync_direction(varchar 32),payment_sync_status_codes_json(json, nullable; lista kodow statusow orderPRO, dla ktorych cron ma sprawdzac oplacenie zamowien),- pola diagnostyki testu (
last_test_status,last_test_http_code,last_test_message,last_test_at), created_at,updated_at.
shoppro_delivery_method_mappings
- Mapowanie form dostawy shopPRO na uslugi dostawy Allegro WZA/InPost per instancja integracji.
- Kolumny:
id(PK, int unsigned, AI),integration_id(int unsigned, FK ->integrations.id),order_delivery_method(varchar 200),carrier(varchar 50; np.allegro,inpost),allegro_delivery_method_id(varchar 128),allegro_credentials_id(varchar 128, nullable),allegro_carrier_id(varchar 128, nullable),allegro_service_name(varchar 255, nullable),created_at,updated_at.
- Indeksy:
shoppro_dm_mapping_unique(UNIQUE:integration_id,order_delivery_method),shoppro_dm_mapping_integration_idx(integration_id).
- Klucze obce:
shoppro_dm_mapping_integration_fk:integration_id->integrations.id(ON DELETE CASCADE,ON UPDATE CASCADE).
apaczka_integration_settings
- Tabela kompatybilnosci dla integracji Apaczka (
id = 1); sekret API jest utrzymywany bazowo wintegrations.api_key_encrypted. - Kolumny:
id(PK, tinyint unsigned),integration_id(int unsigned, UNIQUE, FK ->integrations.id),api_key_encrypted(text, nullable),created_at,updated_at.
inpost_integration_settings
- Tabela ustawien specyficznych InPost ShipX (
id = 1); token API utrzymywany bazowo wintegrations.api_key_encrypted. - Kolumny:
id(PK, tinyint unsigned),integration_id(int unsigned, UNIQUE, FK ->integrations.id),api_token_encrypted(text, nullable),organization_id(varchar 50, nullable),environment(enum: sandbox, production),default_dispatch_method(enum: pop, parcel_locker, courier),default_dispatch_point(varchar 50, nullable),default_insurance(decimal 10,2, nullable),default_locker_size(enum: small, medium, large),default_courier_length,default_courier_width,default_courier_height(smallint unsigned),label_format(enum: Pdf, Zpl, Epl),weekend_delivery,auto_insurance_value,multi_parcel(tinyint 0/1),created_at,updated_at.
Zasady aktualizacji
- Po kazdej migracji dopisz:
- nowe/zmienione tabele i kolumny,
- indeksy i klucze obce,
- wplyw na dane i kompatybilnosc wsteczna.
Drafty (nieaktywne)
database/drafts/20260302_orders_schema_v1.sql:- propozycja normalizacji domeny zamowien pod integracje zewnetrzne (
orders,order_items,order_status_history, platnosci, wysylki, dokumenty, notatki, tagi, sync-state), - plik nie jest odpalany przez obecny migrator (
database/migrations/*.sql).
- propozycja normalizacji domeny zamowien pod integracje zewnetrzne (
bin/deploy_and_seed_orders.php:- techniczny skrypt wdrozeniowy, ktory aplikuje schema z draftu i opcjonalnie seeduje dane testowe.