Zum Inhalt springen

Automatisierungsregeln

Das Modul Automatisierungsregeln führt Aktionen (E-Mail, SMS, Statusänderung, Notiz, Kunden-Tag, Webhook) auf Grundlage von Ereignissen im Shop aus. Regeln definieren Sie im Panel WooCommerce > Automation Rules über eine React-SPA, und die Engine führt sie als Reaktion auf einen Trigger aus.

ElementBeschreibung
TriggerWooCommerce-Ereignis, das eine Regel auslöst (new_order, order_status_changed, …)
FilterLogische Bedingung (order_total > 100, geo_scope in eu, …)
ActionAuszuführende Operation (send_email, add_order_note, webhook, …)
Match modeall - alle Filter erfüllt, any - einer genügt
PriorityAusführungsreihenfolge (kleiner = früher)

Die Regeln werden in der Tabelle wp_polski_pro_automation_rules gespeichert. Ausführungen (matched/skipped, Dry Run, Aktionsergebnis, Fehler) gelangen in wp_polski_pro_automation_logs.

WertWann ausgelöst
new_orderwoocommerce_new_order
order_status_changedwoocommerce_order_status_changed
new_customeruser_register
cart_abandoned(Reserve - Integration mit AbandonedCartService)
product_savedsave_post_product

Verfügbare Felder in den Filtern (FilterField):

FeldQuelleOperatoren
order_totalWC_Order::get_total()equals, gt, lt, not_equals
order_statusWC_Order::get_status()equals, in, not_in
item_countWC_Order::get_item_count()gt, lt, equals
billing_countryISO 3166-1 alpha-2equals, in, not_in
shipping_countryISO 3166-1 alpha-2 (Fallback auf billing)equals, in, not_in
geo_scopepl, eu, eea, non_euequals
customer_emailWC_Order::get_billing_email()equals, contains
payment_methodWC_Order::get_payment_method()equals, in
shipping_methodListe der Methoden aus der Versandpositionin, not_in
product_idListe der Produkt-IDs in der Bestellungin, not_in
categoryListe der product_cat-IDs aus den Positionenin, not_in

Der Operator in / not_in akzeptiert eine durch Kommas getrennte Liste (PL,DE,FR).

Das Feld geo_scope gibt für eine Bestellung/einen Benutzer einen von vier Werten zurück:

WertBereich
plPolen (PL)
euEU-Länder (27 Mitgliedstaaten)
eeaEWR = EU + Norwegen, Island, Liechtenstein
non_euRest der Welt

Anwendungsbeispiel: Eine Regel sendet Kunden aus der EU (mit DSGVO-Hinweis) eine andere Marketing-E-Mail-Vorlage als Kunden außerhalb der EU.

TypParameter
send_emailto (optional), subject, body, marketing (boolean erzwingt Einwilligung)
send_smsDelegiert an polski_pro/automation/send_sms (erfordert SmsNotificationService)
change_order_statusstatus, note
add_order_notenote, customer_note (boolean)
add_customer_tagtag (speichert in user_meta polski_customer_tags)
webhookurl - POST mit {subject_type, subject_id}

Aktionen mit params.marketing = true werden übersprungen, wenn der Kunde keine gültige Marketing-Einwilligung in polski_consent_log hat. Der Filter polski_pro/automation/has_marketing_consent erlaubt es, die Standardlogik zur Einwilligungsprüfung zu ersetzen.

Um eine benutzerdefinierte Aktion hinzuzufügen (z. B. eine Integration mit FreshMail/GetResponse), verwenden Sie den Filter:

add_filter('polski_pro/automation/action', function ($override, $action, $subject, $dryRun) {
if ($action->type->value === 'send_email' && ($action->params['provider'] ?? '') === 'freshmail') {
if ($dryRun) {
return ['dry_run' => true, 'provider' => 'freshmail'];
}
// ... FreshMail-API-Aufruf ...
return ['provider' => 'freshmail', 'sent' => true];
}
return $override;
}, 10, 4);

Alle Endpunkte erfordern manage_woocommerce + den Header X-WP-Nonce.

MethodePfadBeschreibung
GET/polski-pro/v1/automation/rulesListe der Regeln
POST/polski-pro/v1/automation/rulesRegel erstellen
GET/polski-pro/v1/automation/rules/{id}Einzelne Regel abrufen
PUT/polski-pro/v1/automation/rules/{id}Regel aktualisieren
DELETE/polski-pro/v1/automation/rules/{id}Löschen + Bereinigung der Logs
POST/polski-pro/v1/automation/rules/{id}/dry-runSimulation an Bestellung/Benutzer (order_id oder user_id)
GET/polski-pro/v1/automation/logs?limit=200Audit-Log (max 500)
GET/polski-pro/v1/automation/schemaSchema der Trigger/Filter/Aktionen

Geben Sie im Regeleditor eine Order ID ein und klicken Sie auf Run dry run. Die Engine:

  1. Wertet die Filter gegen die angegebene Bestellung aus.
  2. Prüft die Marketing-Einwilligung.
  3. Führt die Aktionen im Dry-Run-Modus aus (ändert keinen Zustand) und gibt das geplante Ergebnis zurück.
  4. Speichert einen Eintrag im Audit-Log mit dem Flag dry_run = 1.
  • Indizes auf enabled, trigger_type, priority, group_label - die Engine ruft nur die zum Trigger passenden Regeln ab.
  • recent($limit) im AutomationLogRepository ist auf 500 Datensätze pro Abfrage begrenzt.
  • Webhooks haben ein Timeout von 10 s.