mysql_clientdb_plugin.inc.php 9.04 KB
Newer Older
tbrehm's avatar
tbrehm committed
1
2
3
<?php

/*
redray's avatar
redray committed
4
Copyright (c) 2007, Till Brehm, projektfarm Gmbh
tbrehm's avatar
tbrehm committed
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

    * Redistributions of source code must retain the above copyright notice,
      this list of conditions and the following disclaimer.
    * Redistributions in binary form must reproduce the above copyright notice,
      this list of conditions and the following disclaimer in the documentation
      and/or other materials provided with the distribution.
    * Neither the name of ISPConfig nor the names of its contributors
      may be used to endorse or promote products derived from this software without
      specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

31
class mysql_clientdb_plugin {
tbrehm's avatar
tbrehm committed
32
	
33
34
	var $plugin_name = 'mysql_clientdb_plugin';
	var $class_name  = 'mysql_clientdb_plugin';
tbrehm's avatar
tbrehm committed
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
	
		
	/*
	 	This function is called when the plugin is loaded
	*/
	
	function onLoad() {
		global $app;
		
		/*
		Register for the events
		*/
		
		//* Mailboxes
		$app->plugins->registerEvent('database_insert',$this->plugin_name,'db_insert');
		$app->plugins->registerEvent('database_update',$this->plugin_name,'db_update');
		$app->plugins->registerEvent('database_delete',$this->plugin_name,'db_delete');
		
		
	}
	
	
	function db_insert($event_name,$data) {
		global $app, $conf;
		
		if($data["new"]["type"] == 'mysql') {
			if(!include_once(ISPC_LIB_PATH.'/mysql_clientdb.conf')) {
				$app->log('Unable to open'.ISPC_LIB_PATH.'/mysql_clientdb.conf',LOGLEVEL_ERROR);
tbrehm's avatar
tbrehm committed
63
				return;
tbrehm's avatar
tbrehm committed
64
65
66
67
68
69
			}
		
			//* Connect to the database
			$link = mysql_connect($clientdb_host, $clientdb_user, $clientdb_password);
			if (!$link) {
				$app->log('Unable to connect to the database'.mysql_error($link),LOGLEVEL_ERROR);
70
				return;
tbrehm's avatar
tbrehm committed
71
			}
redray's avatar
redray committed
72
73
74
75
76
77
78
79

			// Charset for the new table
			if($data["new"]["database_charset"] != '') {
        $query_charset_table = ' DEFAULT CHARACTER SET '.$data["new"]["database_charset"];
			} else {
        $query_charset_table = '';
			}

tbrehm's avatar
tbrehm committed
80
			//* Create the new database
redray's avatar
redray committed
81
			if (mysql_query('CREATE DATABASE '.mysql_real_escape_string($data["new"]["database_name"]).$query_charset_table,$link)) {
tbrehm's avatar
tbrehm committed
82
83
84
85
86
				$app->log('Created MySQL database: '.$data["new"]["database_name"],LOGLEVEL_DEBUG);
			} else {
				$app->log('Unable to connect to the database'.mysql_error($link),LOGLEVEL_ERROR);
			}
			
87
88
89
90
91
92
93
94
95
96
97
			// Create the database user if database is active
			if($data["new"]["active"] == 'y') {
				
				if($data["new"]["remote_access"] == 'y') {
			 		$db_host = '%';
				} else {
					$db_host = 'localhost';
				}
				
				mysql_query("GRANT ALL ON ".mysql_real_escape_string($data["new"]["database_name"]).".* TO '".mysql_real_escape_string($data["new"]["database_user"])."'@'$db_host' IDENTIFIED BY '".mysql_real_escape_string($data["new"]["database_password"])."';",$link);
				//echo "GRANT ALL ON ".mysql_real_escape_string($data["new"]["database_name"]).".* TO '".mysql_real_escape_string($data["new"]["database_user"])."'@'$db_host' IDENTIFIED BY '".mysql_real_escape_string($data["new"]["database_password"])."';";
tbrehm's avatar
tbrehm committed
98
99
100
101
102
103
104
105
106
107
108
109
110
			}
			
			mysql_query("FLUSH PRIVILEGES;",$link);
			mysql_close($link);
		}
	}
	
	function db_update($event_name,$data) {
		global $app, $conf;
		
		if($data["new"]["type"] == 'mysql') {
			if(!include_once(ISPC_LIB_PATH.'/mysql_clientdb.conf')) {
				$app->log('Unable to open'.ISPC_LIB_PATH.'/mysql_clientdb.conf',LOGLEVEL_ERROR);
111
				return;
tbrehm's avatar
tbrehm committed
112
			}
113
			
tbrehm's avatar
tbrehm committed
114
115
116
117
			//* Connect to the database
			$link = mysql_connect($clientdb_host, $clientdb_user, $clientdb_password);
			if (!$link) {
				$app->log('Unable to connect to the database'.mysql_error($link),LOGLEVEL_ERROR);
118
				return;
tbrehm's avatar
tbrehm committed
119
120
			}
			
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
			// Create the database user if database was disabled before
			if($data["new"]["active"] == 'y' && $data["old"]["active"] == 'n') {
				
				if($data["new"]["remote_access"] == 'y') {
			 		$db_host = '%';
				} else {
					$db_host = 'localhost';
				}
				
				mysql_query("GRANT ALL ON ".mysql_real_escape_string($data["new"]["database_name"]).".* TO '".mysql_real_escape_string($data["new"]["database_user"])."'@'$db_host' IDENTIFIED BY '".mysql_real_escape_string($data["new"]["database_password"])."';",$link);
				//echo "GRANT ALL ON ".mysql_real_escape_string($data["new"]["database_name"]).".* TO '".mysql_real_escape_string($data["new"]["database_user"])."'@'$db_host' IDENTIFIED BY '".mysql_real_escape_string($data["new"]["database_password"])."';";
			}
			
			// Remove database user, if inactive
			if($data["new"]["active"] == 'n' && $data["old"]["active"] == 'y') {
				
				if($data["old"]["remote_access"] == 'y') {
			 		$db_host = '%';
				} else {
					$db_host = 'localhost';
				}
				
143
				mysql_query("REVOKE ALL PRIVILEGES ON ".mysql_real_escape_string($data["new"]["database_name"]).".* FROM '".mysql_real_escape_string($data["new"]["database_user"])."';",$link);
144
145
			}
			
tbrehm's avatar
tbrehm committed
146
147
			//* Rename User
			if($data["new"]["database_user"] != $data["old"]["database_user"]) {
148
				mysql_query("RENAME USER '".mysql_real_escape_string($data["old"]["database_user"])."' TO '".mysql_real_escape_string($data["new"]["database_user"])."'",$link);
tbrehm's avatar
tbrehm committed
149
150
151
152
153
154
				$app->log('Renaming mysql user: '.$data["old"]["database_user"].' to '.$data["new"]["database_user"],LOGLEVEL_DEBUG);
			}
			
			//* Remote access option has changed.
			if($data["new"]["remote_access"] != $data["old"]["remote_access"]) {
				if($data["new"]["remote_access"] == 'y') {
155
156
					mysql_query("UPDATE mysql.user SET Host = '%' WHERE User = '".mysql_real_escape_string($data["new"]["database_user"])."' and Host = 'localhost';",$link);
					mysql_query("UPDATE mysql.db SET Host = '%' WHERE User = '".mysql_real_escape_string($data["new"]["database_user"])."' and Host = 'localhost';",$link);
tbrehm's avatar
tbrehm committed
157
				} else {
158
159
					mysql_query("UPDATE mysql.user SET Host = 'localhost' WHERE User = '".mysql_real_escape_string($data["new"]["database_user"])."' and Host = '%';",$link);
					mysql_query("UPDATE mysql.db SET Host = 'localhost' WHERE User = '".mysql_real_escape_string($data["new"]["database_user"])."' and Host = '%';",$link);
tbrehm's avatar
tbrehm committed
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
				}
				$app->log('Changing mysql remote access priveliges for database: '.$data["new"]["database_name"],LOGLEVEL_DEBUG);
			}
			
			//* Get the db host setting for the access priveliges
			if($data["new"]["remote_access"] == 'y') {
			 	$db_host = '%';
			} else {
				$db_host = 'localhost';
			}
			
			/*
			//* Rename database
			if($data["new"]["database_name"] != $data["old"]["database_name"]) {
				mysql_query("",$link);
			}
			*/
			
			//* Change password
			if($data["new"]["database_password"] != $data["old"]["database_password"]) {
180
				mysql_query("SET PASSWORD FOR '".mysql_real_escape_string($data["new"]["database_user"])."'@'$db_host' = PASSWORD('".mysql_real_escape_string($data["new"]["database_password"])."');",$link);
tbrehm's avatar
tbrehm committed
181
182
183
184
185
186
187
188
189
190
191
192
				$app->log('Changing mysql user password for: '.$data["new"]["database_user"],LOGLEVEL_DEBUG);
			}
			
			mysql_query("FLUSH PRIVILEGES;",$link);
			mysql_close($link);
		}
		
	}
	
	function db_delete($event_name,$data) {
		global $app, $conf;
		
193
		if($data["old"]["type"] == 'mysql') {
tbrehm's avatar
tbrehm committed
194
195
			if(!include_once(ISPC_LIB_PATH.'/mysql_clientdb.conf')) {
				$app->log('Unable to open'.ISPC_LIB_PATH.'/mysql_clientdb.conf',LOGLEVEL_ERROR);
196
				return;
tbrehm's avatar
tbrehm committed
197
198
199
200
201
202
			}
		
			//* Connect to the database
			$link = mysql_connect($clientdb_host, $clientdb_user, $clientdb_password);
			if (!$link) {
				$app->log('Unable to connect to the database'.mysql_error($link),LOGLEVEL_ERROR);
203
				return;
tbrehm's avatar
tbrehm committed
204
205
			}
			
206
207
208
209
210
211
212
			//* Get the db host setting for the access priveliges
			if($data["old"]["remote_access"] == 'y') {
			 	$db_host = '%';
			} else {
				$db_host = 'localhost';
			}
			
213
			if(mysql_query("DROP USER '".mysql_real_escape_string($data["old"]["database_user"])."'@'$db_host';",$link)) {
214
215
216
217
				$app->log('Dropping mysql user: '.$data["old"]["database_user"],LOGLEVEL_DEBUG);
			} else {
				$app->log('Error while dropping mysql user: '.$data["old"]["database_user"].' '.mysql_error($link),LOGLEVEL_ERROR);
			}
tbrehm's avatar
tbrehm committed
218
			
219
			if(mysql_query('DROP DATABASE '.mysql_real_escape_string($data["old"]["database_name"]),$link)) {
220
221
222
223
				$app->log('Dropping mysql database: '.$data["old"]["database_name"],LOGLEVEL_DEBUG);
			} else {
				$app->log('Error while dropping mysql database: '.$data["old"]["database_name"].' '.mysql_error($link),LOGLEVEL_ERROR);
			}
tbrehm's avatar
tbrehm committed
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
			
			
			mysql_query("FLUSH PRIVILEGES;",$link);
			mysql_close($link);
		}
		
		
	}
	
	
	

} // end class

?>