You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

321 lines
14 KiB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. {extend name="admin/layout" /}
  2. {block name="title"}系统设置{/block}
  3. {block name="main"}
  4. <div class="container" style="padding-top:70px;">
  5. {if $mod=='sys'}
  6. <div class="col-sm-12 col-md-6 center-block">
  7. <div class="panel panel-primary">
  8. <div class="panel-heading"><h3 class="panel-title">系统基本设置</h3></div>
  9. <div class="panel-body">
  10. <form onsubmit="return saveSetting(this)" method="post" class="form" role="form">
  11. <div class="form-group">
  12. <label>是否开启白名单模式:</label><br/>
  13. <select class="form-control" name="whitelist" default="{:config_get('whitelist')}"><option value="0">关闭</option><option value="1">开启</option></select>
  14. <font color="green">开启白名单模式后,只有在<a href="/admin/list/type/white" target="_blank">白名单列表</a>中的服务器IP才能使用此云端</font>
  15. </div>
  16. <div class="form-group">
  17. <label>安装脚本展示页面开关:</label>
  18. <select class="form-control" name="download_page" default="{:config_get('download_page')}"><option value="0">关闭</option><option value="1">开启</option></select>
  19. <font color="green">页面地址:<a href="/download" target="_blank">/download</a>,开启后可以公开访问,否则只能管理员访问</font>
  20. </div>
  21. <div class="form-group">
  22. <label>宝塔Linux面板最新版本号:</label>
  23. <input type="text" name="new_version" value="{:config_get('new_version')}" class="form-control"/>
  24. <font color="green">用于一键更新脚本获取最新版本号,以及检测更新接口。并确保已在/public/install/update/放置对应版本更新包</font>
  25. </div>
  26. <div class="form-group">
  27. <label>宝塔Linux面板更新日志:</label>
  28. <textarea class="form-control" name="update_msg" rows="5" placeholder="支持HTML代码">{:config_get('update_msg')}</textarea>
  29. <font color="green">用于检测更新接口返回</font>
  30. </div>
  31. <div class="form-group">
  32. <label>宝塔Linux面板更新日期:</label>
  33. <input type="date" name="update_date" value="{:config_get('update_date')}" class="form-control"/>
  34. <font color="green">用于检测更新接口返回</font>
  35. </div>
  36. <div class="form-group">
  37. <label>宝塔Windows面板最新版本号:</label>
  38. <input type="text" name="new_version_win" value="{:config_get('new_version_win')}" class="form-control"/>
  39. <font color="green">用于一键更新脚本获取最新版本号,以及检测更新接口。并确保已在/public/win/panel/放置对应版本更新包</font>
  40. </div>
  41. <div class="form-group">
  42. <label>宝塔Windows面板更新日志:</label>
  43. <textarea class="form-control" name="update_msg_win" rows="5" placeholder="支持HTML代码">{:config_get('update_msg_win')}</textarea>
  44. <font color="green">用于检测更新接口返回</font>
  45. </div>
  46. <div class="form-group">
  47. <label>宝塔Windows面板更新日期:</label>
  48. <input type="date" name="update_date_win" value="{:config_get('update_date_win')}" class="form-control"/>
  49. <font color="green">用于检测更新接口返回</font>
  50. </div>
  51. <div class="form-group text-center">
  52. <input type="submit" name="submit" value="保存" class="btn btn-success btn-block"/>
  53. </div>
  54. </form>
  55. </div>
  56. </div>
  57. </div>
  58. <div class="col-sm-12 col-md-6 center-block">
  59. <div class="panel panel-primary">
  60. <div class="panel-heading"><h3 class="panel-title">宝塔Linux面板接口设置</h3></div>
  61. <div class="panel-body">
  62. <form onsubmit="return saveSetting(this)" method="post" class="form" role="form">
  63. <p>以下宝塔面板请使用官方最新脚本安装并绑定账号,用于获取最新插件列表及插件包</p>
  64. <p><a href="/static/file/kaixin.zip">下载专用插件(Linux)</a>,在面板【软件商店】->【第三方应用】,点击【导入插件】,导入该专用插件。</p>
  65. <div class="form-group">
  66. <label>宝塔面板URL:</label><br/>
  67. <input type="text" name="bt_url" value="{:config_get('bt_url')}" class="form-control"/>
  68. <font color="green">填写规则如:<u>http://192.168.1.1:8888</u> ,不要带其他后缀</font>
  69. </div>
  70. <div class="form-group">
  71. <label>宝塔面板接口密钥:</label>
  72. <input type="text" name="bt_key" value="{:config_get('bt_key')}" class="form-control"/>
  73. </div>
  74. <div class="form-group text-center">
  75. <button type="button" class="btn btn-info btn-block" id="testbturl">测试连接</button>
  76. <input type="submit" name="submit" value="保存" class="btn btn-success btn-block"/>
  77. </div>
  78. </form>
  79. </div>
  80. </div>
  81. <div class="panel panel-primary">
  82. <div class="panel-heading"><h3 class="panel-title">宝塔Windows面板接口设置</h3></div>
  83. <div class="panel-body">
  84. <form onsubmit="return saveSetting(this)" method="post" class="form" role="form">
  85. <p>以下宝塔面板请使用官方最新脚本安装并绑定账号,用于获取最新插件列表及插件包</p>
  86. <p><a href="/static/file/win/kaixin.zip">下载专用插件(Win)</a>,在面板【软件商店】->【第三方应用】,点击【导入插件】,导入该专用插件。</p>
  87. <div class="form-group">
  88. <label>宝塔面板URL:</label><br/>
  89. <input type="text" name="wbt_url" value="{:config_get('wbt_url')}" class="form-control"/>
  90. <font color="green">填写规则如:<u>http://192.168.1.1:8888</u> ,不要带其他后缀</font>
  91. </div>
  92. <div class="form-group">
  93. <label>宝塔面板接口密钥:</label>
  94. <input type="text" name="wbt_key" value="{:config_get('wbt_key')}" class="form-control"/>
  95. </div>
  96. <div class="form-group text-center">
  97. <button type="button" class="btn btn-info btn-block" id="testbturl2">测试连接</button>
  98. <input type="submit" name="submit" value="保存" class="btn btn-success btn-block"/>
  99. </div>
  100. </form>
  101. </div>
  102. </div>
  103. </div>
  104. {elseif $mod=='task'}
  105. <div class="col-sm-12 col-md-6 center-block">
  106. <div class="panel panel-success">
  107. <div class="panel-heading"><h3 class="panel-title">定时任务说明</h3></div>
  108. <div class="panel-body">
  109. <form onsubmit="return saveSetting(this)" method="post" class="form" role="form">
  110. <div class="alert alert-info">使用以下命令可以从宝塔官方获取最新的插件列表并批量下载插件包(增量更新)。<br/>你也可以将此命令添加到crontab以使此云端的插件保持最新,建议1天执行1次。</div>
  111. <div class="alert alert-danger">使用命令执行之后,可能会导致 /data 目录下文件权限不对,后台插件列表下载插件覆盖会报错,需要手动循环设置 /data 目录权限。</div>
  112. <div class="alert alert-warning">上次运行时间:{$runtime|raw}</div>
  113. <div class="list-group-item">php {:app()->getRootPath()}think updateall</div><br/>
  114. </form>
  115. </div>
  116. </div>
  117. </div>
  118. <div class="col-sm-12 col-md-6 center-block">
  119. <div class="panel panel-info">
  120. <div class="panel-heading"><h3 class="panel-title">定时任务设置</h3></div>
  121. <div class="panel-body">
  122. <form onsubmit="return saveSetting(this)" method="post" class="form" role="form">
  123. <div class="form-group">
  124. <label>Linux面板批量下载插件范围:</label><br/>
  125. <select class="form-control" name="updateall_type" default="{:config_get('updateall_type')}"><option value="0">仅免费插件</option><option value="1">免费插件+专业版插件</option><option value="2">免费插件+专业版插件+企业版插件</option></select><font color="green">(批量下载不包含所有第三方插件,第三方插件需要去手动下载。)</font>
  126. </div>
  127. <div class="form-group">
  128. <label>Windows面板批量下载插件范围:</label><br/>
  129. <select class="form-control" name="updateall_type_win" default="{:config_get('updateall_type_win')}"><option value="0">仅免费插件</option><option value="1">免费插件+专业版插件</option><option value="2">免费插件+专业版插件+企业版插件</option></select><font color="green">(批量下载不包含所有第三方插件,第三方插件需要去手动下载。)</font>
  130. </div>
  131. <div class="form-group text-center">
  132. <input type="submit" name="submit" value="保存" class="btn btn-success btn-block"/>
  133. </div>
  134. </form>
  135. </div>
  136. </div>
  137. </div>
  138. {elseif $mod=='account'}
  139. <div class="col-xs-12 col-sm-8 col-lg-6 center-block" style="float: none;">
  140. <div class="panel panel-primary">
  141. <div class="panel-heading"><h3 class="panel-title">管理账号设置</h3></div>
  142. <div class="panel-body">
  143. <form onsubmit="return saveAccount(this)" method="post" class="form" role="form">
  144. <div class="form-group">
  145. <label>用户名:</label><br/>
  146. <input type="text" name="username" value="{:config_get('admin_username')}" class="form-control" required/>
  147. </div>
  148. <div class="form-group">
  149. <label>旧密码:</label>
  150. <input type="password" name="oldpwd" value="" class="form-control" placeholder="请输入当前的管理员密码"/>
  151. </div>
  152. <div class="form-group">
  153. <label>新密码:</label>
  154. <input type="password" name="newpwd" value="" class="form-control" placeholder="不修改请留空"/>
  155. </div>
  156. <div class="form-group">
  157. <label>重输密码:</label>
  158. <input type="password" name="newpwd2" value="" class="form-control" placeholder="不修改请留空"/>
  159. </div>
  160. <div class="form-group text-center">
  161. <input type="submit" name="submit" value="保存" class="btn btn-success btn-block"/>
  162. </div>
  163. <a href="javascript:cleancache()" class="btn btn-default btn-sm btn-block">清理缓存</a>
  164. </form>
  165. </div>
  166. </div>
  167. {elseif $mod=='tools'}
  168. <div class="col-sm-12 col-md-10 col-lg-8 center-block" style="float: none;">
  169. <div class="panel panel-primary">
  170. <div class="panel-heading"><h3 class="panel-title">批量替换工具</h3></div>
  171. <div class="panel-body">
  172. <form onsubmit="return saveAccount(this)" method="post" class="form" role="form">
  173. <div class="alert alert-info" style="word-break:break-all;">使用以下命令可以将bt安装包、更新包和脚本文件里面的<code>http://www.example.com</code>批量替换成当前网址<code>{:request()->root(true)}</code>,每次更新版本后只需要执行一次即可。</div>
  174. <div class="list-group-item" style="word-break:break-all;">cd {:app()->getRootPath()}app/script && chmod +x convert.sh && ./convert.sh {:app()->getRootPath()} {:request()->root(true)}</div><br/>
  175. </form>
  176. </div>
  177. </div>
  178. {/if}
  179. <script src="//cdn.staticfile.org/layer/3.5.1/layer.js"></script>
  180. <script>
  181. $(document).ready(function(){
  182. var items = $("select[default]");
  183. for (i = 0; i < items.length; i++) {
  184. $(items[i]).val($(items[i]).attr("default")||0);
  185. }
  186. $("#testbturl").click(function(){
  187. var bt_url = $("input[name=bt_url]").val();
  188. var bt_key = $("input[name=bt_key]").val();
  189. if(bt_url == ''){
  190. layer.alert('宝塔面板URL不能为空');return;
  191. }
  192. if(bt_url.indexOf('http://')==-1 && bt_url.indexOf('https://')==-1){
  193. layer.alert('宝塔面板URL不正确');return;
  194. }
  195. if(bt_key == ''){
  196. layer.alert('宝塔面板接口密钥不能为空');return;
  197. }
  198. var ii = layer.load(2, {shade:[0.1,'#fff']});
  199. $.ajax({
  200. type : 'POST',
  201. url : '/admin/testbturl',
  202. data : {bt_url:bt_url, bt_key:bt_key},
  203. dataType : 'json',
  204. success : function(data) {
  205. layer.close(ii);
  206. if(data.code == 0){
  207. layer.msg(data.msg, {icon: 1, time:1000})
  208. }else{
  209. layer.alert(data.msg, {icon: 2})
  210. }
  211. },
  212. error:function(data){
  213. layer.close(ii);
  214. layer.msg('服务器错误');
  215. }
  216. });
  217. })
  218. $("#testbturl2").click(function(){
  219. var wbt_url = $("input[name=wbt_url]").val();
  220. var wbt_key = $("input[name=wbt_key]").val();
  221. if(wbt_url == ''){
  222. layer.alert('宝塔面板URL不能为空');return;
  223. }
  224. if(wbt_url.indexOf('http://')==-1 && wbt_url.indexOf('https://')==-1){
  225. layer.alert('宝塔面板URL不正确');return;
  226. }
  227. if(wbt_key == ''){
  228. layer.alert('宝塔面板接口密钥不能为空');return;
  229. }
  230. var ii = layer.load(2, {shade:[0.1,'#fff']});
  231. $.ajax({
  232. type : 'POST',
  233. url : '/admin/testbturl',
  234. data : {bt_url:wbt_url, bt_key:wbt_key},
  235. dataType : 'json',
  236. success : function(data) {
  237. layer.close(ii);
  238. if(data.code == 0){
  239. layer.msg(data.msg, {icon: 1, time:1000})
  240. }else{
  241. layer.alert(data.msg, {icon: 2})
  242. }
  243. },
  244. error:function(data){
  245. layer.close(ii);
  246. layer.msg('服务器错误');
  247. }
  248. });
  249. })
  250. })
  251. function saveSetting(obj){
  252. var ii = layer.load(2, {shade:[0.1,'#fff']});
  253. $.ajax({
  254. type : 'POST',
  255. url : '/admin/set',
  256. data : $(obj).serialize(),
  257. dataType : 'json',
  258. success : function(data) {
  259. layer.close(ii);
  260. if(data.code == 0){
  261. layer.alert('设置保存成功!', {
  262. icon: 1,
  263. closeBtn: false
  264. }, function(){
  265. window.location.reload()
  266. });
  267. }else{
  268. layer.alert(data.msg, {icon: 2})
  269. }
  270. },
  271. error:function(data){
  272. layer.close(ii);
  273. layer.msg('服务器错误');
  274. }
  275. });
  276. return false;
  277. }
  278. function saveAccount(obj){
  279. var ii = layer.load(2, {shade:[0.1,'#fff']});
  280. $.ajax({
  281. type : 'POST',
  282. url : '/admin/setaccount',
  283. data : $(obj).serialize(),
  284. dataType : 'json',
  285. success : function(data) {
  286. layer.close(ii);
  287. if(data.code == 0){
  288. layer.alert('管理账号保存成功!请重新登录。', {
  289. icon: 1,
  290. closeBtn: false
  291. }, function(){
  292. window.location.reload()
  293. });
  294. }else{
  295. layer.alert(data.msg, {icon: 2})
  296. }
  297. },
  298. error:function(data){
  299. layer.close(ii);
  300. layer.msg('服务器错误');
  301. }
  302. });
  303. return false;
  304. }
  305. function cleancache(){
  306. var ii = layer.load(2, {shade:[0.1,'#fff']});
  307. $.ajax({
  308. type : 'GET',
  309. url : '/admin/cleancache',
  310. dataType : 'json',
  311. success : function(data) {
  312. layer.close(ii);
  313. layer.msg('清理缓存成功', {icon: 1});
  314. },
  315. error:function(data){
  316. layer.close(ii);
  317. layer.msg('服务器错误');
  318. }
  319. });
  320. }
  321. </script>
  322. {/block}