install.php aktualisiert
This commit is contained in:
parent
5c29ff6041
commit
d731f0e430
168
install.php
168
install.php
|
@ -1,79 +1,106 @@
|
||||||
|
<?php
|
||||||
|
// Datenbankverbindung herstellen
|
||||||
|
include_once 'config/config.php';
|
||||||
|
|
||||||
|
// Verbindung zur MySQL-Datenbank herstellen
|
||||||
|
$conn = new mysqli($host, $username, $password);
|
||||||
|
if ($conn->connect_error) {
|
||||||
|
die("Verbindung zur Datenbank fehlgeschlagen: " . $conn->connect_error);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($_SERVER["REQUEST_METHOD"] == "POST") {
|
||||||
|
// Formulardaten abrufen
|
||||||
|
$host = $_POST["host"];
|
||||||
|
$username = $_POST["username"];
|
||||||
|
$password = $_POST["password"];
|
||||||
|
$database = $_POST["database"];
|
||||||
|
$email = $_POST["email"];
|
||||||
|
$notification_days = $_POST["notification_days"]; // Hinzugefügtes Feld für die Benachrichtigungstage
|
||||||
|
|
||||||
|
// Datenbank erstellen
|
||||||
|
$sql_create_db = "CREATE DATABASE IF NOT EXISTS $database";
|
||||||
|
if ($conn->query($sql_create_db) === TRUE) {
|
||||||
|
echo "<p>Datenbank erfolgreich erstellt.</p>";
|
||||||
|
|
||||||
|
// Datenbank auswählen
|
||||||
|
$conn->select_db($database);
|
||||||
|
|
||||||
|
// Tabelle erstellen
|
||||||
|
$sql_create_table = "CREATE TABLE IF NOT EXISTS materials (
|
||||||
|
id INT AUTO_INCREMENT PRIMARY KEY,
|
||||||
|
item_name VARCHAR(255) NOT NULL,
|
||||||
|
manufacturer VARCHAR(255) NOT NULL,
|
||||||
|
location VARCHAR(255) NOT NULL,
|
||||||
|
amount_should INT NOT NULL,
|
||||||
|
amount_is INT NOT NULL,
|
||||||
|
expiration_date DATE NOT NULL,
|
||||||
|
barcode VARCHAR(255) NOT NULL,
|
||||||
|
image VARCHAR(255),
|
||||||
|
email VARCHAR(255) NOT NULL,
|
||||||
|
notification_days INT NOT NULL DEFAULT 0
|
||||||
|
)";
|
||||||
|
if ($conn->query($sql_create_table) === TRUE) {
|
||||||
|
echo "<p>Tabelle 'materials' erfolgreich erstellt.</p>";
|
||||||
|
|
||||||
|
// Speichern der Daten in der config.php-Datei
|
||||||
|
$config_content = "<?php\n";
|
||||||
|
$config_content .= "\$host = '$host';\n";
|
||||||
|
$config_content .= "\$username = '$username';\n";
|
||||||
|
$config_content .= "\$password = '$password';\n";
|
||||||
|
$config_content .= "\$database = '$database';\n";
|
||||||
|
$config_content .= "\$email = '$email';\n";
|
||||||
|
$config_content .= "\$notification_days = $notification_days;\n"; // Hinzugefügtes Feld für die Benachrichtigungstage
|
||||||
|
$config_content .= "?>";
|
||||||
|
|
||||||
|
file_put_contents('config/config.php', $config_content);
|
||||||
|
|
||||||
|
// Weiterleitung zur Indexseite nach erfolgreicher Installation
|
||||||
|
header("Location: index.php");
|
||||||
|
exit();
|
||||||
|
} else {
|
||||||
|
echo "<p>Fehler beim Erstellen der Tabelle: " . $conn->error . "</p>";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
echo "<p>Fehler beim Erstellen der Datenbank: " . $conn->error . "</p>";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Datenbankverbindung schließen
|
||||||
|
$conn->close();
|
||||||
|
|
||||||
|
// Aktuellen Pfad ermitteln
|
||||||
|
$current_path = getcwd();
|
||||||
|
|
||||||
|
// Pfad zur PHP-Datei, die den Cron-Job ausführt
|
||||||
|
$cron_script_path = $current_path . '/notification_cron.php';
|
||||||
|
|
||||||
|
// Crontab-Zeile erstellen (hier: Täglich um 13 Uhr)
|
||||||
|
$cron_job = '0 13 * * * /usr/bin/php ' . $cron_script_path;
|
||||||
|
|
||||||
|
// Crontab einrichten
|
||||||
|
exec('crontab -l', $existing_cron_jobs); // Aktuelle Crontab abrufen
|
||||||
|
if (!in_array($cron_job, $existing_cron_jobs)) {
|
||||||
|
$existing_cron_jobs[] = $cron_job; // Neuen Cron-Job hinzufügen
|
||||||
|
$new_cron_tab = implode("\n", $existing_cron_jobs); // Crontab zusammenführen
|
||||||
|
file_put_contents('/tmp/crontab.txt', $new_cron_tab); // Temporäre Crontab-Datei erstellen
|
||||||
|
exec('crontab /tmp/crontab.txt'); // Neue Crontab-Datei einrichten
|
||||||
|
unlink('/tmp/crontab.txt'); // Temporäre Crontab-Datei löschen
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="de">
|
<html lang="de">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<link rel="stylesheet" type="text/css" href="css/install.css">
|
<link rel="stylesheet" type="text/css" href="css/install.css">
|
||||||
<title>Materialverwaltung Installer</title>
|
<link rel="icon" href="img/favicon.png" type="image/x-icon">
|
||||||
|
<title>Viper Installer</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h1>Materialverwaltung Installer</h1>
|
<center><img src="img/logo.png" alt="Logo"></center>
|
||||||
|
<center><h1>Installer</h1></center>
|
||||||
<?php
|
|
||||||
if ($_SERVER["REQUEST_METHOD"] == "POST") {
|
|
||||||
// Formulardaten abrufen
|
|
||||||
$host = $_POST["host"];
|
|
||||||
$username = $_POST["username"];
|
|
||||||
$password = $_POST["password"];
|
|
||||||
$database = $_POST["database"];
|
|
||||||
$email = $_POST["email"];
|
|
||||||
|
|
||||||
// Verbindung zur MySQL-Datenbank herstellen
|
|
||||||
$conn = new mysqli($host, $username, $password);
|
|
||||||
if ($conn->connect_error) {
|
|
||||||
die("Verbindung zur Datenbank fehlgeschlagen: " . $conn->connect_error);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Datenbank erstellen
|
|
||||||
$sql_create_db = "CREATE DATABASE IF NOT EXISTS $database";
|
|
||||||
if ($conn->query($sql_create_db) === TRUE) {
|
|
||||||
echo "<p>Datenbank erfolgreich erstellt.</p>";
|
|
||||||
|
|
||||||
// Datenbank auswählen
|
|
||||||
$conn->select_db($database);
|
|
||||||
|
|
||||||
// Tabelle erstellen
|
|
||||||
$sql_create_table = "CREATE TABLE IF NOT EXISTS materials (
|
|
||||||
id INT AUTO_INCREMENT PRIMARY KEY,
|
|
||||||
item_name VARCHAR(255) NOT NULL,
|
|
||||||
manufacturer VARCHAR(255) NOT NULL,
|
|
||||||
location VARCHAR(255) NOT NULL,
|
|
||||||
amount_should INT NOT NULL,
|
|
||||||
amount_is INT NOT NULL,
|
|
||||||
expiration_date DATE NOT NULL,
|
|
||||||
barcode VARCHAR(255) NOT NULL,
|
|
||||||
image VARCHAR(255),
|
|
||||||
email VARCHAR(255) NOT NULL
|
|
||||||
)";
|
|
||||||
if ($conn->query($sql_create_table) === TRUE) {
|
|
||||||
echo "<p>Tabelle 'materials' erfolgreich erstellt.</p>";
|
|
||||||
|
|
||||||
// Speichern der Daten in der config.php-Datei
|
|
||||||
$config_content = "<?php\n";
|
|
||||||
$config_content .= "\$host = '$host';\n";
|
|
||||||
$config_content .= "\$username = '$username';\n";
|
|
||||||
$config_content .= "\$password = '$password';\n";
|
|
||||||
$config_content .= "\$database = '$database';\n";
|
|
||||||
$config_content .= "\$email = '$email';\n";
|
|
||||||
$config_content .= "?>";
|
|
||||||
|
|
||||||
file_put_contents('config/config.php', $config_content);
|
|
||||||
|
|
||||||
// Weiterleitung zur Indexseite nach erfolgreicher Installation
|
|
||||||
header("Location: index.php");
|
|
||||||
exit();
|
|
||||||
} else {
|
|
||||||
echo "<p>Fehler beim Erstellen der Tabelle: " . $conn->error . "</p>";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
echo "<p>Fehler beim Erstellen der Datenbank: " . $conn->error . "</p>";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Datenbankverbindung schließen
|
|
||||||
$conn->close();
|
|
||||||
}
|
|
||||||
?>
|
|
||||||
|
|
||||||
<h2>Datenbankverbindung eingeben</h2>
|
<h2>Datenbankverbindung eingeben</h2>
|
||||||
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>">
|
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>">
|
||||||
|
@ -94,11 +121,16 @@
|
||||||
<input type="text" id="database" name="database" required>
|
<input type="text" id="database" name="database" required>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="email">E-Mail-Adresse für Materialbenachrichtigungen:</label>
|
<label for="email">E-Mail-Adresse für Benachrichtigungen:</label>
|
||||||
<input type="email" id="email" name="email" required>
|
<input type="email" id="email" name="email" required>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="notification_days">Benachrichtigungstage vor Ablauf:</label> <!-- Neues Feld für Benachrichtigungstage -->
|
||||||
|
<input type="number" id="notification_days" name="notification_days" required>
|
||||||
|
</div>
|
||||||
<input type="submit" value="Installieren">
|
<input type="submit" value="Installieren">
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
|
<span class="watermark">© copyright 2024 by M_Viper</span>
|
||||||
</html>
|
</html>
|
||||||
|
|
Loading…
Reference in New Issue