111 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| /*  Mailadminscript
 | |
|     Copyright (C) 2019  Paul Schürholz contact AT roteserver . de
 | |
| 
 | |
|     This program is free software: you can redistribute it and/or modify
 | |
|     it under the terms of the GNU General Public License as published by
 | |
|     the Free Software Foundation, either version 3 of the License, or
 | |
|     (at your option) any later version.
 | |
| 
 | |
|     This program is distributed in the hope that it will be useful,
 | |
|     but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|     GNU General Public License for more details.
 | |
| 
 | |
|     You should have received a copy of the GNU General Public License
 | |
|     along with this program.  If not, see <http://www.gnu.org/licenses/>. */
 | |
| $config = parse_ini_file('../private/config.ini');
 | |
| try {
 | |
|     $dbh = new PDO('mysql:host=' . $config['dbservername'] . ';dbname=' . $config['dbname'], $config['dbusername'], $config['dbpassword'], array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
 | |
| } catch (PDOException $e) {
 | |
|     //echo 'Connection failled: '. $e->getMessage(); // Errormessage kann Sicherheitsrelevantes enthalen
 | |
|     echo 'Connection failed';
 | |
| }
 | |
| session_start();
 | |
| if ($_SESSION['log'] == 1 and $_SESSION['admin'] == 1) {
 | |
|     echo '<html>
 | |
| <head>
 | |
| <title>Mail Admin Settings</title>
 | |
| </head>
 | |
| <body>
 | |
| <h1>Mail Admin Settings:</h1>';
 | |
|     if (isset($_GET['success'])) {
 | |
|         echo 'Erfolgreich geändert.';
 | |
|     }
 | |
|     if (isset($_GET['fehler'])) {
 | |
|         echo '<h3>Fehler: ' . htmlentities($_GET['fehler']) . '</h3>';
 | |
|     }
 | |
|     echo '<a href="settings.php"><p>Normale Einstellungen</p></a><a href="logout.php"><button>Logout</button></a>';
 | |
|     echo '<h3>Mailadresse aktivieren:</h3>
 | |
| <form name="activatemail" method=POST action="bin/activatemail.php">
 | |
| <label>Activate Mail:<select name="mailuserID">';
 | |
|     $abfrage = "SELECT `id`, `username`, `domain` FROM `accounts` WHERE `enabled` LIKE 0 ORDER by `domain`, `username` ASC";
 | |
|     $result = $dbh->query($abfrage);
 | |
|     while ($emails = $result->fetch()) {
 | |
|         echo '<option value="' . htmlentities($emails['id']) . '">' . htmlentities($emails['username']) . '@' . htmlentities($emails['domain']) . '</option>';
 | |
|     }
 | |
|     echo '</select></label>
 | |
| <input type="submit" name="submit" value="aktivieren"/>';
 | |
| 
 | |
|     echo '</form>
 | |
| <h3>Mailadresse deaktivieren:</h3>
 | |
| <form name="deactivatemail" method=POST action="bin/deactivatemail.php">
 | |
| <label>Deactivate Mail:<select name="mailuserID">';
 | |
|     $abfrage = "SELECT `id`, `username`, `domain` FROM `accounts` WHERE `enabled` LIKE 1 ORDER by `domain`, `username` ASC";
 | |
|     $result = $dbh->query($abfrage);
 | |
|     while ($emails = $result->fetch()) {
 | |
|         echo '<option value="' . htmlentities($emails['id']) . '">' . htmlentities($emails['username']) . '@' . htmlentities($emails['domain']) . '</option>';
 | |
|     }
 | |
|     echo '</select></label>
 | |
| <input type="submit" name="submit" value="deaktivieren"/>
 | |
| </form>
 | |
| <h3>Emailadresse hinzufügen:</h3>
 | |
| <form name="createmailuser" method=POST action="bin/createmailuser.php">
 | |
| <label>Neue email<input type="text" name="newmailusername"/>@<select name="newmaildomainid">';
 | |
|     $abfrage = "SELECT `id`, `domain` FROM `domains` ORDER by `preselectorder` DESC, `domain` ASC";
 | |
|     $result = $dbh->query($abfrage);
 | |
|     while ($domains = $result->fetch()) {
 | |
|         echo '<option value="' . htmlentities($domains['id']) . '">' . htmlentities($domains['domain']) . '</option>';
 | |
|     }
 | |
| echo '</select> (benutze nicht ' .  "'" . ')</label>
 | |
| <label>Neues Passwort<input type="password" name="newmailpw"/>(min. 8 Zeichen, benutze nicht ' .  "'" . ')</label>
 | |
| <label>Neues Passwort wiederholen<input type="password" name="newmailpwrep"/></label>
 | |
| <label>Passwortänderung erzwingen:<input type="checkbox" name="forcepwreset" value="1"/></label>
 | |
| <input type="submit" name="submit" value="Hinzufügen"/>
 | |
| </form>
 | |
| <h3>Passwort einer Email-Adresse ändern:</h3>
 | |
| <form name="changemailpwadm" method=POST action="bin/changemailpwadm.php">
 | |
| <label>Zu ändernde Mail:<select name="changemailid">';
 | |
|     $abfrage = "SELECT `id`, `username`, `domain` FROM `accounts` ORDER by `domain`, `username` ASC";
 | |
|     $result = $dbh->query($abfrage);
 | |
|     while ($emails = $result->fetch()) {
 | |
|         echo '<option value="' . htmlentities($emails['id']) . '">' . htmlentities($emails['username']) . '@' . $emails['domain'] . '</option>';
 | |
|     }
 | |
|     echo '</select></label>';
 | |
|     echo '<label>Neues Passwort: <input type="password" name="newmailpw" /></label><label>Neues Passwort wiederholen: <input type="password" name="newmailpwrep" /></label>
 | |
| <input type="submit" name="submit" value="ÄNDERN"/>
 | |
| </form>
 | |
| <h3>Emailadresse entfernen:</h3>
 | |
| <form name="deletemail" method=POST action="bin/deletemail.php">
 | |
| <label>Delete Mail:<select name="mailuserID">';
 | |
|     $abfrage = "SELECT `id`, `username`, `domain` FROM `accounts` ORDER by `domain`, `username` ASC";
 | |
|     $result = $dbh->query($abfrage);
 | |
|     while ($emails = $result->fetch()) {
 | |
|         echo '<option value="' . htmlentities($emails['id']) . '">' . htmlentities($emails['username']) . '@' . $emails['domain'] . '</option>';
 | |
|     }
 | |
|     echo '</select></label>
 | |
| <input type="submit" name="submit" value="ENTFERNEN"/>
 | |
| </form>
 | |
| <a href="bin/maillistsettings.php"><h3>Maillisten Einstellungen</h3></a>
 | |
| <table><caption>Emailadressen:</caption><tr><th>Email-Adresse</th><th>quota</th><th>enabled</th><th>sendonly</th><th>forcepwreset</th><th>admin</th></tr>';
 | |
| $abfrage = "SELECT `id`, `username`, `domain`, `quota`, `enabled`, `sendonly`, `forcepwreset`, `admin` FROM `accounts` ORDER by `domain`, `username` ASC";
 | |
| $result = $dbh->query($abfrage);
 | |
| while ($emails = $result->fetch()) {
 | |
|     echo '<tr><td>' . htmlentities($emails['username']) . '@' . htmlentities($emails['domain']) . '</td><td>' . htmlentities($emails['quota']) . '</td><td>' . htmlentities($emails['enabled']) . '</td><td>' . htmlentities($emails['sendonly']) . '</td><td>' . htmlentities($emails['forcepwreset']) . '</td><td>' . htmlentities($emails['admin']) . '</td></tr>';
 | |
| }
 | |
| echo '</table></body>
 | |
| </html>';
 | |
|     exit;
 | |
| }
 | |
| header("Location: index.php");
 | |
| ?>
 |