From 73792a0fd40052185befffdc25aeb0783ef69b9b Mon Sep 17 00:00:00 2001 From: qkqpttgf <45693631+qkqpttgf@users.noreply.github.com> Date: Thu, 20 Feb 2020 12:13:36 +0800 Subject: [PATCH] multy disks --- function/normal.php | 327 ++++++++++++++++++++++++++++---------------- 1 file changed, 206 insertions(+), 121 deletions(-) diff --git a/function/normal.php b/function/normal.php index cad76ed..dd7c0c2 100644 --- a/function/normal.php +++ b/function/normal.php @@ -1,5 +1,15 @@ 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 substr($path, 1); //return spurlencode($path, '/'); } @@ -36,11 +46,77 @@ function getGET() } } +function getConfig($str, $disktag = '') +{ + global $innerEnv; + //include 'config.php'; + if ($disktag=='') $disktag = $_SERVER['disktag']; + $s = file_get_contents('config.php'); + $configs = substr($s, 18, -2); + if ($configs!='') { + $envs = json_decode($configs, true); + if (in_array($str, $innerEnv)) { + if (isset($envs[$disktag][$str])) return $envs[$disktag][$str]; + } else if (isset($envs[$str])) return $envs[$str]; + } + return ''; +} + +function setConfig($arr, $disktag = '') +{ + global $innerEnv; + if ($disktag=='') $disktag = $_SERVER['disktag']; + //include 'config.php'; + $s = file_get_contents('config.php'); + $configs = substr($s, 18, -2); + if ($configs!='') $envs = json_decode($configs, true); + $disktags = explode("|",getConfig('disktag')); + //$indisk = 0; + $operatedisk = 0; + foreach ($arr as $k => $v) { + if (in_array($k, $innerEnv)) { + $envs[$disktag][$k] = $v; + /*$diskconfig[$k] = $v; + $indisk = 1;*/ + } elseif ($k=='disktag_add') { + array_push($disktags, $v); + $operatedisk = 1; + } elseif ($k=='disktag_del') { + $disktags = array_diff($disktags, [ $v ]); + $envs[$v] = ''; + $operatedisk = 1; + } else { + $envs[$k] = $v; + } + } + /*if ($indisk) { + $diskconfig = array_filter($diskconfig, 'array_value_isnot_null'); + ksort($diskconfig); + $tmp[$disktag] = json_encode($diskconfig); + }*/ + if ($operatedisk) { + $disktags = array_unique($disktags); + foreach ($disktags as $disktag) if ($disktag!='') $disktag_s .= $disktag . '|'; + if ($disktag_s!='') $envs['disktag'] = substr($disktag_s, 0, -1); + else $envs['disktag'] = ''; + } + $envs = array_filter($envs, 'array_value_isnot_null'); + ksort($envs); + //echo '
'. json_encode($envs, JSON_PRETTY_PRINT).''; + $prestr = '' . $tmptoken . '
' . $tmp['body'] . '', $tmp['stat']); //return message('
' . json_encode($ret, JSON_PRETTY_PRINT) . '', 500); } - if ($_GET['install3']) { + if ($_GET['install1']) { + $_SERVER['disk_oprating'] = $_COOKIE['disktag']; + $_SERVER['disktag'] = $_COOKIE['disktag']; + config_oauth(); if (getConfig('Onedrive_ver')=='MS' || getConfig('Onedrive_ver')=='CN' || getConfig('Onedrive_ver')=='MSC') { return message(' '.getconstStr('JumptoOffice').' @@ -88,17 +168,20 @@ function get_refresh_token() ', getconstStr('Wait').' 1s', 201); } } - if ($_GET['install2']) { - // echo $_POST['Onedrive_ver']; - if ($_POST['Onedrive_ver']=='MS' || $_POST['Onedrive_ver']=='CN' || $_POST['Onedrive_ver']=='MSC') { + if ($_GET['install0']) { + if ($_POST['disktag_add']!='' && ($_POST['Onedrive_ver']=='MS' || $_POST['Onedrive_ver']=='CN' || $_POST['Onedrive_ver']=='MSC')) { + $_SERVER['disktag'] = $_COOKIE['disktag']; + $tmp['disktag_add'] = $_POST['disktag_add']; + $tmp['diskname'] = $_POST['diskname']; $tmp['Onedrive_ver'] = $_POST['Onedrive_ver']; if ($_POST['Onedrive_ver']=='MSC') { $tmp['client_id'] = $_POST['client_id']; - $tmp['client_secret'] = $_POST['client_secret']; + $tmp['client_secret'] = equal_replace(base64_encode($_POST['client_secret'])); + //$_POST['client_secret']; } - $response = setConfig($tmp); + $response = setConfig($tmp, $_COOKIE['disktag']); $title = getconstStr('MayinEnv'); - $html = getconstStr('Wait') . ' 3s'; + $html = getconstStr('Wait') . ' 3s'; if (!$response) { $html = $response . '