27f758e4ffaa2fdb83053d8b66253ae65d53e5a3
bernd webinterface => /webinterface

bernd authored 17 years ago

1) <?php
2) 
3) function get_mysql_accounts($UID)
4) {
5)   $UID = (int) $UID;
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

6)   $result = db_query("SELECT username FROM misc.mysql_accounts WHERE useraccount=$UID");
bernd webinterface => /webinterface

bernd authored 17 years ago

7)   if (mysql_num_rows($result) == 0)
8)     return array();
9)   $list = array();
10)   while ($item = mysql_fetch_object($result))
11)   {
12)     array_push($list, $item->username);
13)   }
14)   return $list;
15) }
16) 
17) function get_mysql_databases($UID)
18) {
19)   $UID = (int) $UID;
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

20)   $result = db_query("SELECT name FROM misc.mysql_database WHERE useraccount=$UID");
bernd webinterface => /webinterface

bernd authored 17 years ago

21)   if (mysql_num_rows($result) == 0)
22)     return array();
23)   $list = array();
24)   while ($item = mysql_fetch_object($result))
25)   {
26)     array_push($list, $item->name);
27)   }
28)   return $list;
29) }
30) 
31) 
32) function get_mysql_access($db, $account)
33) {
34)   $uid = $_SESSION['userinfo']['uid'];
35)   global $mysql_access;
36)   if (!is_array($mysql_access))
37)   {
38)     $mysql_access = array();
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

39)     $result = db_query("SELECT db.name AS db, acc.username AS user FROM misc.mysql_access AS access LEFT JOIN misc.mysql_database AS db ON (db.id=access.database) LEFT JOIN misc.mysql_accounts AS acc ON (acc.id = access.user) WHERE acc.useraccount={$uid} OR db.useraccount={$uid};");
bernd webinterface => /webinterface

bernd authored 17 years ago

40)     if (mysql_num_rows($result) == 0)
41)       return false;
42)     while ($line = mysql_fetch_object($result))
43)       $mysql_access[$line->db][$line->user] = true;
44)   }
45)   return (array_key_exists($db, $mysql_access) && array_key_exists($account, $mysql_access[$db]));
46) }
47) 
48) 
49) function set_mysql_access($db, $account, $status)
50) {
51)   $uid = $_SESSION['userinfo']['uid'];
52)   $db = mysql_real_escape_string($db);
53)   $account = mysql_real_escape_string($account);
54)   $query = '';
55)   if ($status)
56)   {
57)     if (get_mysql_access($db, $account))
58)       return NULL;
59)     $query = "INSERT INTO misc.mysql_access (`database`,user) VALUES ((SELECT id FROM misc.mysql_database WHERE name='{$db}' AND useraccount={$uid} LIMIT 1), (SELECT id FROM misc.mysql_accounts WHERE username='{$account}' AND useraccount={$uid}));";
bernd Logging in allen Modulen

bernd authored 16 years ago

60)     logger("modules/mysql/include/mysql.php", "mysql", "granting access on »{$db}« to »{$account}«");
bernd webinterface => /webinterface

bernd authored 17 years ago

61)   }
62)   else
63)   {
64)     if (! get_mysql_access($db, $account))
65)       return NULL;
66)     $query = "DELETE FROM misc.mysql_access WHERE `database`=(SELECT id FROM misc.mysql_database WHERE name='{$db}' AND useraccount={$uid} LIMIT 1) AND user=(SELECT id FROM misc.mysql_accounts WHERE username='{$account}' AND useraccount={$uid});";
bernd Logging in allen Modulen

bernd authored 16 years ago

67)     logger("modules/mysql/include/mysql.php", "mysql", "revoking access on »{$db}« from »{$account}«");
bernd webinterface => /webinterface

bernd authored 17 years ago

68)   }
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

69)   db_query($query);
bernd webinterface => /webinterface

bernd authored 17 years ago

70) }
71) 
72) 
73) function create_mysql_account($username)
74) {
75)   if (! validate_mysql_dbname($username))
76)   {
bernd Logging in allen Modulen

bernd authored 16 years ago

77)     logger("modules/mysql/include/mysql.php", "mysql", "illegal username »{$username}«");
bernd webinterface => /webinterface

