docs(06-sonarqube-quality): close loop 06-05 — UNIFY complete

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-13 17:26:03 +01:00
parent eb5c9bf345
commit fbb3020180

View File

@@ -0,0 +1,149 @@
---
phase: 06-sonarqube-quality
plan: 05
subsystem: settings
tags: [php, refactoring, god-class, S1448, shoppro, allegro]
requires:
- phase: 06-04
provides: cognitive complexity fixes (S3776)
provides:
- ShopproOrderMapper — all order mapping methods extracted from ShopproOrdersSyncService
- ShopproProductImageResolver — image fetching logic extracted
- AllegroStatusMappingController — status mapping routes extracted from AllegroIntegrationController
- AllegroDeliveryMappingController — delivery mapping routes extracted
- ShopproOrdersSyncService reduced to 9 methods (orchestration only)
affects: ["07-*", "future-testing"]
tech-stack:
added: []
patterns: ["god class split via move-method — no logic change, only structural reorganization"]
key-files:
created:
- src/Modules/Settings/ShopproOrderMapper.php
- src/Modules/Settings/ShopproProductImageResolver.php
- src/Modules/Settings/AllegroStatusMappingController.php
- src/Modules/Settings/AllegroDeliveryMappingController.php
modified:
- src/Modules/Settings/ShopproOrdersSyncService.php
- src/Modules/Settings/AllegroIntegrationController.php
- src/Modules/Cron/CronHandlerFactory.php
- routes/web.php
key-decisions:
- "AllegroIntegrationController stays at 25 methods (not ≤15): file had 35 methods, not 30 as planned — full split requires AllegroImportScheduleService, deferred to next phase"
patterns-established:
- "god class split: extract mapper/resolver classes, inject via constructor, update factory composition"
duration: ~2h
started: 2026-03-13T00:00:00Z
completed: 2026-03-13T00:00:00Z
---
# Phase 06 Plan 05: God Classes Split — Summary
**ShopproOrdersSyncService split 39→9 methods via ShopproOrderMapper + ShopproProductImageResolver; AllegroIntegrationController split 35→25 methods via 2 new controllers — S1448 reduced from 6x to 2x.**
## Performance
| Metric | Value |
|--------|-------|
| Duration | ~2h |
| Started | 2026-03-13 |
| Completed | 2026-03-13 |
| Tasks | 3 completed (incl. 1 checkpoint) |
| Files modified | 8 |
## Acceptance Criteria Results
| Criterion | Status | Notes |
|-----------|--------|-------|
| AC-1: ShopproOrderMapper wydzielony | Pass | 24+ metod mapowania przeniesione; sync używa $this->mapper |
| AC-2: ShopproProductImageResolver wydzielony | Pass | resolveProductImagesForOrder + fetchPrimaryProductImageUrl |
| AC-3: ShopproOrdersSyncService ≤20 metod | Pass | 9 metod (sync + orchestration) |
| AC-4: AllegroIntegrationController podzielony | Partial | 25 metod (cel ≤15) — patrz Odchylenia |
| AC-5: Brak regresji | Pass | Checkpoint human-verify: approved |
## Accomplishments
- ShopproOrdersSyncService: 39 → 9 metod — najduższa klasa w projekcie skurczyła się o 75%
- 4 nowe pliki PHP, każdy z jedną odpowiedzialnością
- routes/web.php zaktualizowane — publiczne URL bez zmian, nowe kontrolery obsługują routing
- CronHandlerFactory wstrzykuje nowe zależności poprawnie
- Zero błędów składniowych (php -l na wszystkich plikach)
## Task Commits
Praca wykonana jako zestaw zmian uncommitted podczas APPLY (paused before UNIFY):
| Task | File | Zmiana |
|------|------|--------|
| Task 1 | ShopproOrderMapper.php | Nowy — 24+ metody mapowania |
| Task 1 | ShopproOrdersSyncService.php | Usunięto metody mapowania, wstrzyknięto mapper |
| Task 1 | CronHandlerFactory.php | Dodano ShopproOrderMapper do kompozycji |
| Task 2 | ShopproProductImageResolver.php | Nowy — image fetching |
| Task 2 | ShopproOrdersSyncService.php | Usunięto image methods, wstrzyknięto resolver |
| Task 3 | AllegroStatusMappingController.php | Nowy — 7 metod |
| Task 3 | AllegroDeliveryMappingController.php | Nowy — 9 metod |
| Task 3 | AllegroIntegrationController.php | Usunięto 10 metod do nowych kontrolerów |
| Task 3 | routes/web.php | Routing przepięty do nowych kontrolerów |
## Files Created/Modified
| File | Zmiana | Cel |
|------|--------|-----|
| `src/Modules/Settings/ShopproOrderMapper.php` | Nowy | Wszystkie metody mapowania danych zamówień Shoppro |
| `src/Modules/Settings/ShopproProductImageResolver.php` | Nowy | Pobieranie zdjęć produktów z API Shoppro |
| `src/Modules/Settings/AllegroStatusMappingController.php` | Nowy | Obsługa mapowań statusów Allegro (7 metod) |
| `src/Modules/Settings/AllegroDeliveryMappingController.php` | Nowy | Obsługa mapowań dostawy Allegro (9 metod) |
| `src/Modules/Settings/ShopproOrdersSyncService.php` | Zmodyfikowany | Orchestrator sync — 9 metod |
| `src/Modules/Settings/AllegroIntegrationController.php` | Zmodyfikowany | Główne ustawienia Allegro — 25 metod |
| `src/Modules/Cron/CronHandlerFactory.php` | Zmodyfikowany | Nowe zależności w kompozycji |
| `routes/web.php` | Zmodyfikowany | Routing do nowych kontrolerów |
## Decisions Made
| Decision | Rationale | Impact |
|----------|-----------|--------|
| AllegroIntegrationController pozostaje przy 25 metodach | Plik miał 35 metod (plan zakładał 30). Prywatne helpery (validate*, findImportSchedule, ensureDefaultSchedules, itp.) nie mogły być przeniesione bez nowej klasy serwisu | AC-4 częściowo — S1448 nadal narusza dla tego pliku; wymaga planu 06-07 lub kolejnej fazy |
## Deviations from Plan
### Summary
| Type | Count | Impact |
|------|-------|--------|
| Scope limit hit | 1 | AllegroIntegrationController 25 metod zamiast ≤15 |
**Total impact:** S1448 spada z 6x do 2x (zamiast planowanego 1x). Odchylenie dokumentowane, nie blokuje.
### Deferred Items
- `AllegroImportScheduleService` extraction — AllegroIntegrationController nadal ma 25 metod (S1448 violation). Wymaga wydzielenia logiki harmonogramów (`findImportSchedule`, `findStatusSyncSchedule`, `currentImportIntervalSeconds`, `ensureDefaultSchedulesExist`) do osobnej klasy.
## Issues Encountered
| Issue | Resolution |
|-------|------------|
| AllegroIntegrationController miał 35 metod, nie 30 | Przeniesiono 10 metod do 2 nowych kontrolerów — max możliwy podział bez nowej klasy serwisu |
## Next Phase Readiness
**Ready:**
- Phase 06 kompletna (6/6 planów zamknięte)
- S1448 violations: 6x → 2x (ShopproIntegrationsController + AllegroIntegrationController)
- Architektura modułu Settings bardziej modularna — łatwiejsze testowanie
**Concerns:**
- AllegroIntegrationController (25 metod) i ShopproIntegrationsController nadal naruszają S1448
- Oba mogą być adresowane w przyszłej fazie maintenance/quality
**Blockers:** None
---
*Phase: 06-sonarqube-quality, Plan: 05*
*Completed: 2026-03-13*