0) $path = substr($_SERVER['REQUEST_URI'], 0, $p); else $path = $_SERVER['REQUEST_URI']; $path = path_format( substr($path, strlen($_SERVER['base_path'])) ); return $path; //return spurlencode($path, '/'); } function getGET() { $p = strpos($_SERVER['REQUEST_URI'],'?'); if ($p>0) { $getstr = substr($_SERVER['REQUEST_URI'], $p+1); $getstrarr = explode("&",$getstr); foreach ($getstrarr as $getvalues) { if ($getvalues != '') { $pos = strpos($getvalues, "="); //echo $pos; if ($pos > 0) { $getarry[urldecode(substr($getvalues, 0, $pos))] = urldecode(substr($getvalues, $pos + 1)); } else { $getarry[urldecode($getvalues)] = true; } } } } if (isset($getarry)) { return $getarry; } else { return []; } } function get_refresh_token() { global $constStr; $url = path_format($_SERVER['PHP_SELF'] . '/'); if ($_GET['authorization_code'] && isset($_GET['code'])) { $tmp = curl_request($_SERVER['oauth_url'] . 'token', 'client_id=' . $_SERVER['client_id'] .'&client_secret=' . $_SERVER['client_secret'] . '&grant_type=authorization_code&requested_token_use=on_behalf_of&redirect_uri=' . $_SERVER['redirect_uri'] .'&code=' . $_GET['code']); if ($tmp['stat']==200) $ret = json_decode($tmp['body'], true); if (isset($ret['refresh_token'])) { $tmptoken = $ret['refresh_token']; $str = ' refresh_token :
'; /*for ($i=1;strlen($tmptoken)>0;$i++) { $t['t' . $i] = substr($tmptoken,0,128); $str .= ' t' . $i . ':

'; $tmptoken=substr($tmptoken,128); } $str .= ' Add t1-t'.--$i.' to environments.*/ $str .= '

Adding refresh_token to Config. '; setConfig([ 'refresh_token' => $tmptoken ]); savecache('access_token', $ret['access_token'], $ret['expires_in'] - 60); $str .= ' '; return message($str, getconstStr('WaitJumpIndex')); } return message('
' . $tmp['body'] . '
', $tmp['stat']); //return message('
' . json_encode($ret, JSON_PRETTY_PRINT) . '
', 500); } if ($_GET['install3']) { if (getConfig('Onedrive_ver')=='MS' || getConfig('Onedrive_ver')=='CN' || getConfig('Onedrive_ver')=='MSC') { return message(' '.getconstStr('JumptoOffice').' ', getconstStr('Wait').' 1s', 201); } } if ($_GET['install2']) { // echo $_POST['Onedrive_ver']; if ($_POST['Onedrive_ver']=='MS' || $_POST['Onedrive_ver']=='CN' || $_POST['Onedrive_ver']=='MSC') { $tmp['Onedrive_ver'] = $_POST['Onedrive_ver']; if ($_POST['Onedrive_ver']=='MSC') { $tmp['client_id'] = $_POST['client_id']; $tmp['client_secret'] = $_POST['client_secret']; } $response = setConfig($tmp); $title = getconstStr('MayinEnv'); $html = getconstStr('Wait') . ' 3s'; if (!$response) { $html = $response . '
Can not write config to file.
'; $title = 'Error'; } return message($html, $title, 201); } } if ($_GET['install1']) { if ($_POST['admin']!='') { $tmp['admin'] = $_POST['admin']; $tmp['language'] = $_POST['language']; $response = setConfig($tmp); if ($response) { if ($constStr['language']!='zh-cn') { $linklang='en-us'; } else $linklang='zh-cn'; $ru = "https://developer.microsoft.com/".$linklang."/graph/quick-start?appID=_appId_&appName=_appName_&redirectUrl=".$_SERVER['redirect_uri']."&platform=option-php"; $deepLink = "/quickstart/graphIO?publicClientSupport=false&appName=OneManager&redirectUrl=".$_SERVER['redirect_uri']."&allowImplicitFlow=false&ru=".urlencode($ru); $app_url = "https://apps.dev.microsoft.com/?deepLink=".urlencode($deepLink); $html = '
Onedrive_Ver:



'; $title = 'Install'; } else { $html = $response . '
Can not write config to file.
'; $title = 'Error'; } return message($html, $title, 201); } } if ($_GET['install0']) { if (!ConfigWriteable()) { $html .= 'Plase make sure the config.php is writeable. run Writeable.sh.'; $title = 'Error'; return message($html, $title, 201); } if (!RewriteEngineOn()) { $html .= 'Plase make sure the RewriteEngine is On.'; $title = 'Error'; return message($html, $title, 201); } $html .= '
language:
'; foreach ($constStr['languages'] as $key1 => $value1) { $html .= '
'; } $html .= '

