Deine Haustür schließt Du ab. Weswegen lässt Du die Hintereingänge aber offen? So und nicht anders verhält es sich mit fast allen Internetzugängen zu Deinem IoT, den Webcams und anderen Geräten.
Hallo Freunde.
Das ist der erste Schritt für eine vollständig neu geschriebene Version für eine Zugriffsverwaltung per Webbrowser, um den Zugriff auf interne Netzwerke per OpenVPN zu gewährleisten. Hierbei handelt es sich im Moment um KEINE sichere Version. Diese wird erst mit Version 1.1.0 erreicht sein. Ich möchte Euch aber heute schon die Möglichkeit geben selbst zu testen, um Ideen oder sogar eigenen Code einbringen zu können.
Ein Upgrade vom Original, Release 0.8 und 1.0.x, wird es mit Version 1.1.0 geben.
Die Installation ist zwar getestet, es kann aber noch Fehler geben.
Eigentlich sollten die definierten Konstanten vom Namen her selbsterklärend sein. (Beispiel ab 1.1.0 gültig und unterscheidet sich zu den vorherigen Versionen)
$dbhost = 'db.home';
$dbport = '3306';
$dbname = 'tester';
$dbuser = 'tester';
$dbpass = 'tester';
$dbtype = 'mysqli';
$dbdebug = FALSE;
$sessdebug = FALSE;
/* Site-Name */
define('_SITE_NAME',"OVPN-WebAdmin");
define('HOME_URL',"vpn.home");
define('_DEFAULT_LANGUAGE','de_DE');
/** Login Site */
define('_LOGINSITE','login1');
Der Eintrag _LOGINSITE definiert den zu ladenden Inhalt für die Loginseite, die Ihr Euch jeweils selbst ausschen könnt. Die verschiedenen Loginseiten werden gespeichert unter include/html/login/ [ Ordner ]. Es wird dann automatisch die login.php geladen und zur Anzeige gebracht.
Es gibt ja schon einige Beispiele unter login1, login2 und login3. Ihr könnt jede eigene Idee umsetzen. Bedingung für ein korrektes funktionieren sind 5 Dinge:
include (REAL_BASE_DIR.'/include/html/login/login.functions.php');
Mit diesem Eintrag ladet Ihr die Templatefunktionen die zur übermittlung der Logindaten benötigt werden.
echo username();
echo password();
Loginfield: hidden Fields
echo hiddenfields();
echo button();
Oftmals kommt es vor, dass bootstrap oder andere zu ladende Styles, weitere Angaben zu den Klassen benötigen. Die entsprechenden Angaben könnt Ihr ganz einfach auf die folgende Weise übergeben:
echo button('btn-primary btn-block');
Das System gibt weitere Angaben heraus, die im folgenden kurz beschrieben werden:
# Der Name der Webseite, eingetragen in der config.php
echo _SITE_NAME;
Standardmäßig wird immer der Inhalt aus dem Array $message angezeigt. Der Aufruf erfolgt am besten per:
echo GET_Lang::nachricht("_LOGIN_DATA");
Da die Klasse class.language.php immer mit geladen wird, kann der Aufruf auf diese Weise erfolgen. Die Klasse sucht dann den entsprechenden Schlüssel, hier _LOGIN_DATA und bringt ihn zur Anzeige. Schlüssel die nicht existieren werden automatisch mit einem LANGUAGE_ERROR und dem übergebenen falschen Eintrag angezeigt.
Möchtet Ihr andere Arrays aus dem Sprachfiles laden, übergebt Ihr einfach den Namen des Arrays, die Klasse findet den Wert und zeigt es Euch an.
echo GET_Lang::nachricht("4","errormessage");
Dieser Eintrag würde den Schlüssel 4 aus dem Array errormessage ausgeben.
Seit Version 1.2.0 habt Ihr die Möglichkeit eigene Fehlerseiten zu kreieren. Die Fehlerseiten werden immer mit dem Eintrag der Login Seite ausgerufen und müssen demnach auch im entsprechenden Ordner - siehe "Konfigurationsdatei config.php" - als error.php vorhanden sein.