靠key识别文件,缓存txt类文件
parent
7256f48844
commit
e229f6594d
|
@ -934,6 +934,7 @@ function MSAPI($method, $path, $data = '', $access_token)
|
||||||
|
|
||||||
function fetch_files($path = '/')
|
function fetch_files($path = '/')
|
||||||
{
|
{
|
||||||
|
global $exts;
|
||||||
$path1 = path_format($path);
|
$path1 = path_format($path);
|
||||||
$path = path_format($_SERVER['list_path'] . path_format($path));
|
$path = path_format($_SERVER['list_path'] . path_format($path));
|
||||||
if (!($files = getcache('path_' . $path))) {
|
if (!($files = getcache('path_' . $path))) {
|
||||||
|
@ -943,12 +944,19 @@ function fetch_files($path = '/')
|
||||||
$pos = strrpos($path, '/');
|
$pos = strrpos($path, '/');
|
||||||
if ($pos>1) {
|
if ($pos>1) {
|
||||||
$parentpath = substr($path, 0, $pos);
|
$parentpath = substr($path, 0, $pos);
|
||||||
$filename = substr($path, $pos+1);
|
$filename = strtolower(substr($path, $pos+1));
|
||||||
if ($parentfiles = getcache('path_' . $parentpath))
|
if ($parentfiles = getcache('path_' . $parentpath. '/')) {
|
||||||
foreach ($parentfiles['children'] as $file)
|
if (isset($parentfiles['children'][$filename]['@microsoft.graph.downloadUrl'])) {
|
||||||
if ($file['name']==$filename)
|
if (in_array(splitlast($filename,'.')[1], $exts['txt'])) {
|
||||||
if (isset($file['@microsoft.graph.downloadUrl']))
|
if (!(isset($parentfiles['children'][$filename]['content'])&&$parentfiles['children'][$filename]['content']['stat']==200)) {
|
||||||
return $file;
|
$content1 = curl_request($parentfiles['children'][$filename]['@microsoft.graph.downloadUrl']);
|
||||||
|
$parentfiles['children'][$filename]['content'] = $content1;
|
||||||
|
savecache('path_' . $parentpath. '/', $parentfiles);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $parentfiles['children'][$filename];
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$url = $_SERVER['api_url'];
|
$url = $_SERVER['api_url'];
|
||||||
if ($path !== '/') {
|
if ($path !== '/') {
|
||||||
|
@ -956,6 +964,8 @@ function fetch_files($path = '/')
|
||||||
if (substr($url,-1)=='/') $url=substr($url,0,-1);
|
if (substr($url,-1)=='/') $url=substr($url,0,-1);
|
||||||
}
|
}
|
||||||
$url .= '?expand=children(select=name,size,file,folder,parentReference,lastModifiedDateTime,@microsoft.graph.downloadUrl)';
|
$url .= '?expand=children(select=name,size,file,folder,parentReference,lastModifiedDateTime,@microsoft.graph.downloadUrl)';
|
||||||
|
$retry = 0;
|
||||||
|
$arr = [];
|
||||||
while ($retry<3&&!$arr['stat']) {
|
while ($retry<3&&!$arr['stat']) {
|
||||||
$arr = curl_request($url, false, ['Authorization' => 'Bearer ' . $_SERVER['access_token']]);
|
$arr = curl_request($url, false, ['Authorization' => 'Bearer ' . $_SERVER['access_token']]);
|
||||||
$retry++;
|
$retry++;
|
||||||
|
@ -1002,7 +1012,7 @@ function children_name($children)
|
||||||
{
|
{
|
||||||
$tmp = [];
|
$tmp = [];
|
||||||
foreach ($children as $file) {
|
foreach ($children as $file) {
|
||||||
$tmp[$file['name']] = $file;
|
$tmp[strtolower($file['name'])] = $file;
|
||||||
}
|
}
|
||||||
return $tmp;
|
return $tmp;
|
||||||
}
|
}
|
||||||
|
@ -1115,6 +1125,10 @@ function render_list($path = '', $files = '')
|
||||||
global $exts;
|
global $exts;
|
||||||
global $constStr;
|
global $constStr;
|
||||||
|
|
||||||
|
if (isset($files['children']['index.html']) && !$_SERVER['admin']) {
|
||||||
|
$htmlcontent = fetch_files(spurlencode(path_format($path . '/index.html'),'/'))['content'];
|
||||||
|
return output($htmlcontent['body'], $htmlcontent['stat']);
|
||||||
|
}
|
||||||
$path = str_replace('%20','%2520',$path);
|
$path = str_replace('%20','%2520',$path);
|
||||||
$path = str_replace('+','%2B',$path);
|
$path = str_replace('+','%2B',$path);
|
||||||
$path = str_replace('&','&',path_format(urldecode($path))) ;
|
$path = str_replace('&','&',path_format(urldecode($path))) ;
|
||||||
|
@ -1147,12 +1161,12 @@ function render_list($path = '', $files = '')
|
||||||
|
|
||||||
$theme = getConfig('theme');
|
$theme = getConfig('theme');
|
||||||
if ( $theme=='' || !file_exists('theme/'.$theme) ) $theme = 'classic.php';
|
if ( $theme=='' || !file_exists('theme/'.$theme) ) $theme = 'classic.php';
|
||||||
$htmlpage = include 'theme/'.$theme;
|
include 'theme/'.$theme;
|
||||||
|
|
||||||
$html = '<!--
|
$html = '<!--
|
||||||
Github : https://github.com/qkqpttgf/OneManager-php
|
Github : https://github.com/qkqpttgf/OneManager-php
|
||||||
-->' . ob_get_clean();
|
-->' . ob_get_clean();
|
||||||
if (isset($htmlpage['statusCode'])) return $htmlpage;
|
//if (isset($htmlpage['statusCode'])) return $htmlpage;
|
||||||
if (isset($_SERVER['Set-Cookie'])) return output($html, $statusCode, [ 'Set-Cookie' => $_SERVER['Set-Cookie'], 'Content-Type' => 'text/html' ]);
|
if (isset($_SERVER['Set-Cookie'])) return output($html, $statusCode, [ 'Set-Cookie' => $_SERVER['Set-Cookie'], 'Content-Type' => 'text/html' ]);
|
||||||
return output($html,$statusCode);
|
return output($html,$statusCode);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue