mirror of
https://github.com/flucont/btcloud.git
synced 2025-10-15 23:30:29 +00:00
Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
50cfdaa06f | ||
![]() |
ae4ed95573 | ||
![]() |
e98206ce0c | ||
![]() |
8946b4fd11 |
@@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
网站后台管理可一键同步宝塔官方的插件列表与增量更新插件包,还有云端使用记录、IP黑白名单、操作日志、定时任务等功能。
|
网站后台管理可一键同步宝塔官方的插件列表与增量更新插件包,还有云端使用记录、IP黑白名单、操作日志、定时任务等功能。
|
||||||
|
|
||||||
本项目自带的宝塔安装包和更新包是7.9.3最新版,已修改适配此第三方云端,并且全开源,无so等加密文件。
|
本项目自带的宝塔安装包和更新包是7.9.5最新版,已修改适配此第三方云端,并且全开源,无so等加密文件。
|
||||||
|
|
||||||
觉得该项目不错的可以给个Star~
|
觉得该项目不错的可以给个Star~
|
||||||
|
|
||||||
|
@@ -52,6 +52,8 @@ class Install extends BaseController
|
|||||||
$sqls=file_get_contents(app()->getRootPath().'install.sql');
|
$sqls=file_get_contents(app()->getRootPath().'install.sql');
|
||||||
$sqls=explode(';', $sqls);
|
$sqls=explode(';', $sqls);
|
||||||
$sqls[]="REPLACE INTO `".$mysql_prefix."config` VALUES ('syskey', '".random(16)."')";
|
$sqls[]="REPLACE INTO `".$mysql_prefix."config` VALUES ('syskey', '".random(16)."')";
|
||||||
|
$sqls[]="REPLACE INTO `".$mysql_prefix."config` VALUES ('admin_username', '".addslashes($admin_username)."')";
|
||||||
|
$sqls[]="REPLACE INTO `".$mysql_prefix."config` VALUES ('admin_password', '".addslashes($admin_password)."')";
|
||||||
$success=0;$error=0;$errorMsg=null;
|
$success=0;$error=0;$errorMsg=null;
|
||||||
foreach ($sqls as $value) {
|
foreach ($sqls as $value) {
|
||||||
$value=trim($value);
|
$value=trim($value);
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
Linux_Version="7.9.4"
|
Linux_Version="7.9.5"
|
||||||
Windows_Version="7.6.0"
|
Windows_Version="7.7.0"
|
||||||
|
|
||||||
FILES=(
|
FILES=(
|
||||||
public/install/src/panel6.zip
|
public/install/src/panel6.zip
|
||||||
|
@@ -2,6 +2,7 @@
|
|||||||
{block name="title"}宝塔第三方云端管理中心{/block}
|
{block name="title"}宝塔第三方云端管理中心{/block}
|
||||||
{block name="main"}
|
{block name="main"}
|
||||||
<style>
|
<style>
|
||||||
|
.table>tbody>tr>td{white-space: normal;}
|
||||||
.query-title {
|
.query-title {
|
||||||
background-color:#f5fafe;
|
background-color:#f5fafe;
|
||||||
word-break: keep-all;
|
word-break: keep-all;
|
||||||
|
@@ -70,12 +70,14 @@ function submitlogin(){
|
|||||||
var pass = $("input[name='pass']").val();
|
var pass = $("input[name='pass']").val();
|
||||||
var code = $("input[name='code']").val();
|
var code = $("input[name='code']").val();
|
||||||
if(user=='' || pass==''){layer.alert('用户名或密码不能为空!');return false;}
|
if(user=='' || pass==''){layer.alert('用户名或密码不能为空!');return false;}
|
||||||
$.ajax({
|
var ii = layer.load(2);
|
||||||
|
$.ajax({
|
||||||
type : 'POST',
|
type : 'POST',
|
||||||
url : '{:request()->url()}',
|
url : '{:request()->url()}',
|
||||||
data: {username:user, password:pass, code:code},
|
data: {username:user, password:pass, code:code},
|
||||||
dataType : 'json',
|
dataType : 'json',
|
||||||
success : function(data) {
|
success : function(data) {
|
||||||
|
layer.close(ii);
|
||||||
if(data.code == 0){
|
if(data.code == 0){
|
||||||
layer.msg('登录成功,正在跳转', {icon: 1,shade: 0.01,time: 15000});
|
layer.msg('登录成功,正在跳转', {icon: 1,shade: 0.01,time: 15000});
|
||||||
window.location.href='/admin';
|
window.location.href='/admin';
|
||||||
@@ -87,6 +89,7 @@ function submitlogin(){
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
error:function(data){
|
error:function(data){
|
||||||
|
layer.close(ii);
|
||||||
layer.msg('服务器错误');
|
layer.msg('服务器错误');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@@ -12,12 +12,12 @@ INSERT INTO `cloud_config` (`key`, `value`) VALUES
|
|||||||
('bt_key', ''),
|
('bt_key', ''),
|
||||||
('whitelist', '0'),
|
('whitelist', '0'),
|
||||||
('download_page', '1'),
|
('download_page', '1'),
|
||||||
('new_version', '7.9.4'),
|
('new_version', '7.9.5'),
|
||||||
('update_msg', '暂无更新日志'),
|
('update_msg', '暂无更新日志'),
|
||||||
('update_date', '2022-07-13'),
|
('update_date', '2022-11-02'),
|
||||||
('new_version_win', '7.6.0'),
|
('new_version_win', '7.7.0'),
|
||||||
('update_msg_win', '暂无更新日志'),
|
('update_msg_win', '暂无更新日志'),
|
||||||
('update_date_win', '2022-06-01'),
|
('update_date_win', '2022-09-09'),
|
||||||
('updateall_type', '0'),
|
('updateall_type', '0'),
|
||||||
('syskey', 'UqP94LtI8eWAIgCP');
|
('syskey', 'UqP94LtI8eWAIgCP');
|
||||||
|
|
||||||
|
@@ -287,7 +287,7 @@ Install_RPM_Pack(){
|
|||||||
|
|
||||||
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
|
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
|
||||||
#yum remove -y python-requests python3-requests python-greenlet python3-greenlet
|
#yum remove -y python-requests python3-requests python-greenlet python3-greenlet
|
||||||
yumPacks="libcurl-devel wget tar gcc make zip unzip openssl openssl-devel gcc libxml2 libxml2-devel libxslt* zlib zlib-devel libjpeg-devel libpng-devel libwebp libwebp-devel freetype freetype-devel lsof pcre pcre-devel vixie-cron crontabs icu libicu-devel c-ares libffi-devel bzip2-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel"
|
yumPacks="libcurl-devel wget tar gcc make zip unzip openssl openssl-devel gcc libxml2 libxml2-devel libxslt* zlib zlib-devel libjpeg-devel libpng-devel libwebp libwebp-devel freetype freetype-devel lsof pcre pcre-devel vixie-cron crontabs icu libicu-devel c-ares libffi-devel bzip2-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel qrencode"
|
||||||
yum install -y ${yumPacks}
|
yum install -y ${yumPacks}
|
||||||
|
|
||||||
for yumPack in ${yumPacks}
|
for yumPack in ${yumPacks}
|
||||||
@@ -313,7 +313,15 @@ Install_Deb_Pack(){
|
|||||||
if [ "${UBUNTU_22}" ];then
|
if [ "${UBUNTU_22}" ];then
|
||||||
apt-get remove needrestart -y
|
apt-get remove needrestart -y
|
||||||
fi
|
fi
|
||||||
|
ALIYUN_CHECK=$(cat /etc/motd|grep "Alibaba Cloud ")
|
||||||
|
if [ "${ALIYUN_CHECK}" ] && [ "${UBUNTU_22}" ];then
|
||||||
|
apt-get remove libicu70 -y
|
||||||
|
fi
|
||||||
apt-get update -y
|
apt-get update -y
|
||||||
|
apt-get install bash -y
|
||||||
|
if [ -f "/usr/bin/bash" ];then
|
||||||
|
ln -sf /usr/bin/bash /bin/sh
|
||||||
|
fi
|
||||||
apt-get install ruby -y
|
apt-get install ruby -y
|
||||||
apt-get install lsb-release -y
|
apt-get install lsb-release -y
|
||||||
#apt-get install ntp ntpdate -y
|
#apt-get install ntp ntpdate -y
|
||||||
@@ -333,7 +341,7 @@ Install_Deb_Pack(){
|
|||||||
apt-get install curl -y
|
apt-get install curl -y
|
||||||
fi
|
fi
|
||||||
|
|
||||||
debPacks="wget curl libcurl4-openssl-dev gcc make zip unzip tar openssl libssl-dev gcc libxml2 libxml2-dev zlib1g zlib1g-dev libjpeg-dev libpng-dev lsof libpcre3 libpcre3-dev cron net-tools swig build-essential libffi-dev libbz2-dev libncurses-dev libsqlite3-dev libreadline-dev tk-dev libgdbm-dev libdb-dev libdb++-dev libpcap-dev xz-utils git";
|
debPacks="wget curl libcurl4-openssl-dev gcc make zip unzip tar openssl libssl-dev gcc libxml2 libxml2-dev zlib1g zlib1g-dev libjpeg-dev libpng-dev lsof libpcre3 libpcre3-dev cron net-tools swig build-essential libffi-dev libbz2-dev libncurses-dev libsqlite3-dev libreadline-dev tk-dev libgdbm-dev libdb-dev libdb++-dev libpcap-dev xz-utils git qrencode";
|
||||||
apt-get install -y $debPacks --force-yes
|
apt-get install -y $debPacks --force-yes
|
||||||
|
|
||||||
for debPack in ${debPacks}
|
for debPack in ${debPacks}
|
||||||
@@ -568,7 +576,7 @@ Install_Bt(){
|
|||||||
if [ -f ${setup_path}/server/panel/data/port.pl ];then
|
if [ -f ${setup_path}/server/panel/data/port.pl ];then
|
||||||
panelPort=$(cat ${setup_path}/server/panel/data/port.pl)
|
panelPort=$(cat ${setup_path}/server/panel/data/port.pl)
|
||||||
else
|
else
|
||||||
RE_NUM=$(expr $RANDOM % 5)
|
RE_NUM=$(expr $RANDOM % 3)
|
||||||
if [ "${RE_NUM}" == "1" ];then
|
if [ "${RE_NUM}" == "1" ];then
|
||||||
panelPort=$(expr $RANDOM % 55535 + 10000)
|
panelPort=$(expr $RANDOM % 55535 + 10000)
|
||||||
fi
|
fi
|
||||||
@@ -673,6 +681,8 @@ Set_Bt_Panel(){
|
|||||||
echo "/${auth_path}" > ${admin_auth}
|
echo "/${auth_path}" > ${admin_auth}
|
||||||
fi
|
fi
|
||||||
chmod -R 700 $pyenv_path/pyenv/bin
|
chmod -R 700 $pyenv_path/pyenv/bin
|
||||||
|
/www/server/panel/pyenv/bin/pip3 install pymongo
|
||||||
|
/www/server/panel/pyenv/bin/pip3 install psycopg2-binary
|
||||||
/www/server/panel/pyenv/bin/pip3 install flask -U
|
/www/server/panel/pyenv/bin/pip3 install flask -U
|
||||||
/www/server/panel/pyenv/bin/pip3 install flask-sock
|
/www/server/panel/pyenv/bin/pip3 install flask-sock
|
||||||
auth_path=$(cat ${admin_auth})
|
auth_path=$(cat ${admin_auth})
|
||||||
@@ -839,6 +849,8 @@ echo "
|
|||||||
+----------------------------------------------------------------------
|
+----------------------------------------------------------------------
|
||||||
| The WebPanel URL will be http://SERVER_IP:8888 when installed.
|
| The WebPanel URL will be http://SERVER_IP:8888 when installed.
|
||||||
+----------------------------------------------------------------------
|
+----------------------------------------------------------------------
|
||||||
|
| 为了您的正常使用,请确保使用全新或纯净的系统安装宝塔面板,不支持已部署项目/环境的系统安装
|
||||||
|
+----------------------------------------------------------------------
|
||||||
"
|
"
|
||||||
while [ "$go" != 'y' ] && [ "$go" != 'n' ]
|
while [ "$go" != 'y' ] && [ "$go" != 'n' ]
|
||||||
do
|
do
|
||||||
@@ -874,4 +886,3 @@ endTime=`date +%s`
|
|||||||
((outTime=($endTime-$startTime)/60))
|
((outTime=($endTime-$startTime)/60))
|
||||||
echo -e "Time consumed:\033[32m $outTime \033[0mMinute!"
|
echo -e "Time consumed:\033[32m $outTime \033[0mMinute!"
|
||||||
|
|
||||||
|
|
||||||
|
Binary file not shown.
Binary file not shown.
@@ -42,7 +42,7 @@ download_Url=$NODE_URL
|
|||||||
setup_path=/www
|
setup_path=/www
|
||||||
version=$(curl -Ss --connect-timeout 5 -m 2 $Btapi_Url/api/panel/get_version)
|
version=$(curl -Ss --connect-timeout 5 -m 2 $Btapi_Url/api/panel/get_version)
|
||||||
if [ "$version" = '' ];then
|
if [ "$version" = '' ];then
|
||||||
version='7.9.4'
|
version='7.9.5'
|
||||||
fi
|
fi
|
||||||
armCheck=$(uname -m|grep arm)
|
armCheck=$(uname -m|grep arm)
|
||||||
if [ "${armCheck}" ];then
|
if [ "${armCheck}" ];then
|
||||||
|
@@ -70,7 +70,7 @@ select_node(){
|
|||||||
get_version(){
|
get_version(){
|
||||||
version=$(curl -Ss --connect-timeout 5 -m 2 $Btapi_Url/api/panel/get_version)
|
version=$(curl -Ss --connect-timeout 5 -m 2 $Btapi_Url/api/panel/get_version)
|
||||||
if [ "$version" = '' ];then
|
if [ "$version" = '' ];then
|
||||||
version='7.9.4'
|
version='7.9.5'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Binary file not shown.
359
wiki/files/bt.js
359
wiki/files/bt.js
@@ -39,87 +39,231 @@ if("undefined" != typeof bt && bt.hasOwnProperty("prompt_confirm")){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if("undefined" != typeof database && database.hasOwnProperty("del_database")){
|
if("undefined" != typeof database && database.hasOwnProperty("del_database")){
|
||||||
database.del_database = function (wid, dbname,obj, callback) {
|
database.del_database = function (wid, dbname, obj, callback) {
|
||||||
var type = $('.database-pos .tabs-item.active').data('type')
|
var is_db_type = false, del_data = []
|
||||||
title = '',
|
if (typeof wid === 'object') {
|
||||||
tips = '是否确认【删除数据库】,'+ (type !== 'mysql'?'当前数据库暂不支持数据库回收站,删除后将无法恢复,请谨慎操作':',删除后可能会影响业务使用!');
|
del_data = wid
|
||||||
if(obj && obj.db_type > 0) tips = '远程数据库不支持数据库回收站,删除后将无法恢复,请谨慎操作';
|
is_db_type = wid.some(function (item) {
|
||||||
var title = typeof dbname === "function" ?'批量删除数据库':'删除数据库 [ '+ dbname +' ]';
|
return item.db_type > 0
|
||||||
layer.open({
|
})
|
||||||
type:1,
|
var ids = [];
|
||||||
title:title,
|
for (var i = 0; i < wid.length; i++) {
|
||||||
icon:0,
|
ids.push(wid[i].id);
|
||||||
skin:'delete_site_layer',
|
}
|
||||||
area: "530px",
|
wid = ids
|
||||||
closeBtn: 2,
|
}
|
||||||
shadeClose: true,
|
var type = $('.database-pos .tabs-item.active').data('type'),
|
||||||
content:"<div class=\'bt-form webDelete pd30\' id=\'site_delete_form\'>" +
|
title = '',
|
||||||
"<i class=\'layui-layer-ico layui-layer-ico0\'></i>" +
|
tips = '';
|
||||||
"<div class=\'f13 check_title\' style=\'margin-bottom: 20px;\'>"+tips+"</div>" +
|
title = typeof dbname === "function" ? '批量删除数据库' : '删除数据库 - [ ' + dbname + ' ]';
|
||||||
"<div style=\'color:red;margin:18px 0 18px 18px;font-size:14px;font-weight: bold;\'>注意:数据无价,请谨慎操作!!!"+(!recycle_bin_db_open?'<br>风险操作:当前数据库回收站未开启,删除数据库将永久消失!':'')+"</div>" +
|
tips = is_db_type || !recycle_bin_db_open || type !== 'mysql' ? '<span class="color-red">当前列表存在彻底删除后无法恢复的数据库</span>,请仔细查看列表,以防误删,是否继续操作?' : '当前列表数据库将迁移至数据库回收站,如需彻底删除请前往数据库回收站,是否继续操作?'
|
||||||
"</div>",
|
var arrs = wid instanceof Array ? wid : [wid]
|
||||||
btn:[lan.public.ok,lan.public.cancel],
|
var ids = JSON.stringify(arrs),
|
||||||
yes:function(indexs){
|
countDown = 9;
|
||||||
var data = {id: wid,name: dbname};
|
if (arrs.length == 1) countDown = 4
|
||||||
if(typeof dbname === "function"){
|
var loadT = bt.load('正在检测数据库数据信息,请稍候...'),
|
||||||
delete data.id;
|
param = { url: 'database/' + bt.data.db_tab_name + '/check_del_data', data: { data: JSON.stringify({ ids: ids }) } }
|
||||||
delete data.name;
|
if (bt.data.db_tab_name == 'mysql') param = { url: 'database?action=check_del_data', data: { ids: ids } }
|
||||||
}
|
bt_tools.send(param, function (res) {
|
||||||
layer.close(indexs)
|
loadT.close()
|
||||||
if(typeof dbname === "function"){
|
layer.open({
|
||||||
dbname(data)
|
type: 1,
|
||||||
}else{
|
title: title,
|
||||||
bt.database.del_database(data, function (rdata) {
|
area: '740px',
|
||||||
layer.closeAll()
|
skin: 'verify_site_layer_info',
|
||||||
if (callback) callback(rdata);
|
closeBtn: 2,
|
||||||
bt.msg(rdata);
|
shadeClose: true,
|
||||||
|
content: '<div class="check_delete_site_main hint_confirm pd30">' +
|
||||||
|
"<div class='hint_title'>\
|
||||||
|
<i class=\'hint-confirm-icon\'></i>\
|
||||||
|
<div class=\'hint_con\'>"+ tips + "</div>\
|
||||||
|
</div>"+
|
||||||
|
'<div id="check_layer_content" class="ptb15">' +
|
||||||
|
'</div>' +
|
||||||
|
'<div class="check_layer_message">' +
|
||||||
|
(is_db_type ? '<span class="color-red">注意:远程数据库暂不支持数据库回收站,选中的数据库将彻底删除</span><br>' : '') +
|
||||||
|
(!recycle_bin_db_open ? '<span class="color-red">风险操作:当前数据库回收站未开启,删除数据库将永久消失</span><br>' : '')
|
||||||
|
+ '<span class="color-red">请仔细阅读以上要删除信息,防止数据库被误删</span></div>' +
|
||||||
|
'</div>',
|
||||||
|
btn: ['下一步', lan.public.cancel],
|
||||||
|
success: function (layers) {
|
||||||
|
setTimeout(function () { $(layers).css('top', ($(window).height() - $(layers).height()) / 2); }, 50)
|
||||||
|
var rdata = res.data,
|
||||||
|
newTime = parseInt(new Date().getTime() / 1000),
|
||||||
|
t_icon = ' <span class="glyphicon glyphicon-info-sign" style="color: red;width:15px;height: 15px;;vertical-align: middle;"></span>';
|
||||||
|
for (var j = 0; j < rdata.length; j++) {
|
||||||
|
for (var i = 0; i < del_data.length; i++) {
|
||||||
|
if (rdata[j].id == del_data[i].id) {
|
||||||
|
var is_time_rule = (newTime - rdata[j].st_time) > (86400 * 30) && (rdata[j].total > 1024 * 10),
|
||||||
|
is_database_rule = res.db_size <= rdata[j].total,
|
||||||
|
database_time = bt.format_data(rdata[j].st_time, 'yyyy-MM-dd'),
|
||||||
|
database_size = bt.format_size(rdata[j].total);
|
||||||
|
var f_size = database_size
|
||||||
|
var t_size = '注意:此数据库较大,可能为重要数据,请谨慎操作.\n数据库:' + database_size;
|
||||||
|
if (rdata[j].total < 2048) t_size = '注意事项:当前数据库不为空,可能为重要数据,请谨慎操作.\n数据库:' + database_size;
|
||||||
|
if (rdata[j].total === 0) t_size = '';
|
||||||
|
rdata[j]['t_size'] = t_size
|
||||||
|
rdata[j]['f_size'] = f_size
|
||||||
|
rdata[j]['database_time'] = database_time
|
||||||
|
rdata[j]['is_time_rule'] = is_time_rule
|
||||||
|
rdata[j]['is_database_rule'] = is_database_rule
|
||||||
|
rdata[j]['db_type'] = del_data[i].db_type
|
||||||
|
rdata[j]['conn_config'] = del_data[i].conn_config
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var filterData = rdata.filter(function (el) {
|
||||||
|
return ids.indexOf(el.id) != -1
|
||||||
|
})
|
||||||
|
bt_tools.table({
|
||||||
|
el: '#check_layer_content',
|
||||||
|
data: filterData,
|
||||||
|
height: '300px',
|
||||||
|
column: [
|
||||||
|
{ fid: 'name', title: '数据库名称' },
|
||||||
|
{
|
||||||
|
title: '数据库大小', template: function (row) {
|
||||||
|
return '<span class="' + (row.is_database_rule ? 'warning' : '') + '" style="width: 110px;" title="' + row.t_size + '">' + row.f_size + (row.is_database_rule ? t_icon : '') + '</span>'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '数据库位置', template: function (row) {
|
||||||
|
var type_column = '-'
|
||||||
|
switch (row.db_type) {
|
||||||
|
case 0:
|
||||||
|
type_column = '本地数据库'
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
type_column = '远程数据库'
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return '<span style="width: 110px;" title="' + type_column + '">' + type_column + '</span>'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '创建时间', template: function (row) {
|
||||||
|
return '<span ' + (is_time_rule && row.total != 0 ? 'class="warning"' : '') + ' title="' + (row.is_time_rule && row.total != 0 ? '重要:此数据库创建时间较早,可能为重要数据,请谨慎操作.' : '') + '时间:' + row.database_time + '">' + row.database_time + '</span>'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '删除结果', align: 'right', template: function (row, index, ev, _that) {
|
||||||
|
var _html = ''
|
||||||
|
switch (row.db_type) {
|
||||||
|
case 0:
|
||||||
|
_html = type !== 'mysql' ? '彻底删除' : (!recycle_bin_db_open ? '彻底删除' : '移至回收站')
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
_html = '彻底删除'
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return '<span style="width: 110px;" class="' + (_html === '彻底删除' ? 'warning' + (row.db_type > 0 ? ' remote_database' : '') : '') + '">' + _html + '</span>'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
success: function () {
|
||||||
|
if ($('.remote_database').length) {
|
||||||
|
$('.remote_database').each(function (index, el) {
|
||||||
|
var id = $(el).parent().parent().parent().index()
|
||||||
|
$('#check_layer_content tbody tr').eq(id).css('background-color', '#ff00000a')
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
yes: function (indes, layers) {
|
||||||
|
title = typeof dbname === "function" ? '二次验证信息,批量删除数据库' : '二次验证信息,删除数据库 - [ ' + dbname + ' ]';
|
||||||
|
if (type !== 'mysql') {
|
||||||
|
tips = '<span class="color-red">当前数据库暂不支持数据库回收站,删除后将无法恢复</span>,此操作不可逆,是否继续操作?';
|
||||||
|
} else {
|
||||||
|
tips = is_db_type ? '<span class="color-red">远程数据库不支持数据库回收站,删除后将无法恢复</span>,此操作不可逆,是否继续操作?' : recycle_bin_db_open ? '删除后如需彻底删除请前往数据库回收站,是否继续操作?' : '删除后可能会影响业务使用,此操作不可逆,是否继续操作?'
|
||||||
|
}
|
||||||
|
layer.open({
|
||||||
|
type: 1,
|
||||||
|
title: title,
|
||||||
|
icon: 0,
|
||||||
|
skin: 'delete_site_layer',
|
||||||
|
area: "530px",
|
||||||
|
closeBtn: 2,
|
||||||
|
shadeClose: true,
|
||||||
|
content: "<div class=\'bt-form webDelete hint_confirm pd30\' id=\'site_delete_form\'>" +
|
||||||
|
"<div class='hint_title'>\
|
||||||
|
<i class=\'hint-confirm-icon\'></i>\
|
||||||
|
<div class=\'hint_con\'>"+ tips + "</div>\
|
||||||
|
</div>"+
|
||||||
|
"<div style=\'color:red;margin:18px 0 18px 18px;font-size:14px;font-weight: bold;\'>注意:数据无价,请谨慎操作!!!" + (type === 'mysql' && !recycle_bin_db_open ? '<br>风险操作:当前数据库回收站未开启,删除数据库将永久消失!' : '') + "</div>"+
|
||||||
|
"</div>",
|
||||||
|
btn: ['确认删除', '取消删除'],
|
||||||
|
yes: function (indexs) {
|
||||||
|
var data = {
|
||||||
|
id: wid,
|
||||||
|
name: dbname
|
||||||
|
};
|
||||||
|
if (typeof dbname === "function") {
|
||||||
|
delete data.id;
|
||||||
|
delete data.name;
|
||||||
|
}
|
||||||
|
layer.close(indexs)
|
||||||
|
layer.close(indes)
|
||||||
|
if (typeof dbname === "function") {
|
||||||
|
dbname(data)
|
||||||
|
} else {
|
||||||
|
data.id = data.id[0]
|
||||||
|
bt.database.del_database(data, function (rdata) {
|
||||||
|
layer.closeAll()
|
||||||
|
if (callback) callback(rdata);
|
||||||
|
bt.msg(rdata);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if("undefined" != typeof site && site.hasOwnProperty("del_site")){
|
if("undefined" != typeof site && site.hasOwnProperty("del_site")){
|
||||||
site.del_site = function(wid, wname, callback) {
|
site.del_site = function (wid, wname, callback) {
|
||||||
var title = typeof wname === "function" ?'批量删除站点':'删除站点 [ '+ wname +' ]';
|
title = typeof wname === "function" ? '批量删除站点' : '删除站点 [ ' + wname + ' ]';
|
||||||
layer.open({
|
layer.open({
|
||||||
type:1,
|
type: 1,
|
||||||
title:title,
|
title: title,
|
||||||
icon:0,
|
icon: 0,
|
||||||
skin:'delete_site_layer',
|
skin: 'delete_site_layer',
|
||||||
area: "440px",
|
area: "440px",
|
||||||
closeBtn: 2,
|
closeBtn: 2,
|
||||||
shadeClose: true,
|
shadeClose: true,
|
||||||
content:"<div class=\'bt-form webDelete pd30\' id=\'site_delete_form\'>" +
|
content: "<div class=\'bt-form webDelete pd30\' id=\'site_delete_form\'>" +
|
||||||
'<i class="layui-layer-ico layui-layer-ico0"></i>' +
|
'<i class="layui-layer-ico layui-layer-ico0"></i>' +
|
||||||
"<div class=\'f13 check_title\'>是否要删除关联的FTP、数据库、站点目录!</div>" +
|
"<div class=\'f13 check_title\'>是否要删除关联的FTP、数据库、站点目录!</div>" +
|
||||||
"<div class=\"check_type_group\">" +
|
"<div class=\"check_type_group\">" +
|
||||||
"<label><input type=\"checkbox\" name=\"ftp\"><span>FTP</span></label>" +
|
"<label><input type=\"checkbox\" name=\"ftp\"><span>FTP</span></label>" +
|
||||||
"<label><input type=\"checkbox\" name=\"database\"><span>数据库</span>"+ (!recycle_bin_db_open?'<span class="glyphicon glyphicon-info-sign" style="color: red"></span>':'') +"</label>" +
|
"<label><input type=\"checkbox\" name=\"database\"><span>数据库</span>" + (!recycle_bin_db_open ? '<span class="glyphicon glyphicon-info-sign" style="color: red"></span>' : '') + "</label>" +
|
||||||
"<label><input type=\"checkbox\" name=\"path\"><span>站点目录</span>"+ (!recycle_bin_open?'<span class="glyphicon glyphicon-info-sign" style="color: red"></span>':'') +"</label>" +
|
"<label><input type=\"checkbox\" name=\"path\"><span>站点目录</span>" + (!recycle_bin_open ? '<span class="glyphicon glyphicon-info-sign" style="color: red"></span>' : '') + "</label>" +
|
||||||
"</div>"+
|
"</div>" +
|
||||||
"</div>",
|
"</div>",
|
||||||
btn:[lan.public.ok,lan.public.cancel],
|
btn: [lan.public.ok, lan.public.cancel],
|
||||||
success:function(layers,indexs){
|
success: function (layers, indexs) {
|
||||||
$(layers).find('.check_type_group label').hover(function(){
|
$(layers).find('.check_type_group label').hover(function () {
|
||||||
var name = $(this).find('input').attr('name');
|
var name = $(this).find('input').attr('name');
|
||||||
if(name === 'data' && !recycle_bin_db_open){
|
if (name === 'database' && !recycle_bin_db_open) {
|
||||||
layer.tips('风险操作:当前数据库回收站未开启,删除数据库将永久消失!', this, {tips: [1, 'red'],time:0})
|
layer.tips('风险操作:当前数据库回收站未开启,删除数据库将永久消失!', this, { tips: [1, 'red'], time: 0 })
|
||||||
}else if(name === 'path' && !recycle_bin_open){
|
} else if (name === 'path' && !recycle_bin_open) {
|
||||||
layer.tips('风险操作:当前文件回收站未开启,删除站点目录将永久消失!', this, {tips: [1, 'red'],time:0})
|
layer.tips('风险操作:当前文件回收站未开启,删除站点目录将永久消失!', this, { tips: [1, 'red'], time: 0 })
|
||||||
}
|
}
|
||||||
},function(){
|
}, function () {
|
||||||
layer.closeAll('tips');
|
layer.closeAll('tips');
|
||||||
})
|
});
|
||||||
},
|
},
|
||||||
yes:function(indexs){
|
yes: function (indexs) {
|
||||||
var data = {id: wid,webname: wname};
|
var data = { id: wid, webname: wname };
|
||||||
$('#site_delete_form input[type=checkbox]').each(function (index, item) {
|
$('#site_delete_form input[type=checkbox]').each(function (index, item) {
|
||||||
if($(item).is(':checked')) data[$(item).attr('name')] = 1
|
if ($(item).is(':checked')) data[$(item).attr('name')] = 1
|
||||||
})
|
})
|
||||||
var is_database = data.hasOwnProperty('database'),is_path = data.hasOwnProperty('path'),is_ftp = data.hasOwnProperty('ftp');
|
var is_database = data.hasOwnProperty('database'), is_path = data.hasOwnProperty('path'), is_ftp = data.hasOwnProperty('ftp');
|
||||||
if((!is_database && !is_path) && (!is_ftp || is_ftp)){
|
if ((!is_database && !is_path) && (!is_ftp || is_ftp)) {
|
||||||
if(typeof wname === "function"){
|
if (typeof wname === "function") {
|
||||||
wname(data)
|
wname(data)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -130,22 +274,95 @@ if("undefined" != typeof site && site.hasOwnProperty("del_site")){
|
|||||||
})
|
})
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
if(typeof wname === "function"){
|
if (typeof wname === "function") {
|
||||||
delete data.id;
|
delete data.id;
|
||||||
delete data.webname;
|
delete data.webname;
|
||||||
}
|
}
|
||||||
layer.close(indexs)
|
layer.close(indexs)
|
||||||
if(typeof wname === "function"){
|
var ids = JSON.stringify(wid instanceof Array ? wid : [wid]), countDown = typeof wname === 'string' ? 4 : 9;
|
||||||
console.log(data)
|
title = typeof wname === "function" ? '二次验证信息,批量删除站点' : '二次验证信息,删除站点 [ ' + wname + ' ]';
|
||||||
wname(data)
|
var loadT = bt.load('正在检测站点数据信息,请稍候...')
|
||||||
}else{
|
bt.send('check_del_data', 'site/check_del_data', { ids: ids }, function (res) {
|
||||||
bt.site.del_site(data, function (rdata) {
|
loadT.close()
|
||||||
layer.closeAll()
|
layer.open({
|
||||||
if (rdata.status) site.get_list();
|
type: 1,
|
||||||
if (callback) callback(rdata);
|
title: title,
|
||||||
bt.msg(rdata);
|
closeBtn: 2,
|
||||||
|
skin: 'verify_site_layer_info',
|
||||||
|
area: '740px',
|
||||||
|
content: '<div class="check_delete_site_main pd30">' +
|
||||||
|
'<i class="layui-layer-ico layui-layer-ico0"></i>' +
|
||||||
|
'<div class="check_layer_title">堡塔温馨提示您,请冷静几秒钟,确认以下要删除的数据。</div>' +
|
||||||
|
'<div class="check_layer_content">' +
|
||||||
|
'<div class="check_layer_item">' +
|
||||||
|
'<div class="check_layer_site"></div>' +
|
||||||
|
'<div class="check_layer_database"></div>' +
|
||||||
|
'</div>' +
|
||||||
|
'</div>' +
|
||||||
|
'<div class="check_layer_error ' + (is_database && data['database'] && !recycle_bin_db_open ? '' : 'hide') + '"><span class="glyphicon glyphicon-info-sign"></span>风险事项:当前未开启数据库回收站功能,删除数据库后,数据库将永久消失!</div>' +
|
||||||
|
'<div class="check_layer_error ' + (is_path && data['path'] && !recycle_bin_open ? '' : 'hide') + '"><span class="glyphicon glyphicon-info-sign"></span>风险事项:当前未开启文件回收站功能,删除站点目录后,站点目录将永久消失!</div>' +
|
||||||
|
'<div class="check_layer_message"><span style="color:red">注意:请仔细阅读以上要删除信息,防止网站数据被误删</span></div>' +
|
||||||
|
'</div>',
|
||||||
|
// recycle_bin_db_open &&
|
||||||
|
// recycle_bin_open &&
|
||||||
|
btn: ['确认删除', '取消删除'],
|
||||||
|
success: function (layers) {
|
||||||
|
var html = '', rdata = res.data;
|
||||||
|
for (var i = 0; i < rdata.length; i++) {
|
||||||
|
var item = rdata[i], newTime = parseInt(new Date().getTime() / 1000),
|
||||||
|
t_icon = '<span class="glyphicon glyphicon-info-sign" style="color: red;width:15px;height: 15px;;vertical-align: middle;"></span>';
|
||||||
|
|
||||||
|
site_html = (function (item) {
|
||||||
|
if (!is_path) return ''
|
||||||
|
var is_time_rule = (newTime - item.st_time) > (86400 * 30) && (item.total > 1024 * 10),
|
||||||
|
is_path_rule = res.file_size <= item.total,
|
||||||
|
dir_time = bt.format_data(item.st_time, 'yyyy-MM-dd'),
|
||||||
|
dir_size = bt.format_size(item.total);
|
||||||
|
|
||||||
|
var f_html = '<i ' + (is_path_rule ? 'class="warning"' : '') + ' style = "vertical-align: middle;" > ' + (item.limit ? '大于50MB' : dir_size) + '</i> ' + (is_path_rule ? t_icon : '');
|
||||||
|
var f_title = (is_path_rule ? '注意:此目录较大,可能为重要数据,请谨慎操作.\n' : '') + '目录:' + item.path + '(' + (item.limit ? '大于' : '') + dir_size + ')';
|
||||||
|
|
||||||
|
return '<div class="check_layer_site">' +
|
||||||
|
'<span title="站点:' + item.name + '">站点名:' + item.name + '</span>' +
|
||||||
|
'<span title="' + f_title + '" >目录:<span style="vertical-align: middle;max-width: 160px;width: auto;">' + item.path + '</span> (' + f_html + ')</span>' +
|
||||||
|
'<span title="' + (is_time_rule ? '注意:此站点创建时间较早,可能为重要数据,请谨慎操作.\n' : '') + '时间:' + dir_time + '">创建时间:<i ' + (is_time_rule ? 'class="warning"' : '') + '>' + dir_time + '</i></span>' +
|
||||||
|
'</div>'
|
||||||
|
}(item)),
|
||||||
|
database_html = (function (item) {
|
||||||
|
if (!is_database || !item.database) return '';
|
||||||
|
var is_time_rule = (newTime - item.st_time) > (86400 * 30) && (item.total > 1024 * 10),
|
||||||
|
is_database_rule = res.db_size <= item.database.total,
|
||||||
|
database_time = bt.format_data(item.database.st_time, 'yyyy-MM-dd'),
|
||||||
|
database_size = bt.format_size(item.database.total);
|
||||||
|
|
||||||
|
var f_size = '<i ' + (is_database_rule ? 'class="warning"' : '') + ' style = "vertical-align: middle;" > ' + database_size + '</i> ' + (is_database_rule ? t_icon : '');
|
||||||
|
var t_size = '注意:此数据库较大,可能为重要数据,请谨慎操作.\n数据库:' + database_size;
|
||||||
|
|
||||||
|
return '<div class="check_layer_database">' +
|
||||||
|
'<span title="数据库:' + item.database.name + '">数据库:' + item.database.name + '</span>' +
|
||||||
|
'<span title="' + t_size + '">大小:' + f_size + '</span>' +
|
||||||
|
'<span title="' + (is_time_rule && item.database.total != 0 ? '重要:此数据库创建时间较早,可能为重要数据,请谨慎操作.' : '') + '时间:' + database_time + '">创建时间:<i ' + (is_time_rule && item.database.total != 0 ? 'class="warning"' : '') + '>' + database_time + '</i></span>' +
|
||||||
|
'</div>'
|
||||||
|
}(item))
|
||||||
|
if ((site_html + database_html) !== '') html += '<div class="check_layer_item">' + site_html + database_html + '</div>';
|
||||||
|
}
|
||||||
|
if (html === '') html = '<div style="text-align: center;width: 100%;height: 100%;line-height: 300px;font-size: 15px;">无数据</div>'
|
||||||
|
$('.check_layer_content').html(html)
|
||||||
|
},
|
||||||
|
yes: function (indes, layers) {
|
||||||
|
if (typeof wname === "function") {
|
||||||
|
wname(data)
|
||||||
|
} else {
|
||||||
|
bt.site.del_site(data, function (rdata) {
|
||||||
|
layer.closeAll()
|
||||||
|
if (rdata.status) site.get_list();
|
||||||
|
if (callback) callback(rdata);
|
||||||
|
bt.msg(rdata);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
122
wiki/files/win/PluginLoader.py
Normal file
122
wiki/files/win/PluginLoader.py
Normal file
@@ -0,0 +1,122 @@
|
|||||||
|
#coding: utf-8
|
||||||
|
import public,os,sys,json
|
||||||
|
|
||||||
|
#获取插件列表(0/1)
|
||||||
|
def get_plugin_list(force = 0):
|
||||||
|
api_root_url = 'https://api.bt.cn'
|
||||||
|
api_url = api_root_url+ '/wpanel/get_plugin_list'
|
||||||
|
cache_file = 'data/plugin_list.json'
|
||||||
|
|
||||||
|
if force==0 and os.path.exists(cache_file):
|
||||||
|
jsonData = public.readFile(cache_file)
|
||||||
|
softList = json.loads(jsonData)
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
jsonData = public.HttpGet(api_url)
|
||||||
|
except Exception as ex:
|
||||||
|
raise public.error_conn_cloud(str(ex))
|
||||||
|
softList = json.loads(jsonData)
|
||||||
|
if type(softList)!=dict or 'list' not in softList: raise Exception('云端插件列表获取失败')
|
||||||
|
public.writeFile(cache_file, jsonData)
|
||||||
|
return softList
|
||||||
|
|
||||||
|
#获取授权状态() 返回:0.免费版 1.专业版 2.企业版 -1.获取失败
|
||||||
|
def get_auth_state():
|
||||||
|
try:
|
||||||
|
softList = get_plugin_list()
|
||||||
|
if softList['ltd'] > -1:
|
||||||
|
return 2
|
||||||
|
elif softList['pro'] > -1:
|
||||||
|
return 1
|
||||||
|
else:
|
||||||
|
return 0
|
||||||
|
except:
|
||||||
|
return -1
|
||||||
|
|
||||||
|
#执行插件方法(插件名,方法名,参数)
|
||||||
|
def plugin_run(plugin_name, def_name, args):
|
||||||
|
if not plugin_name or not def_name: return public.returnMsg(False,'插件名称和插件方法名称不能为空!')
|
||||||
|
if not path_check(plugin_name) or not path_check(def_name): return public.returnMsg(False,'插件名或方法名不能包含特殊符号!')
|
||||||
|
p_path = public.get_plugin_path(plugin_name)
|
||||||
|
if not os.path.exists(p_path + '/index.php') and not os.path.exists(p_path + '/%s_main.py' % plugin_name): return public.returnMsg(False,'插件不存在!')
|
||||||
|
|
||||||
|
is_php = os.path.exists(p_path + '/index.php')
|
||||||
|
if not is_php:
|
||||||
|
sys.path.append(p_path)
|
||||||
|
plugin_main = __import__(plugin_name + '_main')
|
||||||
|
try:
|
||||||
|
if sys.version_info[0] == 2:
|
||||||
|
reload(plugin_main)
|
||||||
|
else:
|
||||||
|
from imp import reload
|
||||||
|
reload(plugin_main)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
plu = eval('plugin_main.' + plugin_name + '_main()')
|
||||||
|
if not hasattr(plu, def_name):
|
||||||
|
return public.returnMsg(False,'在[%s]插件中找不到[%s]方法' % (plugin_name,def_name))
|
||||||
|
|
||||||
|
if 'plugin_get_object' in args and args.plugin_get_object == 1:
|
||||||
|
if not is_php:
|
||||||
|
return getattr(plu, def_name)
|
||||||
|
else:
|
||||||
|
return None
|
||||||
|
else:
|
||||||
|
if not is_php:
|
||||||
|
data = eval('plu.' + def_name + '(args)')
|
||||||
|
else:
|
||||||
|
import panelPHP
|
||||||
|
args.s = def_name
|
||||||
|
args.name = plugin_name
|
||||||
|
data = panelPHP.panelPHP(plugin_name).exec_php_script(args)
|
||||||
|
return data
|
||||||
|
|
||||||
|
#执行模块方法(模块名,方法名,参数)
|
||||||
|
def module_run(mod_name, def_name, args):
|
||||||
|
if not mod_name or not def_name: return public.returnMsg(False,'模块名称和模块方法名称不能为空!')
|
||||||
|
if not path_check(mod_name) or not path_check(def_name): return public.returnMsg(False,'模块名或方法名不能包含特殊符号!')
|
||||||
|
|
||||||
|
if 'model_index' in args:
|
||||||
|
if args.model_index:
|
||||||
|
mod_file = "{}/{}Model/{}Model.py".format(public.get_class_path(),args.model_index,mod_name)
|
||||||
|
else:
|
||||||
|
mod_file = "{}/projectModel/{}Model.py".format(public.get_class_path(),mod_name)
|
||||||
|
else:
|
||||||
|
module_list = get_module_list()
|
||||||
|
for module_dir in module_list:
|
||||||
|
mod_file = "{}/{}/{}Model.py".format(public.get_class_path(),module_dir,mod_name)
|
||||||
|
if os.path.exists(mod_file): break
|
||||||
|
|
||||||
|
if not os.path.exists(mod_file):
|
||||||
|
return public.returnMsg(False,'模块[%s]不存在' % mod_name)
|
||||||
|
|
||||||
|
def_object = public.get_script_object(mod_file)
|
||||||
|
if not def_object: return public.returnMsg(False,'模块[%s]不存在!' % mod_name)
|
||||||
|
try:
|
||||||
|
run_object = getattr(def_object.main(),def_name,None)
|
||||||
|
except:
|
||||||
|
return public.returnMsg(False,'模块入口实例化失败' % mod_name)
|
||||||
|
if not run_object: return public.returnMsg(False,'在[%s]模块中找不到[%s]方法' % (mod_name,def_name))
|
||||||
|
if 'module_get_object' in args and args.module_get_object == 1:
|
||||||
|
return run_object
|
||||||
|
result = run_object(args)
|
||||||
|
return result
|
||||||
|
|
||||||
|
#获取模块文件夹列表
|
||||||
|
def get_module_list():
|
||||||
|
list = []
|
||||||
|
class_path = public.get_class_path()
|
||||||
|
f_list = os.listdir(class_path)
|
||||||
|
for fname in f_list:
|
||||||
|
f_path = class_path+'/'+fname
|
||||||
|
if os.path.isdir(f_path) and len(fname) > 6 and fname.find('.') == -1 and fname.find('Model') != -1:
|
||||||
|
list.append(fname)
|
||||||
|
return list
|
||||||
|
|
||||||
|
#检查路径是否合法
|
||||||
|
def path_check(path):
|
||||||
|
list = ["./","..",",",";",":","?","'","\"","<",">","|","\\","\n","\r","\t","\b","\a","\f","\v","*","%","&","$","#","@","!","~","`","^","(",")","+","=","{","}","[","]"]
|
||||||
|
for i in path:
|
||||||
|
if i in list:
|
||||||
|
return False
|
||||||
|
return True
|
@@ -1,60 +0,0 @@
|
|||||||
#coding: utf-8
|
|
||||||
import public,os,sys,json
|
|
||||||
|
|
||||||
class Plugin:
|
|
||||||
name = False
|
|
||||||
p_path = None
|
|
||||||
is_php = False
|
|
||||||
plu = None
|
|
||||||
__api_root_url = 'https://api.bt.cn'
|
|
||||||
__api_url = __api_root_url+ '/wpanel/get_plugin_list'
|
|
||||||
__cache_file = 'data/plugin_list.json'
|
|
||||||
|
|
||||||
def __init__(self, name):
|
|
||||||
self.name = name
|
|
||||||
self.p_path = public.get_plugin_path(name)
|
|
||||||
self.is_php = os.path.exists(self.p_path + '/index.php')
|
|
||||||
|
|
||||||
def get_plugin_list(self, force = False):
|
|
||||||
if force==False and os.path.exists(self.__cache_file):
|
|
||||||
jsonData = public.readFile(self.__cache_file)
|
|
||||||
softList = json.loads(jsonData)
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
jsonData = public.HttpGet(self.__api_url)
|
|
||||||
except Exception as ex:
|
|
||||||
raise public.error_conn_cloud(str(ex))
|
|
||||||
softList = json.loads(jsonData)
|
|
||||||
if type(softList)!=dict or 'list' not in softList: raise Exception('云端插件列表获取失败')
|
|
||||||
public.writeFile(self.__cache_file, jsonData)
|
|
||||||
|
|
||||||
return softList
|
|
||||||
|
|
||||||
def isdef(self, fun):
|
|
||||||
if not self.is_php:
|
|
||||||
sys.path.append(self.p_path)
|
|
||||||
plugin_main = __import__(self.name + '_main')
|
|
||||||
try:
|
|
||||||
from imp import reload
|
|
||||||
reload(plugin_main)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
self.plu = eval('plugin_main.' + self.name + '_main()')
|
|
||||||
if not hasattr(self.plu, fun):
|
|
||||||
if self.name == 'btwaf' and fun == 'index':
|
|
||||||
raise Exception("未购买")
|
|
||||||
return False
|
|
||||||
return True
|
|
||||||
|
|
||||||
def exec_fun(self, args):
|
|
||||||
fun = args.s
|
|
||||||
if not self.is_php:
|
|
||||||
plu = self.plu
|
|
||||||
data = eval('plu.' + fun + '(args)')
|
|
||||||
else:
|
|
||||||
import panelPHP
|
|
||||||
args.s = fun
|
|
||||||
args.name = self.name
|
|
||||||
data = panelPHP.panelPHP(self.name).exec_php_script(args)
|
|
||||||
return data
|
|
||||||
|
|
@@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
- 全局搜索替换 https://api.bt.cn => http://www.example.com
|
- 全局搜索替换 https://api.bt.cn => http://www.example.com
|
||||||
|
|
||||||
- 全局搜索替换 https://www.bt.cn/api/ => http://www.example.com/api/(需排除clearModel.py、ipsModel.py)
|
- 全局搜索替换 https://www.bt.cn/api/ => http://www.example.com/api/(需排除clearModel.py、scanningModel.py、ipsModel.py)
|
||||||
|
|
||||||
- 全局搜索替换 http://download.bt.cn/install/update6.sh => http://www.example.com/install/update6.sh
|
- 全局搜索替换 http://download.bt.cn/install/update6.sh => http://www.example.com/install/update6.sh
|
||||||
|
|
||||||
@@ -40,6 +40,8 @@
|
|||||||
|
|
||||||
在 def check_domain_cloud(domain): 这一行下面加上 return
|
在 def check_domain_cloud(domain): 这一行下面加上 return
|
||||||
|
|
||||||
|
在 def get_improvement(): 这一行下面加上 return False
|
||||||
|
|
||||||
- class/panelPlugin.py 文件,download_icon方法内替换 public.GetConfigValue('home') => 'https://www.bt.cn'
|
- class/panelPlugin.py 文件,download_icon方法内替换 public.GetConfigValue('home') => 'https://www.bt.cn'
|
||||||
|
|
||||||
- class/panelPlugin.py 文件,删除public.total_keyword(get.query)这一行
|
- class/panelPlugin.py 文件,删除public.total_keyword(get.query)这一行
|
||||||
@@ -67,12 +69,16 @@
|
|||||||
|
|
||||||
"check_panel_msg": check_panel_msg,
|
"check_panel_msg": check_panel_msg,
|
||||||
|
|
||||||
|
PluginLoader.daemon_panel()
|
||||||
|
|
||||||
|
- 去除WebRTC连接:BTPanel/static/js/public.js 删除stun.start();这一行
|
||||||
|
|
||||||
- 去除首页广告:BTPanel/static/js/index.js 文件删除最下面index.recommend_paid_version()这一行
|
- 去除首页广告:BTPanel/static/js/index.js 文件删除最下面index.recommend_paid_version()这一行
|
||||||
|
|
||||||
- 去除内页广告:BTPanel/templates/default/layout.html 删除getPaymentStatus();这一行
|
|
||||||
|
|
||||||
- 去除首页自动检测更新,避免频繁请求云端:BTPanel/static/js/index.js 文件注释掉bt.system.check_update这一段代码外的setTimeout
|
- 去除首页自动检测更新,避免频繁请求云端:BTPanel/static/js/index.js 文件注释掉bt.system.check_update这一段代码外的setTimeout
|
||||||
|
|
||||||
|
- 去除内页广告:BTPanel/templates/default/layout.html 删除getPaymentStatus();这一行
|
||||||
|
|
||||||
- [可选]去除各种计算题:复制bt.js到 BTPanel/static/ ,在 BTPanel/templates/default/layout.html 的\</body\>前面加入
|
- [可选]去除各种计算题:复制bt.js到 BTPanel/static/ ,在 BTPanel/templates/default/layout.html 的\</body\>前面加入
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
|
@@ -8,11 +8,11 @@
|
|||||||
|
|
||||||
Windows版宝塔由于加密文件太多,无法全部解密,因此无法做到全开源。
|
Windows版宝塔由于加密文件太多,无法全部解密,因此无法做到全开源。
|
||||||
|
|
||||||
- 删除pluginAuth.cp38-win_amd64.pyd,将win/pluginAuth.py复制到class文件夹
|
- 删除PluginLoader.pyd,将win/PluginLoader.py复制到class文件夹
|
||||||
|
|
||||||
- 全局搜索替换 https://api.bt.cn => http://www.example.com
|
- 全局搜索替换 https://api.bt.cn => http://www.example.com
|
||||||
|
|
||||||
- 全局搜索替换 https://www.bt.cn/api/ => http://www.example.com/api/
|
- 全局搜索替换 https://www.bt.cn/api/ => http://www.example.com/api/(需排除ipsModel.py)
|
||||||
|
|
||||||
- 全局搜索替换 http://www.bt.cn/api/ => http://www.example.com/api/
|
- 全局搜索替换 http://www.bt.cn/api/ => http://www.example.com/api/
|
||||||
|
|
||||||
@@ -50,7 +50,7 @@ Windows版宝塔由于加密文件太多,无法全部解密,因此无法做
|
|||||||
|
|
||||||
- 去除面板日志上报:script/site_task.py 文件
|
- 去除面板日志上报:script/site_task.py 文件
|
||||||
|
|
||||||
删除最下面 logs_analysis() 这1行
|
- 删除最下面 logs_analysis() 这1行
|
||||||
|
|
||||||
- 去除首页广告:BTPanel/static/js/index.js 文件删除最下面index.recommend_paid_version()这一行
|
- 去除首页广告:BTPanel/static/js/index.js 文件删除最下面index.recommend_paid_version()这一行
|
||||||
|
|
||||||
@@ -72,5 +72,5 @@ Windows版宝塔由于加密文件太多,无法全部解密,因此无法做
|
|||||||
|
|
||||||
删除 if not os.path.exists(self.sitePath + '/.htaccess') 这一行
|
删除 if not os.path.exists(self.sitePath + '/.htaccess') 这一行
|
||||||
|
|
||||||
|
- [可选]关闭自动生成访问日志:在 BTPanel/\_\_init\_\_.py 删除public.write_request_log()这一行
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user