mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-06 03:58:04 +08:00
ComposerUpdate
This commit is contained in:
parent
11f00c254a
commit
12f94b19e6
@ -38,7 +38,7 @@ class Module extends Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* 安装模块代码
|
||||
* 安装更新模块
|
||||
* @auth true
|
||||
*/
|
||||
public function install()
|
||||
|
@ -27,22 +27,19 @@ use think\admin\service\ModuleService;
|
||||
class Update extends Controller
|
||||
{
|
||||
|
||||
/**
|
||||
* 获取模块信息
|
||||
*/
|
||||
public function version()
|
||||
{
|
||||
$modules = ModuleService::instance()->getModules();
|
||||
$this->success('获取模块信息成功!', $modules);
|
||||
}
|
||||
|
||||
/**
|
||||
* 读取文件内容
|
||||
*/
|
||||
public function get()
|
||||
{
|
||||
if (file_exists($file = $this->app->getRootPath() . decode(input('encode', '0')))) {
|
||||
$this->success('读取文件成功!', ['content' => base64_encode(file_get_contents($file))]);
|
||||
$filename = decode(input('encode', '0'));
|
||||
if (!ModuleService::instance()->checkAllowDownload($filename)) {
|
||||
$this->error('下载的文件不在认证规则中!');
|
||||
}
|
||||
if (file_exists($realname = $this->app->getRootPath() . $filename)) {
|
||||
$this->success('读取文件内容成功!', [
|
||||
'content' => base64_encode(file_get_contents($realname)),
|
||||
]);
|
||||
} else {
|
||||
$this->error('读取文件内容失败!');
|
||||
}
|
||||
@ -59,4 +56,12 @@ class Update extends Controller
|
||||
));
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取模块信息
|
||||
*/
|
||||
public function version()
|
||||
{
|
||||
$this->success('获取模块信息成功!', ModuleService::instance()->getModules());
|
||||
}
|
||||
|
||||
}
|
@ -17,11 +17,15 @@
|
||||
return [
|
||||
'name' => 'admin',
|
||||
'author' => 'Anyon',
|
||||
'version' => '2020.08.01.00',
|
||||
'version' => '2020.08.05.00',
|
||||
'content' => 'ThinkAdmin 系统基础模块',
|
||||
'changes' => [
|
||||
'2020.08.05.00' => [
|
||||
'content' => '优化系统模块管理',
|
||||
'database' => ['select version()'],
|
||||
],
|
||||
'2020.08.03.00' => [
|
||||
'content' => '模块初始化提交',
|
||||
'content' => '系统模块初始化提交',
|
||||
'database' => ['select version()'],
|
||||
],
|
||||
],
|
||||
|
8
composer.lock
generated
8
composer.lock
generated
@ -879,12 +879,12 @@
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/zoujingli/ThinkLibrary.git",
|
||||
"reference": "d799064954094a3ca5d548d2b6e1e575a4dbeac5"
|
||||
"reference": "8e1a13fd20d0a454ecccab056a0f6ebe477fe65f"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/d799064954094a3ca5d548d2b6e1e575a4dbeac5",
|
||||
"reference": "d799064954094a3ca5d548d2b6e1e575a4dbeac5",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/8e1a13fd20d0a454ecccab056a0f6ebe477fe65f",
|
||||
"reference": "8e1a13fd20d0a454ecccab056a0f6ebe477fe65f",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -928,7 +928,7 @@
|
||||
],
|
||||
"description": "ThinkPHP v6.0 Development Library",
|
||||
"homepage": "http://thinkadmin.top",
|
||||
"time": "2020-08-03T09:33:56+00:00"
|
||||
"time": "2020-08-05T02:41:59+00:00"
|
||||
},
|
||||
{
|
||||
"name": "zoujingli/wechat-developer",
|
||||
|
8
vendor/composer/installed.json
vendored
8
vendor/composer/installed.json
vendored
@ -903,12 +903,12 @@
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/zoujingli/ThinkLibrary.git",
|
||||
"reference": "d799064954094a3ca5d548d2b6e1e575a4dbeac5"
|
||||
"reference": "8e1a13fd20d0a454ecccab056a0f6ebe477fe65f"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/d799064954094a3ca5d548d2b6e1e575a4dbeac5",
|
||||
"reference": "d799064954094a3ca5d548d2b6e1e575a4dbeac5",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/8e1a13fd20d0a454ecccab056a0f6ebe477fe65f",
|
||||
"reference": "8e1a13fd20d0a454ecccab056a0f6ebe477fe65f",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -924,7 +924,7 @@
|
||||
"ext-json": "*",
|
||||
"topthink/framework": "^6.0"
|
||||
},
|
||||
"time": "2020-08-03T09:33:56+00:00",
|
||||
"time": "2020-08-05T02:41:59+00:00",
|
||||
"type": "library",
|
||||
"extra": {
|
||||
"think": {
|
||||
|
2
vendor/services.php
vendored
2
vendor/services.php
vendored
@ -1,5 +1,5 @@
|
||||
<?php
|
||||
// This file is automatically generated at:2020-08-03 18:04:42
|
||||
// This file is automatically generated at:2020-08-05 10:46:09
|
||||
declare (strict_types = 1);
|
||||
return array (
|
||||
0 => 'think\\admin\\Library',
|
||||
|
@ -62,18 +62,20 @@ class Library extends Service
|
||||
*/
|
||||
public function register()
|
||||
{
|
||||
// 输入默认过滤
|
||||
$this->app->request->filter(['trim']);
|
||||
// 加载中文语言
|
||||
$this->app->lang->load(__DIR__ . '/lang/zh-cn.php', 'zh-cn');
|
||||
$this->app->lang->load(__DIR__ . '/lang/en-us.php', 'en-us');
|
||||
// 输入变量默认过滤
|
||||
$this->app->request->filter(['trim']);
|
||||
// 判断访问模式,兼容 CLI 访问控制器
|
||||
if ($this->app->request->isCli()) {
|
||||
if (empty($_SERVER['REQUEST_URI']) && isset($_SERVER['argv'][1])) {
|
||||
$this->app->request->setPathinfo($_SERVER['argv'][1]);
|
||||
}
|
||||
} else {
|
||||
if ($this->app->request->request('not_init_session', 0) == 0) {
|
||||
$isSess = $this->app->request->request('not_init_session', 0) > 0;
|
||||
$notYar = stripos($this->app->request->header('user-agent', ''), 'PHP Yar RPC-') !== false;
|
||||
if ($notYar && $isSess) {
|
||||
// 注册会话初始化中间键
|
||||
$this->app->middleware->add(SessionInit::class);
|
||||
// 注册语言包处理中间键
|
||||
|
@ -117,7 +117,7 @@ class Install extends Command
|
||||
$data = InstallService::instance()->grenerateDifference($this->rules, $this->ignore);
|
||||
if (empty($data)) $this->output->writeln('No need to update the file if the file comparison is consistent');
|
||||
else foreach ($data as $file) {
|
||||
[$state, $mode, $name] = InstallService::instance()->fileSynchronization($file);
|
||||
[$state, $mode, $name] = InstallService::instance()->updateFileByDownload($file);
|
||||
if ($state) {
|
||||
if ($mode === 'add') $this->output->writeln("--- {$name} add successfully");
|
||||
if ($mode === 'mod') $this->output->writeln("--- {$name} update successfully");
|
||||
|
@ -142,7 +142,7 @@ class AdminService extends Service
|
||||
*/
|
||||
public function clearCache()
|
||||
{
|
||||
$this->app->cache->delete('system_auth_node');
|
||||
$this->app->cache->delete('SystemAuthNode');
|
||||
return $this;
|
||||
}
|
||||
|
||||
|
@ -60,12 +60,12 @@ class InstallService extends Service
|
||||
*/
|
||||
protected function initialize()
|
||||
{
|
||||
// 应用根目录
|
||||
$this->root = strtr($this->app->getRootPath(), '\\', '/');
|
||||
// 应用框架版本
|
||||
$this->version = $this->app->config->get('app.thinkadmin_ver') ?: 'v4';
|
||||
// 线上应用代码
|
||||
$this->server = "https://{$this->version}.thinkadmin.top";
|
||||
// 应用根目录
|
||||
$this->root = strtr($this->app->getRootPath(), '\\', '/');
|
||||
}
|
||||
|
||||
/**
|
||||
@ -87,11 +87,11 @@ class InstallService extends Service
|
||||
}
|
||||
|
||||
/**
|
||||
* 同步更新文件
|
||||
* @param array $file
|
||||
* 下载并更新文件
|
||||
* @param array $file 文件信息
|
||||
* @return array
|
||||
*/
|
||||
public function fileSynchronization($file)
|
||||
public function updateFileByDownload(array $file): array
|
||||
{
|
||||
if (in_array($file['type'], ['add', 'mod'])) {
|
||||
if ($this->downloadFile(encode($file['name']))) {
|
||||
@ -117,7 +117,8 @@ class InstallService extends Service
|
||||
*/
|
||||
private function downloadFile($encode)
|
||||
{
|
||||
$result = json_decode(HttpExtend::get("{$this->server}?s=admin/api.update/get&encode={$encode}"), true);
|
||||
$source = "{$this->server}/admin/api.update/get?encode={$encode}";
|
||||
$result = json_decode(HttpExtend::get($source), true);
|
||||
if (empty($result['code'])) return false;
|
||||
$filename = $this->root . decode($encode);
|
||||
file_exists(dirname($filename)) || mkdir(dirname($filename), 0755, true);
|
||||
@ -141,10 +142,10 @@ class InstallService extends Service
|
||||
* @param array $ignore 忽略规则
|
||||
* @return array
|
||||
*/
|
||||
public function grenerateDifference($rules = [], $ignore = [])
|
||||
public function grenerateDifference(array $rules = [], array $ignore = []): array
|
||||
{
|
||||
[$this->rules, $this->ignore, $data] = [$rules, $ignore, []];
|
||||
$result = json_decode(HttpExtend::post("{$this->server}?s=/admin/api.update/node", [
|
||||
$result = json_decode(HttpExtend::post("{$this->server}/admin/api.update/node", [
|
||||
'rules' => json_encode($this->rules), 'ignore' => json_encode($this->ignore),
|
||||
]), true);
|
||||
if (!empty($result['code'])) {
|
||||
@ -164,24 +165,24 @@ class InstallService extends Service
|
||||
* @param array $local 本地文件列表信息
|
||||
* @return array
|
||||
*/
|
||||
private function grenerateDifferenceContrast(array $serve = [], array $local = [])
|
||||
private function grenerateDifferenceContrast(array $serve = [], array $local = []): array
|
||||
{
|
||||
// 数据扁平化
|
||||
[$_serve, $_local, $_new] = [[], [], []];
|
||||
[$_serve, $_local, $_diffy] = [[], [], []];
|
||||
foreach ($serve as $t) $_serve[$t['name']] = $t;
|
||||
foreach ($local as $t) $_local[$t['name']] = $t;
|
||||
unset($serve, $local);
|
||||
// 线上数据差异计算
|
||||
foreach ($_serve as $t) isset($_local[$t['name']]) ? array_push($_new, [
|
||||
foreach ($_serve as $t) isset($_local[$t['name']]) ? array_push($_diffy, [
|
||||
'type' => $t['hash'] === $_local[$t['name']]['hash'] ? null : 'mod', 'name' => $t['name'],
|
||||
]) : array_push($_new, ['type' => 'add', 'name' => $t['name']]);
|
||||
]) : array_push($_diffy, ['type' => 'add', 'name' => $t['name']]);
|
||||
// 本地数据增量计算
|
||||
foreach ($_local as $t) if (!isset($_serve[$t['name']])) array_push($_new, ['type' => 'del', 'name' => $t['name']]);
|
||||
foreach ($_local as $t) if (!isset($_serve[$t['name']])) array_push($_diffy, ['type' => 'del', 'name' => $t['name']]);
|
||||
unset($_serve, $_local);
|
||||
usort($_new, function ($a, $b) {
|
||||
usort($_diffy, function ($a, $b) {
|
||||
return $a['name'] !== $b['name'] ? ($a['name'] > $b['name'] ? 1 : -1) : 0;
|
||||
});
|
||||
return $_new;
|
||||
return $_diffy;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -191,7 +192,7 @@ class InstallService extends Service
|
||||
* @param array $data 扫描结果列表
|
||||
* @return array
|
||||
*/
|
||||
public function getList(array $rules, array $ignore = [], array $data = [])
|
||||
public function getList(array $rules, array $ignore = [], array $data = []): array
|
||||
{
|
||||
// 扫描规则文件
|
||||
foreach ($rules as $key => $rule) {
|
||||
@ -199,9 +200,10 @@ class InstallService extends Service
|
||||
$data = array_merge($data, $this->scanList("{$this->root}{$name}"));
|
||||
}
|
||||
// 清除忽略文件
|
||||
foreach ($data as $key => $item) foreach ($ignore as $ingore) {
|
||||
if (stripos($item['name'], $ingore) === 0) unset($data[$key]);
|
||||
foreach ($data as $key => $item) foreach ($ignore as $igr) {
|
||||
if (stripos($item['name'], $igr) === 0) unset($data[$key]);
|
||||
}
|
||||
// 返回文件数据
|
||||
return ['rules' => $rules, 'ignore' => $ignore, 'list' => $data];
|
||||
}
|
||||
|
||||
@ -211,7 +213,7 @@ class InstallService extends Service
|
||||
* @param array $data 扫描结果
|
||||
* @return array
|
||||
*/
|
||||
private function scanList($path, $data = [])
|
||||
private function scanList($path, $data = []): array
|
||||
{
|
||||
if (file_exists($path)) if (is_dir($path)) foreach (scandir($path) as $sub) {
|
||||
if (strpos($sub, '.') !== 0) if (is_dir($temp = "{$path}/{$sub}")) {
|
||||
@ -227,14 +229,14 @@ class InstallService extends Service
|
||||
|
||||
/**
|
||||
* 获取指定文件信息
|
||||
* @param string $filename
|
||||
* @param string $realname 文件路径
|
||||
* @return array
|
||||
*/
|
||||
private function getInfo($filename)
|
||||
private function getInfo($realname): array
|
||||
{
|
||||
return [
|
||||
'name' => str_replace($this->root, '', $filename),
|
||||
'hash' => md5(preg_replace('/\s+/', '', file_get_contents($filename))),
|
||||
'name' => str_replace($this->root, '', $realname),
|
||||
'hash' => md5(preg_replace('/\s+/', '', file_get_contents($realname))),
|
||||
];
|
||||
}
|
||||
}
|
@ -81,7 +81,7 @@ class ModuleService extends Service
|
||||
} else {
|
||||
$lines = [];
|
||||
foreach ($data as $file) {
|
||||
[$state, $mode, $name] = InstallService::instance()->fileSynchronization($file);
|
||||
[$state, $mode, $name] = InstallService::instance()->updateFileByDownload($file);
|
||||
if ($state) {
|
||||
if ($mode === 'add') $lines[] = "add {$name} successed";
|
||||
if ($mode === 'mod') $lines[] = "modify {$name} successed";
|
||||
@ -113,6 +113,39 @@ class ModuleService extends Service
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取允许下载的规则
|
||||
* @return array
|
||||
*/
|
||||
public function getAllowDownloadRule(): array
|
||||
{
|
||||
$data = $this->app->cache->get('moduleAllowRule', []);
|
||||
if (is_array($data) && count($data) > 0) return $data;
|
||||
$data = ['config', 'public/static'];
|
||||
foreach (array_keys($this->getModules()) as $name) $data[] = "app/{$name}";
|
||||
$this->app->cache->set('moduleAllowRule', $data, 30);
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* 检查文件是否可下载
|
||||
* @param string $name 文件名称
|
||||
* @return boolean
|
||||
*/
|
||||
public function checkAllowDownload($name): bool
|
||||
{
|
||||
// 禁止下载数据库配置文件
|
||||
if (stripos($name, 'database.php') !== false) {
|
||||
return false;
|
||||
}
|
||||
// 检查允许下载的文件规则
|
||||
foreach ($this->getAllowDownloadRule() as $rule) {
|
||||
if (stripos($name, $rule) !== false) return true;
|
||||
}
|
||||
// 不在允许下载的文件规则
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取模块版本信息
|
||||
* @param string $name 模块名称
|
||||
|
@ -94,7 +94,7 @@ class NodeService extends Service
|
||||
static $data = [];
|
||||
if (empty($force)) {
|
||||
if (count($data) > 0) return $data;
|
||||
$data = $this->app->cache->get('system_auth_node', []);
|
||||
$data = $this->app->cache->get('SystemAuthNode', []);
|
||||
if (count($data) > 0) return $data;
|
||||
} else {
|
||||
$data = [];
|
||||
@ -113,7 +113,7 @@ class NodeService extends Service
|
||||
}
|
||||
}
|
||||
$data = array_change_key_case($data, CASE_LOWER);
|
||||
$this->app->cache->set('system_auth_node', $data);
|
||||
$this->app->cache->set('SystemAuthNode', $data);
|
||||
return $data;
|
||||
}
|
||||
|
||||
|
@ -55,6 +55,17 @@ class OpenService extends Service
|
||||
$this->appkey = $appkey ?: sysconf('data.cuci_open_appkey');
|
||||
}
|
||||
|
||||
/**
|
||||
* 接口数据签名
|
||||
* @param array $data [time, nostr, json, sign]
|
||||
* @return array
|
||||
*/
|
||||
public function signData(array $data): array
|
||||
{
|
||||
[$time, $nostr, $json] = [time(), uniqid(), json_encode($data, JSON_UNESCAPED_UNICODE)];
|
||||
return [$time, $nostr, $json, md5("{$this->appid}#{$json}#{$time}#{$this->appkey}#{$nostr}")];
|
||||
}
|
||||
|
||||
/**
|
||||
* 接口数据请求
|
||||
* @param string $uri 接口地址
|
||||
@ -64,11 +75,10 @@ class OpenService extends Service
|
||||
*/
|
||||
public function doRequest(string $uri, array $data = []): array
|
||||
{
|
||||
[$time, $nostr, $json] = [time(), uniqid(), json_encode($data)];
|
||||
$sign = md5($this->appid . '#' . $json . '#' . $time . '#' . $this->appkey . '#' . $nostr);
|
||||
$data = ['appid' => $this->appid, 'time' => $time, 'nostr' => $nostr, 'sign' => $sign, 'data' => $json];
|
||||
$result = json_decode(HttpExtend::post("https://open.cuci.cc/{$uri}", $data), true);
|
||||
if (empty($result)) throw new \think\admin\Exception('接口响应异常');
|
||||
[$time, $nostr, $json, $sign] = $this->signData($data);
|
||||
$post = ['appid' => $this->appid, 'time' => $time, 'nostr' => $nostr, 'sign' => $sign, 'data' => $json];
|
||||
$result = json_decode(HttpExtend::post("https://open.cuci.cc/{$uri}", $post), true);
|
||||
if (empty($result)) throw new \think\admin\Exception('服务端接口响应异常');
|
||||
if (empty($result['code'])) throw new \think\admin\Exception($result['info']);
|
||||
return $result['data'] ?? [];
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user