123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- <?php
-
- ini_set('memory_limit','5120M');
- set_time_limit(0);
- function remove_comments(&$output){
- $lines = explode("\n",$output);
- $output = "";
-
- $linecount = count($lines);
- $in_comment = false;
- for($i = 0; $i < $linecount; $i++){
- if(preg_match("/^\/\*/",preg_quote($lines[$i]))){
- $in_comment = true;
- }
- if(!$in_comment){
- $output .= $lines[$i] . "\n";
- }
- if(preg_match("/\*\/$/",preg_quote($lines[$i]))){
- $in_comment = false;
- }
- }
- unset($lines);
- return $output;
- }
- function remove_remarks($sql){
- $lines = explode("\n", $sql);
-
- $sql = "";
- $linecount = count($lines);
- $output = "";
- for ($i = 0; $i < $linecount; $i++){
- if (($i != ($linecount - 1)) || (strlen($lines[$i]) > 0)){
- if (isset($lines[$i][0]) && $lines[$i][0] != "#"){
- $output .= $lines[$i] . "\n";
- }else{
- $output .= "\n";
- }
-
- $lines[$i] = "";
- }
- }
- return $output;
- }
- function split_sql_file($sql, $delimiter){
-
- $tokens = explode($delimiter, $sql);
-
- $sql = "";
- $output = array();
-
- $matches = array();
-
- $token_count = count($tokens);
- for ($i = 0; $i < $token_count; $i++){
-
- if(($i != ($token_count - 1)) || (strlen($tokens[$i] > 0))){
-
- $total_quotes = preg_match_all("/'/", $tokens[$i], $matches);
-
-
- $escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$i], $matches);
- $unescaped_quotes = $total_quotes - $escaped_quotes;
-
- if(($unescaped_quotes % 2) == 0){
-
- $output[] = $tokens[$i];
-
- $tokens[$i] = "";
- }else{
-
-
- $temp = $tokens[$i] . $delimiter;
-
- $tokens[$i] = "";
-
- $complete_stmt = false;
- for ($j = $i + 1; (!$complete_stmt && ($j < $token_count)); $j++){
-
- $total_quotes = preg_match_all("/'/", $tokens[$j], $matches);
-
-
- $escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$j], $matches);
- $unescaped_quotes = $total_quotes - $escaped_quotes;
- if(($unescaped_quotes % 2) == 1){
-
-
- $output[] = $temp . $tokens[$j];
-
- $tokens[$j] = "";
- $temp = "";
-
- $complete_stmt = true;
-
- $i = $j;
- }else{
-
-
- $temp .= $tokens[$j] . $delimiter;
-
- $tokens[$j] = "";
- }
- }
- }
- }
- }
- return $output;
- }
-
- $method = $_SERVER['REQUEST_METHOD'];
- if(isset($_GET['type'])){
- if(isset($_GET['id'])){
- $id = $_GET['id'];
- switch($_GET['type']){
- case 'install':
- if($id == "run"){
- $path = realpath(dirname(__FILE__));
- if(isset($_GET['dbuser'])&&isset($_GET['dbpass'])&&isset($_GET['dbname'])&&isset($_GET['dbhost'])&&isset($_GET['dbtemplate'])&&isset($_GET['email'])){
- $dbuser = $_GET['dbuser'];
- $dbpass = $_GET['dbpass'];
- $dbname = $_GET['dbname'];
- $dbhost = $_GET['dbhost'];
- $email = $_GET['email'];
- $dbms_schema = $_GET['dbtemplate'].'.sql';
- $sql_query = @fread(@fopen($dbms_schema, 'r'), @filesize($dbms_schema)) or die("Can't access template: ".$_GET['dbtemplate'].".sql");
- $sql_query = remove_comments($sql_query);
- $sql_query = remove_remarks($sql_query);
- $sql_query = split_sql_file($sql_query, ';');
- file_put_contents('../config.default.json',"{\"host\":\"{$dbhost}\",\"user\":\"{$dbuser}\",\"password\":\"{$dbpass}\",\"database\":\"{$dbname}\",\"expire\":86400,\"email\":\"{$email}\"}");
- require_once('../php/database.php');
- foreach($sql_query as $sql){
- query($sql) or die('Error in query: '.get_sql()->error);
- }
- echo 'pass';
- }else{
- echo "Please don't leave any fields blank";
- }
- }elseif($id=='config'){
- echo file_get_contents('index.template.html');
- }elseif($id='cleanup'){
- $files = scandir($path);
- foreach($files as $file){
- if($file != '.' && $file != '..'){
- @unlink($path.'/'.$file);
- }
- }
- @rmdir($path);
- }else{
- die('Invalid id');
- }
- break;
- default:
- require_once('../api.php');
- }
- }else{
- die("id missing");
- }
- }else{
- die("type missing");
- }
- ?>
|