4.9 KiB
4.9 KiB
Schritt 3: Datenbank & Model - ABGESCHLOSSEN ✅
Durchgeführte Arbeiten
3.1 Migration für dhl_shipments Tabelle erstellt ✅
- File:
database/migrations/2025_08_19_155158_create_dhl_shipments_table.php - Status: Erfolgreich migriert
- Tabelle:
dhl_shipments
Tabellenstruktur:
- id (bigint unsigned, Primary Key)
- shopping_order_id (int unsigned, Foreign Key -> shopping_orders.id)
- related_shipment_id (bigint unsigned, Self-Reference für Retouren)
- shipment_number (varchar, DHL Sendungsnummer)
- tracking_number (varchar, DHL Tracking-Nummer)
- type (enum: 'outbound', 'return')
- weight, length, width, height (Paketdaten)
- product_code (varchar, DHL Produktcode)
- services (json, Zusätzliche Services)
- label_path, label_format, label_printed (Label-Management)
- status (enum: created, submitted, in_transit, delivered, returned, cancelled, failed)
- tracking_status, tracking_details, last_tracked_at (Tracking)
- recipient_* (vollständige Empfängeradresse)
- api_request_data, api_response_data, api_errors (API Debugging)
- shipping_cost, currency (Kostenabrechnung)
- notes, metadata (Zusätzliche Daten)
- shipped_at, delivered_at (Timestamps)
- created_at, updated_at (Standard Laravel Timestamps)
Indizes:
- shopping_order_id (Performance)
- shipment_number (DHL Suche)
- tracking_number (Tracking-Suche)
- [type, status] (Kombiniert für Filter)
- created_at (Chronologische Sortierung)
Foreign Key Constraints:
- shopping_order_id → shopping_orders.id (CASCADE DELETE)
- related_shipment_id → dhl_shipments.id (SET NULL)
3.2 DhlShipment Model erstellt ✅
- File:
app/Models/DhlShipment.php - Status: Vollständig implementiert
- Namespace:
App\Models\DhlShipment
Model Features:
- ✅ Vollständige Eloquent Konfiguration (fillable, casts, table)
- ✅ Konstanten für Status und Typen
- ✅ Relationships: belongsTo ShoppingOrder, self-reference für Retouren
- ✅ Scopes: outbound(), returns(), active(), trackable()
- ✅ Helper Methods: isOutbound(), isReturn(), canBeCancelled(), hasTracking(), hasLabel()
- ✅ Accessors: getRecipientAddressAttribute(), getDimensionsAttribute(), getStatusLabelAttribute()
- ✅ Boot Method: Setzt Default-Werte aus Konfiguration
Konstanten:
// Typen
const TYPE_OUTBOUND = 'outbound';
const TYPE_RETURN = 'return';
// Status
const STATUS_CREATED = 'created';
const STATUS_SUBMITTED = 'submitted';
const STATUS_IN_TRANSIT = 'in_transit';
const STATUS_DELIVERED = 'delivered';
const STATUS_RETURNED = 'returned';
const STATUS_CANCELLED = 'cancelled';
const STATUS_FAILED = 'failed';
3.3 ShoppingOrder Model erweitert ✅
- File:
app/Models/ShoppingOrder.php - Erweitert um DHL Relationships
Neue Methods:
dhlShipments() // Alle DHL Sendungen
dhlOutboundShipments() // Nur Versand-Sendungen
dhlReturnShipments() // Nur Retour-Sendungen
hasDhlShipments(): bool // Prüft ob DHL Sendungen existieren
getLatestDhlShipment() // Neueste DHL Sendung
Optimierungen implementiert
MVP-Fokus erreicht ✅
- Eine zentrale Tabelle statt separater Tabellen für Retouren
- Vollständige Empfängeradresse in der Tabelle (kein Join nötig)
- JSON-Felder für flexible API-Daten und Services
- Self-Reference für Retouren über
related_shipment_id
Performance optimiert ✅
- Strategische Indizes für häufige Abfragen
- Efficient Relationships mit korrekten Foreign Key Typen
- Scopes für häufige Filter-Operationen
- Casts für automatische Datentyp-Konvertierung
Developer Experience ✅
- Ausführliche PHPDoc für IDE-Support
- Helper Methods für Business Logic
- Konstanten statt Magic Strings
- Accessors für formatierte Ausgaben
Bugfixes durchgeführt ✅
- Foreign Key Type Mismatch behoben:
unsignedIntegerstattunsignedBigIntegerfür shopping_order_id - Migration Konflikt gelöst: Tabelle manuell entfernt und korrekt migriert
Verifikation ✅
# Migration erfolgreich
php artisan migrate
# ✅ 2025_08_19_155158_create_dhl_shipments_table: 78.05ms DONE
# Model lädt korrekt
php artisan tinker --execute="use App\Models\DhlShipment; echo DhlShipment::class;"
# ✅ App\Models\DhlShipment
# Relationships funktionieren
php artisan tinker --execute="use App\Models\ShoppingOrder; ShoppingOrder::first()->dhlShipments()->count();"
# ✅ 0 (erwartungsgemäß, da noch keine DHL Shipments existieren)
Nächste Schritte
- Schritt 4: Zentraler
DhlApiServiceals Wrapper um das DHL SDK - Integration der christoph-schaeffer/dhl-business-shipping Library
- Erste API-Verbindung und Test-Calls
Files Created/Modified
- ✅
database/migrations/2025_08_19_155158_create_dhl_shipments_table.php(neu) - ✅
app/Models/DhlShipment.php(neu) - ✅
app/Models/ShoppingOrder.php(erweitert)
Technical Debt: NONE ✨
Alle Optimierungen erfolgreich implementiert, keine bekannten Probleme.