martin3r / platform-printing
Printing Service for Platform
dev-main
2025-09-09 09:13 UTC
This package is auto-updated.
Last update: 2025-09-09 09:13:30 UTC
README
Ein modulares Printing-System für die Platform mit CloudPRNT-Unterstützung.
Features
- Drucker-Management: Verwaltung von Druckern mit Benutzername/Passwort-Authentifizierung
- Drucker-Gruppen: Gruppierung von Druckern für gemeinsame Print Jobs
- Print Jobs: Modulübergreifende Print Job-Verwaltung
- CloudPRNT API: Kompatible API für CloudPRNT-Drucker
- Loose Coupling: Keine direkten Abhängigkeiten zwischen Modulen
Installation
- Service Provider in
composer.json
registrieren - Migrations ausführen:
php artisan migrate
- Config veröffentlichen:
php artisan vendor:publish --tag=printing-config
Verwendung
In anderen Modulen
use Platform\Printing\Traits\HasPrintJobs; class SalesDeal extends Model { use HasPrintJobs; // ... } // Print Job erstellen $deal->createPrintJob('deal_details', ['show_pricing' => true]); // Print Jobs für Gruppe erstellen $deal->createPrintJobsForGroup(1, 'deal_details');
CloudPRNT API
Die API ist unter /api/printing/
verfügbar:
POST /poll
- Drucker fragt nach JobsGET /job/{uuid}
- Job-Inhalt abrufenDELETE /confirm/{uuid}
- Job als abgeschlossen markierenPOST /error/{uuid}
- Job-Fehler melden
Datenmodell
Printers
name
: Name des Druckerslocation
: Standortusername
: CloudPRNT-Benutzernamepassword
: CloudPRNT-Passwortis_active
: Aktiv/Inaktiv
Printer Groups
name
: Name der Gruppedescription
: Beschreibungis_active
: Aktiv/Inaktiv
Print Jobs
printable_type
: Model-Klasse (polymorph)printable_id
: Model-ID (polymorph)template
: Template-Namedata
: Template-Daten (JSON)status
: Job-Statusprinter_id
: Spezifischer Drucker (optional)printer_group_id
: Drucker-Gruppe (optional)
Templates
Templates werden in der Config definiert:
'templates' => [ 'default' => 'Standard', 'deal_details' => 'Deal Details', 'ticket_summary' => 'Ticket Zusammenfassung', ],
Workflow
- User erstellt Print Job für ein Model (z.B. SalesDeal)
- Service erstellt PrintJob in der Datenbank
- Drucker fragt via CloudPRNT API nach Jobs
- Service antwortet mit Job-Details
- Drucker holt Job-Inhalt ab
- Drucker druckt und bestätigt
- Service markiert Job als abgeschlossen
Sicherheit
- Drucker-Authentifizierung via Username/Password
- Team-Isolation (Drucker sind team-spezifisch)
- UUID-basierte Job-Identifikation
- Logging aller API-Aufrufe
Erweiterung
Neue Templates
- Template in Config hinzufügen
generateJobContent()
inPrintingService
erweitern- Template-Logik implementieren
Neue Printable Models
HasPrintJobs
Trait hinzufügen- Template-Daten in
createPrintJob()
übergeben - Template-Logik in
PrintingService
erweitern