add setup=auth, check if another building
parent
05531b5fe1
commit
21c1120867
|
@ -151,7 +151,7 @@ function setConfig($arr, $disktag = '')
|
||||||
}
|
}
|
||||||
$envs = array_filter($envs, 'array_value_isnot_null');
|
$envs = array_filter($envs, 'array_value_isnot_null');
|
||||||
//ksort($envs);
|
//ksort($envs);
|
||||||
sortConfig($envs);
|
//sortConfig($envs);
|
||||||
//error_log1(json_encode($arr, JSON_PRETTY_PRINT) . ' => tmp:' . json_encode($envs, JSON_PRETTY_PRINT));
|
//error_log1(json_encode($arr, JSON_PRETTY_PRINT) . ' => tmp:' . json_encode($envs, JSON_PRETTY_PRINT));
|
||||||
//echo json_encode($arr, JSON_PRETTY_PRINT) . ' => tmp:' . json_encode($envs, JSON_PRETTY_PRINT);
|
//echo json_encode($arr, JSON_PRETTY_PRINT) . ' => tmp:' . json_encode($envs, JSON_PRETTY_PRINT);
|
||||||
return setVercelConfig($envs, getConfig('HerokuappId'), getConfig('APIKey'));
|
return setVercelConfig($envs, getConfig('HerokuappId'), getConfig('APIKey'));
|
||||||
|
@ -187,16 +187,24 @@ function install()
|
||||||
$title = 'Error';
|
$title = 'Error';
|
||||||
return message($html, $title, 400);
|
return message($html, $title, 400);
|
||||||
} else {
|
} else {
|
||||||
/*$html = '<script>
|
$html = getconstStr('Success') . '
|
||||||
|
<script>
|
||||||
var status = "' . $response['DplStatus'] . '";
|
var status = "' . $response['DplStatus'] . '";
|
||||||
|
var i = 0;
|
||||||
var expd = new Date();
|
var expd = new Date();
|
||||||
expd.setTime(expd.getTime()+1000);
|
expd.setTime(expd.getTime()+1000);
|
||||||
var expires = "expires="+expd.toGMTString();
|
var expires = "expires="+expd.toGMTString();
|
||||||
document.cookie=\'language=; path=/; \'+expires;
|
document.cookie=\'language=; path=/; \'+expires;
|
||||||
|
var uploadList = setInterval(function(){
|
||||||
|
if (document.getElementById("dis").style.display=="none") {
|
||||||
|
console.log(i++);
|
||||||
|
} else {
|
||||||
|
clearInterval(uploadList);
|
||||||
|
location.href = "' . path_format($_SERVER['base_path'] . '/') . '";
|
||||||
|
}
|
||||||
|
}, 1000);
|
||||||
</script>';
|
</script>';
|
||||||
return message($html, $title, 201, 1);*/
|
return message($html, $title, 201, 1);
|
||||||
$data["dplId"] = $response['DplStatus'];
|
|
||||||
return output(json_encode($data), 201);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -208,10 +216,9 @@ language:<br>';
|
||||||
$html .= '
|
$html .= '
|
||||||
<label><input type="radio" name="language" value="'.$key1.'" '.($key1==$constStr['language']?'checked':'').' onclick="changelanguage(\''.$key1.'\')">'.$value1.'</label><br>';
|
<label><input type="radio" name="language" value="'.$key1.'" '.($key1==$constStr['language']?'checked':'').' onclick="changelanguage(\''.$key1.'\')">'.$value1.'</label><br>';
|
||||||
}
|
}
|
||||||
//if (getConfig('APIKey')=='')
|
|
||||||
$html .= '<br>
|
$html .= '<br>
|
||||||
<a href="https://vercel.com/account/tokens" target="_blank">' . getconstStr('Create') . ' token</a><br>
|
<a href="https://vercel.com/account/tokens" target="_blank">' . getconstStr('Create') . ' token</a><br>
|
||||||
<label>Token:<input name="APIKey" type="password" placeholder="" value="' . getConfig('APIKey') . '"></label><br>';
|
<label>Token:<input name="APIKey" type="password" placeholder="" value=""></label><br>';
|
||||||
$html .= '<br>
|
$html .= '<br>
|
||||||
<label>Set admin password:<input name="admin" type="password" placeholder="' . getconstStr('EnvironmentsDescription')['admin'] . '" size="' . strlen(getconstStr('EnvironmentsDescription')['admin']) . '"></label><br>';
|
<label>Set admin password:<input name="admin" type="password" placeholder="' . getconstStr('EnvironmentsDescription')['admin'] . '" size="' . strlen(getconstStr('EnvironmentsDescription')['admin']) . '"></label><br>';
|
||||||
$html .= '
|
$html .= '
|
||||||
|
@ -244,52 +251,7 @@ language:<br>';
|
||||||
alert(\'input Token\');
|
alert(\'input Token\');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
t.style.display = "none";
|
return true;
|
||||||
errordiv.innerHTML = "' . getconstStr('Wait') . '";
|
|
||||||
var xhr = new XMLHttpRequest();
|
|
||||||
xhr.open("POST", t.action);
|
|
||||||
xhr.onload = function(e) {
|
|
||||||
if (xhr.status==201) {
|
|
||||||
var res = JSON.parse(xhr.responseText);
|
|
||||||
getStatus(res.dplId, t.APIKey.value);
|
|
||||||
} else {
|
|
||||||
t.style.display = "";
|
|
||||||
errordiv.innerHTML = xhr.status + "<br>" + xhr.responseText;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
xhr.send("admin=" + t.admin.value + "&APIKey=" + t.APIKey.value);
|
|
||||||
|
|
||||||
var x = "";
|
|
||||||
var min = 0;
|
|
||||||
function getStatus(id, VercelToken) {
|
|
||||||
x += ".";
|
|
||||||
min++;
|
|
||||||
var xhr = new XMLHttpRequest();
|
|
||||||
var url = "https://api.vercel.com/v11/now/deployments/" + id;
|
|
||||||
xhr.open("GET", url);
|
|
||||||
xhr.setRequestHeader("Authorization", "Bearer " + VercelToken);
|
|
||||||
xhr.onload = function(e) {
|
|
||||||
if (xhr.status==200) {
|
|
||||||
var deployStat = JSON.parse(xhr.responseText).readyState;
|
|
||||||
if (deployStat=="READY") {
|
|
||||||
x = "";
|
|
||||||
min = 0;
|
|
||||||
errordiv.innerHTML = "Deploy done.";
|
|
||||||
location.href = "/";
|
|
||||||
} else {
|
|
||||||
errordiv.innerHTML = deployStat + ", " + min + ".<br>' . getconstStr('Wait') . ' " + x;
|
|
||||||
if (deployStat!=="ERROR") setTimeout(function() { getStatus(id, VercelToken) }, 1000);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
t.style.display = "";
|
|
||||||
console.log(xhr.status);
|
|
||||||
console.log(xhr.responseText);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
xhr.send(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
</script>';
|
</script>';
|
||||||
$title = getconstStr('SelectLanguage');
|
$title = getconstStr('SelectLanguage');
|
||||||
|
@ -329,7 +291,7 @@ function copyFolder($from, $to)
|
||||||
|
|
||||||
function setVercelConfig($envs, $appId, $token)
|
function setVercelConfig($envs, $appId, $token)
|
||||||
{
|
{
|
||||||
//sortConfig($envs); cant view in vercel, not need sort.
|
sortConfig($envs);
|
||||||
$outPath = '/tmp/code/';
|
$outPath = '/tmp/code/';
|
||||||
$outPath_Api = $outPath . 'api/';
|
$outPath_Api = $outPath . 'api/';
|
||||||
$coderoot = __DIR__;
|
$coderoot = __DIR__;
|
||||||
|
@ -345,7 +307,8 @@ function setVercelConfig($envs, $appId, $token)
|
||||||
|
|
||||||
function VercelUpdate($appId, $token, $sourcePath = "")
|
function VercelUpdate($appId, $token, $sourcePath = "")
|
||||||
{
|
{
|
||||||
$url = "https://api.vercel.com/v12/now/deployments";
|
if (checkBuilding($appId, $token)) return '{"error":{"message":"Another building is in progress."}}';
|
||||||
|
$url = "https://api.vercel.com/v13/deployments";
|
||||||
$header["Authorization"] = "Bearer " . $token;
|
$header["Authorization"] = "Bearer " . $token;
|
||||||
$header["Content-Type"] = "application/json";
|
$header["Content-Type"] = "application/json";
|
||||||
$data["name"] = "OneManager";
|
$data["name"] = "OneManager";
|
||||||
|
@ -367,6 +330,23 @@ function VercelUpdate($appId, $token, $sourcePath = "")
|
||||||
return json_encode($result);
|
return json_encode($result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function checkBuilding($projectId, $token)
|
||||||
|
{
|
||||||
|
$r = 0;
|
||||||
|
$url = "https://api.vercel.com/v6/deployments/?projectId=" . $projectId;
|
||||||
|
$header["Authorization"] = "Bearer " . $token;
|
||||||
|
$header["Content-Type"] = "application/json";
|
||||||
|
$response = curl("GET", $url, '', $header);
|
||||||
|
//echo json_encode($response, JSON_PRETTY_PRINT) . " ,res<br>";
|
||||||
|
$result = json_decode($response["body"], true);
|
||||||
|
foreach ( $result['deployments'] as $deployment ) {
|
||||||
|
if ($deployment['state']!=="READY") $r++;
|
||||||
|
}
|
||||||
|
return $r;
|
||||||
|
//if ($r===0) return true;
|
||||||
|
//else return false;
|
||||||
|
}
|
||||||
|
|
||||||
function getEachFiles(&$file, $base, $path = "")
|
function getEachFiles(&$file, $base, $path = "")
|
||||||
{
|
{
|
||||||
//if (substr($base, -1)=="/") $base = substr($base, 0, -1);
|
//if (substr($base, -1)=="/") $base = substr($base, 0, -1);
|
||||||
|
@ -453,7 +433,7 @@ function WaitFunction($deployid = '') {
|
||||||
}
|
}
|
||||||
$header["Authorization"] = "Bearer " . getConfig('APIKey');
|
$header["Authorization"] = "Bearer " . getConfig('APIKey');
|
||||||
$header["Content-Type"] = "application/json";
|
$header["Content-Type"] = "application/json";
|
||||||
$url = "https://api.vercel.com/v11/now/deployments/" . $deployid;
|
$url = "https://api.vercel.com/v11/deployments/" . $deployid;
|
||||||
$response = curl("GET", $url, "", $header);
|
$response = curl("GET", $url, "", $header);
|
||||||
if ($response['stat']==200) {
|
if ($response['stat']==200) {
|
||||||
$result = json_decode($response['body'], true);
|
$result = json_decode($response['body'], true);
|
||||||
|
@ -465,3 +445,48 @@ function WaitFunction($deployid = '') {
|
||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function changeAuthKey() {
|
||||||
|
if ($_POST['APIKey']!='') {
|
||||||
|
$APIKey = $_POST['APIKey'];
|
||||||
|
$tmp['APIKey'] = $APIKey;
|
||||||
|
$response = setConfigResponse( setVercelConfig($tmp, getConfig('HerokuappId'), $APIKey) );
|
||||||
|
if (api_error($response)) {
|
||||||
|
$html = api_error_msg($response);
|
||||||
|
$title = 'Error';
|
||||||
|
return message($html, $title, 400);
|
||||||
|
} else {
|
||||||
|
$html = getconstStr('Success') . '
|
||||||
|
<script>
|
||||||
|
var status = "' . $response['DplStatus'] . '";
|
||||||
|
var i = 0;
|
||||||
|
var uploadList = setInterval(function(){
|
||||||
|
if (document.getElementById("dis").style.display=="none") {
|
||||||
|
console.log(i++);
|
||||||
|
} else {
|
||||||
|
clearInterval(uploadList);
|
||||||
|
location.href = "' . path_format($_SERVER['base_path'] . '/') . '";
|
||||||
|
}
|
||||||
|
}, 1000);
|
||||||
|
</script>';
|
||||||
|
return message($html, $title, 201, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$html = '
|
||||||
|
<form action="" method="post" onsubmit="return notnull(this);">
|
||||||
|
<a href="https://vercel.com/account/tokens" target="_blank">' . getconstStr('Create') . ' token</a><br>
|
||||||
|
<label>Token:<input name="APIKey" type="password" placeholder="" value=""></label><br>
|
||||||
|
<input type="submit" value="' . getconstStr('Submit') . '">
|
||||||
|
</form>
|
||||||
|
<script>
|
||||||
|
function notnull(t)
|
||||||
|
{
|
||||||
|
if (t.APIKey.value==\'\') {
|
||||||
|
alert(\'Input Token\');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
</script>';
|
||||||
|
return message($html, 'Change platform Auth token or key', 200);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue