2-Faktor-Authentisierung für Backend-Logins zusätzlich zu Benutzername und Passwort
+
Authentisierung wird nur bei Benutzerkonten gezeigt, die dieses aktiviert haben - sonst nur Standardanmeldung
+
die Basis der Passwortgenerierung wird für jedes Benutzerkonto individuell angelegt
+
Einrichtung des Zugangs in der Auth-App kann durch scanbaren QR-Code oder kopierbare Zeichenkette erfolgen
+
Validierung der Einmalpassworte und Generierung der QR-Codes werden ausschließlich innerhalb des Shops durchgeführt - keine Kommunikation nach außen nötig
Im Ordner docs finden Sie den Ordner Precheck. Mit dessen Inhalt können Sie die Mindestanforderungen auf Ihrem
+Server direkt prüfen. Kopieren Sie die enthaltenen Dateien und Ordner unverändert in das source-Verzeichnis Ihres
+installierten OXID-Shops. Rufen Sie nun über Ihren Browser die folgende Adresse auf:
Beachten Sie, dass die Ihnen vorliegende Modulversion entsprechend für PHP 5.6, PHP 7.0, PHP 7.1 oder PHP 7.2 kompatibel ist. Im Zweifelsfall kontaktieren Sie uns und nennen den für Ihren Shop genutzten Decoder und die PHP-Version.
+
Kontrollieren Sie bitte auch, ob diese Modulversion für die von Ihnen eingesetzte Shopedition (Community Edition (CE), Professional Edition (PE) oder Enterprise Edition (EE)) ausgelegt ist.
Löschen Sie den Ordner totp und seine enthaltenen Elemente aus dem Verzeichnis source/modules/d3 Ihres Shops.
+Bestätigen Sie anschließend im Shopadmin unter Erweiterungen -> Module -> Installierte Shop-Module die Nachricht:
+
+
Es gibt registrierte Erweiterungen im eShop, deren Verzeichnis nicht vorhanden ist.
+Möchten Sie alle Modulinformationen einschließlich Konfigurationseinstellungen und Blockinformationen für Templates löschen?
Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des source- und vendor-Verzeichnisses). Führen Sie Sie dort diesen Befehl aus:
+
php composer remove d3/totp --no-update
+
+
+
Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+
+
Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.
Deaktivieren Sie das Modul 2-Faktor-Authentisierung über den Shopadmin Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Deaktivieren.
Deaktivieren Sie alle vorhandenen Erweiterungen, die auf dem Modul 2-Faktor-Authentisierung aufbauen und löschen bitte alle Dateien dieser Erweiterungen. Entfernen Sie ebenfalls alle individuellen Templateanpassungen für dieses Modul.
Leeren Sie das Verzeichnis tmp über Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren.
+
Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+
Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
Führen Sie in der Konsole im selben Verzeichnis diesen Befehl aus, um das Modul 2-Faktor-Authentisierung zur Installation hinzuzufügen:
+
php composer require d3/totp --update-no-dev
+
+
+
Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.
Aktivieren Sie das Modul über den Shopadmin unter Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Aktivieren.
+
+
Enterprise Editon: Achten Sie darauf, dass das Modul in weiteren Shops (Mall) ebenfalls aktiviert werden muss, um dessen Funktion dort auch zu nutzen.
Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des source- und vendor-Verzeichnisses). Senden Sie dort diesen Befehl ab:
Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+
+
Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.
Manche Provider erfordern besondere Einstellungen für installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer FAQ.
Wenn der Modul-Connector installiert ist, startet direkt nach der Modulaktivierung der Assistent, der Sie durch die Shopanpassung führt. Darin können Sie verschiedene Optionen der Installation wählen.
+
Den Installationsassistenten finden Sie auch unter den Menüpunkten Admin -> Module -> Modul-Connector -> Modulverwaltung -> Modulinstallation.
+
Bei tiefgreifenden Änderungen an Ihrem Shop (z.B. Hinzufügen weiterer Sprachen oder Mandanten) rufen Sie den Installationsassistenten bitte erneut auf, um dann eventuell notwendige Nacharbeiten für das Modul ausführen zu lassen.
+
Möchten Sie die Änderungen manuell installieren, können Sie sich über diesen Assistenten ebenfalls eine Checkliste erstellen.
+
ohne installierte Modul-Connector
+
Führen Sie bitte die Anweisungen in der Datei install.sql im docs-Ordner in Ihrer Datenbank aus.
Leeren Sie das Verzeichnis tmp über Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren.
+
Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+
Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
Bei individuellen Änderungen von Moduldateien empfehlen wir, jeweils die Überladungsmöglichkeiten des Shops dafür zu verwenden. So brauchen Sie die originalen Moduldateien nicht verändern und erhalten sich so die Updatefähigkeit des Shops und des Moduls. Beachten Sie, dass Moduldateien bei Updateinstallationen überschrieben werden.
+
Weitere Informationen zu den Überladungsmöglichkeiten verschiedener Dateien finden Sie in unserer FAQ.
Aktivieren Sie die 2-Faktor-Authentisierung im Backend unter Benutzer verwalten -> Benutzer -> 2-Faktor-Authentisierung.
+
Ab dann erfordert das Login im Backend für das jeweilige Benutzerkonto neben Benutzername auch die Angabe eines Einmalpasswortes.
+
Diese zusätzliche Absicherung kann im Adminbereich jederzeit wieder entfernt werden.
+
zusätzliche Konfigurationsparameter in der Datei config.inc.php möglich:
+
blDisableTotpGlobally => true: deaktiviert diese zusätzlichen Sicherung shopweit für alle Benutzer. Diese Option ist für den Fall vorbehalten, wenn der Adminbereich aus einem technischen Grund und von diesem Modul verursacht nicht mehr aufgerufen werden kann.
Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres
+Shops (oberhalb des source- und vendor-Verzeichnisses). Führen Sie dort diesen Befehl aus:
+
php composer update d3/totp --no-dev
+
+
+
Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+
+
Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.
Deaktivieren Sie das Modul über den Shopadmin unter Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Deaktivieren.
Manche Provider erfordern besondere Einstellungen für installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer FAQ.
Ob Shopanpassungen notwendig sind, ist von der Versionsänderung des Moduls abhängig.
+
Möglicherweise sehen Sie nach dem Neuaktivieren des Moduls den Installationsassistent, der Sie durch die Änderungen führt. Folgen Sie dann den einzelnen Schritten. Möchten Sie die Änderungen manuell installieren, können Sie sich über diesen Assistenten ebenfalls eine Checkliste erstellen.
+
Wird der Assistent nicht gezeigt (Sie sehen wieder die Modulübersicht), waren keine Anpassungen am Shop notwendig.
+
Ob erforderliche Updates ausgeführt werden sollen, können Sie jederzeit im Adminbereich unter Module -> Modul-Connector -> Modulverwaltung -> Modulinstallation prüfen.
+
ohne installiertem Modul-Connector
+
Prüfen Sie bitte, ob in der Datei "update.sql" im docs-Ordner Änderungen hinterlegt sind, die in der Datenbank ausgeführt werden sollten.
Leeren Sie das Verzeichnis tmp über Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren.
+
Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+
Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unter Hilfe und Support genannten Kontaktdaten Bescheid.
Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unten genannten Kontaktdaten Bescheid.
+
Haben Sie Fragen oder Unklarheiten in Verbindung mit diesem Modul oder dessen Installation, stehen Ihnen Hilfetexte in unserer Modul-FAQ zur Verfügung. Finden Sie darin die benötigten Antworten nicht, kontaktieren Sie uns bitte unter den folgenden Möglichkeiten:
per Telefon: (+49) 37 21 / 26 80 90 zu unseren Bürozeiten
+
+
Geben Sie bitte an, wo und wie wir gegebenenfalls vorhandene Schwierigkeiten nachvollziehen können. Sind Ihre Fragen shopspezifisch, benötigen wir möglicherweise Zugangsdaten zum betreffenden Shop.
+
Wir wünschen Ihnen mit Ihrem Shop und dem Modul viel Erfolg!
';
+ }
+ }
+ }
+
+ $("body").addClass("with-search").scrollTop(0);
+ tipue_backdrop.show();
+ tipue_container.scrollTop(0);
+ tipue_container.show().html(output);
+ }
+
+ };
+
+})(jQuery);
diff --git a/docs/Documentation/tipuesearch/tipuesearch_content.json b/docs/Documentation/tipuesearch/tipuesearch_content.json
new file mode 100644
index 0000000..8075ac8
--- /dev/null
+++ b/docs/Documentation/tipuesearch/tipuesearch_content.json
@@ -0,0 +1 @@
+{"pages":[{"title":"<\/i> 2-Faktor-Authentisierung","text":"","tags":"","url":"index.html"},{"title":"Changelog","text":"Unreleased 1.0.0.0 2018-10-24 - #1000 Added 2-Faktor-Authentisierung f\u00fcr Backend-Logins zus\u00e4tzlich zu Benutzername und Passwort Authentisierung wird nur bei Benutzerkonten gezeigt, die dieses aktiviert haben - sonst nur Standardanmeldung die Basis der Passwortgenerierung wird f\u00fcr jedes Benutzerkonto individuell angelegt Einrichtung des Zugangs in der Auth-App kann durch scanbaren QR-Code oder kopierbare Zeichenkette erfolgen Validierung der Einmalpassworte und Generierung der QR-Codes werden ausschlie\u00dflich innerhalb des Shops durchgef\u00fchrt - keine Kommunikation nach au\u00dfen n\u00f6tig","tags":"","url":"changelog\/Changelog.html"},{"title":"Installation \/ Update \/ Deinstallation","text":"Anforderungen Neuinstallation Update Deinstallation Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unter Hilfe und Support genannten Kontaktdaten Bescheid.","tags":"","url":"installation\/index.html"},{"title":"Systemanforderungen","text":"PHP Version 5.6.x bis 7.2.x PHP Decoder installierter ionCube Loader Shopversionen \/ -editionen OXID eShop Community Edition in Compilation Version 6.0.x 6.1.x OXID eShop Professional Edition in Compilation Version 6.0.x 6.1.x oder OXID eShop Enterprise Edition in Compilation Version 6.0.x 6.1.x Installation via Composer Beachten Sie, dass die Ihnen vorliegende Modulversion entsprechend f\u00fcr PHP 5.6, PHP 7.0, PHP 7.1 oder PHP 7.2 kompatibel ist. Im Zweifelsfall kontaktieren Sie uns und nennen den f\u00fcr Ihren Shop genutzten Decoder und die PHP-Version. Kontrollieren Sie bitte auch, ob diese Modulversion f\u00fcr die von Ihnen eingesetzte Shopedition (Community Edition (CE), Professional Edition (PE) oder Enterprise Edition (EE)) ausgelegt ist. optional: Modul-Connector (kostenfrei bei erh\u00e4ltlich) ab Version 5.1.1.4 Ist der Modul-Connector installiert, k\u00f6nnen Datenbank\u00e4nderungen \u00fcber die automatische Installation eingerichtet und \u00fcberwacht werden.","tags":"","url":"installation\/Anforderungen\/Systemanforderungen.html"},{"title":"Anforderungspr\u00fcfung","text":"Im Ordner docs finden Sie den Ordner Precheck. Mit dessen Inhalt k\u00f6nnen Sie die Mindestanforderungen auf Ihrem Server direkt pr\u00fcfen. Kopieren Sie die enthaltenen Dateien und Ordner unver\u00e4ndert in das source-Verzeichnis Ihres installierten OXID-Shops. Rufen Sie nun \u00fcber Ihren Browser die folgende Adresse auf: http:\/\/www.ihreadresse.de\/d3precheck.php Ihnen werden nun Details und Ergebnisse zur Anforderungspr\u00fcfung angezeigt. L\u00f6schen Sie diese Scripte mit Hilfe der in der \u00dcbersicht enthaltenen Funktion bitte unbedingt nach der Pr\u00fcfung wieder von Ihrem Server.","tags":"","url":"installation\/Anforderungen\/Anforderungspruefung.html"},{"title":"Neuinstallation","text":"Schnellstart per Composer php composer config repositories.d3 composer https:\/\/satis.oxidmodule.com php composer require d3\/totp \u2013-update-no-dev Detailliertere Angaben zur Installation entnehmen Sie bitte den folgenden Schritten.","tags":"","url":"installation\/Neuinstallation\/index.html"},{"title":"Paketquelle hinzuf\u00fcgen","text":"Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des source- und vendor-Verzeichnisses). Senden Sie dort diesen Befehl ab: php composer config repositories.d3 composer https:\/\/satis.oxidmodule.com Achten Sie darauf, dass die Installation \u00fcber Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete. Ben\u00f6tigt Ihre Installation einen anderen Aufruf von Composer, \u00e4ndern Sie den Befehl bitte entsprechend ab. F\u00fcr weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.","tags":"","url":"installation\/Neuinstallation\/Paketquelle_hinzufuegen.html"},{"title":"Modul zur Installation hinzuf\u00fcgen","text":"F\u00fchren Sie in der Konsole im selben Verzeichnis diesen Befehl aus, um das Modul 2-Faktor-Authentisierung zur Installation hinzuzuf\u00fcgen: php composer require d3\/totp --update-no-dev Ben\u00f6tigt Ihre Installation einen anderen Aufruf von Composer, \u00e4ndern Sie den Befehl bitte entsprechend ab. F\u00fcr weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.","tags":"","url":"installation\/Neuinstallation\/Modul_hinzufuegen.html"},{"title":"Providerspezifische Installation","text":"Manche Provider erfordern besondere Einstellungen f\u00fcr installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer FAQ.","tags":"","url":"installation\/Neuinstallation\/Providerspezifische_Installation.html"},{"title":"Modul im Shop aktivieren","text":"Aktivieren Sie das Modul \u00fcber den Shopadmin unter Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Aktivieren. Enterprise Editon: Achten Sie darauf, dass das Modul in weiteren Shops (Mall) ebenfalls aktiviert werden muss, um dessen Funktion dort auch zu nutzen.","tags":"","url":"installation\/Neuinstallation\/Modul_im_Shop_aktivieren.html"},{"title":"Shopanpassungen installieren","text":"mit installiertem Modul-Connector Wenn der Modul-Connector installiert ist, startet direkt nach der Modulaktivierung der Assistent, der Sie durch die Shopanpassung f\u00fchrt. Darin k\u00f6nnen Sie verschiedene Optionen der Installation w\u00e4hlen. Den Installationsassistenten finden Sie auch unter den Men\u00fcpunkten Admin -> Module -> Modul-Connector -> Modulverwaltung -> Modulinstallation. Bei tiefgreifenden \u00c4nderungen an Ihrem Shop (z.B. Hinzuf\u00fcgen weiterer Sprachen oder Mandanten) rufen Sie den Installationsassistenten bitte erneut auf, um dann eventuell notwendige Nacharbeiten f\u00fcr das Modul ausf\u00fchren zu lassen. M\u00f6chten Sie die \u00c4nderungen manuell installieren, k\u00f6nnen Sie sich \u00fcber diesen Assistenten ebenfalls eine Checkliste erstellen. ohne installierte Modul-Connector F\u00fchren Sie bitte die Anweisungen in der Datei install.sql im docs-Ordner in Ihrer Datenbank aus.","tags":"","url":"installation\/Neuinstallation\/Shopanpassungen_installieren.html"},{"title":"TMP-Ordner leeren","text":"Leeren Sie das Verzeichnis tmp \u00fcber Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren. Sofern die Views nicht automatisch aktualisiert werden, f\u00fchren Sie dies noch durch. Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, f\u00fchren Sie diese bitte aus.","tags":"","url":"installation\/Neuinstallation\/TMP-Ordner_leeren.html"},{"title":"Updatefaehigkeit","text":"Bei individuellen \u00c4nderungen von Moduldateien empfehlen wir, jeweils die \u00dcberladungsm\u00f6glichkeiten des Shops daf\u00fcr zu verwenden. So brauchen Sie die originalen Moduldateien nicht ver\u00e4ndern und erhalten sich so die Updatef\u00e4higkeit des Shops und des Moduls. Beachten Sie, dass Moduldateien bei Updateinstallationen \u00fcberschrieben werden. Weitere Informationen zu den \u00dcberladungsm\u00f6glichkeiten verschiedener Dateien finden Sie in unserer FAQ.","tags":"","url":"installation\/Neuinstallation\/Updatefaehigkeit.html"},{"title":"Modul deaktivieren","text":"Deaktivieren Sie das Modul \u00fcber den Shopadmin unter Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Deaktivieren.","tags":"","url":"installation\/Update\/Modul_deaktivieren.html"},{"title":"Dateien erneuern","text":"Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des source- und vendor-Verzeichnisses). F\u00fchren Sie dort diesen Befehl aus: php composer update d3\/totp --no-dev Achten Sie darauf, dass die Installation \u00fcber Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete. Ben\u00f6tigt Ihre Installation einen anderen Aufruf von Composer, \u00e4ndern Sie den Befehl bitte entsprechend ab. F\u00fcr weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.","tags":"","url":"installation\/Update\/Dateien_erneuern.html"},{"title":"Providerspezifische Installation","text":"Manche Provider erfordern besondere Einstellungen f\u00fcr installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer FAQ.","tags":"","url":"installation\/Update\/Providerspezifische_Installation.html"},{"title":"Modulinformationen aktualisieren","text":"Wechseln Sie im Adminbereich zu Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Aktivieren.","tags":"","url":"installation\/Update\/Modulinformationen_aktualisieren.html"},{"title":"Shopanpassungen installierren","text":"mit installiertem Modul-Connector Ob Shopanpassungen notwendig sind, ist von der Versions\u00e4nderung des Moduls abh\u00e4ngig. M\u00f6glicherweise sehen Sie nach dem Neuaktivieren des Moduls den Installationsassistent, der Sie durch die \u00c4nderungen f\u00fchrt. Folgen Sie dann den einzelnen Schritten. M\u00f6chten Sie die \u00c4nderungen manuell installieren, k\u00f6nnen Sie sich \u00fcber diesen Assistenten ebenfalls eine Checkliste erstellen. Wird der Assistent nicht gezeigt (Sie sehen wieder die Modul\u00fcbersicht), waren keine Anpassungen am Shop notwendig. Ob erforderliche Updates ausgef\u00fchrt werden sollen, k\u00f6nnen Sie jederzeit im Adminbereich unter Module -> Modul-Connector -> Modulverwaltung -> Modulinstallation pr\u00fcfen. ohne installiertem Modul-Connector Pr\u00fcfen Sie bitte, ob in der Datei "update.sql" im docs-Ordner \u00c4nderungen hinterlegt sind, die in der Datenbank ausgef\u00fchrt werden sollten.","tags":"","url":"installation\/Update\/Shopanpassungen_installieren.html"},{"title":"TMP-Ordner leeren","text":"Leeren Sie das Verzeichnis tmp \u00fcber Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren. Sofern die Views nicht automatisch aktualisiert werden, f\u00fchren Sie dies noch durch. Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, f\u00fchren Sie diese bitte aus.","tags":"","url":"installation\/Update\/TMP-Ordner_leeren.html"},{"title":"Erweiterungen anpassen","text":"Haben Sie f\u00fcr dieses Modul eigene Erweiterung entwickelt, gleichen Sie dies bitte mit der neuen Fassung des Moduls ab.","tags":"","url":"installation\/Update\/Erweiterungen_anpassen.html"},{"title":"Installationspr\u00fcfung","text":"Um die erfolgreiche Installation zu pr\u00fcfen, k\u00f6nnen Sie die folgende(n) Checkliste(n) verwenden: Einstellungsunabh\u00e4ngige Pr\u00fcfungen Backend Modul ist unter Erweiterungen -> Module aktiv geschaltet Modul zeigt unter Benutzer verwalten -> Benutzer -> 2-Faktor-Authentisierung einen eigenen Bereich f\u00fcr Einstellungen Einstellungsabh\u00e4ngige Pr\u00fcfungen Backend Nach Aktivierung fragt das Backend neben Benutzername und Passwort auch ein Einmalpasswort ab.","tags":"","url":"installation\/Installationspruefung.html"},{"title":"Schnellstart","text":"Aktivieren Sie die 2-Faktor-Authentisierung im Backend unter Benutzer verwalten -> Benutzer -> 2-Faktor-Authentisierung. Ab dann erfordert das Login im Backend f\u00fcr das jeweilige Benutzerkonto neben Benutzername auch die Angabe eines Einmalpasswortes. Diese zus\u00e4tzliche Absicherung kann im Adminbereich jederzeit wieder entfernt werden. zus\u00e4tzliche Konfigurationsparameter in der Datei config.inc.php m\u00f6glich: blDisableTotpGlobally => true: deaktiviert diese zus\u00e4tzlichen Sicherung shopweit f\u00fcr alle Benutzer. Diese Option ist f\u00fcr den Fall vorbehalten, wenn der Adminbereich aus einem technischen Grund und von diesem Modul verursacht nicht mehr aufgerufen werden kann.","tags":"","url":"installation\/Schnellstart.html"},{"title":"Modulerweiterungen deaktivieren und entfernen","text":"Deaktivieren Sie alle vorhandenen Erweiterungen, die auf dem Modul 2-Faktor-Authentisierung aufbauen und l\u00f6schen bitte alle Dateien dieser Erweiterungen. Entfernen Sie ebenfalls alle individuellen Templateanpassungen f\u00fcr dieses Modul.","tags":"","url":"installation\/Deinstallation\/Modulerweiterungen_deaktivieren_und_entfernen.html"},{"title":"Modul deaktivieren","text":"Deaktivieren Sie das Modul 2-Faktor-Authentisierung \u00fcber den Shopadmin Erweiterungen -> Module. Klicken Sie nach Auswahl von 2-Faktor-Authentisierung auf den Button Deaktivieren.","tags":"","url":"installation\/Deinstallation\/Modul_deaktivieren.html"},{"title":"Modul aus der Installation entfernen","text":"Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des source- und vendor-Verzeichnisses). F\u00fchren Sie Sie dort diesen Befehl aus: php composer remove d3\/totp --no-update Achten Sie darauf, dass die Installation \u00fcber Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete. Ben\u00f6tigt Ihre Installation einen anderen Aufruf von Composer, \u00e4ndern Sie den Befehl bitte entsprechend ab. F\u00fcr weitere Optionen dieses Befehls lesen Sie bitte die Dokumentation von Composer.","tags":"","url":"installation\/Deinstallation\/Modul_aus_der_Installation_entfernen.html"},{"title":"Dateien l\u00f6schen","text":"L\u00f6schen Sie den Ordner totp und seine enthaltenen Elemente aus dem Verzeichnis source\/modules\/d3 Ihres Shops. Best\u00e4tigen Sie anschlie\u00dfend im Shopadmin unter Erweiterungen -> Module -> Installierte Shop-Module die Nachricht: Es gibt registrierte Erweiterungen im eShop, deren Verzeichnis nicht vorhanden ist. M\u00f6chten Sie alle Modulinformationen einschlie\u00dflich Konfigurationseinstellungen und Blockinformationen f\u00fcr Templates l\u00f6schen?","tags":"","url":"installation\/Deinstallation\/Dateien_loeschen.html"},{"title":"Datenbank bereinigen","text":"Das Modul legt Informationen in der Datenbank ab. Sofern diese Daten nicht mehr ben\u00f6tigt werden, k\u00f6nnen diese gel\u00f6scht werden. Legen Sie sich vorab bitte unbedingt eine Sicherung an, um die Daten im Zweifelsfall wiederherstellen zu k\u00f6nnen. F\u00fcr das Modul 2-Faktor-Authentisierung sind dies die folgende Tabellen und Felder: die komplette Tabelle d3totp","tags":"","url":"installation\/Deinstallation\/Datenbank_bereinigen.html"},{"title":"TMP-Ordner leeren","text":"Leeren Sie das Verzeichnis tmp \u00fcber Admin -> Module -> Modul-Connector -> TMP leeren. Markieren Sie komplett leeren und klicken auf TMP leeren. Sofern die Views nicht automatisch aktualisiert werden, f\u00fchren Sie dies noch durch. Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, f\u00fchren Sie diese bitte aus.","tags":"","url":"installation\/Deinstallation\/TMP-Ordner_leeren.html"},{"title":"Hilfe und Support","text":"Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unten genannten Kontaktdaten Bescheid. Haben Sie Fragen oder Unklarheiten in Verbindung mit diesem Modul oder dessen Installation, stehen Ihnen Hilfetexte in unserer Modul-FAQ zur Verf\u00fcgung. Finden Sie darin die ben\u00f6tigten Antworten nicht, kontaktieren Sie uns bitte unter den folgenden M\u00f6glichkeiten: per E-Mail: support@shopmodule.com oder \u00fcber das Kontaktformular auf Oxidmodule.com oder per Telefon: (+49) 37 21 \/ 26 80 90 zu unseren B\u00fcrozeiten Geben Sie bitte an, wo und wie wir gegebenenfalls vorhandene Schwierigkeiten nachvollziehen k\u00f6nnen. Sind Ihre Fragen shopspezifisch, ben\u00f6tigen wir m\u00f6glicherweise Zugangsdaten zum betreffenden Shop. Wir w\u00fcnschen Ihnen mit Ihrem Shop und dem Modul viel Erfolg! Ihr -Team.","tags":"","url":"support\/Hilfe-und-Support.html"}]}
\ No newline at end of file
diff --git a/docs/Precheck/d3precheck.php b/docs/Precheck/d3precheck.php
new file mode 100644
index 0000000..044fb81
--- /dev/null
+++ b/docs/Precheck/d3precheck.php
@@ -0,0 +1,2605 @@
+
+ * @link http://www.oxidmodule.com
+ */
+
+/**
+ * Alle Anforderungen sind über $this->_aCheck konfigurierbar. Manche Anforderungen haben dazu noch weitergehende
+ * Informationen. Die Struktur dieser Requirementbeschreibungen:
+ *
+ * array(
+ * 'blExec' => 1, // obligatorisch: 0 = keine Prüfung, 1 = Püfung wird ausgeführt
+ * 'aParams' => array(...), // optional, Inhalt ist von jeweiliger Prüfung abhängig
+ * )
+ *
+ * "Desc1": Diese Struktur kann allein eine Bedingung beschreiben. Wenn mehrere dieser Bedingungen
+ * nötig sind (z.B. bei unterschiedlichen Bibliotheksanforderungen), kann diese Struktur als
+ * Arrayelemente auch mehrfach genannt werden (kaskadierbar). Grundsätzlich sind alle Requirements
+ * kaskadierbar, jedoch ergibt dies nicht bei allen Sinn. :) Eine Kaskadierung sieht so aus:
+ *
+ * array(
+ * array(
+ * 'blExec' => 1,
+ * ...
+ * ),
+ * array(
+ * 'blExec' => 1,
+ * ...
+ * )
+ * )
+ *
+ * Unbedingt zu vermeiden sind Änderungen in der Scriptlogik, da diese bei Updates nur schwer zu übernehmen sind.
+ */
+
+class requConfig
+{
+ public $sModName = 'D³ 2-Faktor-Authentisierung';
+
+ public $sModId = 'd3totp';
+
+ public $sModVersion = '1.0.0.0';
+
+ /********************** check configuration section ************************/
+
+ public $aCheck = array(
+ // kleinste erlaubte PHP-Version
+ 'hasMinPhpVersion' => array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'version' => '5.6.0'
+ )
+ ),
+
+ // größte erlaubte PHP-Version
+ 'hasMaxPhpVersion' => array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'version' => '7.1.200'
+ )
+ ),
+
+ // PHP-Version zwischen 'from' und 'to'
+ 'hasFromToPhpVersion' => array(
+ 'blExec' => 1,
+ 'aParams' => array(
+ 'from' => '5.6.0',
+ 'to' => '7.2.900',
+ )
+ ),
+
+ // benötigt Zend Optimizer (PHP 5.2) bzw. Zend Guard Loader (> PHP 5.2)
+ 'hasZendLoaderOptimizer' => array(
+ 'blExec' => 0,
+ ),
+
+ // benötigt IonCubeLoader
+ 'hasIonCubeLoader' => array(
+ 'blExec' => 0,
+ ),
+
+ // benötigt Zend Decoder oder IonCubeLoader
+ 'hasIonCubeOrZendLoader' => array(
+ 'blExec' => 0,
+ ),
+
+ // benötigte PHP-Extension (kaskadierbar (siehe "Desc1"))
+ 'hasExtension' => array(
+ array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'type' => 'OpenSSL',
+ ),
+ ),
+ array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'type' => 'soap'
+ ),
+ ),
+ ),
+
+ // benötigte cURL-Version
+ 'hasMinCurlVersion' => array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'version' => '7.26.0',
+ ),
+ ),
+
+ // benötigte OpenSSL-Version (Angabe in Versionsformat)
+ 'hasMinOpenSSLVersion' => array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'version' => '1.0.1.5',
+ ),
+ ),
+
+ // minimal benötigte Compilationversion (editionsgetrennt), wird (sofern möglich) Remote aktualisiert
+ 'hasMinShopVersion' => array(
+ 'blExec' => 1,
+ 'aParams' => array(
+ 'PE' => '6.0.0',
+ 'CE' => '6.0.0',
+ 'EE' => '6.0.0'
+ ),
+ ),
+
+ // maximal verwendbare Compilationversion (editionsgetrennt), wird (sofern möglich) Remote aktualisiert
+ 'hasMaxShopVersion' => array(
+ 'blExec' => 1,
+ 'aParams' => array(
+ 'PE' => '6.1.0',
+ 'CE' => '6.1.0',
+ 'EE' => '6.1.0'
+ ),
+ ),
+
+ // verfügbar für diese Shopeditionen, wird (sofern möglich) Remote aktualisiert
+ 'isShopEdition' => array(
+ 'blExec' => 1,
+ 'aParams' => array(
+ array(
+ 'PE',
+ 'EE',
+ 'CE',
+ ),
+ ),
+ ),
+
+ // benötigt Modul-Connector
+ 'hasModCfg' => array(
+ 'blExec' => 1
+ ),
+
+ // benötigt mindestens diese Erweiterungen / Version lt. d3_cfg_mod (kaskadierbar (siehe "Desc1"))
+ 'hasMinModCfgVersion' => array(
+ array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'id' => 'd3modcfg_lib',
+ 'name' => 'Modul-Connector',
+ 'version' => '5.1.0.0',
+ ),
+ ),
+ ),
+
+ // verwendbar bis zu diesen Erweiterungen / Version lt. d3_cfg_mod (kaskadierbar (siehe "Desc1"))
+ 'hasMaxModCfgVersion' => array(
+ array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'id' => 'd3modcfg_lib',
+ 'name' => 'Modul-Connector',
+ 'version' => '5.1.0.0',
+ ),
+ ),
+ ),
+
+ // benötigt neuen Lizenzschlüssel
+ 'requireNewLicence' => array(
+ array(
+ 'blExec' => 0,
+ 'aParams' => array(
+ 'checkVersion' => true, // soll Versionsnummer des installierten Moduls gegengeprüft werden?
+ 'remainingDigits' => 2, // zu prüfende Stellen für neue Lizenz
+ ),
+ ),
+ ),
+ );
+}
+
+/********* don't change content from here **********************/
+
+date_default_timezone_set('Europe/Berlin');
+
+/**
+ * Class requcheck
+ */
+class requCheck
+{
+ public $sVersion = '5.0.0';
+
+ protected $_db = false;
+
+ public $dbHost;
+
+ public $dbUser;
+
+ public $dbPwd;
+
+ public $dbName;
+
+ /** @var requConfig */
+ public $oConfig;
+
+ /** @var requLayout */
+ public $oLayout;
+
+ protected $_sInFolderFileName = 'd3precheckinfolder.php';
+
+ public $sVersionTag = '@@version@@';
+
+ /********************** functional section ************************/
+
+ public $blGlobalResult = true;
+
+ /**
+ *
+ */
+ public function __construct()
+ {
+ $this->oConfig = new requConfig();
+ $this->oLayout = new requLayout($this, $this->oConfig);
+ $this->oRemote = new requRemote();
+ }
+
+ /**
+ * @param string $sName
+ * @param array $aArguments
+ */
+ public function __call ($sName, $aArguments)
+ {
+ $this->oLayout->{$sName}($aArguments);
+ }
+
+ public function startCheck()
+ {
+ $this->oLayout->getHTMLHeader();
+
+ $oCheckTransformation = new requTransformation($this);
+ $this->oConfig->aCheck = $oCheckTransformation->transformCheckList($this->oConfig->aCheck);
+
+ $this->_runThroughChecks($this->oConfig->aCheck);
+
+ $this->oLayout->getHTMLFooter();
+ }
+
+ /**
+ * traversable requirement check
+ *
+ * @param $aCheckList
+ * @param string $sForceCheckType
+ */
+ protected function _runThroughChecks($aCheckList, $sForceCheckType = '')
+ {
+ foreach ($aCheckList as $sCheckType => $aConf) {
+ if (array_key_exists('blExec', $aConf)) {
+ if ($aConf['blExec']) {
+ if (strlen($sForceCheckType)) {
+ $sCheckType = $sForceCheckType;
+ }
+ $this->displayCheck($sCheckType, $aConf);
+ }
+ } else {
+ $this->_runThroughChecks($aConf, $sCheckType);
+ }
+ }
+ }
+
+ /**
+ * @param $sMethodName
+ * @param null $aArguments
+ *
+ * @return array
+ */
+ public function checkInSubDirs($sMethodName, $aArguments = null)
+ {
+ $sFolder = '.';
+
+ $aCheckScripts = $this->_walkThroughDirs($sFolder);
+ $aReturn = $this->_checkScripts($aCheckScripts, $sMethodName, $aArguments);
+
+ return $aReturn;
+ }
+
+ /**
+ * @param $sFolder
+ *
+ * @return array
+ */
+ protected function _walkThroughDirs($sFolder)
+ {
+ $aIgnoreDirItems = array('.', '..');
+ $aCheckScripts = array();
+
+ try {
+ /** @var SplFileInfo $oFileInfo */
+ $oIterator = new RecursiveDirectoryIterator($sFolder);
+
+ foreach ($oIterator as $oFileInfo) {
+ if (in_array($oFileInfo->getFileName(), $aIgnoreDirItems)) {
+ continue;
+ }
+ if ($oFileInfo->isDir()) {
+ $aCheckScripts = array_merge($aCheckScripts, $this->_walkThroughDirs($oFileInfo->getRealPath()));
+ } elseif ($oFileInfo->isFile()) {
+ if (strtolower($oFileInfo->getFilename()) == $this->_sInFolderFileName) {
+ $aCheckScripts[] = str_replace('\\', '/', $oFileInfo->getRealPath());
+ }
+ }
+ }
+ } catch (UnexpectedValueException $oEx) {
+ sprintf($this->oLayout->translate('unableExecuteDirectoryIterator'), $oEx->getMessage());
+ $this->addMessage(
+ sprintf($this->oLayout->translate('unableExecuteDirectoryIterator'), $oEx->getMessage())
+ );
+ }
+
+ return $aCheckScripts;
+ }
+
+ public function addMessage($sMessage)
+ {
+ $this->aMessages[md5($sMessage)] = $sMessage;
+ }
+
+ public function getMessages()
+ {
+ return $this->aMessages;
+ }
+
+ /**
+ * @param $aScriptList
+ * @param $sMethodName
+ * @param $aArguments
+ *
+ * @return array
+ */
+ protected function _checkScripts($aScriptList, $sMethodName, $aArguments)
+ {
+ $aReturn = array();
+
+ foreach ($aScriptList as $sScriptPath) {
+ $sUrl = $this->_getFolderCheckUrl(
+ $sScriptPath,
+ $sMethodName,
+ $aArguments
+ );
+
+ $sVersionUrl = $this->_getFolderCheckUrl(
+ $sScriptPath,
+ 'getVersion',
+ array()
+ );
+
+ $sContent = serialize(null);
+ $sVersion = serialize(null);
+
+ if ($this->_hasCurl()) {
+ $sContent = $this->_getContentByCurl($sUrl);
+ $sVersion = $this->_getContentByCurl($sVersionUrl);
+ } elseif ($this->_hasAllowUrlFopen()) {
+ $sContent = file_get_contents($sUrl);
+ $sVersion = file_get_contents($sVersionUrl);
+ }
+
+ $sBasePath = $this->getBasePath($sScriptPath);
+ $aReturn[$sBasePath] = unserialize($sContent);
+ $aReturn[$this->sVersionTag][$sBasePath] = unserialize($sVersion);
+ }
+
+ return $aReturn;
+ }
+
+ /**
+ * @return bool
+ */
+ protected function _hasCurl()
+ {
+ if (extension_loaded('curl') && function_exists('curl_init')) {
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * @return bool
+ */
+ protected function _hasAllowUrlFopen()
+ {
+ if (ini_get('allow_url_fopen')) {
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * @param $sUrl
+ *
+ * @return bool|mixed
+ */
+ protected function _getContentByCurl($sUrl)
+ {
+ $iTimeOut = 5;
+ $ch = curl_init();
+ $sCurl_URL = preg_replace('@^((http|https)://)@', '', $sUrl);
+
+ curl_setopt($ch, CURLOPT_URL, $sCurl_URL);
+ curl_setopt($ch, CURLOPT_HEADER, 0);
+ curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
+ curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
+ curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $iTimeOut);
+ curl_setopt($ch, CURLOPT_TIMEOUT, $iTimeOut);
+ curl_setopt($ch, CURLOPT_POST, 0);
+ $sContent = curl_exec($ch);
+ curl_close($ch);
+
+ if (false == $sContent ||
+ strstr(strtolower($sContent), strtolower('Request Entity Too Large')) ||
+ strstr(strtolower($sContent), strtolower('not allow request data with POST requests'))
+ ) {
+ return false;
+ }
+
+ return $sContent;
+ }
+
+ /**
+ * @param $sScriptPath
+ * @param $sMethodName
+ * @param $aArguments
+ *
+ * @return string
+ */
+ protected function _getFolderCheckUrl($sScriptPath, $sMethodName, $aArguments)
+ {
+ $sBaseDir = str_replace(
+ array(basename($_SERVER['SCRIPT_FILENAME']), '\\'),
+ array('', '/'),
+ realpath($_SERVER['SCRIPT_FILENAME'])
+ );
+ $sUrlAdd = str_replace($sBaseDir, '', $sScriptPath);
+ $sBaseUrl = 'http://' . $_SERVER['HTTP_HOST'] . str_replace(
+ basename($_SERVER['SCRIPT_NAME']),
+ '',
+ $_SERVER['SCRIPT_NAME']
+ );
+
+ $sUrl = $sBaseUrl . $sUrlAdd . '?fnc=' . $sMethodName . '¶ms=' . urlencode(serialize($aArguments));
+
+ return $sUrl;
+ }
+
+ /**
+ * @param null $sFolder
+ *
+ * @return mixed
+ */
+ public function getBasePath($sFolder = null)
+ {
+ if (!$sFolder) {
+ $sFolder = $_SERVER['SCRIPT_FILENAME'];
+ }
+
+ $sScriptFileName = str_replace('\\', '/', realpath($_SERVER['SCRIPT_FILENAME']));
+ $sSearch = substr(str_replace(basename($sScriptFileName), '', $sScriptFileName), 0, -1);
+
+ $sFolder = str_replace('\\', '/', realpath($sFolder));
+
+ return str_replace(array(basename($sFolder), $sSearch), '', $sFolder);
+ }
+
+ /**
+ * @return string
+ */
+ public function getVersion()
+ {
+ return $this->sVersion;
+ }
+
+ /**
+ * @param $mResult
+ *
+ * @return bool
+ */
+ protected function _hasFalseInResult($mResult)
+ {
+ if (is_array($mResult)) {
+ foreach ($mResult as $blResult) {
+ if (false === $blResult) {
+ $this->blGlobalResult = false;
+
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ if (false === $mResult) {
+ $this->blGlobalResult = false;
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * @param $mResult
+ *
+ * @return bool
+ */
+ protected function _hasNullInResult($mResult)
+ {
+ if (is_array($mResult)) {
+ foreach ($mResult as $blResult) {
+ if ($blResult === null) {
+ $this->blGlobalResult = false;
+
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ if ($mResult === null) {
+ $this->blGlobalResult = false;
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * @param $mResult
+ *
+ * @return bool
+ */
+ protected function _hasNoticeInResult($mResult)
+ {
+ if (is_array($mResult)) {
+ foreach ($mResult as $blResult) {
+ if ($blResult === 'notice') {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ if ($mResult === 'notice') {
+ return true;
+ }
+
+ return false;
+ }
+
+ /********************** conversion function section ************************/
+
+ /**
+ * @param $mParam
+ */
+ public function aTos(&$mParam)
+ {
+ if (is_array($mParam)) {
+ $mParam = implode($this->oLayout->translate('or'), $mParam);
+ }
+ }
+
+ /**
+ * @return string
+ */
+ public function getLang()
+ {
+ if (isset($_REQUEST['lang'])) {
+ return strtolower($_REQUEST['lang']);
+ }
+
+ return 'de';
+ }
+
+ /**
+ * @return bool|resource
+ */
+ public function getDb()
+ {
+ if (!$this->_db) {
+ if (file_exists('config.inc.php')) {
+ require_once('config.inc.php');
+ ini_set('error_reporting', E_ALL^E_NOTICE);
+ $this->_db = mysqli_connect($this->dbHost, $this->dbUser, $this->dbPwd, $this->dbName);
+ }
+ }
+
+ return $this->_db;
+ }
+
+ /**
+ * @param $version
+ * @param int $iUnsetPart
+ *
+ * @return string
+ */
+ public function versionToInt($version, $iUnsetPart = 0)
+ {
+ $match = explode('.', $version);
+
+ return sprintf(
+ '%d%03d%03d%03d',
+ $this->_getVersionDigit($match[0], $iUnsetPart),
+ $this->_getVersionDigit($match[1], $iUnsetPart),
+ $this->_getVersionDigit($match[2], $iUnsetPart),
+ $this->_getVersionDigit($match[3], $iUnsetPart)
+ );
+ }
+
+ /**
+ * @param $sMatch
+ * @param $iUnsetPart
+ *
+ * @return int
+ */
+ protected function _getVersionDigit($sMatch, $iUnsetPart)
+ {
+ return intval($sMatch !== null ? $sMatch : $iUnsetPart);
+ }
+
+ /********************** layout function section ************************/
+
+ public function deleteme()
+ {
+ $sFolder = '.';
+
+ $this->_checkDelFilesInDir($sFolder);
+ $this->_delFile($_SERVER['SCRIPT_FILENAME']);
+
+ if (is_file($_SERVER['SCRIPT_FILENAME'])) {
+ exit($this->oLayout->translate('unableDeleteFile'));
+ } else {
+ exit($this->oLayout->translate('goodBye'));
+ }
+ }
+
+ /**
+ * @param $sFolder
+ */
+ protected function _checkDelFilesInDir($sFolder)
+ {
+ $aIgnoreDirItems = array('.', '..');
+
+ /** @var SplFileInfo $oFileInfo */
+ foreach (new RecursiveDirectoryIterator($sFolder) as $oFileInfo) {
+ if (!in_array($oFileInfo->getFileName(), $aIgnoreDirItems) && $oFileInfo->isDir()) {
+ $this->_checkDelFilesInDir($oFileInfo->getRealPath());
+ } elseif ($oFileInfo->isFile()) {
+ if (strtolower($oFileInfo->getFilename()) == $this->_sInFolderFileName) {
+ $this->_delFile(str_replace('\\', '/', $oFileInfo->getRealPath()));
+ }
+ }
+ }
+ }
+
+ /**
+ * @param $sPath
+ */
+ protected function _delFile($sPath)
+ {
+ unlink($sPath);
+ }
+
+ /**
+ * @param $sCheckType
+ * @param $aConfiguration
+ */
+ public function displayCheck($sCheckType, &$aConfiguration)
+ {
+ $sGenCheckType = preg_replace("@(\_[0-9]$)@", "", $sCheckType);
+ $oTests = new requTests($this, $this->oConfig, $this->getDb(), $this->oRemote);
+ if (method_exists($oTests, $sGenCheckType)) {
+ $this->_checkResult($oTests, $sGenCheckType, $sCheckType, $aConfiguration);
+ } else {
+ $this->oLayout->getUncheckableItem($sCheckType, $aConfiguration);
+ $this->blGlobalResult = false;
+ }
+ }
+
+ /**
+ * @param $oTests
+ * @param $sGenCheckType
+ * @param $sCheckType
+ * @param $aConfiguration
+ */
+ protected function _checkResult($oTests, $sGenCheckType, $sCheckType, $aConfiguration)
+ {
+ $mResult = $oTests->{$sGenCheckType}($aConfiguration);
+ $sElementId = (md5($sGenCheckType . serialize($aConfiguration)));
+
+ if ($this->_hasNoticeInResult($mResult)) {
+ $this->oLayout->getUnknownItem($mResult, $sElementId, $sCheckType, $aConfiguration);
+ } elseif ($this->_hasNullInResult($mResult)) {
+ $this->oLayout->getUnknownItem($mResult, $sElementId, $sCheckType, $aConfiguration);
+ } elseif ($this->_hasFalseInResult($mResult)) {
+ $this->oLayout->getNoSuccessItem($mResult, $sElementId, $sCheckType, $aConfiguration);
+ } else {
+ $this->oLayout->getSuccessItem($mResult, $sElementId, $sCheckType, $aConfiguration);
+ }
+ }
+
+ public function showinfo()
+ {
+ phpinfo();
+ }
+}
+
+/**
+ * Class requLayout
+ */
+class requLayout
+{
+ public $oBase;
+ public $oConfig;
+
+ /**
+ * @param requCheck $oBase
+ * @param requConfig $oConfig
+ */
+ public function __construct(requCheck $oBase, requConfig $oConfig)
+ {
+ $this->oBase = $oBase;
+ $this->oConfig = $oConfig;
+ }
+
+ public function getHTMLHeader()
+ {
+ $sScriptName = $_SERVER['SCRIPT_NAME'];
+ $sTranslRequCheck = $this->translate('RequCheck');
+ $sModName = $this->oConfig->sModName;
+ $sModVersion = $this->oConfig->sModVersion;
+
+ echo <<< EOT
+
+
+
+
+ $sTranslRequCheck "$sModName" $sModVersion
+
+
+
+
+
+
+
+
+
Das Modul erfordert eine PHP-Version die nicht kleiner ist '.
+ 'als %1$s.
'.
+ '
Die passende PHP-Version '.
+ 'ist auf Ihrem Server aktiv.
'.
+ '
Das Modul kann in '.
+ 'PHP-Versionen kleiner als %1$s nicht ausgeführt werden. Fragen Sie Ihren Serverprovider '.
+ 'nach der Anpassung der PHP-Installation oder kontaktieren Sie uns für eine alternative '.
+ 'Modulversion.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
Das Modul erfordert eine PHP-Version die nicht höher ist '.
+ 'als %1$s.
'.
+ '
Die passende PHP-Version '.
+ 'ist auf Ihrem Server aktiv.
'.
+ '
Das Modul kann in '.
+ 'PHP-Versionen höher als %1$s nicht ausgeführt werden. Fragen Sie Ihren Serverprovider '.
+ 'nach der Anpassung der PHP-Installation oder kontaktieren Sie uns für eine alternative '.
+ 'Modulversion.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
',
+ 'hasFromToPhpVersion' => 'Server verwendet PHP Version zwischen %1$s und %2$s',
+ 'hasFromToPhpVersion_DESC' => '
Das Modul erfordert eine PHP-Version zwischen %1$s und %2$s.
'.
+ '
Die passende PHP-Version '.
+ 'ist auf Ihrem Server aktiv.
'.
+ '
Das Modul kann '.
+ 'außerhalb der PHP-Versionen nicht ausgeführt werden. Fragen Sie Ihren Serverprovider '.
+ 'nach der Anpassung der PHP-Installation oder kontaktieren Sie uns für eine alternative '.
+ 'Modulversion.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
Die %1$s-Erweiterung ist '.
+ 'auf Ihrem Server vorhanden.
'.
+ '
Das Modul kann ohne die '.
+ '%1$s-Erweiterung nicht ausgeführt werden. Fragen Sie bei Ihrem Serverprovider nach der '.
+ 'Installation dieser Erweiterung.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
cURL ist nicht oder in einer '.
+ 'älteren Version installiert. Fragen Sie Ihren Serverprovider nach einer passenden '.
+ 'cURL-Version.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
OpenSSL ist in '.
+ 'passender Version installiert.
'.
+ '
OpenSSL ist nicht oder in '.
+ 'einer älteren Version installiert. Fragen Sie Ihren Serverprovider nach einer passenden '.
+ 'OpenSSL-Version.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
Die Shopsoftware ist in '.
+ 'passender Version installiert.
'.
+ '
Das Modul kann in dieser '.
+ 'Version der Shopsoftware nicht installiert werden. Fragen Sie nach einer früheren '.
+ 'Modulversion, die für Ihre Shopversion getestet wurde.
Das Modul ist bis zur Shopversion %1$s freigegeben.
'.
+ '
Die Shopsoftware ist in '.
+ 'passender Version installiert.
'.
+ '
Wir können nicht '.
+ 'garantieren, dass das Modul in Ihrer Shopversion funktioniert. Fragen Sie nach einer aktuelleren '.
+ 'Modulversion, die für Ihren Shop passt.
',
+ 'hasMinModCfgVersion' => '%2$s (ModCfg-Eintrag "%1$s") mindestens in Version %3$s',
+ 'hasMinModCfgVersion_DESC' => '
Das Modul benötigt die Zusatzsoftware "%2$s" mindestens in '.
+ 'Version %3$s
'.
+ '
Die Software ist in '.
+ 'passender Version installiert.
'.
+ '
Die Zusatzsoftware ist '.
+ 'möglicherweise gar nicht oder in falscher Version installiert. Bitte installieren Sie die '.
+ 'Zusatzsoftware, bevor Sie diese Installation fortsetzen.
',
+ 'hasMaxModCfgVersion' => '%2$s (ModCfg-Eintrag "%1$s") maximal in Version %3$s',
+ 'hasMaxModCfgVersion_DESC' => '
Das Modul benötigt die Zusatzsoftware "%2$s" höchstens '.
+ 'in Version %3$s
'.
+ '
Die Software ist in '.
+ 'passender Version installiert.
'.
+ '
Die Zusatzsoftware ist '.
+ 'möglicherweise gar nicht oder in falscher Version installiert. Bitte installieren Sie die '.
+ 'Zusatzsoftware, bevor Sie diese Installation fortsetzen.
',
+ 'requireNewLicence' => 'bisheriger Lizenzschlüssel kann verwendet werden',
+ 'requireNewLicence_DESC' => '
Diese Prüfung versucht zu ermitteln, ob Sie für den '.
+ 'Einsatz dieses Moduls einen aktuellen Lizenzschlüssel benötigen:
'.
+ '
Sie haben für dieses '.
+ 'Modul einen Lizenzschlüssel hinterlegt, der wahrscheinlich auch für die neue '.
+ 'Modulversion geeignet ist.
'.
+ '
Sie benötigen '.
+ 'für dieses Modul wahrscheinlich einen neuen Lizenzschlüssel. Haben Sie diesen schon '.
+ 'vorliegen, führen Sie die Installation aus und tragen den Lizenzschlüssel dann im '.
+ 'Adminbereich Ihres Shops ein. Ansonsten können Sie den Lizenzschlüssel in unserem Shop '.
+ 'www.oxidmodule.com erwerben oder '.
+ 'sich ebenfalls im Adminbereich Ihres Shops einen kostenfreien Test-Lizenzschlüssel '.
+ 'erstellen.
Das Modul erfordert zwingend den D3 Modul-Connector.
'.
+ '
Der Modul-Connector ist '.
+ 'installiert.
'.
+ '
Das Modul kann ohne den Modul-'.
+ 'Connector nicht ausgeführt werden. Bitte laden Sie sich diesen kostenfrei aus unserem Shop '.
+ 'unter www.oxidmodule.com/'.
+ 'connector/ und installieren diesen vorab.
Das Modul erfordert (je nach PHP-Version) den Zend Optimizer '.
+ 'bzw. den Zend Guard Loader. Achten Sie darauf, ein für den verfügbaren Decoder '.
+ 'erstelltes Installationspaket zu verwenden.
'.
+ '
Der passende Decoder ist '.
+ 'auf Ihrem Server installiert.
'.
+ '
Der passende Decoder ist '.
+ 'auf Ihrem Server installiert. Es ist eine zusätzliche Erweiterungen (Zend OPcache) installiert, '.
+ 'die im Zusammenspiel mit dem Decoder Fehler verursachen kann.
'.
+ '
Das Modul kann ohne den '.
+ 'passenden Decoder nicht ausgeführt werden. Fragen Sie Ihren Serverprovider nach der '.
+ 'Installation des passenden Zend-Decoders.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
Das Modul erfordert den ionCube Loader. Achten Sie darauf, ein '.
+ 'für den verfügbaren Decoder erstelltes Installationspaket zu verwenden.
'.
+ '
Der passende Decoder ist '.
+ 'auf Ihrem Server installiert.
'.
+ '
Das Modul kann ohne den '.
+ 'passenden Decoder nicht ausgeführt werden. Fragen Sie Ihren Serverprovider nach der '.
+ 'Installation des ionCube Loaders.
'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
Das Modul erfordert den ionCube Loader oder den Zend '.
+ 'Optimizer / Guard Loader. Achten Sie darauf, ein für die verfügbaren Decoder erstelltes '.
+ 'Installationspaket zu verwenden (%1$s).
'.
+ '
Ein passender Decoder ist '.
+ 'auf Ihrem Server installiert.
'.
+ '
Ein passender Decoder ist '.
+ 'auf Ihrem Server installiert. Es ist jedoch ein Abbruchgrund festgestellt worden, der zu Fehlern '.
+ 'führen kann. Details entnehmen Sie bitte den folgenden Hinweisen.
'.
+ '
Das Modul kann ohne einen '.
+ 'passenden Decoder nicht ausgeführt werden. Fragen Sie Ihren Serverprovider nach der '.
+ 'Installation des ionCube Loaders oder des Zend Optimizers / Guard Loaders.
'.
+ '%2$s'.
+ '
Über den [+]-Button können Sie Ergebnisse zu den getesteten Verzeichnissen '.
+ 'abrufen. Je nach Servereinstellung können die Ergebnisse abweichen. Nur die rot markierten '.
+ 'Verzeichnisse erfordern eine Anpassung.
'.
+ '
Details zu Ihrer Serverinstallation sehen Sie durch Klick auf den Button "PHPInfo anzeigen". '.
+ 'Bei Fragen kontaktieren Sie uns bitte über '.
+ 'support@shopmodule.com.
',
+ 'RemoteVersionDiff' => ' (Remotescript hat abweichende Version oder ist nicht '.
+ 'prüfbar, Ergebnis mglw. nicht sicher)',
+ 'globalSuccess' => 'Die technische Prüfung war erfolgreich. Sie können das Modul '.
+ 'installieren.*
',
+ 'globalNotSuccess' => 'Die technische Prüfung war nicht erfolgreich. Bitte kontrollieren '.
+ 'Sie die rot oder orange markierten Bedingungen.
',
+ 'deleteFile1' => 'Löschen Sie diese Datei nach der Verwendung bitte unbedingt wieder von '.
+ 'Ihrem Server! Klicken Sie hier, um diese Datei zu löschen.',
+ 'showPhpInfo' => 'PHPinfo anzeigen',
+ 'dependentoffurther' => '* abhängig von ungeprüften Voraussetzungen',
+ 'oneandonedescription' => '** geprüft wurde das Ausführungsverzeichnis, '.
+ 'providerabhängig müssen Unterverzeichnisse separat geprüft werden (z.B. bei 1&1)',
+ 'or' => ' oder ',
+ 'toggleswitch' => 'Klick für Details zur Prüfung',
+ 'unableDeleteFile' => 'Datei konnte nicht gelöscht werden. Bitte löschen Sie diese '.
+ 'manuell.',
+ 'goodBye' => 'Auf Wiedersehen.',
+ 'unableExecuteDirectoryIterator' => 'Es können nicht alle Unterverzeichnisse auf weitere Prüfungen '.
+ 'kontrolliert werden. (%1$s)',
+ 'availableDecoder' => 'verfügbar: %1$s - auf passendes Installationspaket achten!',
+ 'noDecoderAvailable' => 'kein verwendbarer Decoder verfügbar',
+ 'availableDecoder_hasZendLoaderOptimizer' => 'Zend Guard Loader / Optimizer',
+ 'notAvailableDecoder_hasZendLoaderOptimizer' => '
Der Zend Guard Loader / Optimizer ist nicht '.
+ 'installiert.
',
+ 'decoderIssue_hasZendLoaderOptimizer' => '
Der Zend-Decoder ist '.
+ 'auf Ihrem Server installiert. Es ist jedoch eine zusätzliche Erweiterungen (Zend OPcache) '.
+ 'installiert, die im Zusammenspiel mit dem Zend-Decoder Fehler verursachen kann.
Es wurde ein nicht definierter Abbruchgrund bei der '.
+ 'Verwendung des ionCube-Decoders festgestellt.
',
+ ),
+ 'en' => array(
+ 'RequCheck' => 'Requirement check',
+ 'ExecNotice' => 'Execute this check script in the root directory of your shop. In this '.
+ 'case only checks can executed succesfully.',
+ 'RequSucc' => 'condition is fulfilled',
+ 'RequNotSucc' => 'condition isn\'t fulfilled',
+ 'RequUnknown' => 'condition unclear, see notes in help text',
+ 'RequNotCheckable' => 'condition isn\'t checkable',
+ 'hasMinPhpVersion' => 'at least PHP version %1$s',
+ 'hasMinPhpVersion_DESC' => '
The module requires a PHP version at least %1$s
'.
+ '
The appropriate version of PHP '.
+ 'is activated on your server.
'.
+ '
The module can not be executed within '.
+ 'the actived PHP version. Ask your server provider for for the adaption of your PHP installation or '.
+ 'contact us for another module version.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasMaxPhpVersion' => 'not more than PHP version %1$s',
+ 'hasMaxPhpVersion_DESC' => '
The module requires a PHP version not more than %1$s
'.
+ '
The appropriate version of PHP '.
+ 'is activated on your server.
'.
+ '
The module can not be executed within '.
+ 'the actived PHP version. Ask your server provider for for the adaption of your PHP installation or '.
+ 'contact us for another module version.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasFromToPhpVersion' => 'server use PHP version between %1$s and %2$s',
+ 'hasFromToPhpVersion_DESC'=> '
The module requires a PHP version between %1$s and %2$s
'.
+ '
The appropriate version of PHP '.
+ 'is activated on your server.
'.
+ '
The module can not be executed within '.
+ 'the actived PHP version. Ask your server provider for for the adaption of your PHP installation or '.
+ 'contact us for another module version.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
The %1$s server extension is '.
+ 'available on your server.
'.
+ '
The module can not be executed '.
+ 'without the %1$s extension. Ask your server provider for installing this extension.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasMinCurlVersion' => 'at least cURL version %1$s',
+ 'hasMinCurlVersion_DESC' => '
The module requires at least cURL version %1$s.
'.
+ '
cURL is available '.
+ 'in a compatible version.
'.
+ '
cURL is not installed or '.
+ 'installed in an older version. Ask your server provider for an appropriate version.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasMinOpenSSLVersion' => 'at least OpenSSL version %1$s',
+ 'hasMinOpenSSLVersion_DESC' => '
The module requires at least OpenSSL version %1$s.
'.
+ '
OpenSSL is availabe '.
+ 'in a compatible version.
'.
+ '
OpenSSL is not installed or '.
+ 'installed in an older version. Ask your server provider for an appropriate version.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasMinShopVersion' => 'at least shop version %1$s',
+ 'hasMinShopVersion_DESC' => '
The module is released to shop version %1$s
'.
+ '
The shop software is installed '.
+ 'in a compatible version.
'.
+ '
We can not guarantee, '.
+ 'that this module works properly in your shop version. Please ask for a matching module version.
',
+ 'hasMinModCfgVersion' => '%2$s (ModCfg item "%1$s") at least in version %3$s',
+ 'hasMinModCfgVersion_DESC' => '
The module requires additional software "%2$s" at least '.
+ 'in version %3$s
'.
+ '
The software is installed '.
+ 'in a compatible version.
'.
+ '
The additional software is '.
+ 'not installed or in wrong version available. Please install the additional software before '.
+ 'proceeding this installation.
',
+ 'hasMaxModCfgVersion' => '%2$s (ModCfg item "%1$s") not more than in version %3$s',
+ 'hasMaxModCfgVersion_DESC' => '
The module requires additional software "%2$s" not more than '.
+ 'in version %3$s
'.
+ '
The software is installed '.
+ 'in a compatible version.
'.
+ '
The additional software is '.
+ 'be installed or in wrong version available. Please install the additional software before '.
+ 'proceeding this installation.
',
+ 'requireNewLicence' => 'former licence key can be used',
+ 'requireNewLicence_DESC' => '
This test tries to determine whether you need a new licence key '.
+ 'for the use of this module
'.
+ '
You have stored a license key '.
+ 'for this module, which is probably also compatible for the new module version.
'.
+ '
You need likely a new license '.
+ 'key for this module. Do you have already one, run the installation and then apply the license '.
+ 'key in the admin panel of your shop. Otherwise, you can purchase it in our shop '.
+ 'oxidmodule.com or also create a '.
+ 'free trial license key in the admin panel of your shop.
The module requires necessarily the D3 Module Connector.
'.
+ '
The Module Connector is '.
+ 'installed.
'.
+ '
The module can not be executed '.
+ 'without the Module Connector. Please download this free of charge from our shop '.
+ 'www.oxidmodule.com/'.
+ 'connector/ and install it beforehand.
The module requires (depending on the PHP version) the Zend Guard Optimizer '.
+ 'or the Zend Guard Loader.
'.
+ '
The appropriate decoder is '.
+ 'installed on your server.
'.
+ '
The decoder is '.
+ 'installed on your server. There is an additional installed extension (Zend OPcache), '.
+ 'which can cause errors in combination with the decoder.
'.
+ '
The decoder isn\'t '.
+ 'installed on your server. The module can\'t installed or executed. Please contact your server provider.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'hasIonCubeLoader' => 'ionCube Loader installed (pay attention to the compatible ionCube installation package!)',
+ 'hasIonCubeLoader_DESC' => '
The module requires the ionCube Loader.
'.
+ '
The appropriate decoder is '.
+ 'installed on your server.
'.
+ '
The decoder isn\'t '.
+ 'installed on your server. The module can\'t installed or executed. Please contact your server provider.
'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
The module requires the ionCube Loader or the Zend '.
+ 'Optimizer / Guard Loader. Pay attention to use a compatible installation package (%1$s).
'.
+ '
One of the appropriate '.
+ 'decoders is installed on your server.
'.
+ '
One of the appropriate '.
+ 'decoder is installed on your server. An undefined abort reason has been found, which can cause '.
+ 'to errors. For details, please refer to the following notes.
'.
+ '
None of the decoders is '.
+ 'installed on your server. The module can\'t installed or executed. Please contact your server provider.
'.
+ '%2$s'.
+ '
The [+] button show details for all tested directories. Depending on the server settings, '.
+ 'the results may vary. Only the red marked directories requires adaptation.
'.
+ '
Details about your server installation you can see by clicking on the button "show PHPinfo". '.
+ 'If you have any questions, please contact us at '.
+ 'support@shopmodule.com.
',
+ 'RemoteVersionDiff' => ' (Remote script has different version or isn\'t '.
+ 'callable, result may not be safe)',
+ 'globalSuccess' => 'The technical test was successful. Your server is ready for installing '.
+ 'the module.*
',
+ 'globalNotSuccess' => 'The technical test wasn\'t successfull. Please check the red or orange marked '.
+ 'conditions.
',
+ 'deleteFile1' => 'Please delete this file after use on your server! Click here, to delete this file.',
+ 'showPhpInfo' => 'show PHPinfo',
+ 'dependentoffurther' => '* dependent of further unchecked conditions',
+ 'oneandonedescription' => '** this check use execution directory only, provider dependend '.
+ 'subdirectories have to check separately (e.g. at 1&1)',
+ 'or' => ' or ',
+ 'toggleswitch' => 'click for details',
+ 'unableDeleteFile' => 'Unable to delete file. Please delete it manually.',
+ 'goodBye' => 'Good Bye.',
+ 'unableExecuteDirectoryIterator' => 'Unable to check subdirectories for further checks. (%1$s)',
+ 'availableDecoder' => 'available: %1$s - pay attention to the compatible installation package!',
+ 'noDecoderAvailable' => 'no usable decoder available',
+ 'availableDecoder_hasZendLoaderOptimizer' => 'Zend Guard Loader / Optimizer',
+ 'notAvailableDecoder_hasZendLoaderOptimizer' => '
The Zend decoder is '.
+ 'installed on your server. There is an additional installed extension (Zend OPcache), '.
+ 'which can cause errors in combination with the decoder.
";
+}
+
+$oRequCheck = new requcheck;
+if (isset($_REQUEST['fnc']) && $_REQUEST['fnc']) {
+ $oRequCheck->{$_REQUEST['fnc']}();
+} else {
+ $oRequCheck->startCheck();
+}
diff --git a/docs/install.sql b/docs/install.sql
new file mode 100644
index 0000000..c8d2b0c
--- /dev/null
+++ b/docs/install.sql
@@ -0,0 +1,9 @@
+CREATE TABLE `d3totp` (
+ `OXID` CHAR(32) NOT NULL,
+ `OXUSERID` CHAR(32) NOT NULL,
+ `USETOTP` TINYINT(1) NOT NULL DEFAULT '0',
+ `SEED` VARCHAR(125) NOT NULL DEFAULT '0',
+ PRIMARY KEY (`OXID`),
+ UNIQUE INDEX `OXUSERID` (`OXUSERID`)
+)
+ENGINE=InnoDB
\ No newline at end of file
diff --git a/docs/update.sql b/docs/update.sql
new file mode 100644
index 0000000..892dc86
--- /dev/null
+++ b/docs/update.sql
@@ -0,0 +1 @@
+# no update instructions available
\ No newline at end of file
diff --git a/resources/build/sources/docs/_index.md b/resources/build/sources/docs/_index.md
new file mode 100644
index 0000000..e69de29
diff --git a/resources/build/sources/docs/changelog/010_Changelog.md b/resources/build/sources/docs/changelog/010_Changelog.md
new file mode 100644
index 0000000..66e4e63
--- /dev/null
+++ b/resources/build/sources/docs/changelog/010_Changelog.md
@@ -0,0 +1,14 @@
+---
+title: Changelog
+---
+
+## Unreleased
+
+## 1.0.0.0
+2018-10-24 - #1000
+#### Added
+- 2-Faktor-Authentisierung für Backend-Logins zusätzlich zu Benutzername und Passwort
+- Authentisierung wird nur bei Benutzerkonten gezeigt, die dieses aktiviert haben - sonst nur Standardanmeldung
+- die Basis der Passwortgenerierung wird für jedes Benutzerkonto individuell angelegt
+- Einrichtung des Zugangs in der Auth-App kann durch scanbaren QR-Code oder kopierbare Zeichenkette erfolgen
+- Validierung der Einmalpassworte und Generierung der QR-Codes werden ausschließlich innerhalb des Shops durchgeführt - keine Kommunikation nach außen nötig
diff --git a/resources/build/sources/docs/config.json b/resources/build/sources/docs/config.json
new file mode 100644
index 0000000..9be9c62
--- /dev/null
+++ b/resources/build/sources/docs/config.json
@@ -0,0 +1,76 @@
+{
+ "title": " 2-Faktor-Authentisierung",
+ "moduleversion": "1.0.0.0",
+ "titledesc": "für den Oxid eShop",
+ "author": "D³ Data Development",
+ "moduledate": "24.10.2018",
+ "editors": "DS",
+ "tagline": "",
+ "image": "",
+ "ignore": {
+ "files": [],
+ "folders": [".idea"]
+ },
+ "live": {
+ "clean_urls": true
+ },
+ "html": {
+ "theme": "d3",
+ "breadcrumbs": true,
+ "breadcrumb_separator": "Chevrons",
+ "toggle_code": false,
+ "date_modified": true,
+ "date_modified_format": "d.m.Y",
+ "float": false,
+ "inherit_index": true,
+ "auto_landing": true,
+
+ "links": {
+ "Shop": "https://www.oxidmodule.com",
+ "Blog": "https://blog.oxidmodule.com",
+ "FAQ": "https://faq.oxidmodule.com",
+ "D³ Support-Center": "https://support.shopmodule.com/",
+ "Kontakt": "https://www.oxidmodule.com/kontakt",
+ "Impressum": "https://www.oxidmodule.com/impressum"
+ },
+
+ "powered_by": ""
+ },
+ "languages": {
+ "installation": "Installation",
+ "changelog": "Changelog",
+ "support": "Support"
+ },
+ "processor": "d3processor",
+ "language": "de",
+ "strings": {
+ "de": {
+ "CodeBlocks_title": "Code-Blöcke",
+ "CodeBlocks_hide": "Aus",
+ "CodeBlocks_below": "Unterhalb",
+ "CodeBlocks_inline": "Linear",
+ "CodeBlocks_show": "Code-Blöcke anzeigen",
+ "Search_placeholder": "Suchen...",
+ "Link_previous": "Zurück",
+ "Link_next": "Weiter",
+ "Edit_on": "Bearbeiten bei :name:",
+ "View_on_github": "Bei GitHub anzeigen",
+ "View_documentation": "Dokumentation anzeigen",
+ "Table_of_contents": "Inhaltsverzeichnis",
+ "author": "Autor",
+ "moduledate": "Stand",
+ "version": "Version",
+ "editors": "Bearbeiter",
+ "selectversion": "Version wechseln"
+ }
+ },
+ "variables": {
+ "modulename" : " 2-Faktor-Authentisierung",
+ "menutitle" : " 2-Faktor-Authentisierung",
+ "modulefolder" : "totp",
+ "modcfgident" : "d3totp",
+ "composerident" : "d3/totp"
+ },
+ "versionselector": true,
+ "versiondirectoryindex": 2
+}
diff --git a/resources/build/sources/docs/installation/010_Anforderungen/010_Systemanforderungen.md b/resources/build/sources/docs/installation/010_Anforderungen/010_Systemanforderungen.md
new file mode 100644
index 0000000..16cedda
--- /dev/null
+++ b/resources/build/sources/docs/installation/010_Anforderungen/010_Systemanforderungen.md
@@ -0,0 +1,28 @@
+---
+title: Systemanforderungen
+---
+
+* PHP Version
+ * 5.6.x bis 7.2.x
+* PHP Decoder
+ * installierter ionCube Loader
+* Shopversionen / -editionen
+ * OXID eShop Community Edition in Compilation Version
+ * 6.0.x
+ * 6.1.x
+ * OXID eShop Professional Edition in Compilation Version
+ * 6.0.x
+ * 6.1.x
+ * oder OXID eShop Enterprise Edition in Compilation Version
+ * 6.0.x
+ * 6.1.x
+* Installation via [Composer](https://getcomposer.org)
+
+Beachten Sie, dass die Ihnen vorliegende Modulversion entsprechend für **PHP 5.6**, **PHP 7.0**, **PHP 7.1** oder **PHP 7.2** kompatibel ist. Im Zweifelsfall kontaktieren Sie uns und nennen den für Ihren Shop genutzten Decoder und die PHP-Version.
+
+Kontrollieren Sie bitte auch, ob diese Modulversion für die von Ihnen eingesetzte Shopedition (Community Edition (CE), Professional Edition (PE) oder Enterprise Edition (EE)) ausgelegt ist.
+
+### optional:
+* D3 Modul-Connector ([kostenfrei bei D3 erhältlich](https://www.oxidmodule.com/connector/)) ab Version 5.1.1.4
+
+Ist der D3 Modul-Connector installiert, können Datenbankänderungen über die automatische Installation eingerichtet und überwacht werden.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/010_Anforderungen/020_Anforderungspruefung.md b/resources/build/sources/docs/installation/010_Anforderungen/020_Anforderungspruefung.md
new file mode 100644
index 0000000..1237b53
--- /dev/null
+++ b/resources/build/sources/docs/installation/010_Anforderungen/020_Anforderungspruefung.md
@@ -0,0 +1,14 @@
+---
+title: Anforderungsprüfung
+---
+
+Im Ordner `docs` finden Sie den Ordner `Precheck`. Mit dessen Inhalt können Sie die Mindestanforderungen auf Ihrem
+Server direkt prüfen. Kopieren Sie die enthaltenen Dateien und Ordner unverändert in das `source`-Verzeichnis Ihres
+installierten OXID-Shops. Rufen Sie nun über Ihren Browser die folgende Adresse auf:
+
+[http://www.ihreadresse.de/d3precheck.php](http://www.ihreadresse.de/d3precheck.php)
+
+Ihnen werden nun Details und Ergebnisse zur Anforderungsprüfung angezeigt.
+
+> [!] Löschen Sie diese Scripte mit Hilfe der in der Übersicht enthaltenen Funktion bitte unbedingt nach der Prüfung
+wieder von Ihrem Server.
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/010_Paketquelle_hinzufuegen.md b/resources/build/sources/docs/installation/020_Neuinstallation/010_Paketquelle_hinzufuegen.md
new file mode 100644
index 0000000..0a42da1
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/010_Paketquelle_hinzufuegen.md
@@ -0,0 +1,13 @@
+---
+title: Paketquelle hinzufügen
+---
+
+Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des `source`- und `vendor`-Verzeichnisses). Senden Sie dort diesen Befehl ab:
+
+```bash
+php composer config repositories.d3 composer https://satis.oxidmodule.com
+```
+
+> [!] Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+> [i] Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die [Dokumentation von Composer](https://getcomposer.org/doc/03-cli.md#require).
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/020_Modul_hinzufuegen.md b/resources/build/sources/docs/installation/020_Neuinstallation/020_Modul_hinzufuegen.md
new file mode 100644
index 0000000..46062ac
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/020_Modul_hinzufuegen.md
@@ -0,0 +1,11 @@
+---
+title: Modul zur Installation hinzufügen
+---
+
+Führen Sie in der Konsole im selben Verzeichnis diesen Befehl aus, um das Modul **{$modulename}** zur Installation hinzuzufügen:
+
+```bash
+php composer require {$composerident} --update-no-dev
+```
+
+> [i] Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die [Dokumentation von Composer](https://getcomposer.org/doc/03-cli.md#require).
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/040_Providerspezifische_Installation.md b/resources/build/sources/docs/installation/020_Neuinstallation/040_Providerspezifische_Installation.md
new file mode 100644
index 0000000..e59a8b9
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/040_Providerspezifische_Installation.md
@@ -0,0 +1,5 @@
+---
+title: Providerspezifische Installation
+---
+
+Manche Provider erfordern besondere Einstellungen für installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer [FAQ](http://faq.oxidmodule.com/Modulinstallation/providerspezifische-Installation/).
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/050_Modul_im_Shop_aktivieren.md b/resources/build/sources/docs/installation/020_Neuinstallation/050_Modul_im_Shop_aktivieren.md
new file mode 100644
index 0000000..c79d004
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/050_Modul_im_Shop_aktivieren.md
@@ -0,0 +1,7 @@
+---
+title: Modul im Shop aktivieren
+---
+
+Aktivieren Sie das Modul über den Shopadmin unter [ Erweiterungen ] -> [ Module ]. Klicken Sie nach Auswahl von [ {$menutitle} ] auf den Button [ Aktivieren ].
+
+> [!] **Enterprise Editon**: Achten Sie darauf, dass das Modul in weiteren Shops (Mall) ebenfalls aktiviert werden muss, um dessen Funktion dort auch zu nutzen.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/060_Shopanpassungen_installieren.md b/resources/build/sources/docs/installation/020_Neuinstallation/060_Shopanpassungen_installieren.md
new file mode 100644
index 0000000..43f9dad
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/060_Shopanpassungen_installieren.md
@@ -0,0 +1,17 @@
+---
+title: Shopanpassungen installieren
+---
+
+# mit installiertem D3 Modul-Connector
+
+Wenn der D3 Modul-Connector installiert ist, startet direkt nach der Modulaktivierung der Assistent, der Sie durch die Shopanpassung führt. Darin können Sie verschiedene Optionen der Installation wählen.
+
+Den Installationsassistenten finden Sie auch unter den Menüpunkten [ Admin ] -> [ D3 Module ] -> [ Modul-Connector ] -> [ Modulverwaltung ] -> [ Modulinstallation ].
+
+Bei tiefgreifenden Änderungen an Ihrem Shop (z.B. Hinzufügen weiterer Sprachen oder Mandanten) rufen Sie den Installationsassistenten bitte erneut auf, um dann eventuell notwendige Nacharbeiten für das Modul ausführen zu lassen.
+
+Möchten Sie die Änderungen manuell installieren, können Sie sich über diesen Assistenten ebenfalls eine Checkliste erstellen.
+
+# ohne installiertem D3 Modul-Connector
+
+Führen Sie bitte die Anweisungen in der Datei `install.sql` im docs-Ordner in Ihrer Datenbank aus.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/070_TMP-Ordner_leeren.md b/resources/build/sources/docs/installation/020_Neuinstallation/070_TMP-Ordner_leeren.md
new file mode 100644
index 0000000..06d3b35
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/070_TMP-Ordner_leeren.md
@@ -0,0 +1,9 @@
+---
+title: TMP-Ordner leeren
+---
+
+Leeren Sie das Verzeichnis `tmp` über [ Admin ] -> [ D3 Module ] -> [ Modul-Connector ] -> [ TMP leeren ]. Markieren Sie [ komplett leeren ] und klicken auf [ TMP leeren ].
+
+Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+> [i] Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/100_Updatefaehigkeit.md b/resources/build/sources/docs/installation/020_Neuinstallation/100_Updatefaehigkeit.md
new file mode 100644
index 0000000..1913bce
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/100_Updatefaehigkeit.md
@@ -0,0 +1,7 @@
+---
+Title: Updatefähigkeit
+---
+
+Bei individuellen Änderungen von Moduldateien empfehlen wir, jeweils die Überladungsmöglichkeiten des Shops dafür zu verwenden. So brauchen Sie die originalen Moduldateien nicht verändern und erhalten sich so die Updatefähigkeit des Shops und des Moduls. Beachten Sie, dass Moduldateien bei Updateinstallationen überschrieben werden.
+
+Weitere Informationen zu den Überladungsmöglichkeiten verschiedener Dateien finden Sie in unserer [FAQ](http://faq.oxidmodule.com/Modulinstallation/Modulanpassungen/).
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/020_Neuinstallation/_index.md b/resources/build/sources/docs/installation/020_Neuinstallation/_index.md
new file mode 100644
index 0000000..286ecbb
--- /dev/null
+++ b/resources/build/sources/docs/installation/020_Neuinstallation/_index.md
@@ -0,0 +1,13 @@
+---
+Title: Schnellstart per Composer
+---
+
+## Schnellstart per Composer
+
+```bash
+php composer config repositories.d3 composer https://satis.oxidmodule.com
+
+php composer require {$composerident} –-update-no-dev
+```
+
+Detailliertere Angaben zur Installation entnehmen Sie bitte den folgenden Schritten.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/010_Modul_deaktivieren.md b/resources/build/sources/docs/installation/030_Update/010_Modul_deaktivieren.md
new file mode 100644
index 0000000..44fe98e
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/010_Modul_deaktivieren.md
@@ -0,0 +1,5 @@
+---
+title: Modul deaktivieren
+---
+
+Deaktivieren Sie das Modul über den Shopadmin unter [ Erweiterungen ] -> [ Module ]. Klicken Sie nach Auswahl von [ {$menutitle} ] auf den Button [ Deaktivieren ].
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/020_Dateien_erneuern.md b/resources/build/sources/docs/installation/030_Update/020_Dateien_erneuern.md
new file mode 100644
index 0000000..f4ef305
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/020_Dateien_erneuern.md
@@ -0,0 +1,14 @@
+---
+title: Dateien erneuern
+---
+
+Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres
+Shops (oberhalb des `source`- und `vendor`-Verzeichnisses). Führen Sie dort diesen Befehl aus:
+
+```bash
+php composer update {$composerident} --no-dev
+```
+
+> [!] Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+> [i] Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die [Dokumentation von Composer](https://getcomposer.org/doc/03-cli.md#require).
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/030_Providerspezifische_Installation.md b/resources/build/sources/docs/installation/030_Update/030_Providerspezifische_Installation.md
new file mode 100644
index 0000000..e59a8b9
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/030_Providerspezifische_Installation.md
@@ -0,0 +1,5 @@
+---
+title: Providerspezifische Installation
+---
+
+Manche Provider erfordern besondere Einstellungen für installierte Module. Ob Ihr Anbieter spezielle Anforderungen stellt und wie diese aussehen, kontrollieren Sie bitte in unserer [FAQ](http://faq.oxidmodule.com/Modulinstallation/providerspezifische-Installation/).
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/040_Modulinformationen_aktualisieren.md b/resources/build/sources/docs/installation/030_Update/040_Modulinformationen_aktualisieren.md
new file mode 100644
index 0000000..0c545a9
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/040_Modulinformationen_aktualisieren.md
@@ -0,0 +1,5 @@
+---
+title: Modulinformationen aktualisieren
+---
+
+Wechseln Sie im Adminbereich zu [ Erweiterungen ] -> [ Module ]. Klicken Sie nach Auswahl von [ {$menutitle} ] auf den Button [ Aktivieren ].
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/050_Shopanpassungen_installieren.md b/resources/build/sources/docs/installation/030_Update/050_Shopanpassungen_installieren.md
new file mode 100644
index 0000000..9bd0f68
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/050_Shopanpassungen_installieren.md
@@ -0,0 +1,17 @@
+---
+title: Shopanpassungen installierren
+---
+
+# mit installiertem D3 Modul-Connector
+
+Ob Shopanpassungen notwendig sind, ist von der Versionsänderung des Moduls abhängig.
+
+Möglicherweise sehen Sie nach dem Neuaktivieren des Moduls den Installationsassistent, der Sie durch die Änderungen führt. Folgen Sie dann den einzelnen Schritten. Möchten Sie die Änderungen manuell installieren, können Sie sich über diesen Assistenten ebenfalls eine Checkliste erstellen.
+
+Wird der Assistent nicht gezeigt (Sie sehen wieder die Modulübersicht), waren keine Anpassungen am Shop notwendig.
+
+Ob erforderliche Updates ausgeführt werden sollen, können Sie jederzeit im Adminbereich unter [ D3 Module ] -> [ Modul-Connector ] -> [ Modulverwaltung ] -> [ Modulinstallation ] prüfen.
+
+# ohne installiertem D3 Modul-Connector
+
+Prüfen Sie bitte, ob in der Datei "update.sql" im docs-Ordner Änderungen hinterlegt sind, die in der Datenbank ausgeführt werden sollten.
diff --git a/resources/build/sources/docs/installation/030_Update/060_TMP-Ordner_leeren.md b/resources/build/sources/docs/installation/030_Update/060_TMP-Ordner_leeren.md
new file mode 100644
index 0000000..06d3b35
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/060_TMP-Ordner_leeren.md
@@ -0,0 +1,9 @@
+---
+title: TMP-Ordner leeren
+---
+
+Leeren Sie das Verzeichnis `tmp` über [ Admin ] -> [ D3 Module ] -> [ Modul-Connector ] -> [ TMP leeren ]. Markieren Sie [ komplett leeren ] und klicken auf [ TMP leeren ].
+
+Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+> [i] Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/030_Update/080_Erweiterungen_anpassen.md b/resources/build/sources/docs/installation/030_Update/080_Erweiterungen_anpassen.md
new file mode 100644
index 0000000..07cc1d2
--- /dev/null
+++ b/resources/build/sources/docs/installation/030_Update/080_Erweiterungen_anpassen.md
@@ -0,0 +1,5 @@
+---
+title: Erweiterungen anpassen
+---
+
+Haben Sie für dieses Modul eigene Erweiterung entwickelt, gleichen Sie dies bitte mit der neuen Fassung des Moduls ab.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/040_Installationspruefung.md b/resources/build/sources/docs/installation/040_Installationspruefung.md
new file mode 100644
index 0000000..a6e58b6
--- /dev/null
+++ b/resources/build/sources/docs/installation/040_Installationspruefung.md
@@ -0,0 +1,18 @@
+---
+title: Installationsprüfung
+---
+
+Um die erfolgreiche Installation zu prüfen, können Sie die folgende(n) Checkliste(n) verwenden:
+
+## Einstellungsunabhängige Prüfungen
+
+### Backend
+
+* Modul ist unter [ Erweiterungen ] -> [ Module ] aktiv geschaltet
+* Modul zeigt unter [ Benutzer verwalten ] -> [ Benutzer ] -> [ 2-Faktor-Authentisierung ] einen eigenen Bereich für Einstellungen
+
+## Einstellungsabhängige Prüfungen
+
+### Backend
+
+* Nach Aktivierung fragt das Backend neben Benutzername und Passwort auch ein Einmalpasswort ab.
diff --git a/resources/build/sources/docs/installation/050_Schnellstart.md b/resources/build/sources/docs/installation/050_Schnellstart.md
new file mode 100644
index 0000000..b7b7279
--- /dev/null
+++ b/resources/build/sources/docs/installation/050_Schnellstart.md
@@ -0,0 +1,13 @@
+---
+title: Schnellstart
+---
+
+Aktivieren Sie die 2-Faktor-Authentisierung im Backend unter [ Benutzer verwalten ] -> [ Benutzer ] -> [ 2-Faktor-Authentisierung ].
+
+Ab dann erfordert das Login im Backend für das jeweilige Benutzerkonto neben Benutzername auch die Angabe eines Einmalpasswortes.
+
+Diese zusätzliche Absicherung kann im Adminbereich jederzeit wieder entfernt werden.
+
+## zusätzliche Konfigurationsparameter in der Datei `config.inc.php` möglich:
+
+`blDisableTotpGlobally` => true: deaktiviert diese zusätzlichen Sicherung shopweit für alle Benutzer. Diese Option ist für den Fall vorbehalten, wenn der Adminbereich aus einem technischen Grund und von diesem Modul verursacht nicht mehr aufgerufen werden kann.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/010_Modulerweiterungen_deaktivieren_und_entfernen.md b/resources/build/sources/docs/installation/060_Deinstallation/010_Modulerweiterungen_deaktivieren_und_entfernen.md
new file mode 100644
index 0000000..666288e
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/010_Modulerweiterungen_deaktivieren_und_entfernen.md
@@ -0,0 +1,5 @@
+---
+title: Modulerweiterungen deaktivieren und entfernen
+---
+
+Deaktivieren Sie alle vorhandenen Erweiterungen, die auf dem Modul **{$modulename}** aufbauen und löschen bitte alle Dateien dieser Erweiterungen. Entfernen Sie ebenfalls alle individuellen Templateanpassungen für dieses Modul.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/020_Modul_deaktivieren.md b/resources/build/sources/docs/installation/060_Deinstallation/020_Modul_deaktivieren.md
new file mode 100644
index 0000000..cca9ec9
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/020_Modul_deaktivieren.md
@@ -0,0 +1,6 @@
+---
+title: Modul deaktivieren
+---
+
+Deaktivieren Sie das Modul **{$modulename}** über den Shopadmin [ Erweiterungen ] -> [ Module ]. Klicken Sie nach Auswahl von [ {$menutitle} ] auf den Button [ Deaktivieren ].
+
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/030_Modul_aus_der_Installation_entfernen.md b/resources/build/sources/docs/installation/060_Deinstallation/030_Modul_aus_der_Installation_entfernen.md
new file mode 100644
index 0000000..f1e839c
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/030_Modul_aus_der_Installation_entfernen.md
@@ -0,0 +1,13 @@
+---
+title: Modul aus der Installation entfernen
+---
+
+Starten Sie die Konsole Ihres Webservers und wechseln in das Hauptverzeichnis Ihres Shops (oberhalb des `source`- und `vendor`-Verzeichnisses). Führen Sie Sie dort diesen Befehl aus:
+
+```Bash
+php composer remove {$composerident} --no-update
+```
+
+> [!] Achten Sie darauf, dass die Installation über Composer mit derselben PHP-Version erfolgt, in der auch Ihr Shop installiert ist. Sie erhalten sonst unpassende Modulpakete.
+
+> [i] Benötigt Ihre Installation einen anderen Aufruf von Composer, ändern Sie den Befehl bitte entsprechend ab. Für weitere Optionen dieses Befehls lesen Sie bitte die [Dokumentation von Composer](https://getcomposer.org/doc/03-cli.md#require).
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/040_Dateien_loeschen.md b/resources/build/sources/docs/installation/060_Deinstallation/040_Dateien_loeschen.md
new file mode 100644
index 0000000..9165304
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/040_Dateien_loeschen.md
@@ -0,0 +1,9 @@
+---
+title: Dateien löschen
+---
+
+Löschen Sie den Ordner `{$modulefolder}` und seine enthaltenen Elemente aus dem Verzeichnis `source/modules/d3` Ihres Shops.
+Bestätigen Sie anschließend im Shopadmin unter [ Erweiterungen ] -> [ Module ] -> [ Installierte Shop-Module ] die Nachricht:
+
+> Es gibt registrierte Erweiterungen im eShop, deren Verzeichnis nicht vorhanden ist.
+Möchten Sie alle Modulinformationen einschließlich Konfigurationseinstellungen und Blockinformationen für Templates löschen?
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/050_Datenbank_bereinigen.md b/resources/build/sources/docs/installation/060_Deinstallation/050_Datenbank_bereinigen.md
new file mode 100644
index 0000000..4ee21a7
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/050_Datenbank_bereinigen.md
@@ -0,0 +1,11 @@
+---
+title: Datenbank bereinigen
+---
+
+Das Modul legt Informationen in der Datenbank ab. Sofern diese Daten nicht mehr benötigt werden, können diese gelöscht werden.
+
+> [!] Legen Sie sich vorab bitte unbedingt eine Sicherung an, um die Daten im Zweifelsfall wiederherstellen zu können.
+
+Für das Modul **{$modulename}** sind dies die folgende Tabellen und Felder:
+
+* die komplette Tabelle `d3totp`
diff --git a/resources/build/sources/docs/installation/060_Deinstallation/060_TMP-Ordner_leeren.md b/resources/build/sources/docs/installation/060_Deinstallation/060_TMP-Ordner_leeren.md
new file mode 100644
index 0000000..06d3b35
--- /dev/null
+++ b/resources/build/sources/docs/installation/060_Deinstallation/060_TMP-Ordner_leeren.md
@@ -0,0 +1,9 @@
+---
+title: TMP-Ordner leeren
+---
+
+Leeren Sie das Verzeichnis `tmp` über [ Admin ] -> [ D3 Module ] -> [ Modul-Connector ] -> [ TMP leeren ]. Markieren Sie [ komplett leeren ] und klicken auf [ TMP leeren ].
+
+Sofern die Views nicht automatisch aktualisiert werden, führen Sie dies noch durch.
+
+> [i] Erfordert Ihre Installation eine andere Vorgehensweise zum Leeren des Caches oder zum Aktualisieren der Datenbank-Viewtabellen, führen Sie diese bitte aus.
\ No newline at end of file
diff --git a/resources/build/sources/docs/installation/_index.md b/resources/build/sources/docs/installation/_index.md
new file mode 100644
index 0000000..438c26d
--- /dev/null
+++ b/resources/build/sources/docs/installation/_index.md
@@ -0,0 +1,10 @@
+---
+title: Installation / Update / Deinstallation
+---
+
+* [Anforderungen](installation/010_Anforderungen/010_Systemanforderungen.md)
+* [Neuinstallation](installation/020_Neuinstallation/010_Paketquelle_hinzufuegen.md)
+* [Update](installation/030_Update/010_Modul_deaktivieren.md)
+* [Deinstallation](installation/060_Deinstallation/010_Modulerweiterungen_deaktivieren_und_entfernen.md)
+
+Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unter [Hilfe und Support](support/010_Hilfe-und-Support.md) genannten Kontaktdaten Bescheid.
diff --git a/resources/build/sources/docs/support/010_Hilfe-und-Support.md b/resources/build/sources/docs/support/010_Hilfe-und-Support.md
new file mode 100644
index 0000000..30408f9
--- /dev/null
+++ b/resources/build/sources/docs/support/010_Hilfe-und-Support.md
@@ -0,0 +1,16 @@
+---
+title: Hilfe und Support
+---
+
+Bei Bedarf bieten wir Ihnen auch gern die Installation des Moduls in Ihrem Shop an. Geben Sie uns bitte unter den unten genannten Kontaktdaten Bescheid.
+
+Haben Sie Fragen oder Unklarheiten in Verbindung mit diesem Modul oder dessen Installation, stehen Ihnen Hilfetexte in unserer [Modul-FAQ](http://faq.oxidmodule.com/) zur Verfügung. Finden Sie darin die benötigten Antworten nicht, kontaktieren Sie uns bitte unter den folgenden Möglichkeiten:
+1. per E-Mail: oder
+2. über das Kontaktformular auf [Oxidmodule.com](https://www.oxidmodule.com/) oder
+3. per Telefon: (+49) 37 21 / 26 80 90 zu unseren Bürozeiten
+
+Geben Sie bitte an, wo und wie wir gegebenenfalls vorhandene Schwierigkeiten nachvollziehen können. Sind Ihre Fragen shopspezifisch, benötigen wir möglicherweise Zugangsdaten zum betreffenden Shop.
+
+Wir wünschen Ihnen mit Ihrem Shop und dem Modul viel Erfolg!
+
+Ihr D³-Team.
diff --git a/src/metadata.php b/src/metadata.php
index 18f49df..134c330 100644
--- a/src/metadata.php
+++ b/src/metadata.php
@@ -77,14 +77,3 @@ $aModule = [
ModuleSetup\Installation::class
]
];
-
-// CREATE TABLE `d3totp` (
-// `OXID` CHAR(32) NOT NULL,
-// `OXUSERID` CHAR(32) NOT NULL,
-// `USETOTP` TINYINT(1) NOT NULL DEFAULT '0',
-// `SEED` VARCHAR(125) NOT NULL DEFAULT '0',
-// PRIMARY KEY (`OXID`),
-// UNIQUE INDEX `Schl�ssel 2` (`OXUSERID`)
-//)
-//ENGINE=InnoDB
-//;
\ No newline at end of file