|
| 1 | +<?php |
| 2 | + |
| 3 | +/* |
| 4 | +Copyright (c) 2014, Till Brehm, projektfarm Gmbh |
| 5 | +All rights reserved. |
| 6 | +
|
| 7 | +Redistribution and use in source and binary forms, with or without modification, |
| 8 | +are permitted provided that the following conditions are met: |
| 9 | +
|
| 10 | + * Redistributions of source code must retain the above copyright notice, |
| 11 | + this list of conditions and the following disclaimer. |
| 12 | + * Redistributions in binary form must reproduce the above copyright notice, |
| 13 | + this list of conditions and the following disclaimer in the documentation |
| 14 | + and/or other materials provided with the distribution. |
| 15 | + * Neither the name of ISPConfig nor the names of its contributors |
| 16 | + may be used to endorse or promote products derived from this software without |
| 17 | + specific prior written permission. |
| 18 | +
|
| 19 | +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND |
| 20 | +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| 21 | +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. |
| 22 | +IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, |
| 23 | +INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
| 24 | +BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 25 | +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| 26 | +OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
| 27 | +NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, |
| 28 | +EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 29 | +*/ |
| 30 | + |
| 31 | + |
| 32 | +$path = realpath(dirname(__FILE__)) . '/..'; |
| 33 | +$iface_path = realpath(dirname(__FILE__)) . '/../../interface/web'; |
| 34 | + |
| 35 | +require $path . '/lib/mysql_clientdb.conf'; |
| 36 | + |
| 37 | +if(isset($argv[1])) $dbname = $argv[1]; |
| 38 | +else $dbname = 'dbispconfig'; |
| 39 | +if(!preg_match('/^[a-zA-Z0-9]+$/', $dbname)) die("Invalid database name\n"); |
| 40 | + |
| 41 | +$link = mysqli_init(); |
| 42 | +$con = mysqli_real_connect($link, $clientdb_host, $clientdb_user, $clientdb_password, $dbname); |
| 43 | +if(!$con) die('DB CON ERROR' . "\n"); |
| 44 | + |
| 45 | +$qry = "SELECT username, passwort FROM sys_user WHERE active = '1'"; |
| 46 | +$result = mysqli_query($link, $qry); |
| 47 | +if(!$result) die('Could not read users' . "\n"); |
| 48 | + |
| 49 | +$cont = ''; |
| 50 | +while($row = mysqli_fetch_assoc($result)) { |
| 51 | + $cont .= $row['username'] . ':' . $row['passwort'] . "\n"; |
| 52 | +} |
| 53 | +mysqli_free_result($result); |
| 54 | +mysqli_close($link); |
| 55 | + |
| 56 | +if($cont == '') die('No users found' . "\n"); |
| 57 | + |
| 58 | +if(file_exists($iface_path . '/.htpasswd')) rename($iface_path . '/.htpasswd', $iface_path . '/.htpasswd.old'); |
| 59 | +file_put_contents($iface_path . '/.htpasswd', $cont); |
| 60 | +chmod($iface_path . '/.htpasswd', 0644); |
| 61 | + |
| 62 | +$cont = 'AuthType Basic |
| 63 | +AuthName "Login" |
| 64 | +AuthUserFile ' . $iface_path . '/.htpasswd |
| 65 | +require valid-user'; |
| 66 | + |
| 67 | +if(file_exists($iface_path . '/.htaccess')) rename($iface_path . '/.htaccess', $iface_path . '/.htaccess.old'); |
| 68 | +file_put_contents($iface_path . '/.htaccess', $cont); |
| 69 | +chmod($iface_path . '/.htaccess', 0644); |
| 70 | +unset($cont); |
| 71 | + |
| 72 | +print 'Data written. Please check, if everything is working correctly.' . "\n"; |
| 73 | +exit; |
| 74 | + |
| 75 | +?> |
0 commit comments