Gelöst Woocommerce Connector aktivierung erzeugt fataler Fehler - Aktivierungsproblem

pnmffm

Aktives Mitglied
17. Oktober 2018
6
0
Hallo ich habe Probleme bei der Aktivierung des Plugins bei Wordpress.
Kriege die Fehlermeldung: "Das Plugin kann nicht aktiviert werden, da es einen fatalen Fehler erzeugt."

Dachte erst es könnte wie hier beschrieben an der zu neuen WooCommerce Version liegen und habe auf die letzte kompatible Version (von v.3.4.7 auf v.3.4.5.) gedowngraded.
Aber das Problem bleibt bestehen...

Habe dann den integrity check drüber laufen lassen und bekomme relativ viele Warnungen unter "Produkte ohne Preis" angezeigt.
Schaue ich mir diese Beitrag-ID's in der Datenbank an, sind dies aber keine Produkte sondern nur gespeicherte Nachrichten von Contact-Form 7 welche durch Flamingo gespeichert werden. Diese haben den Post-Type "flamingo_inbound"

Kann das auch der Grund für den fatalen Fehler sein?

Connector v1.5.7
Woocommerce v3.4.5
WP v4.9.8

Vielen Dank im Voraus!
LG
 
Zuletzt bearbeitet:

pnmffm

Aktives Mitglied
17. Oktober 2018
6
0
Hey Tobias,

es ist zwar nicht viel zu sehen, aber ja klar...

Hier die Fehlermeldung beim Versuch den Connector zu aktivieren:
fataler-fehler.JPG

Hier der Warnungen vom integrity-check:
produkte-ohne-preis.JPG
 
Zuletzt bearbeitet:

T4DT.GmbH

Offizieller Servicepartner
SPBanner
6. November 2018
326
158
Hannover
Falls du eine sprechende Fehlermeldung suchst:
Fatal error: Uncaught Error: Call to undefined function jtlwcc_deactivate_plugins() in /www/htdocs/w01894ad/eminent. shop/wp-content/plugins/woo- jtl-connector/includes/JtlConnectorAdmin.php:50 Stack trace: #0 /www/htdocs/w01894ad/eminent.shop/wp-includes/class-wp-hook.php(286): JtlConnectorAdmin::plugin_activation('') #1 /www/htdocs/w01894ad/eminent.shop/wp-includes/class-wp-hook.php(310): WP_Hook->apply_filters('', Array) #2 /www/htdocs/w01894ad/eminent.shop/wp-includes/plugin.php(453): WP_Hook->do_action(Array) #3 /www/htdocs/w01894ad/eminent.shop/wp-admin/plugins.php(180): do_action('activate_woo-jt...') #4 {main} thrown in /www/htdocs/w01894ad/eminent.shop/wp-content/plugins/woo-jtl-connector/includes/JtlConnectorAdmin.php on line 50

Ich habe den gesamten Connector durchsucht und die angegebene Methode jtlwcc_deactivate_plugins() tatsächlich nicht gefunden. Wie heißt die Datei, in die Definition stehen sollte?
 

T4DT.GmbH

Offizieller Servicepartner
SPBanner
6. November 2018
326
158
Hannover
Diese Funktion wird definiert und verwendet. Vielleicht versuchen Sie ein händisches Update des Connectors.

Ich habe den Fehler gefunden und für meinen Kunden behoben:
Eure Version der definierten Funktion:
PHP:
function jtlwcc_deactivate_plugin() {
    deactivate_plugins( __FILE__ );
}

Korrekt müsste es lauten:
PHP:
function jtlwcc_deactivate_plugin(string $plugin) {
    deactivate_plugins( $plugin );
}

Bitte unbedingt an die Entwicklung weiter geben und schnellstmöglich fix rausgeben. Durch den Fehler ändert sich die Signatur der Methode. Das Plugin dürfte in dieser Version niemand aktiviert bekommen.
 

Jan Weskamp

