$dash_len) { $dash_str .= substr($password, 0, $dash_len) . '-'; $password = substr($password, $dash_len); } $dash_str .= $password; return $dash_str; } function createSQLUserAndDatabase($user) { $pass = generatePassword(); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e \'CREATE DATABASE IF NOT EXISTS '.$user.';\'', $output); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "CREATE USER IF NOT EXISTS \''.$user.'\'@\'localhost\' IDENTIFIED BY \''.$pass.'\';"', $output); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "GRANT ALL PRIVILEGES ON '.$user.'.* TO \''.$user.'\'@\'localhost\';"', $output); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "FLUSH PRIVILEGES;"', $output); return ['database' => $user, 'user' => $user, 'password' => $pass]; } function removeMySQLUserAndDatabase($user) { exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e \'DROP DATABASE IF EXISTS '.$user.';\'', $output); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "DROP USER IF EXISTS \''.$user.'\'@\'localhost\';"', $output); exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "FLUSH PRIVILEGES;"', $output); return; } function createUnixUserWithQuota($user, $quota) { $pass = generatePassword(); exec('useradd -m -p "'.$pass.'" '.$user, $output); exec('setquota -u '.$user.' '.$quota.' '.$quota.' 0 0 -a /dev/loop0', $output); // TODO : handle errors return ['user' => $user, 'password' => $pass, 'quota' => $quota]; } function removeUnixUser($user) { exec('deluser --remove-home '.$user, $output); // TODO : handle errors return; } function createNginxConfig($domain, $user, $herseUser, $hersePass) { // Create new Plates instance $templates = new League\Plates\Engine('./templates'); // Render a template echo $templates->render('nginx-yeswiki.pro', ['domain' => $domain, 'user' => $user]); addHerse($nginxFile, $herseUser, $hersePass); } function removeNginxConfig($domain, $user) { } function createPhpFpmConfig($user) { } function removePhpFpmConfig($user) { } function copyYesWikiFiles($domain, $user, $type) { $destDir = '/home'.'/'.$user.'/'.$domain; exec('mkdir -p '.$destDir, $output); // TODO : handle errors return; } function copyYesWikiDatabase($user, $type) { $databaseModel = ($type === 'solo') ? $_SERVER['solomodel'] : $_SERVER['fermemodel']; exec('mysql -u '.$_SERVER['mysqluser'].' -p'.$_SERVER['mysqlpassword'].' -e "DUPLICATE '.$databaseModel.' TO '.$user.';"', $output); // TODO : handle errors return; } function checkHerse($herseUser, $hersePass) { if (empty($herseUser) && empty($hersePass)) { return false; // no herse needed } elseif (empty($herseUser) || empty($hersePass)) { throw new Exception('You need an username AND a password to add a herse.'); } return true; // herse needed } function addHerse(&$nginxFile, $herseUser, $hersePass) { if (empty($herseUser) && empty($hersePass)) { return ; // no herse needed } elseif (empty($herseUser) || empty($hersePass)) { throw new Exception('You need an username AND a password to add a herse.'); } else { //add herse to the domain echo $nginxFile; } } function removeYesWiki($domain, $user) { // enlever la db et le user sql // enlever la config nginx et la conf php-fpm // enlever le user unix et son home }