bernd authored 17 years ago

78)     input_error("Der eingegebene Benutzername entspricht leider nicht der Konvention. Bitte tragen Sie einen passenden Namen ein.");
79)     return NULL;
80)   }
81)   $uid = $_SESSION['userinfo']['uid'];
82)   $username = mysql_real_escape_string($username);
bernd Logging in allen Modulen

bernd authored 16 years ago

83)   logger("modules/mysql/include/mysql.php", "mysql", "creating user »{$username}«");
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

84)   db_query("INSERT INTO misc.mysql_accounts (username, password, useraccount) VALUES ('$username', '!', $uid);");
bernd webinterface => /webinterface

bernd authored 17 years ago

85) }
86) 
87) 
88) function delete_mysql_account($username)
89) {
90)   $username = mysql_real_escape_string($username);
91)   $uid = $_SESSION['userinfo']['uid'];
bernd Logging in allen Modulen

bernd authored 16 years ago

92)   logger("modules/mysql/include/mysql.php", "mysql", "deleting user »{$username}«");
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

93)   db_query("DELETE FROM misc.mysql_accounts WHERE username='{$username}' AND useraccount='{$uid}' LIMIT 1;");
bernd webinterface => /webinterface

bernd authored 17 years ago

94) }
95) 
96) 
97) function create_mysql_database($dbname)
98) {
99)   if (! validate_mysql_dbname($dbname))
100)   {
bernd Logging in allen Modulen

bernd authored 16 years ago

101)     logger("modules/mysql/include/mysql.php", "mysql", "illegal db-name »{$dbname}«");
bernd webinterface => /webinterface

bernd authored 17 years ago

102)     input_error("Der eingegebene Datenbankname entspricht leider nicht der Konvention. Bitte tragen Sie einen passenden Namen ein.");
103)     return NULL;
104)   }
105)   $dbname = mysql_real_escape_string($dbname);
106)   $uid = $_SESSION['userinfo']['uid'];
bernd Logging in allen Modulen

bernd authored 16 years ago

107)   logger("modules/mysql/include/mysql.php", "mysql", "creating database »{$dbname}«");
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

108)   db_query("INSERT INTO misc.mysql_database (name, useraccount) VALUES ('$dbname', $uid);");
bernd webinterface => /webinterface

bernd authored 17 years ago

109) }
110) 
111) 
112) function delete_mysql_database($dbname)
113) {
114)   $dbname = mysql_real_escape_string($dbname);
115)   $uid = $_SESSION['userinfo']['uid'];
bernd Logging in allen Modulen

bernd authored 16 years ago

116)   logger("modules/mysql/include/mysql.php", "mysql", "removing database »{$dbname}«");
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

117)   db_query("DELETE FROM misc.mysql_database WHERE name='{$dbname}' AND useraccount='{$uid}' LIMIT 1;");
bernd webinterface => /webinterface

bernd authored 17 years ago

118) }
119) 
120) 
121) function validate_mysql_username($username)
122) {
123)   $sys_username = $_SESSION['userinfo']['username'];
124)   return preg_match("/^{$sys_username}(_[a-zA-Z0-9_-]+)?$/", $username);
125) }
126) 
127) 
128) function validate_mysql_dbname($dbname)
129) {
130)   // Funktioniert! ;-)
131)   return validate_mysql_username($dbname);
132) }
133) 
134) 
135) 
136) function set_mysql_password($username, $password)
137) {
138)   $username = mysql_real_escape_string($username);
139)   $password = mysql_real_escape_string($password);
140)   $uid = $_SESSION['userinfo']['uid'];
bernd Logging in allen Modulen

bernd authored 16 years ago

141)   logger("modules/mysql/include/mysql.php", "mysql", "updating password for »{$username}«");
bernd sql-abfragen abstrahiert

bernd authored 16 years ago

142)   db_query("UPDATE misc.mysql_accounts SET password=PASSWORD('$password') WHERE username='$username' AND useraccount=$uid;");