500) $event['body']=substr($event['body'],0,strpos($event['body'],'base64')+30) . '...Too Long!...' . substr($event['body'],-50); echo urldecode(json_encode($event, JSON_PRETTY_PRINT)) . ' ' . urldecode(json_encode($context, JSON_PRETTY_PRINT)) . ' '; } function GetGlobalVariable($event) { $_GET = $event['queryString']; foreach ($_GET as $k => $v) { if ($v=='') $_GET[$k] = true; } $postbody = explode("&",$event['body']); foreach ($postbody as $postvalues) { $pos = strpos($postvalues,"="); $_POST[urldecode(substr($postvalues,0,$pos))]=urldecode(substr($postvalues,$pos+1)); } $cookiebody = explode("; ",$event['headers']['Cookie'][0]); foreach ($cookiebody as $cookievalues) { $pos = strpos($cookievalues,"="); $_COOKIE[urldecode(substr($cookievalues,0,$pos))]=urldecode(substr($cookievalues,$pos+1)); } } function GetPathSetting($event, $context) { $_SERVER['firstacceptlanguage'] = strtolower(splitfirst(splitfirst($event['headers']['Accept-Language'][0],';')[0],',')[0]); $_SERVER['accountId'] = $context['accountId']; $_SERVER['region'] = $context['region']; $_SERVER['service_name'] = $context['service']['name']; $_SERVER['function_name'] = $context['function']['name']; //$path = str_replace('%5D', ']', str_replace('%5B', '[', $event['path']));//%5B //$path = $event['path']; $path = $event['requestURI']; if (strpos($path, '?')) $path = substr($path, 0, strpos($path, '?')); $tmp = urldecode($event['requestURI']); if (strpos($tmp, '?')) $tmp = substr($tmp, 0, strpos($tmp, '?')); if ($path=='/'||$path=='') { $_SERVER['base_path'] = $tmp; } else { while ($tmp!=urldecode($tmp)) $tmp = urldecode($tmp); $tmp1 = urldecode($event['path']); while ($tmp1!=urldecode($tmp1)) $tmp1 = urldecode($tmp1); $_SERVER['base_path'] = substr($tmp, 0, strlen($tmp)-strlen($tmp1)+1); //$_SERVER['base_path'] = substr($tmp, 0, strlen(urldecode($event['path']))); } $_SERVER['base_path'] = spurlencode($_SERVER['base_path'], '/'); if (substr($path,-1)=='/') $path=substr($path,0,-1); $_SERVER['is_guestup_path'] = is_guestup_path($path); //$_SERVER['PHP_SELF'] = path_format($_SERVER['base_path'] . $path); $_SERVER['REMOTE_ADDR'] = $event['clientIP']; $_SERVER['HTTP_X_REQUESTED_WITH'] = $event['headers']['X-Requested-With'][0]; if (isset($event['headers']['Authorization'])) { $basicAuth = splitfirst(base64_decode(splitfirst($event['headers']['Authorization'][0], 'Basic ')[1]), ':'); $_SERVER['PHP_AUTH_USER'] = $basicAuth[0]; $_SERVER['PHP_AUTH_PW'] = $basicAuth[1]; } $_SERVER['HTTP_HOST'] = $event['headers']['Host'][0]; $_SERVER['REQUEST_SCHEME'] = $event['headers']['X-Forwarded-Proto'][0]; $_SERVER['host'] = $_SERVER['REQUEST_SCHEME'] . '://' . $_SERVER['HTTP_HOST']; $_SERVER['referhost'] = explode('/', $event['headers']['Referer'][0])[2]; $_SERVER['HTTP_IF_MODIFIED_SINCE'] = $event['headers']['If-Modified-Since'][0]; $_SERVER['FC_SERVER_PATH'] = '/var/fc/runtime/php7.2'; return $path; //return spurlencode($path, '/'); } function getConfig($str, $disktag = '') { if (isInnerEnv($str)) { if ($disktag=='') $disktag = $_SERVER['disktag']; $env = json_decode(getenv($disktag), true); if (isset($env[$str])) { if (isBase64Env($str)) return base64y_decode($env[$str]); else return $env[$str]; } } else { if (isBase64Env($str)) return base64y_decode(getenv($str)); else return getenv($str); } return ''; } function setConfig($arr, $disktag = '') { if ($disktag=='') $disktag = $_SERVER['disktag']; $disktags = explode("|", getConfig('disktag')); $diskconfig = json_decode(getenv($disktag), true); $tmp = []; $indisk = 0; $operatedisk = 0; foreach ($arr as $k => $v) { if (isCommonEnv($k)) { if (isBase64Env($k)) $tmp[$k] = base64y_encode($v); else $tmp[$k] = $v; } elseif (isInnerEnv($k)) { if (isBase64Env($k)) $diskconfig[$k] = base64y_encode($v); else $diskconfig[$k] = $v; $indisk = 1; } elseif ($k=='disktag_add') { array_push($disktags, $v); $operatedisk = 1; } elseif ($k=='disktag_del') { $disktags = array_diff($disktags, [ $v ]); $tmp[$v] = ''; $operatedisk = 1; } elseif ($k=='disktag_copy') { $newtag = $v . '_' . date("Ymd_His"); $tmp[$newtag] = getConfig($v); array_push($disktags, $newtag); $operatedisk = 1; } elseif ($k=='disktag_rename' || $k=='disktag_newname') { if ($arr['disktag_rename']!=$arr['disktag_newname']) $operatedisk = 1; } else { $tmp[$k] = json_encode($v); } } if ($indisk) { $diskconfig = array_filter($diskconfig, 'array_value_isnot_null'); ksort($diskconfig); $tmp[$disktag] = json_encode($diskconfig); } if ($operatedisk) { if (isset($arr['disktag_newname']) && $arr['disktag_newname']!='') { $tags = []; foreach ($disktags as $tag) { if ($tag==$arr['disktag_rename']) array_push($tags, $arr['disktag_newname']); else array_push($tags, $tag); } $tmp['disktag'] = implode('|', $tags); $tmp[$arr['disktag_newname']] = getConfig($arr['disktag_rename']); $tmp[$arr['disktag_rename']] = ''; } else { $disktags = array_unique($disktags); foreach ($disktags as $disktag) if ($disktag!='') $disktag_s .= $disktag . '|'; if ($disktag_s!='') $tmp['disktag'] = substr($disktag_s, 0, -1); else $tmp['disktag'] = ''; } } // echo '正式设置:'.json_encode($tmp,JSON_PRETTY_PRINT).' //'; $response = updateEnvironment($tmp, $_SERVER['accountId'], $_SERVER['region'], $_SERVER['service_name'], $_SERVER['function_name'], getConfig('AccessKeyID'), getConfig('AccessKeySecret')); //WaitSCFStat(); return $response; } function install() { global $constStr; if ($_GET['install2']) { $tmp['admin'] = $_POST['admin']; $response = setConfigResponse( setConfig($tmp) ); if (api_error($response)) { $html = api_error_msg($response); $title = 'Error'; return message($html, $title, 201); } if (needUpdate()) { OnekeyUpate(); return message('update to github version, reinstall. ', 'Program updating', 201); } return output('Jump ', 302); } if ($_GET['install1']) { //if ($_POST['admin']!='') { $tmp['timezone'] = $_COOKIE['timezone']; $AccessKeyID = getConfig('AccessKeyID'); if ($AccessKeyID=='') { $AccessKeyID = $_POST['AccessKeyID']; $tmp['AccessKeyID'] = $AccessKeyID; } $AccessKeySecret = getConfig('AccessKeySecret'); if ($AccessKeySecret=='') { $AccessKeySecret = $_POST['AccessKeySecret']; $tmp['AccessKeySecret'] = $AccessKeySecret; } $response = setConfigResponse( SetbaseConfig($tmp, $_SERVER['accountId'], $_SERVER['region'], $_SERVER['service_name'], $_SERVER['function_name'], $AccessKeyID, $AccessKeySecret) ); if (api_error($response)) { $html = api_error_msg($response); $title = 'Error'; return message($html, $title, 201); } else { $html .= '
'; $title = getconstStr('SetAdminPassword'); return message($html, $title, 201); } //} } if ($_GET['install0']) { $html .= ' '; $title = getconstStr('SelectLanguage'); return message($html, $title, 201); } $html .= ''.getconstStr('ClickInstall').', '.getconstStr('LogintoBind'); $title = 'Install'; return message($html, $title, 201); } function FCAPI2016($config, $Method, $data = '') { $accountId = $config['accountId']; $region = $config['region']; $service_name = $config['service_name']; $function_name = $config['function_name']; $AccessKeyID = $config['AccessKeyID']; $AccessKeySecret = $config['AccessKeySecret']; $host = $accountId . '.' . $region . '-internal.fc.aliyuncs.com'; $path = '/2016-08-15/services/' . $service_name . '/functions/' . $function_name; $url = 'https://' . $host . $path; $ContentMd5 = ''; $ContentType = 'application/json'; date_default_timezone_set('UTC'); // unset last timezone setting $Date = substr(gmdate("r", time()), 0, -5) . 'GMT'; $CanonicalizedFCHeaders = ''; $CanonicalizedResource = $path; $signaturestr = $Method . "\n" . $ContentMd5 . "\n" . $ContentType . "\n" . $Date . "\n" . $CanonicalizedFCHeaders . $CanonicalizedResource; $signature = base64_encode(hash_hmac('sha256', $signaturestr, $AccessKeySecret, true)); $header['Host'] = $host; $header['Date'] = $Date; $header['Content-Type'] = $ContentType; $header['Authorization'] = 'FC ' . $AccessKeyID . ':' . $signature; $header['Content-Length'] = strlen($data); //return curl($Method, $url, $data, $header)['body']; $p = 0; while ($response['stat']==0 && $p<3) { $response = curl($Method, $url, $data, $header); $p++; } if ($response['stat']==0) { $tmp['ErrorCode'] = 'Network Error'; $tmp['ErrorMessage'] = 'Can not connect ' . $host; return json_encode($tmp); } if ($response['stat']!=200) { $tmp = json_decode($response['body'], true); $tmp['ErrorMessage'] .= '