'; $title = getconstStr('SelectLanguage'); return message($html, $title, 201); } $html .= 'refresh_token not exist, click to install.'; $title = 'Error'; return message($html, $title, 201); } function ConfigWriteable() { $t = md5( md5(time()).rand(1000,9999) ); setConfig([ 'tmp' => $t ]); $tmp = getConfig('tmp'); setConfig([ 'tmp' => '' ]); if ($tmp == $t) return true; return false; } function RewriteEngineOn() { $http_type = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://'; $tmpurl = $http_type . $_SERVER['SERVER_NAME']; //if $_SERVER['SERVER_PORT'] $tmpurl .= path_format($_SERVER['base_path'] . '/config.php'); $tmp = curl_request($tmpurl); if ($tmp['stat']==200) return false; if ($tmp['stat']==201) return true; //when install return 201, after installed return 404 or 200; return false; } function getConfig($str) { //include 'config.php'; $s = file_get_contents('config.php'); $configs = substr($s, 18, -2); if ($configs!='') { $envs = json_decode($configs, true); if (isset($envs[$str])) return $envs[$str]; } return ''; /* if (!class_exists('mydbreader')) { class mydbreader extends SQLite3 { function __construct() { $this->open( __DIR__ .'/.ht.db'); } } } $db = new mydbreader(); if(!$db){ echo $db->lastErrorMsg(); } else { //echo "Opened database successfully
\n"; $id=rand(1,309); $sql="select * from config where id=".$str.";"; $ret = $db->query($sql); if(!$ret){ echo $db->lastErrorMsg(); } else { $row = $ret->fetchArray(SQLITE3_ASSOC); $value1 = $row['value']; } $db->close(); } return $value1; */ } function array_value_isnot_null($arr) { return $arr!==''; } function setConfig($arr) { //include 'config.php'; $s = file_get_contents('config.php'); $configs = substr($s, 18, -2); if ($configs!='') $envs = json_decode($configs, true); foreach ($arr as $k1 => $v1) { $envs[$k1] = $v1; } $envs = array_filter($envs, 'array_value_isnot_null'); ksort($envs); //echo '
'. json_encode($envs, JSON_PRETTY_PRINT).'
'; $prestr = 'OneManager '.getconstStr('Setup').''; /*if ($_POST['updateProgram']==getconstStr('updateProgram')) { $response = json_decode(updataProgram($function_name, $Region, $namespace), true)['Response']; if (isset($response['Error'])) { $html = $response['Error']['Code'] . '
' . $response['Error']['Message'] . '

function_name:' . $_SERVER['function_name'] . '
Region:' . $_SERVER['Region'] . '
namespace:' . $namespace . '
'; $title = 'Error'; } else { $html .= getconstStr('UpdateSuccess') . '
'; $title = getconstStr('Setup'); } return message($html, $title); }*/ if ($_POST['submit1']) { foreach ($_POST as $k => $v) { if (in_array($k, $constEnv)) { //if (!(getConfig($k)==''&&$v=='')) $tmp[$k] = $v; } } if ($tmp['domain_path']!='') { $tmp1 = explode("|",$tmp['domain_path']); $tmparr = []; foreach ($tmp1 as $multidomain_paths){ $pos = strpos($multidomain_paths,":"); if ($pos>0) $tmparr[substr($multidomain_paths, 0, $pos)] = path_format(substr($multidomain_paths, $pos+1)); } $tmp['domain_path'] = $tmparr; } $response = setConfig($tmp); if (!$response) { $html = $response . '
'; $title = 'Error'; } else { $html .= ''; } } if ($_GET['preview']) { $preurl = $_SERVER['PHP_SELF'] . '?preview'; } else { $preurl = path_format($_SERVER['PHP_SELF'] . '/'); } $html .= ' '.getconstStr('Back').'    Github
'; /*if ($needUpdate) { $html .= '
' . $_SERVER['github_version'] . '
'; } else { $html .= getconstStr('NotNeedUpdate'); }*/ $html .= '
'; foreach ($constEnv as $key) { if ($key=='language') { $html .= ' '; } elseif ($key=='theme') { $theme_arr = scandir('theme'); $html .= ' '; } /*elseif ($key=='domain_path') { $tmp = getConfig($key); $domain_path = ''; foreach ($tmp as $k1 => $v1) { $domain_path .= $k1 . ':' . $v1 . '|'; } $domain_path = substr($domain_path, 0, -1); $html .= ' '; }*/ else $html .= ' '; } $html .= '
'; return message($html, getconstStr('Setup')); }