Neu Mehrfaches triggern des HOOK_TOOLSGLOBAL_INC_BERECHNEVERSANDPREIS Hooks

AlexKimmig

Neues Mitglied
25. März 2022
4
0
Hallo miteinander,

ich arbeite aktuell an einer Entwicklung eines JTL- Shop 5.0 Plugins.
Dabei verwenden wir in der Bootstrap.php den Dispatcher um uns gegen diverse Hooks zu subscriben.

Die meisten Hooks (wie der HOOK_SMARTY_OUTPUTFILTER) werden einmalig beim entsprechenden Triggerpunkt ausgeführt.
Nun zum Problem: Die Hooks HOOK_TOOLSGLOBAL_INC_BERECHNEVERSANDPREIS & HOOK_CALCULATESHIPPINGFEES werden z.B. im Bestellvorgang pro Versandart 3x getriggered (Siehe Screenshot).

Der Hook ist wie im zweiten Screenshot gezeigt implementiert.

Das führt dann dazu, dass unser Plugin im Hintergrund unnötig viele API-Calls gegen den Versandanbieter stellt.

Woher kommt dieses Verhalten und gibt es eine entsprechende Konfiguration / Methodik damit der HOOK nur 1x ausgelöst wird?

Vielen Dank und beste Grüße
 

Anhänge

  • hooks.PNG
    hooks.PNG
    302 KB · Aufrufe: 9
  • implementation.PNG
    implementation.PNG
    25,5 KB · Aufrufe: 9

FMoche

Moderator
Mitarbeiter
15. Dezember 2014
1.369
347
Halle (Saale)
Ein Hook wir halt so oft aufgerufen wie die ihn ausführende Methode/Funktion - HOOK_TOOLSGLOBAL_INC_BERECHNEVERSANDPREIS also immer bei Aufruf von ShippingMethod::calculateShippingFees(). Da diese Methode oft aufgerufen wird (tlw. in einem Loop, z.B. für alle vorhandenen Versandarten), wird auch der Hook oft getriggert - ich verstehe also ehrlich gesagt deine Frage nicht ganz.
 

AlexKimmig

Neues Mitglied
25. März 2022
4
0
Ein Hook wir halt so oft aufgerufen wie die ihn ausführende Methode/Funktion - HOOK_TOOLSGLOBAL_INC_BERECHNEVERSANDPREIS also immer bei Aufruf von ShippingMethod::calculateShippingFees(). Da diese Methode oft aufgerufen wird (tlw. in einem Loop, z.B. für alle vorhandenen Versandarten), wird auch der Hook oft getriggert - ich verstehe also ehrlich gesagt deine Frage nicht ganz.
Hallo,

Wie gesagt ist es mir durchaus klar, dass der Hook für jede Versandart getriggered wird. Jedoch ist es mir nicht klar warum der selbe Hook pro Versandart Im Checkout jeweils 3x angestoßen wird. Warum sollten für eine Versandart 3x die Versandkosten ermittelt werden?
Dann benötigt man einen Cache, damit die Konsumierte API nicht unnötigerweise belastet wird.
Ist die Frage damit klarer?
 

FMoche

Moderator
Mitarbeiter
15. Dezember 2014
1.369
347
Halle (Saale)
Naja, wenn ich mir mal die Calls angucke, wird das bei der Liste der verfügbaren, der günstigsten und der bevorzugten Versandarten aufgerufen. Das sind schonmal 3.
Und ggf. nochmal bei der abschließenden Prüfung versandartenKorrekt(). Kann also durchaus angehen, dass das mehrfach für dieselbe Methode getriggert wird.
Da wirst du also dann nicht drum herum kommen, dir die Ergebnisse deines API-Calls ggf. irgendwo zwischenzuspeichern und anschließend zu prüfen, ob du ihn für diese Methode schon ausgeführt hast.
 
Ähnliche Themen
Titel Forum Antworten Datum
1.11.5 Weiterhin Absturz bei Aufruf des Zahlungsmoduls JTL-Wawi 1.11 6
Neu Eigene Felder des Artikels per Exportvorlage Auftrag auslesen Schnittstellen Import / Export 0
Neu Netto EK des letzten Monats berechnen User helfen Usern - Fragen zu JTL-Wawi 1
Neu Eingangsbestätigung des Shops erneut versenden Allgemeine Fragen zu JTL-Shop 2
Anfrage zur Einrichtung des Dashboards (Gewinnanzeige) in JTL-Wawi – Remote-Support über AnyDesk JTL-Wawi 1.10 6
Neu Labeldrucker Toshiba B-EV4 druckt nur 2/3 des Versandlabels User helfen Usern 1
Vote für debugging des Mobile Server Fehlers JTL-Wawi 1.11 1
JTL-Wawi stürzt beim Speichern des Shopify-Connectors jedes Mal ab JTL-Wawi 1.11 0
Neu Aktivierung des Kundenkontos per Bestätigungsemail Allgemeine Fragen zu JTL-Shop 5
Neu Falsche Währung auf Amazon-Rechnung des Kunden (externer Beleg) JTL-Wawi - Fehler und Bugs 3
Neu In welcher SQL Tabelle finde ich den Ansprechpartner des Herstellers? User helfen Usern - Fragen zu JTL-Wawi 2
Neu Erwartbares Chaos beim Einführung "Prüfung des Empfängernamens" ? Smalltalk 2
Neu Ameise Import - Kind-Artikel - Kurzbeschreibung/Beschreibung des Vaterartikel? User helfen Usern - Fragen zu JTL-Wawi 2
So aktivieren Sie FEFO (Zuweisung des zuerst ablaufenden Bestands) für Arbeitsaufträge. JTL-Wawi 1.10 0

Ähnliche Themen