summaryrefslogtreecommitdiffstats
path: root/lib/setup.php
diff options
context:
space:
mode:
authorRobin Appelman <icewind1991@gmail.com>2011-06-21 23:58:02 +0200
committerRobin Appelman <icewind1991@gmail.com>2011-06-21 23:58:02 +0200
commit36dbb8edab6de784c45eee688000c5e330e70478 (patch)
treee6d5bebdcac08e685aae0d2e08ed3ad17e02e5b8 /lib/setup.php
parent299d7bc3063a064cd0d86af75e4172fd46cdd81e (diff)
downloadnextcloud-server-36dbb8edab6de784c45eee688000c5e330e70478.tar.gz
nextcloud-server-36dbb8edab6de784c45eee688000c5e330e70478.zip
prefix the mysql user name to avoid collissions
Diffstat (limited to 'lib/setup.php')
-rw-r--r--lib/setup.php15
1 files changed, 11 insertions, 4 deletions
diff --git a/lib/setup.php b/lib/setup.php
index 281f24db507..0a8c9650cbc 100644
--- a/lib/setup.php
+++ b/lib/setup.php
@@ -97,13 +97,20 @@ class OC_SETUP {
else {
$query="SELECT user FROM mysql.user WHERE user='$dbuser'"; //this should be enough to check for admin rights in mysql
if(mysql_query($query, $connection)) {
- self::createDBUser($username, $password, $connection);
//use the admin login data for the new database user
- OC_CONFIG::setValue('dbuser', $username);
- OC_CONFIG::setValue('dbpassword', $password);
+
+ //add prefix to the mysql user name to prevent collissions
+ $dbusername='oc_mysql_'.$username;
+ //hash the password so we don't need to store the admin config in the config file
+ $dbpassowrd=md5(time().$password);
+
+ self::createDBUser($dbusername, $dbpassowrd, $connection);
+
+ OC_CONFIG::setValue('dbuser', $dbusername);
+ OC_CONFIG::setValue('dbpassword', $dbpassowrd);
//create the database
- self::createDatabase($dbname, $username, $connection);
+ self::createDatabase($dbname, $dbusername, $connection);
}
else {
OC_CONFIG::setValue('dbuser', $dbuser);