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() { $getstr = urldecode(substr($_SERVER['REQUEST_URI'], strpos($_SERVER['REQUEST_URI'],'?'))); while (substr($getstr, 0, 1) == '/' || substr($getstr, 0, 1) == '?') $getstr = substr($getstr, 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, $constStr['WaitJumpIndex'][$constStr['language']]); } 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(' '.$constStr['JumptoOffice'][$constStr['language']].' ', $constStr['Wait'][$constStr['language']].' 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 = $constStr['MayinEnv'][$constStr['language']]; $html = $constStr['Wait'][$constStr['language']] . ' 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 = $constStr['SelectLanguage'][$constStr['language']]; 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'] . path_format($_SERVER['base_path'] . '/config.php'); $tmp = curl_request($tmpurl); 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.json'); 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'; 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 = '