pull/98/head
			
			
		
		
							parent
							
								
									f703269fe3
								
							
						
					
					
						commit
						6d7376eb6c
					
				|  | @ -1,252 +0,0 @@ | ||||||
| <?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 substr($path, 1); |  | ||||||
|     //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 getConfig($str, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     if (in_array($str, $InnerEnv)) { |  | ||||||
|         if ($disktag=='') $disktag = $_SERVER['disktag']; |  | ||||||
|         $env = json_decode(getenv($disktag), true); |  | ||||||
|         if (isset($env[$str])) { |  | ||||||
|             if (in_array($str, $Base64Env)) return equal_replace($env[$str],1); |  | ||||||
|             else return $env[$str]; |  | ||||||
| 	} |  | ||||||
|     } else { |  | ||||||
| 	if (in_array($str, $Base64Env)) return equal_replace(getenv($str),1); |  | ||||||
|         else return getenv($str); |  | ||||||
|     } |  | ||||||
|     return ''; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfig($arr, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     if ($disktag=='') $disktag = $_SERVER['disktag']; |  | ||||||
|     $disktags = explode("|",getConfig('disktag')); |  | ||||||
|     $diskconfig = json_decode(getenv($disktag), true); |  | ||||||
|     $tmp = []; |  | ||||||
|     $indisk = 0; |  | ||||||
|     $oparetdisk = 0; |  | ||||||
|     foreach ($arr as $k => $v) { |  | ||||||
|         if (in_array($k, $InnerEnv)) { |  | ||||||
|             if (in_array($k, $Base64Env)) $diskconfig[$k] = equal_replace($v); |  | ||||||
|             else $diskconfig[$k] = $v; |  | ||||||
|             $indisk = 1; |  | ||||||
|         } elseif ($k=='disktag_add') { |  | ||||||
|             array_push($disktags, $v); |  | ||||||
|             $oparetdisk = 1; |  | ||||||
|         } elseif ($k=='disktag_del') { |  | ||||||
|             $disktags = array_diff($disktags, [ $v ]); |  | ||||||
|             $tmp[$v] = ''; |  | ||||||
|             $oparetdisk = 1; |  | ||||||
|         } else { |  | ||||||
|             if (in_array($k, $Base64Env)) $tmp[$k] = equal_replace($v); |  | ||||||
|             else $tmp[$k] = $v; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     if ($indisk) { |  | ||||||
|         $diskconfig = array_filter($diskconfig, 'array_value_isnot_null'); |  | ||||||
|         ksort($diskconfig); |  | ||||||
|         $tmp[$disktag] = json_encode($diskconfig); |  | ||||||
|     } |  | ||||||
|     if ($oparetdisk) { |  | ||||||
|         $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'] = ''; |  | ||||||
|     } |  | ||||||
|     foreach ($tmp as $key => $val) if ($val=='') $tmp[$key]=null; |  | ||||||
| //    echo '正式设置:'.json_encode($tmp,JSON_PRETTY_PRINT).'
 |  | ||||||
| //';
 |  | ||||||
|     return setHerokuConfig($tmp, getConfig('function_name'), getConfig('APIKey')); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function install() |  | ||||||
| { |  | ||||||
|     global $constStr; |  | ||||||
|     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 xxxx.herokuapp.com'; |  | ||||||
|                 $tmp['function_name'] = $function_name; |  | ||||||
| 	        } |  | ||||||
|             $response = json_decode(setHerokuConfig($tmp, $function_name, $APIKey)['body'], true); |  | ||||||
|             if (api_error($response)) { |  | ||||||
|                 $html = api_error_msg($response); |  | ||||||
|                 $title = 'Error'; |  | ||||||
|             } else { |  | ||||||
|                 return output('Jump<meta http-equiv="refresh" content="3;URL=' . path_format($_SERVER['base_path'] . '/') . '">', 302); |  | ||||||
|             } |  | ||||||
|             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>Set admin password:<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.APIKey.value==\'\') { |  | ||||||
|                 alert(\'input API Key\'); |  | ||||||
|                 return false; |  | ||||||
|             }'; |  | ||||||
|         $html .= ' |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|     </script>'; |  | ||||||
|         $title = getconstStr('SelectLanguage'); |  | ||||||
|         return message($html, $title, 201); |  | ||||||
|     } |  | ||||||
|     $html .= '<a href="?install0">'.getconstStr('ClickInstall').'</a>, '.getconstStr('LogintoBind'); |  | ||||||
|     $title = 'Error'; |  | ||||||
|     return message($html, $title, 201); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function HerokuAPI($method, $url, $data = '', $apikey) |  | ||||||
| { |  | ||||||
|     if ($method=='PATCH'||$method=='POST') { |  | ||||||
|         $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 updateHerokuapp($function_name, $apikey, $source) |  | ||||||
| { |  | ||||||
|     $tmp['source_blob']['url'] = $source; |  | ||||||
|     $data = json_encode($tmp); |  | ||||||
|     return HerokuAPI('POST', 'https://api.heroku.com/apps/' . $function_name . '/builds', $data, $apikey); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function api_error($response) |  | ||||||
| { |  | ||||||
|     return isset($response['id'])&&isset($response['message']); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function api_error_msg($response) |  | ||||||
| { |  | ||||||
|     return $response['id'] . '<br> |  | ||||||
| ' . $response['message'] . '<br><br> |  | ||||||
| function_name:' . $_SERVER['function_name'] . '<br> |  | ||||||
| <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function OnekeyUpate($auth = 'qkqpttgf', $project = 'OneManager-php', $branch = 'master') |  | ||||||
| { |  | ||||||
|     //'https://github.com/qkqpttgf/OneManager-php/tarball/master/';
 |  | ||||||
|     $source = 'https://github.com/' . $auth . '/' . $project . '/tarball/' . $branch . '/'; |  | ||||||
|     return json_decode(updateHerokuapp(getConfig('function_name'), getConfig('APIKey'), $source)['body'], true); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfigResponse($response) |  | ||||||
| { |  | ||||||
|     return json_decode( $response['body'], true ); |  | ||||||
| } |  | ||||||
|  | @ -1,254 +0,0 @@ | ||||||
| <?php |  | ||||||
| 
 |  | ||||||
| function getpath() |  | ||||||
| { |  | ||||||
|     $_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 substr($path, 1); |  | ||||||
|     //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 getConfig($str, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     //include 'config.php';
 |  | ||||||
|     $s = file_get_contents('config.php'); |  | ||||||
|     $configs = substr($s, 18, -2); |  | ||||||
|     if ($configs!='') { |  | ||||||
|         $envs = json_decode($configs, true); |  | ||||||
|         if (in_array($str, $InnerEnv)) { |  | ||||||
|             if ($disktag=='') $disktag = $_SERVER['disktag']; |  | ||||||
|             if (isset($envs[$disktag][$str])) { |  | ||||||
|                 if (in_array($str, $Base64Env)) return equal_replace($envs[$disktag][$str],1); |  | ||||||
|                 else return $envs[$disktag][$str]; |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             if (isset($envs[$str])) { |  | ||||||
|                 if (in_array($str, $Base64Env)) return equal_replace($envs[$str],1); |  | ||||||
|                 else return $envs[$str]; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return ''; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfig($arr, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     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)) { |  | ||||||
|             if (in_array($k, $Base64Env)) $envs[$disktag][$k] = equal_replace($v); |  | ||||||
|             else $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 { |  | ||||||
|             if (in_array($k, $Base64Env)) $envs[$k] = equal_replace($v); |  | ||||||
|             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 '<pre>'. json_encode($envs, JSON_PRETTY_PRINT).'</pre>';
 |  | ||||||
|     $prestr = '<?php $configs = \' |  | ||||||
| '; |  | ||||||
|     $aftstr = ' |  | ||||||
| \';'; |  | ||||||
|     return file_put_contents('config.php', $prestr . json_encode($envs, JSON_PRETTY_PRINT) . $aftstr); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function install() |  | ||||||
| { |  | ||||||
|     global $constStr; |  | ||||||
|     if ($_GET['install2']) { |  | ||||||
|         if ($_POST['admin']!='') { |  | ||||||
|             $tmp['admin'] = $_POST['admin']; |  | ||||||
|             $tmp['language'] = $_POST['language']; |  | ||||||
|             $response = setConfig($tmp); |  | ||||||
|             if (api_error($response)) { |  | ||||||
|                 $html = api_error_msg($response); |  | ||||||
|                 $title = 'Error'; |  | ||||||
|                 return message($html, $title, 201); |  | ||||||
|             } else { |  | ||||||
|                 return output('Jump<script>document.cookie=\'language=; path=/\';</script><meta http-equiv="refresh" content="3;URL=' . path_format($_SERVER['base_path'] . '/') . '">', 302); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     if ($_GET['install1']) { |  | ||||||
|         if (!ConfigWriteable()) { |  | ||||||
|             $html .= getconstStr('MakesuerWriteable'); |  | ||||||
|             $title = 'Error'; |  | ||||||
|             return message($html, $title, 201); |  | ||||||
|         } |  | ||||||
|         /*if (!RewriteEngineOn()) { |  | ||||||
|             $html .= getconstStr('MakesuerRewriteOn'); |  | ||||||
|             $title = 'Error'; |  | ||||||
|             return message($html, $title, 201); |  | ||||||
|         }*/ |  | ||||||
|         $html .= '<button id="checkrewritebtn" onclick="checkrewrite();">'.getconstStr('MakesuerRewriteOn').'</button> |  | ||||||
| <div id="formdiv" style="display: none"> |  | ||||||
|     <form action="?install2" method="post" onsubmit="return notnull(this);"> |  | ||||||
|         <input name="admin" type="password" placeholder="' . getconstStr('EnvironmentsDescription')['admin'] . '" size="' . strlen(getconstStr('EnvironmentsDescription')['admin']) . '"><br> |  | ||||||
|         <input id="submitbtn" type="submit" value="'.getconstStr('Submit').'" disabled> |  | ||||||
|     </form> |  | ||||||
| </div> |  | ||||||
|     <script> |  | ||||||
|         function notnull(t) |  | ||||||
|         { |  | ||||||
|             if (t.admin.value==\'\') { |  | ||||||
|                 alert(\''.getconstStr('SetAdminPassword').'\'); |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         function checkrewrite() |  | ||||||
|         { |  | ||||||
|             url=location.protocol + "//" + location.host; |  | ||||||
|             //if (location.port!="") url += ":" + location.port;
 |  | ||||||
|             url += location.pathname; |  | ||||||
|             if (url.substr(-1)!="/") url += "/"; |  | ||||||
|             url += "config.php"; |  | ||||||
|             //alert(url);
 |  | ||||||
|             var xhr4 = new XMLHttpRequest(); |  | ||||||
|             xhr4.open("GET", url); |  | ||||||
|             xhr4.setRequestHeader("x-requested-with","XMLHttpRequest"); |  | ||||||
|             xhr4.send(null); |  | ||||||
|             xhr4.onload = function(e){ |  | ||||||
|                 console.log(xhr4.responseText+","+xhr4.status); |  | ||||||
|                 if (xhr4.status==201) { |  | ||||||
|                     document.getElementById("checkrewritebtn").style.display = "none"; |  | ||||||
|                     document.getElementById("submitbtn").disabled = false; |  | ||||||
|                     document.getElementById("formdiv").style.display = ""; |  | ||||||
|                 } else { |  | ||||||
|                     alert(url+"\n"+xhr4.status); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     </script>'; |  | ||||||
|         $title = getconstStr('SetAdminPassword'); |  | ||||||
|         return message($html, $title, 201); |  | ||||||
|     } |  | ||||||
|     if ($_GET['install0']) { |  | ||||||
|         $html .= ' |  | ||||||
|     <form action="?install1" method="post"> |  | ||||||
| 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>'; |  | ||||||
|         } |  | ||||||
|         $html .= ' |  | ||||||
|         <input type="submit" value="'.getconstStr('Submit').'"> |  | ||||||
|     </form> |  | ||||||
|     <script> |  | ||||||
|         function changelanguage(str) |  | ||||||
|         { |  | ||||||
|             document.cookie=\'language=\'+str+\'; path=/\'; |  | ||||||
|             location.href = location.href; |  | ||||||
|         } |  | ||||||
|     </script>'; |  | ||||||
|         $title = getconstStr('SelectLanguage'); |  | ||||||
|         return message($html, $title, 201); |  | ||||||
|     } |  | ||||||
|     $html .= '<a href="?install0">'.getconstStr('ClickInstall').'</a>, '.getconstStr('LogintoBind'); |  | ||||||
|     $title = 'Error'; |  | ||||||
|     return message($html, $title, 201); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function ConfigWriteable() |  | ||||||
| { |  | ||||||
|     $t = md5( md5(time()).rand(1000,9999) ); |  | ||||||
|     $r = setConfig([ 'tmp' => $t ]); |  | ||||||
|     $tmp = getConfig('tmp'); |  | ||||||
|     setConfig([ 'tmp' => '' ]); |  | ||||||
|     if ($tmp == $t) return true; |  | ||||||
|     if ($r) 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'].':'.$_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 api_error($response) |  | ||||||
| { |  | ||||||
|     return !$response; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function api_error_msg($response) |  | ||||||
| { |  | ||||||
|     return $response . '<br> |  | ||||||
| Can not write config to file.<br> |  | ||||||
| <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function OnekeyUpate() |  | ||||||
| { |  | ||||||
|     return json_decode(updateHerokuapp(getConfig('function_name'), getConfig('APIKey'))['body'], true); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfigResponse($response) |  | ||||||
| { |  | ||||||
|     return $response; |  | ||||||
| } |  | ||||||
|  | @ -1,421 +0,0 @@ | ||||||
| <?php |  | ||||||
| 
 |  | ||||||
| function printInput($event, $context) |  | ||||||
| { |  | ||||||
|     if (strlen(json_encode($event['body']))>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']; |  | ||||||
|     $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']); |  | ||||||
|     foreach ($cookiebody as $cookievalues) { |  | ||||||
|         $pos = strpos($cookievalues,"="); |  | ||||||
|         $_COOKIE[urldecode(substr($cookievalues,0,$pos))]=urldecode(substr($cookievalues,$pos+1)); |  | ||||||
|     } |  | ||||||
|     $_SERVER['USER'] = 'qcloud'; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function GetPathSetting($event, $context) |  | ||||||
| { |  | ||||||
|     $_SERVER['function_name'] = $context['function_name']; |  | ||||||
|     $_SERVER['namespace'] = $context['namespace']; |  | ||||||
|     $host_name = $event['headers']['host']; |  | ||||||
|     $_SERVER['HTTP_HOST'] = $host_name; |  | ||||||
|     $serviceId = $event['requestContext']['serviceId']; |  | ||||||
|     if ( $serviceId === substr($host_name,0,strlen($serviceId)) ) { |  | ||||||
|         $_SERVER['base_path'] = '/'.$event['requestContext']['stage'].'/'.$_SERVER['function_name'].'/'; |  | ||||||
|         $_SERVER['Region'] = getenv('Region'); |  | ||||||
|         if ($_SERVER['Region'] == '') { |  | ||||||
|             $_SERVER['Region'] = substr($host_name, strpos($host_name, '.')+1); |  | ||||||
|             $_SERVER['Region'] = substr($_SERVER['Region'], 0, strpos($_SERVER['Region'], '.')); |  | ||||||
|         } |  | ||||||
|         $path = substr($event['path'], strlen('/'.$_SERVER['function_name'].'/')); |  | ||||||
|     } else { |  | ||||||
|         $_SERVER['base_path'] = $event['requestContext']['path']; |  | ||||||
|         $_SERVER['Region'] = getenv('Region'); |  | ||||||
|         $path = substr($event['path'], strlen($event['requestContext']['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['requestContext']['sourceIp']; |  | ||||||
|     $_SERVER['HTTP_X_REQUESTED_WITH'] = $event['headers']['x-requested-with']; |  | ||||||
|     return $path; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function getConfig($str, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     if (in_array($str, $InnerEnv)) { |  | ||||||
|         if ($disktag=='') $disktag = $_SERVER['disktag']; |  | ||||||
|         $env = json_decode(getenv($disktag), true); |  | ||||||
|         if (isset($env[$str])) { |  | ||||||
|             if (in_array($str, $Base64Env)) return equal_replace($env[$str],1); |  | ||||||
|             else return $env[$str]; |  | ||||||
|         } |  | ||||||
|     } else { |  | ||||||
|         if (in_array($str, $Base64Env)) return equal_replace(getenv($str),1); |  | ||||||
|         else return getenv($str); |  | ||||||
|     } |  | ||||||
|     return ''; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfig($arr, $disktag = '') |  | ||||||
| { |  | ||||||
|     global $InnerEnv; |  | ||||||
|     global $Base64Env; |  | ||||||
|     if ($disktag=='') $disktag = $_SERVER['disktag']; |  | ||||||
|     $disktags = explode("|",getConfig('disktag')); |  | ||||||
|     $diskconfig = json_decode(getenv($disktag), true); |  | ||||||
|     $tmp = []; |  | ||||||
|     $indisk = 0; |  | ||||||
|     $oparetdisk = 0; |  | ||||||
|     foreach ($arr as $k => $v) { |  | ||||||
|         if (in_array($k, $InnerEnv)) { |  | ||||||
|             if (in_array($k, $Base64Env)) $diskconfig[$k] = equal_replace($v); |  | ||||||
|             else $diskconfig[$k] = $v; |  | ||||||
|             $indisk = 1; |  | ||||||
|         } elseif ($k=='disktag_add') { |  | ||||||
|             array_push($disktags, $v); |  | ||||||
|             $oparetdisk = 1; |  | ||||||
|         } elseif ($k=='disktag_del') { |  | ||||||
|             $disktags = array_diff($disktags, [ $v ]); |  | ||||||
|             $tmp[$v] = ''; |  | ||||||
|             $oparetdisk = 1; |  | ||||||
|         } else { |  | ||||||
|             if (in_array($k, $Base64Env)) $tmp[$k] = equal_replace($v); |  | ||||||
|             else $tmp[$k] = $v; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     if ($indisk) { |  | ||||||
|         $diskconfig = array_filter($diskconfig, 'array_value_isnot_null'); |  | ||||||
|         ksort($diskconfig); |  | ||||||
|         $tmp[$disktag] = json_encode($diskconfig); |  | ||||||
|     } |  | ||||||
|     if ($oparetdisk) { |  | ||||||
|         $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['function_name'], $_SERVER['Region'], $_SERVER['namespace'], getConfig('SecretId'), getConfig('SecretKey')); |  | ||||||
|     WaitSCFStat(); |  | ||||||
|     return $response; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function WaitSCFStat() |  | ||||||
| { |  | ||||||
|     $trynum = 0; |  | ||||||
|     while( json_decode(getfunctioninfo($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], getConfig('SecretId'), getConfig('SecretKey')),true)['Response']['Status']!='Active' ) echo ' |  | ||||||
| '.++$trynum; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function install() |  | ||||||
| { |  | ||||||
|     global $constStr; |  | ||||||
|     if ($_GET['install2']) { |  | ||||||
|         $tmp['admin'] = $_POST['admin']; |  | ||||||
|         setConfig($tmp); |  | ||||||
|         if (needUpdate()) { |  | ||||||
|             OnekeyUpate(); |  | ||||||
|             //updateProgram($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], $SecretId, $SecretKey);
 |  | ||||||
|             return message('update to github version, reinstall.<script>document.cookie=\'language=; path=/\';</script><meta http-equiv="refresh" content="3;URL=' . $url . '">', 'Program updating', 201); |  | ||||||
|         } |  | ||||||
|         return output('Jump<script>document.cookie=\'language=; path=/\';</script><meta http-equiv="refresh" content="3;URL=' . path_format($_SERVER['base_path'] . '/') . '">', 302); |  | ||||||
|     } |  | ||||||
|     if ($_GET['install1']) { |  | ||||||
|         //if ($_POST['admin']!='') {
 |  | ||||||
|             $tmp['language'] = $_POST['language']; |  | ||||||
|             $tmp['Region'] = $_POST['Region']; |  | ||||||
|             $SecretId = getConfig('SecretId'); |  | ||||||
|             if ($SecretId=='') { |  | ||||||
|                 $SecretId = $_POST['SecretId']; |  | ||||||
|                 $tmp['SecretId'] = $SecretId; |  | ||||||
|             } |  | ||||||
|             $SecretKey = getConfig('SecretKey'); |  | ||||||
|             if ($SecretKey=='') { |  | ||||||
|                 $SecretKey = $_POST['SecretKey']; |  | ||||||
|                 $tmp['SecretKey'] = $SecretKey; |  | ||||||
|             } |  | ||||||
|             $response = json_decode(SetbaseConfig($tmp, $_SERVER['function_name'], $_POST['Region'], $_SERVER['namespace'], $SecretId, $SecretKey), true)['Response']; |  | ||||||
|             if (api_error($response)) { |  | ||||||
|                 $html = api_error_msg($response); |  | ||||||
|                 $title = 'Error'; |  | ||||||
|                 return message($html, $title, 201); |  | ||||||
|             } else { |  | ||||||
|                 $html .= ' |  | ||||||
|     <form action="?install2" method="post" onsubmit="return notnull(this);"> |  | ||||||
|         <label>'.getconstStr('SetAdminPassword').':<input name="admin" type="password" placeholder="' . getconstStr('EnvironmentsDescription')['admin'] . '" size="' . strlen(getconstStr('EnvironmentsDescription')['admin']) . '"></label><br> |  | ||||||
|         <input type="submit" value="'.getconstStr('Submit').'"> |  | ||||||
|     </form> |  | ||||||
|     <script> |  | ||||||
|         function notnull(t) |  | ||||||
|         { |  | ||||||
|             if (t.admin.value==\'\') { |  | ||||||
|                 alert(\''.getconstStr('SetAdminPassword').'\'); |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|     </script>'; |  | ||||||
|                 $title = getconstStr('SetAdminPassword'); |  | ||||||
|                 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('SecretId')==''||getConfig('SecretKey')=='') $html .= ' |  | ||||||
|         <a href="https://console.cloud.tencent.com/cam/capi" target="_blank">'.getconstStr('Create').' SecretId & SecretKey</a><br> |  | ||||||
|         <label>SecretId:<input name="SecretId" type="text" placeholder="" size=""></label><br> |  | ||||||
|         <label>SecretKey:<input name="SecretKey" type="text" placeholder="" size=""></label><br>'; |  | ||||||
|         $html .= ' |  | ||||||
|         <select class="changelanguage" name="Region"> |  | ||||||
|             <option value="">选择区域</option> |  | ||||||
|             <option value="ap-beijing">华北地区(北京)</option> |  | ||||||
|             <option value="ap-chengdu">西南地区(成都)</option> |  | ||||||
|             <option value="ap-guangzhou">华南地区(广州)</option> |  | ||||||
|             <option value="ap-guangzhou-open">华南地区(广州Open)</option> |  | ||||||
|             <option value="ap-hongkong">港澳台地区(中国香港)</option> |  | ||||||
|             <option value="ap-mumbai">亚太南部(孟买)</option> |  | ||||||
|             <option value="ap-shanghai">华东地区(上海)</option> |  | ||||||
|             <option value="ap-shanghai-fsi">华东地区(上海金融)</option> |  | ||||||
|             <option value="ap-singapore">亚太东南(新加坡)</option> |  | ||||||
|             <option value="ap-tokyo">亚太东北(东京)</option> |  | ||||||
|             <option value="na-siliconvalley">美国西部(硅谷)</option> |  | ||||||
|             <option value="na-toronto">北美地区(多伦多)</option> |  | ||||||
|         </select>(腾讯几个月了还不做出来,只能先弄选择了)<br> |  | ||||||
|         <input type="submit" value="'.getconstStr('Submit').'"> |  | ||||||
|     </form> |  | ||||||
|     <script> |  | ||||||
|         function changelanguage(str) |  | ||||||
|         { |  | ||||||
|             document.cookie=\'language=\'+str+\'; path=/\'; |  | ||||||
|             location.href = location.href; |  | ||||||
|         } |  | ||||||
|         function notnull(t) |  | ||||||
|         {'; |  | ||||||
|         if (getConfig('SecretId')==''||getConfig('SecretKey')=='') $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 .= '<a href="?install0">'.getconstStr('ClickInstall').'</a>, '.getconstStr('LogintoBind'); |  | ||||||
|     $title = 'Error'; |  | ||||||
|     return message($html, $title, 201); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function post2url($url, $data) |  | ||||||
| { |  | ||||||
|     $ch = curl_init(); |  | ||||||
|     curl_setopt($ch, CURLOPT_URL, $url); |  | ||||||
|     curl_setopt($ch, CURLOPT_POST, 1); |  | ||||||
|     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); |  | ||||||
|     $response = curl_exec($ch); |  | ||||||
|     curl_close($ch); |  | ||||||
|     //echo $response;
 |  | ||||||
|     return $response; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function ReorganizeDate($arr) |  | ||||||
| { |  | ||||||
|     $str = ''; |  | ||||||
|     ksort($arr); |  | ||||||
|     foreach ($arr as $k1 => $v1) { |  | ||||||
|         $str .= '&' . $k1 . '=' . $v1; |  | ||||||
|     } |  | ||||||
|     $str = substr($str, 1); // remove first '&'. 去掉第一个&
 |  | ||||||
|     return $str; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function getfunctioninfo($function_name, $Region, $Namespace, $SecretId, $SecretKey) |  | ||||||
| { |  | ||||||
|     //$meth = 'GET';
 |  | ||||||
|     $meth = 'POST'; |  | ||||||
|     $host = 'scf.tencentcloudapi.com'; |  | ||||||
|     $tmpdata['Action'] = 'GetFunction'; |  | ||||||
|     $tmpdata['FunctionName'] = $function_name; |  | ||||||
|     $tmpdata['Namespace'] = $Namespace; |  | ||||||
|     $tmpdata['Nonce'] = time(); |  | ||||||
|     $tmpdata['Region'] = $Region; |  | ||||||
|     $tmpdata['SecretId'] = $SecretId; |  | ||||||
|     $tmpdata['Timestamp'] = time(); |  | ||||||
|     $tmpdata['Token'] = ''; |  | ||||||
|     $tmpdata['Version'] = '2018-04-16'; |  | ||||||
|     $data = ReorganizeDate($tmpdata); |  | ||||||
|     $signStr = base64_encode(hash_hmac('sha1', $meth.$host.'/?'.$data, $SecretKey, true)); |  | ||||||
|     //echo urlencode($signStr);
 |  | ||||||
|     //return file_get_contents('https://'.$url.'&Signature='.urlencode($signStr));
 |  | ||||||
|     return post2url('https://'.$host, $data.'&Signature='.urlencode($signStr)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function updateEnvironment($Envs, $function_name, $Region, $Namespace, $SecretId, $SecretKey) |  | ||||||
| { |  | ||||||
|     //print_r($Envs);
 |  | ||||||
|     WaitSCFStat(); |  | ||||||
|     //json_decode($a,true)['Response']['Environment']['Variables'][0]['Key']
 |  | ||||||
|     $tmp = json_decode(getfunctioninfo($function_name, $Region, $Namespace, $SecretId, $SecretKey),true)['Response']['Environment']['Variables']; |  | ||||||
|     foreach ($tmp as $tmp1) { |  | ||||||
|         $tmp_env[$tmp1['Key']] = $tmp1['Value']; |  | ||||||
|     } |  | ||||||
|     foreach ($Envs as $key1 => $value1) { |  | ||||||
|         $tmp_env[$key1] = $value1; |  | ||||||
|     } |  | ||||||
|     $tmp_env = array_filter($tmp_env, 'array_value_isnot_null'); // remove null. 清除空值
 |  | ||||||
|     $tmp_env['Region'] = $Region; |  | ||||||
|     ksort($tmp_env); |  | ||||||
| 
 |  | ||||||
|     $i = 0; |  | ||||||
|     foreach ($tmp_env as $key1 => $value1) { |  | ||||||
|         $tmpdata['Environment.Variables.'.$i.'.Key'] = $key1; |  | ||||||
|         $tmpdata['Environment.Variables.'.$i.'.Value'] = $value1; |  | ||||||
|         $i++; |  | ||||||
|     } |  | ||||||
|     $meth = 'POST'; |  | ||||||
|     $host = 'scf.tencentcloudapi.com'; |  | ||||||
|     $tmpdata['Action'] = 'UpdateFunctionConfiguration'; |  | ||||||
|     $tmpdata['FunctionName'] = $function_name; |  | ||||||
|     $tmpdata['Namespace'] = $Namespace; |  | ||||||
|     $tmpdata['Nonce'] = time(); |  | ||||||
|     $tmpdata['Region'] = $Region; |  | ||||||
|     $tmpdata['SecretId'] = $SecretId; |  | ||||||
|     $tmpdata['Timestamp'] = time(); |  | ||||||
|     $tmpdata['Token'] = ''; |  | ||||||
|     $tmpdata['Version'] = '2018-04-16'; |  | ||||||
|     $data = ReorganizeDate($tmpdata); |  | ||||||
|     $signStr = base64_encode(hash_hmac('sha1', $meth.$host.'/?'.$data, $SecretKey, true)); |  | ||||||
|     //echo urlencode($signStr);
 |  | ||||||
|     return post2url('https://'.$host, $data.'&Signature='.urlencode($signStr)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function SetbaseConfig($Envs, $function_name, $Region, $Namespace, $SecretId, $SecretKey) |  | ||||||
| { |  | ||||||
|     echo json_encode($Envs,JSON_PRETTY_PRINT); |  | ||||||
|     /*$trynum = 0; |  | ||||||
|     while( json_decode(getfunctioninfo($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], $SecretId, $SecretKey),true)['Response']['Status']!='Active' ) echo ' |  | ||||||
| '.++$trynum;*/ |  | ||||||
|     //json_decode($a,true)['Response']['Environment']['Variables'][0]['Key']
 |  | ||||||
|     $tmp = json_decode(getfunctioninfo($function_name, $Region, $Namespace, $SecretId, $SecretKey),true)['Response']['Environment']['Variables']; |  | ||||||
|     foreach ($tmp as $tmp1) { |  | ||||||
|         $tmp_env[$tmp1['Key']] = $tmp1['Value']; |  | ||||||
|     } |  | ||||||
|     foreach ($Envs as $key1 => $value1) { |  | ||||||
|         $tmp_env[$key1] = $value1; |  | ||||||
|     } |  | ||||||
|     $tmp_env = array_filter($tmp_env, 'array_value_isnot_null'); // remove null. 清除空值
 |  | ||||||
|     $tmp_env['Region'] = $Region; |  | ||||||
|     ksort($tmp_env); |  | ||||||
| 
 |  | ||||||
|     $i = 0; |  | ||||||
|     foreach ($tmp_env as $key1 => $value1) { |  | ||||||
|         $tmpdata['Environment.Variables.'.$i.'.Key'] = $key1; |  | ||||||
|         $tmpdata['Environment.Variables.'.$i.'.Value'] = $value1; |  | ||||||
|         $i++; |  | ||||||
|     } |  | ||||||
|     $meth = 'POST'; |  | ||||||
|     $host = 'scf.tencentcloudapi.com'; |  | ||||||
|     $tmpdata['Action'] = 'UpdateFunctionConfiguration'; |  | ||||||
|     $tmpdata['FunctionName'] = $function_name; |  | ||||||
|     $tmpdata['Namespace'] = $Namespace; |  | ||||||
|     $tmpdata['Nonce'] = time(); |  | ||||||
|     $tmpdata['Region'] = $Region; |  | ||||||
|     $tmpdata['SecretId'] = $SecretId; |  | ||||||
|     $tmpdata['Timestamp'] = time(); |  | ||||||
|     $tmpdata['Token'] = ''; |  | ||||||
|     $tmpdata['Version'] = '2018-04-16'; |  | ||||||
|     $tmpdata['Description'] = 'Onedrive index and manager in SCF.'; |  | ||||||
|     $tmpdata['MemorySize'] = 64; |  | ||||||
|     $tmpdata['Timeout'] = 30; |  | ||||||
|     $data = ReorganizeDate($tmpdata); |  | ||||||
|     echo $data; |  | ||||||
|     $signStr = base64_encode(hash_hmac('sha1', $meth.$host.'/?'.$data, $SecretKey, true)); |  | ||||||
|     //echo urlencode($signStr);
 |  | ||||||
|     return post2url('https://'.$host, $data.'&Signature='.urlencode($signStr)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function updateProgram($function_name, $Region, $Namespace, $SecretId, $SecretKey, $source = '') |  | ||||||
| { |  | ||||||
|     WaitSCFStat(); |  | ||||||
|     $meth = 'POST'; |  | ||||||
|     $host = 'scf.tencentcloudapi.com'; |  | ||||||
|     $tmpdata['Action'] = 'UpdateFunctionCode'; |  | ||||||
|     $tmpdata['Code.GitUrl'] = $source; |  | ||||||
|     $tmpdata['CodeSource'] = 'Git'; |  | ||||||
|     $tmpdata['FunctionName'] = $function_name; |  | ||||||
|     $tmpdata['Handler'] = 'index.main_handler'; |  | ||||||
|     $tmpdata['Namespace'] = $Namespace; |  | ||||||
|     $tmpdata['Nonce'] = time(); |  | ||||||
|     $tmpdata['Region'] = $Region; |  | ||||||
|     $tmpdata['SecretId'] = $SecretId; |  | ||||||
|     $tmpdata['Timestamp'] = time(); |  | ||||||
|     $tmpdata['Token'] = ''; |  | ||||||
|     $tmpdata['Version'] = '2018-04-16'; |  | ||||||
|     $data = ReorganizeDate($tmpdata); |  | ||||||
|     $signStr = base64_encode(hash_hmac('sha1', $meth.$host.'/?'.$data, $SecretKey, true)); |  | ||||||
|     //echo urlencode($signStr);
 |  | ||||||
|     return post2url('https://'.$host, $data.'&Signature='.urlencode($signStr)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function api_error($response) |  | ||||||
| { |  | ||||||
|     return isset($response['Error']); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function api_error_msg($response) |  | ||||||
| { |  | ||||||
|     return $response['Error']['Code'] . '<br> |  | ||||||
| ' . $response['Error']['Message'] . '<br><br> |  | ||||||
| function_name:' . $_SERVER['function_name'] . '<br> |  | ||||||
| Region:' . $_SERVER['Region'] . '<br> |  | ||||||
| namespace:' . $_SERVER['namespace'] . '<br> |  | ||||||
| <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function OnekeyUpate($auth = 'qkqpttgf', $project = 'OneManager-php', $branch = 'master') |  | ||||||
| { |  | ||||||
|     //'https://github.com/qkqpttgf/OneManager-php/tree/v2-MultiDisk';
 |  | ||||||
|     $source = 'https://github.com/' . $auth . '/' . $project . '/tree/' . $branch; |  | ||||||
|     return json_decode(updateProgram($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], getConfig('SecretId'), getConfig('SecretKey'), $source), true)['Response']; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function setConfigResponse($response) |  | ||||||
| { |  | ||||||
|     return json_decode( $response, true )['Response']; |  | ||||||
| } |  | ||||||
|  | @ -239,9 +239,9 @@ function_name:' . $_SERVER['function_name'] . '<br> | ||||||
| <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; | <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function OnekeyUpate($auth = 'qkqpttgf', $project = 'OneManager-php', $branch = 'master') | function OnekeyUpate($auth = 'ldxw', $project = 'OneManager-php', $branch = 'master') | ||||||
| { | { | ||||||
|     //'https://github.com/qkqpttgf/OneManager-php/tarball/master/';
 |     //'https://github.com/ldxw/OneManager-php/tarball/master/';
 | ||||||
|     $source = 'https://github.com/' . $auth . '/' . $project . '/tarball/' . $branch . '/'; |     $source = 'https://github.com/' . $auth . '/' . $project . '/tarball/' . $branch . '/'; | ||||||
|     return json_decode(updateHerokuapp(getConfig('function_name'), getConfig('APIKey'), $source)['body'], true); |     return json_decode(updateHerokuapp(getConfig('function_name'), getConfig('APIKey'), $source)['body'], true); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -408,9 +408,9 @@ namespace:' . $_SERVER['namespace'] . '<br> | ||||||
| <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; | <button onclick="location.href = location.href;">'.getconstStr('Refresh').'</button>'; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function OnekeyUpate($auth = 'qkqpttgf', $project = 'OneManager-php', $branch = 'master') | function OnekeyUpate($auth = 'ldxw', $project = 'OneManager-php', $branch = 'master') | ||||||
| { | { | ||||||
|     //'https://github.com/qkqpttgf/OneManager-php/tree/v2-MultiDisk';
 |     //'https://github.com/ldxw/OneManager-php/tree/v2-MultiDisk';
 | ||||||
|     $source = 'https://github.com/' . $auth . '/' . $project . '/tree/' . $branch; |     $source = 'https://github.com/' . $auth . '/' . $project . '/tree/' . $branch; | ||||||
|     return json_decode(updateProgram($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], getConfig('SecretId'), getConfig('SecretKey'), $source), true)['Response']; |     return json_decode(updateProgram($_SERVER['function_name'], $_SERVER['Region'], $_SERVER['namespace'], getConfig('SecretId'), getConfig('SecretKey'), $source), true)['Response']; | ||||||
| } | } | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1198
									
								
								theme/onemoe.php.bk
								
								
								
								
							
							
						
						
									
										1198
									
								
								theme/onemoe.php.bk
								
								
								
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	 ldxw
						ldxw