diff --git a/platform/Replit.php b/platform/Replit.php
new file mode 100644
index 0000000..a7b0601
--- /dev/null
+++ b/platform/Replit.php
@@ -0,0 +1,386 @@
+0) $path = substr($_SERVER['REQUEST_URI'], 0, $p);
+ else $path = $_SERVER['REQUEST_URI'];
+ $path = path_format( substr($path, strlen($_SERVER['base_path'])) );
+ return $path;
+}
+
+function getGET()
+{
+ if (!$_POST) {
+ if (!!$HTTP_RAW_POST_DATA) {
+ $tmpdata = $HTTP_RAW_POST_DATA;
+ } else {
+ $tmpdata = file_get_contents('php://input');
+ }
+ if (!!$tmpdata) {
+ $postbody = explode("&", $tmpdata);
+ foreach ($postbody as $postvalues) {
+ $pos = strpos($postvalues,"=");
+ $_POST[urldecode(substr($postvalues,0,$pos))]=urldecode(substr($postvalues,$pos+1));
+ }
+ }
+ }
+ if (isset($_SERVER['UNENCODED_URL'])) $_SERVER['REQUEST_URI'] = $_SERVER['UNENCODED_URL'];
+ $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 ReplitAPI($op, $key, $value = '') {
+ //error_log1($op . '_' . $key . '_' . $value);
+ $apiurl = getenv('REPLIT_DB_URL');
+ //foreach (explode("\n", curl('GET', $apiurl . '?prefix')['body']) as $a) curl('DELETE', $apiurl . '/' . $a);
+ if ($op === 'r') {
+ if (!($config = getcache('REPLIT_CONFIG'))) {
+ $config = json_decode(curl('GET', $apiurl . '/REPLIT_CONFIG')['body'], true);
+ savecache('REPLIT_CONFIG', $config);
+ }
+ return ['stat'=>200, 'body'=>(is_array($config[$key])?json_encode($config[$key]):$config[$key])];
+ } elseif ($op === 'w') {
+ return curl('POST', $apiurl, 'REPLIT_CONFIG=' . $value, ["Content-Type"=>"application/x-www-form-urlencoded"]);
+ } elseif ($op === 'd') {
+ // not use
+ return curl('DELETE', $apiurl . '/' . $key);
+ } else {
+ return ['stat'=>500, 'body'=>'error option input to function ReplitAPI().'];
+ }
+}
+
+function getConfig($str, $disktag = '')
+{
+ if (isInnerEnv($str)) {
+ if ($disktag=='') $disktag = $_SERVER['disktag'];
+ $env = json_decode(ReplitAPI('r', $disktag)['body'], true);
+ if (isset($env[$str])) {
+ if (isBase64Env($str)) return base64y_decode($env[$str]);
+ else return $env[$str];
+ }
+ } else {
+ if (isBase64Env($str)) return base64y_decode(ReplitAPI('r', $str)['body']);
+ else return ReplitAPI('r', $str)['body'];
+ }
+ return '';
+}
+
+function setConfig($arr, $disktag = '')
+{
+ if (!($envs = getcache('REPLIT_CONFIG'))) {
+ $envs = json_decode(curl('GET', getenv('REPLIT_DB_URL') . '/REPLIT_CONFIG')['body'], true);
+ //savecache('REPLIT_CONFIG', $envs);
+ }
+ if ($disktag=='') $disktag = $_SERVER['disktag'];
+ $disktags = explode("|", getConfig('disktag'));
+ $indisk = 0;
+ $operatedisk = 0;
+ foreach ($arr as $k => $v) {
+ if (isCommonEnv($k)) {
+ if (isBase64Env($k)) $envs[$k] = base64y_encode($v);
+ else $envs[$k] = $v;
+ } elseif (isInnerEnv($k)) {
+ if (isBase64Env($k)) $envs[$disktag][$k] = base64y_encode($v);
+ else $envs[$disktag][$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;
+ } elseif ($k=='disktag_copy') {
+ $newtag = $v . '_' . date("Ymd_His");
+ $envs[$newtag] = $envs[$v];
+ array_push($disktags, $newtag);
+ $operatedisk = 1;
+ } elseif ($k=='disktag_rename' || $k=='disktag_newname') {
+ if ($arr['disktag_rename']!=$arr['disktag_newname']) $operatedisk = 1;
+ } else {
+ $envs[$k] = $v;
+ }
+ }
+ if ($indisk) {
+ $diskconfig = $envs[$disktag];
+ $diskconfig = array_filter($diskconfig, 'array_value_isnot_null');
+ ksort($diskconfig);
+ $envs[$disktag] = $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);
+ }
+ $envs['disktag'] = implode('|', $tags);
+ $envs[$arr['disktag_newname']] = $envs[$arr['disktag_rename']];
+ unset($envs[$arr['disktag_rename']]);
+ } else {
+ $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');
+ $response = ReplitAPI('w', 'REPLIT_CONFIG', json_encode($envs));
+ //error_log1(json_encode($arr, JSON_PRETTY_PRINT) . ' => tmp:' . json_encode($envs, JSON_PRETTY_PRINT));
+ savecache('REPLIT_CONFIG', null, '', 0);
+ if (api_error($response)) return ['stat'=>$response['stat'], 'body'=>$response['body'] . "
\nError in writting " . $key . "=" . $val];
+ return $response;
+}
+
+function install()
+{
+ global $constStr;
+ if ($_GET['install2']) {
+ if ($_POST['admin']!='') {
+ $tmp['admin'] = $_POST['admin'];
+ //$tmp['language'] = $_COOKIE['language'];
+ $tmp['timezone'] = $_COOKIE['timezone'];
+ $response = setConfigResponse( setConfig($tmp) );
+ if (api_error($response)) {
+ $html = api_error_msg($response);
+ $title = 'Error';
+ return message($html, $title, 201);
+ } else {
+ return output('Jump
+
+ ', 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 .= '
+
'. json_encode($response, JSON_PRETTY_PRINT).'' . '