Moderator
Mitarbeiter
19. August 2015
346
35
Ich habe den Fehler gefunden und für meinen Kunden behoben:
Eure Version der definierten Funktion:
PHP:
function jtlwcc_deactivate_plugin() {
    deactivate_plugins( __FILE__ );
}

Korrekt müsste es lauten:
PHP:
function jtlwcc_deactivate_plugin(string $plugin) {
    deactivate_plugins( $plugin );
}

Bitte unbedingt an die Entwicklung weiter geben und schnellstmöglich fix rausgeben. Durch den Fehler ändert sich die Signatur der Methode. Das Plugin dürfte in dieser Version niemand aktiviert bekommen.

Hallo T4DT.GmbH,

Ich bin der besagte Entwickler, der sich das mal anschauen sollte und ich muss dir sagen deine Lösung ist "falsch" bzw. nicht so gedacht ;)

PHP:
function jtlwcc_deactivate_plugin() {
    deactivate_plugins( __FILE__ );
}

Das hier ist korrekt. Es gab einen Bug in der 1.6.2 der durch das Refactoring aufgetreten ist. Wir bemühen uns stets solche Dinge zu vermeiden.

Und nun Explizit hierzu: "Durch den Fehler ändert sich die Signatur der Methode. Das Plugin dürfte in dieser Version niemand aktiviert bekommen. "

Es handelt sich hierbei nicht um eine "Methode", sondern um eine Wrapper-"Funktion". Diese wurde vom vorherigen Entwickler eingebaut um ggf. zusätzliche Logik auszuführen, wenn man das Plugin deaktiviert. Nur zur Ergänzung, eine Signatur kann sich nicht ändern. Vor allem wenn wir eine eigene Funktion schreiben, für die wir keine Parameter angedacht haben.
Das Aktivieren sollte wirklich ein Problem darstellen, allerdings konnte man von der 1.6.1 auf die 1.6.2 updaten, was zu Problemen führen könnte.

Die 1.6.3 funktioniert ohne diesen Fehler, das updaten könnte nur ein Problem werden.
Um das zu lösen einfach diese Zeile:

PHP:
function jtlwcc_deactivate_plugin() {
    jtlwcc_deactivate_plugins( __FILE__ );
}

gegen diese tauschen:

PHP:
function jtlwcc_deactivate_plugin() {
    deactivate_plugins( __FILE__ );
}

mfg

Jan W.
 

T4DT.GmbH

Offizieller Servicepartner
SPBanner
6. November 2018
326
158
Hannover
Ich will jetzt nicht päpstlicher sein als der Papst, daher gehe ich nicht weiter auf die Ausführungen ein, die zu dieser Herangehensweise geführt hat.

Jedoch ist eine Sache einfach und wichtig: Wenn ich eine Methode mit einem Parameter aufrufe und das geschieht im Plugin-Aktivierungsprozess:
PHP:
if ( jtlwcc_woocommerce_deactivated() ) {
            jtlwcc_deactivate_plugins( __FILE__ );
            add_action( 'admin_notices', 'jtlwcc_woocommerce_not_activated' );
            
        }
Unter Signatur einer Methode versteht man den Namen + Überladung. Im Connector in der Klasse JtlConnectorAdmin wird diese genauso verwendet.
In der Definition taucht der Übergabeparameter nicht auf, bzw. es wird schlicht keiner erwartet! Wenn das so gewollt ist, muss du halt die JtlConnectorAdmin korrigieren. An welcher Stelle du das machst ist gehüpft wie gesprungen.
Aber der Funktions-/Methodenaufruf ist syntaktisch schlicht und einfach falsch und muss korrigiert werden!
 
