397 lines
17 KiB
PHP
397 lines
17 KiB
PHP
|
<?php
|
|||
|
|
|||
|
function getpath()
|
|||
|
{
|
|||
|
$_SERVER['REMOTE_ADDR'] = $_SERVER['HTTP_X_FORWARDED_FOR'];
|
|||
|
$_SERVER['base_path'] = path_format(substr($_SERVER['SCRIPT_NAME'], 0, -10) . '/');
|
|||
|
$p = strpos($_SERVER['REQUEST_URI'],'?');
|
|||
|
if ($p>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 :<br>';
|
|||
|
/*for ($i=1;strlen($tmptoken)>0;$i++) {
|
|||
|
$t['t' . $i] = substr($tmptoken,0,128);
|
|||
|
$str .= '
|
|||
|
t' . $i . ':<textarea readonly style="width: 95%">' . $t['t' . $i] . '</textarea><br><br>';
|
|||
|
$tmptoken=substr($tmptoken,128);
|
|||
|
}
|
|||
|
$str .= '
|
|||
|
Add t1-t'.--$i.' to environments.*/
|
|||
|
$str .= '
|
|||
|
<textarea readonly style="width: 95%">' . $tmptoken . '</textarea><br><br>
|
|||
|
Adding refresh_token to Config.
|
|||
|
<script>
|
|||
|
var texta=document.getElementsByTagName(\'textarea\');
|
|||
|
for(i=0;i<texta.length;i++) {
|
|||
|
texta[i].style.height = texta[i].scrollHeight + \'px\';
|
|||
|
}
|
|||
|
document.cookie=\'language=; path=/\';
|
|||
|
</script>';
|
|||
|
setConfig([ 'refresh_token' => $tmptoken ]);
|
|||
|
savecache('access_token', $ret['access_token'], $ret['expires_in'] - 60);
|
|||
|
$str .= '
|
|||
|
<meta http-equiv="refresh" content="5;URL=' . $url . '">';
|
|||
|
return message($str, getconstStr('WaitJumpIndex'));
|
|||
|
}
|
|||
|
return message('<pre>' . $tmp['body'] . '</pre>', $tmp['stat']);
|
|||
|
//return message('<pre>' . json_encode($ret, JSON_PRETTY_PRINT) . '</pre>', 500);
|
|||
|
}
|
|||
|
if ($_GET['install3']) {
|
|||
|
if (getConfig('Onedrive_ver')=='MS' || getConfig('Onedrive_ver')=='CN' || getConfig('Onedrive_ver')=='MSC') {
|
|||
|
return message('
|
|||
|
<a href="" id="a1">'.getconstStr('JumptoOffice').'</a>
|
|||
|
<script>
|
|||
|
url=location.protocol + "//" + location.host + "'.$url.'";
|
|||
|
url="'. $_SERVER['oauth_url'] .'authorize?scope='. $_SERVER['scope'] .'&response_type=code&client_id='. $_SERVER['client_id'] .'&redirect_uri='. $_SERVER['redirect_uri'] . '&state=' .'"+encodeURIComponent(url);
|
|||
|
document.getElementById(\'a1\').href=url;
|
|||
|
//window.open(url,"_blank");
|
|||
|
location.href = url;
|
|||
|
</script>
|
|||
|
', 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 = json_decode(setConfig($tmp)['body'], true);
|
|||
|
$title = getconstStr('MayinEnv');
|
|||
|
$html = getconstStr('Wait') . ' 3s<meta http-equiv="refresh" content="3;URL=' . $url . '?install3">';
|
|||
|
if (isset($response['id'])&&isset($response['message'])) {
|
|||
|
$html = $response['id'] . '<br>
|
|||
|
' . $response['message'] . '<br><br>
|
|||
|
function_name:' . $_SERVER['function_name'] . '<br>
|
|||
|
<button onclick="location.href = location.href;">'.$constStr['Reflesh'][$constStr['language']].'</button>';
|
|||
|
$title = 'Error';
|
|||
|
}
|
|||
|
return message($html, $title, 201);
|
|||
|
}
|
|||
|
}
|
|||
|
if ($_GET['install1']) {
|
|||
|
if ($_POST['admin']!='') {
|
|||
|
$tmp['admin'] = $_POST['admin'];
|
|||
|
$tmp['language'] = $_POST['language'];
|
|||
|
$APIKey = getConfig('APIKey');
|
|||
|
if ($APIKey=='') {
|
|||
|
$APIKey = $_POST['APIKey'];
|
|||
|
$tmp['APIKey'] = $APIKey;
|
|||
|
}
|
|||
|
$function_name = getConfig('function_name');
|
|||
|
if ($function_name=='') {
|
|||
|
$tmp1 = substr($_SERVER['HTTP_HOST'], 0, strrpos($_SERVER['HTTP_HOST'], '.'));
|
|||
|
$maindomain = substr($tmp1, strrpos($tmp1, '.')+1);
|
|||
|
if ($maindomain=='herokuapp') $function_name = substr($tmp1, 0, strrpos($tmp1, '.'));
|
|||
|
else $function_name = 'visit from x.herokuapp.com';
|
|||
|
$tmp['function_name'] = $function_name;
|
|||
|
}
|
|||
|
$response = json_decode(setHerokuConfig($tmp, $function_name, $APIKey)['body'], true);
|
|||
|
if (isset($response['id'])&&isset($response['message'])) {
|
|||
|
$html = $response['id'] . '<br>
|
|||
|
' . $response['message'] . '<br><br>
|
|||
|
function_name:' . $_SERVER['function_name'] . '<br>
|
|||
|
<button onclick="location.href = location.href;">'.$constStr['Reflesh'][$constStr['language']].'</button>';
|
|||
|
$title = 'Error';
|
|||
|
} else {
|
|||
|
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 = '
|
|||
|
<form action="?install2" method="post">
|
|||
|
Onedrive_Ver:<br>
|
|||
|
<label><input type="radio" name="Onedrive_ver" value="MS" checked>MS: '.getconstStr('OndriveVerMS').'</label><br>
|
|||
|
<label><input type="radio" name="Onedrive_ver" value="CN">CN: '.getconstStr('OndriveVerCN').'</label><br>
|
|||
|
<label><input type="radio" name="Onedrive_ver" value="MSC" onclick="document.getElementById(\'secret\').style.display=\'\';">MSC: '.getconstStr('OndriveVerMSC').'
|
|||
|
<div id="secret" style="display:none">
|
|||
|
<a href="'.$app_url.'" target="_blank">'.getconstStr('GetSecretIDandKEY').'</a><br>
|
|||
|
client_secret:<input type="text" name="client_secret"><br>
|
|||
|
client_id(12345678-90ab-cdef-ghij-klmnopqrstuv):<input type="text" name="client_id"><br>
|
|||
|
</div>
|
|||
|
</label><br>
|
|||
|
<input type="submit" value="'.getconstStr('Submit').'">
|
|||
|
</form>';
|
|||
|
$title = 'Install';
|
|||
|
}
|
|||
|
return message($html, $title, 201);
|
|||
|
}
|
|||
|
}
|
|||
|
if ($_GET['install0']) {
|
|||
|
$html .= '
|
|||
|
<form action="?install1" method="post" onsubmit="return notnull(this);">
|
|||
|
language:<br>';
|
|||
|
foreach ($constStr['languages'] as $key1 => $value1) {
|
|||
|
$html .= '
|
|||
|
<label><input type="radio" name="language" value="'.$key1.'" '.($key1==$constStr['language']?'checked':'').' onclick="changelanguage(\''.$key1.'\')">'.$value1.'</label><br>';
|
|||
|
}
|
|||
|
if (getConfig('APIKey')=='') $html .= '
|
|||
|
<a href="https://dashboard.heroku.com/account" target="_blank">'.getconstStr('Create').' API Key</a><br>
|
|||
|
<label>API Key:<input name="APIKey" type="text" placeholder="" size=""></label><br>';
|
|||
|
$html .= '
|
|||
|
<label>admin:<input name="admin" type="password" placeholder="' . getconstStr('EnvironmentsDescription')['admin'] . '" size="' . strlen(getconstStr('EnvironmentsDescription')['admin']) . '"></label><br>';
|
|||
|
$html .= '
|
|||
|
<input type="submit" value="'.getconstStr('Submit').'">
|
|||
|
</form>
|
|||
|
<script>
|
|||
|
function changelanguage(str)
|
|||
|
{
|
|||
|
document.cookie=\'language=\'+str+\'; path=/\';
|
|||
|
location.href = location.href;
|
|||
|
}
|
|||
|
function notnull(t)
|
|||
|
{
|
|||
|
if (t.admin.value==\'\') {
|
|||
|
alert(\'input admin\');
|
|||
|
return false;
|
|||
|
}';
|
|||
|
if (getConfig('APIKey')=='') $html .= '
|
|||
|
if (t.SecretId.value==\'\') {
|
|||
|
alert(\'input SecretId\');
|
|||
|
return false;
|
|||
|
}
|
|||
|
if (t.SecretKey.value==\'\') {
|
|||
|
alert(\'input SecretKey\');
|
|||
|
return false;
|
|||
|
}';
|
|||
|
$html .= '
|
|||
|
return true;
|
|||
|
}
|
|||
|
</script>';
|
|||
|
$title = getconstStr('SelectLanguage');
|
|||
|
return message($html, $title, 201);
|
|||
|
}
|
|||
|
$html .= 'refresh_token not exist, <a href="?install0">click to install.</a>';
|
|||
|
$title = 'Error';
|
|||
|
return message($html, $title, 201);
|
|||
|
}
|
|||
|
|
|||
|
function getConfig($str)
|
|||
|
{
|
|||
|
return getenv($str);
|
|||
|
}
|
|||
|
|
|||
|
function array_value_isnot_null($arr)
|
|||
|
{
|
|||
|
return $arr!=='';
|
|||
|
}
|
|||
|
|
|||
|
function setConfig($arr)
|
|||
|
{
|
|||
|
return setHerokuConfig($arr, getConfig('function_name'), getConfig('APIKey'));
|
|||
|
}
|
|||
|
|
|||
|
function HerokuAPI($method, $url, $data = '', $apikey)
|
|||
|
{
|
|||
|
if ($method=='PATCH') {
|
|||
|
$headers['Content-Type'] = 'application/json';
|
|||
|
}
|
|||
|
$headers['Authorization'] = 'Bearer ' . $apikey;
|
|||
|
$headers['Accept'] = 'application/vnd.heroku+json; version=3';
|
|||
|
//if (!isset($headers['Accept'])) $headers['Accept'] = '*/*';
|
|||
|
//if (!isset($headers['Referer'])) $headers['Referer'] = $url;
|
|||
|
$sendHeaders = array();
|
|||
|
foreach ($headers as $headerName => $headerVal) {
|
|||
|
$sendHeaders[] = $headerName . ': ' . $headerVal;
|
|||
|
}
|
|||
|
error_log($method . $url . $data . $apikey);
|
|||
|
$ch = curl_init();
|
|||
|
curl_setopt($ch, CURLOPT_URL, $url);
|
|||
|
curl_setopt($ch, CURLOPT_CUSTOMREQUEST,$method);
|
|||
|
curl_setopt($ch, CURLOPT_POSTFIELDS,$data);
|
|||
|
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
|
|||
|
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10);
|
|||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
|||
|
curl_setopt($ch, CURLOPT_HEADER, 0);
|
|||
|
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
|
|||
|
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
|
|||
|
curl_setopt($ch, CURLOPT_HTTPHEADER, $sendHeaders);
|
|||
|
$response['body'] = curl_exec($ch);
|
|||
|
$response['stat'] = curl_getinfo($ch,CURLINFO_HTTP_CODE);
|
|||
|
curl_close($ch);
|
|||
|
error_log($response['stat'].'
|
|||
|
'.$response['body'].'
|
|||
|
');
|
|||
|
return $response;
|
|||
|
}
|
|||
|
|
|||
|
function getHerokuConfig($function_name, $apikey)
|
|||
|
{
|
|||
|
return HerokuAPI('GET', 'https://api.heroku.com/apps/' . $function_name . '/config-vars', '', $apikey);
|
|||
|
}
|
|||
|
|
|||
|
function setHerokuConfig($env, $function_name, $apikey)
|
|||
|
{
|
|||
|
$data = json_encode($env);
|
|||
|
return HerokuAPI('PATCH', 'https://api.heroku.com/apps/' . $function_name . '/config-vars', $data, $apikey);
|
|||
|
}
|
|||
|
|
|||
|
function EnvOpt($function_name, $needUpdate = 0)
|
|||
|
{
|
|||
|
global $constStr;
|
|||
|
$constEnv = [
|
|||
|
//'admin',
|
|||
|
'adminloginpage', 'domain_path', 'guestup_path', 'passfile',
|
|||
|
//'private_path',
|
|||
|
'public_path', 'sitename', 'language', 'theme'
|
|||
|
];
|
|||
|
asort($constEnv);
|
|||
|
$html = '<title>OneManager '.getconstStr('Setup').'</title>';
|
|||
|
/*if ($_POST['updateProgram']==getconstStr('updateProgram')) {
|
|||
|
$response = json_decode(updataProgram($function_name, $Region, $namespace), true)['Response'];
|
|||
|
if (isset($response['Error'])) {
|
|||
|
$html = $response['Error']['Code'] . '<br>
|
|||
|
' . $response['Error']['Message'] . '<br><br>
|
|||
|
function_name:' . $_SERVER['function_name'] . '<br>
|
|||
|
Region:' . $_SERVER['Region'] . '<br>
|
|||
|
namespace:' . $namespace . '<br>
|
|||
|
<button onclick="location.href = location.href;">'.getconstStr('Reflesh').'</button>';
|
|||
|
$title = 'Error';
|
|||
|
} else {
|
|||
|
$html .= getconstStr('UpdateSuccess') . '<br>
|
|||
|
<button onclick="location.href = location.href;">'.getconstStr('Reflesh').'</button>';
|
|||
|
$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 . '<br>
|
|||
|
<button onclick="location.href = location.href;">'.getconstStr('Reflesh').'</button>';
|
|||
|
$title = 'Error';
|
|||
|
} else {
|
|||
|
$html .= '<script>location.href=location.href</script>';
|
|||
|
}
|
|||
|
}
|
|||
|
if ($_GET['preview']) {
|
|||
|
$preurl = $_SERVER['PHP_SELF'] . '?preview';
|
|||
|
} else {
|
|||
|
$preurl = path_format($_SERVER['PHP_SELF'] . '/');
|
|||
|
}
|
|||
|
$html .= '
|
|||
|
<a href="'.$preurl.'">'.getconstStr('Back').'</a>
|
|||
|
<a href="https://github.com/qkqpttgf/OneManager-php">Github</a><br>';
|
|||
|
/*if ($needUpdate) {
|
|||
|
$html .= '<pre>' . $_SERVER['github_version'] . '</pre>
|
|||
|
<form action="" method="post">
|
|||
|
<input type="submit" name="updateProgram" value="'.getconstStr('updateProgram').'">
|
|||
|
</form>';
|
|||
|
} else {
|
|||
|
$html .= getconstStr('NotNeedUpdate');
|
|||
|
}*/
|
|||
|
$html .= '
|
|||
|
<form action="" method="post">
|
|||
|
<table border=1 width=100%>';
|
|||
|
foreach ($constEnv as $key) {
|
|||
|
if ($key=='language') {
|
|||
|
$html .= '
|
|||
|
<tr>
|
|||
|
<td><label>' . $key . '</label></td>
|
|||
|
<td width=100%>
|
|||
|
<select name="' . $key .'">';
|
|||
|
foreach ($constStr['languages'] as $key1 => $value1) {
|
|||
|
$html .= '
|
|||
|
<option value="'.$key1.'" '.($key1==getConfig($key)?'selected="selected"':'').'>'.$value1.'</option>';
|
|||
|
}
|
|||
|
$html .= '
|
|||
|
</select>
|
|||
|
</td>
|
|||
|
</tr>';
|
|||
|
} elseif ($key=='theme') {
|
|||
|
$theme_arr = scandir('theme');
|
|||
|
$html .= '
|
|||
|
<tr>
|
|||
|
<td><label>' . $key . '</label></td>
|
|||
|
<td width=100%>
|
|||
|
<select name="' . $key .'">';
|
|||
|
foreach ($theme_arr as $v1) {
|
|||
|
if ($v1!='.' && $v1!='..') $html .= '
|
|||
|
<option value="'.$v1.'" '.($v1==getConfig($key)?'selected="selected"':'').'>'.$v1.'</option>';
|
|||
|
}
|
|||
|
$html .= '
|
|||
|
</select>
|
|||
|
</td>
|
|||
|
</tr>';
|
|||
|
} /*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 .= '
|
|||
|
<tr>
|
|||
|
<td><label>' . $key . '</label></td>
|
|||
|
<td width=100%><input type="text" name="' . $key .'" value="' . $domain_path . '" placeholder="' . getconstStr('EnvironmentsDescription')[$key] . '" style="width:100%"></td>
|
|||
|
</tr>';
|
|||
|
}*/ else $html .= '
|
|||
|
<tr>
|
|||
|
<td><label>' . $key . '</label></td>
|
|||
|
<td width=100%><input type="text" name="' . $key .'" value="' . getConfig($key) . '" placeholder="' . getconstStr('EnvironmentsDescription')[$key] . '" style="width:100%"></td>
|
|||
|
</tr>';
|
|||
|
}
|
|||
|
$html .= '</table>
|
|||
|
<input type="submit" name="submit1" value="'.getconstStr('Setup').'">
|
|||
|
</form>';
|
|||
|
return message($html, getconstStr('Setup'));
|
|||
|
}
|