Preskočiť na obsah

Reguly automatyzacji

Tento obsah zatiaľ nie je dostupný vo vašom jazyku.

Modul Reguly automatyzacji uruchamia akcje (email, SMS, zmiana statusu, notatka, tag klienta, webhook) na podstawie zdarzen w sklepie. Reguly definiujesz w panelu WooCommerce > Automation Rules poprzez React SPA, a silnik wykonuje je w odpowiedzi na trigger.

ElementOpis
TriggerZdarzenie WooCommerce uruchamiajace regule (new_order, order_status_changed, …)
FilterWarunek logiczny (order_total > 100, geo_scope in eu, …)
ActionOperacja do wykonania (send_email, add_order_note, webhook, …)
Match modeall — wszystkie filtry spelnione, any — wystarczy jeden
PriorityKolejnosc wykonywania (mniejsze = wczesniej)

Reguly sa zapisywane w tabeli wp_polski_pro_automation_rules. Wykonania (matched/skipped, dry run, wynik akcji, blad) trafiaja do wp_polski_pro_automation_logs.

WartoscKiedy wystrzeliwane
new_orderwoocommerce_new_order
order_status_changedwoocommerce_order_status_changed
new_customeruser_register
cart_abandoned(rezerwa - integracja z AbandonedCartService)
product_savedsave_post_product

Pola dostepne w filtrach (FilterField):

PoleZrodloOperatory
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 do 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_methodLista metod z pozycji wysylkiin, not_in
product_idLista ID produktow w zamowieniuin, not_in
categoryLista ID product_cat z pozycji zamowieniain, not_in

Operator in / not_in przyjmuje liste rozdzielona przecinkami (PL,DE,FR).

Pole geo_scope zwraca jedna z czterech wartosci dla zamowienia/uzytkownika:

WartoscZakres
plPolska (PL)
euKraje UE (27 panstw czlonkowskich)
eeaEOG = UE + Norwegia, Islandia, Liechtenstein
non_euReszta swiata

Przyklad uzycia: regula wysyla inny szablon emaila marketingowego klientom z UE (z notka RODO) niz spoza UE.

TypParametry
send_emailto (opcjonalne), subject, body, marketing (boolean wymuszajace zgode)
send_smsDelegowane do polski_pro/automation/send_sms (wymaga SmsNotificationService)
change_order_statusstatus, note
add_order_notenote, customer_note (boolean)
add_customer_tagtag (zapisuje do user_meta polski_customer_tags)
webhookurl — POST z {subject_type, subject_id}

Akcje z params.marketing = true sa pomijane, jesli klient nie ma waznej zgody marketingowej w polski_consent_log. Filtr polski_pro/automation/has_marketing_consent pozwala zastapic domyslna logike sprawdzania zgody.

Aby dodac niestandardowa akcje (np. integracje z FreshMail/GetResponse), uzyj filtru:

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'];
}
// ... wywolanie API FreshMail ...
return ['provider' => 'freshmail', 'sent' => true];
}
return $override;
}, 10, 4);

Wszystkie endpointy wymagaja manage_woocommerce + naglowka X-WP-Nonce.

MetodaSciezkaOpis
GET/polski-pro/v1/automation/rulesLista regul
POST/polski-pro/v1/automation/rulesUtworzenie reguly
GET/polski-pro/v1/automation/rules/{id}Pobranie pojedynczej reguly
PUT/polski-pro/v1/automation/rules/{id}Aktualizacja reguly
DELETE/polski-pro/v1/automation/rules/{id}Usuniecie + czyszczenie logow
POST/polski-pro/v1/automation/rules/{id}/dry-runSymulacja na zamowieniu/uzytkowniku (order_id lub user_id)
GET/polski-pro/v1/automation/logs?limit=200Dziennik audytu (max 500)
GET/polski-pro/v1/automation/schemaSchemat triggerow/filtrow/akcji

W edytorze reguly podaj Order ID i kliknij Run dry run. Silnik:

  1. Ewaluuje filtry wzgledem podanego zamowienia.
  2. Sprawdza zgode marketingowa.
  3. Wykonuje akcje w trybie dry-run (nie modyfikuje stanu) i zwraca planowany rezultat.
  4. Zapisuje wpis w dzienniku audytu z flaga dry_run = 1.
  • Indeksy na enabled, trigger_type, priority, group_label — silnik pobiera tylko reguly pasujace do triggera.
  • recent($limit) w AutomationLogRepository jest ograniczone do 500 rekordow na zapytanie.
  • Webhooki maja timeout 10s.