Ähnliche Themen
Titel Forum Antworten Datum
Neu WooCommerce und JTL Wawi lassen sich nicht verbinden WooCommerce-Connector 3
Variationsertikel erstellen und in Woocommerce einbinden JTL-Wawi 1.9 4
Neu kein Produkte trotz Upload in WooCommerce WooCommerce-Connector 1
Neu Plugin: WooCommerce Wallet oder Gutscheine mit JTL nutzen - Fehler in der MwSt User helfen Usern - Fragen zu JTL-Wawi 0
Neu Artikelupload WooCommerce langsam Schnittstellen Import / Export 1
Neu Sonderpreise von JTL zu Woocommerce WooCommerce-Connector 0
Neu Bestandskunden JTL Wawi als Kundenaccounts Woocommerce anlegen WooCommerce-Connector 3
Neu WPC Product Bundles for WooCommerce // automatische Funktionsumstellung durch JTL Wawi WooCommerce-Connector 0
Neu Woocommerce Bezahlung Synchronisation - ohne JTL Wawi Zahlungsmodul Funktion WooCommerce-Connector 2
Neu "Sonderartikel" in WooCommerce WooCommerce-Connector 1
Neu Wawi Kategorie verhindert Übertragung zu Woocommerce -> $logger must not be accessed before initialization WooCommerce-Connector 0
Neu JTL: "Führende" Datenbank -> Änderungen in WooCommerce WooCommerce-Connector 0
Neu WooCommerce-Kategorie Name wird nicht übertragen -> WooCommerce-Kategorie #1, #2, #3 wird als Name genommen WooCommerce-Connector 1
Neu JTL-Connector funktioniert nicht mehr WooCommerce-Connector 0
Neu Gibt es keinen Gambio Connector mehr mehr mit PHP8 und höher? Gambio-Connector 0
Neu JTL Connector - Shopify Abgleich. Bestellbestätigungsemails werden die ganze Zeit dem Kunden gemailt. Shopware-Connector 0
Neu Fehler bei Connector Shopify-Connector 2
Neu GPSR Produktverordnung JTL Connector Shopify User helfen Usern - Fragen zu JTL-Wawi 0
Neu Shopify Connector funktioniert nicht mehr, Fehlerlog anbei Shopify-Connector 10
Neu TSE Connector Vertrag kündigen Allgemeine Fragen zu JTL-POS 2
Neu Shopify Connector, Änderung der URL Onlineshop-Anbindung 0
Neu JTL-Connector / 2 Shops / Unterschiedliche Lagerbestände zuweisen Shopify-Connector 0
Neu JTL-ERP-Connector funktioniert ab 20.09.2024 nicht mehr mit Shopify!? Shopify-Connector 2
Neu Dringende Hilfe benötigt: JTL-Connector Fehler beim Shopware-Abgleich Shopware-Connector 15
Neu Für den Shop-Connector konnte kein Steuersatz zugeordnet werden. WooCommerce-Connector 1
Neu Prestashop Connector 2.0.0 ignoriert deaktivierte Überverkaufseinstellung bei Artikelupload PrestaShop-Connector 0
Neu Plugins für den Shopify Connector Shopify-Connector 1
Neu Dringende Hilfe benötigt: JTL-Connector Fehler beim Shopify-Abgleich trotz "200 OK" - Hat jemand eine Lösung? Shopify-Connector 1
Neu Schon ab JTL Starter parallel zu einem JTL CFE Shop: Gambio-Shop mit Connector 3.1.0 Gambio-Connector 0
Neu Bei Verkaufskanaldeaktivierung eines Child-Artikels löscht Prestashop Connector 2.0.0 den Parent-Artikel samt aller Child-Artikel des Parents PrestaShop-Connector 0
Neu Bitte implementiert ein rudimentäres Error-Handling im Connector! Shopify-Connector 0
Neu Fiskal Cloud Connector (FCC) 4.1.1 - verpflichtendes Update bis spätestens 31. Juli 2024? Allgemeine Fragen zu JTL-POS 5
Neu Staffelpreise werden von JTL-Connector nicht zu Shopify übertragen Shopify-Connector 7
Neu JTL-Connector leitet Bestellung ohne Rabatt an WaWi (PrestaShop) PrestaShop-Connector 0
Neu Keine Verbindung zwischen Woocomerce und Connector WooCommerce-Connector 3

Ähnliche Themen