扩展插件功能完善

测试扩展编写
This commit is contained in:
2016-09-18 23:30:26 +08:00
parent e818c386e2
commit 8e3a918182
4 changed files with 102 additions and 55 deletions
+44
View File
@@ -0,0 +1,44 @@
<?php
// +----------------------------------------------------------------------
// | OneThink [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.onethink.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: yangweijie <yangweijiester@gmail.com> <code-tech.diandian.com>
// +----------------------------------------------------------------------
namespace addons\test;
use app\common\controller\Addons;
/**
* 系统环境信息插件
* @author thinkphp
*/
class Test extends Addons {
public $info = array(
'name' => 'Test',
'title' => '测试',
'description' => '用于显示一些服务器的信息',
'status' => 1,
'author' => 'molong',
'version' => '0.1',
);
public function AdminIndex(){
}
public function test(){
}
public function install(){
return true;
}
public function uninstall(){
return true;
}
}
+1 -3
View File
@@ -87,9 +87,7 @@ class Addons extends \app\common\model\Base {
if ($info) {
$result = $this->save(array('isinstall'=>1, 'status'=>1), array('id'=>$info));
}else{
$data['isinstall'] = 1;
$data['status'] = 1;
$result = $this->save($data);
$result = false;
}
if (false !== $result) {
return model('Hooks')->addHooks($data['name']);
+22 -17
View File
@@ -19,7 +19,7 @@ class Hooks extends Base {
array('name' => 'name', 'title' => '钩子名称', 'type' => 'text', 'help' => '需要在程序中先添加钩子,否则无效'),
array('name' => 'description', 'title' => '钩子描述', 'type' => 'text', 'help' => '钩子的描述信息'),
array('name' => 'type_text', 'title' => '钩子类型', 'type' => 'select', 'help' => '钩子的描述信息'),
array('name'=>'addons','title'=>'插件排序','type'=>'kanban')
array('name' => 'addons', 'title' => '插件排序', 'type' => 'kanban'),
);
public function initialize() {
@@ -33,8 +33,8 @@ class Hooks extends Base {
}
protected function setAddonsAttr($value) {
if ($value[1]) {
$string = implode(",", $value[1]);
if ($value) {
$string = implode(",", $value);
return $string;
}
}
@@ -72,29 +72,28 @@ class Hooks extends Base {
$this->error = "未实现{$addons_name}插件的入口文件";
return false;
}
$methods = get_class_methods($addons_class);
$methods = array_diff(get_class_methods($addons_class), get_class_methods('\app\common\controller\Addons'));
$methods = array_diff($methods, array('install', 'uninstall'));
foreach ($methods as $item) {
if ('Addon' === substr($item, -5, 5)) {
$info = $this->where('name', substr($item, 0, -5))->find();
$info = $this->where('name', $item)->find();
if (null == $info) {
$save = array(
'name' => $addons_name,
'name' => $item,
'description' => '',
'type' => 1,
'addons' => array($addons_name),
'update_time' => time(),
'status' => 1
'status' => 1,
);
self::create($save);
} else {
if ($info['addons']) {
$addons = explode(',', $info['addons']);
array_push($addons, substr($item, 0, -5));
array_push($addons, $addons_name);
} else {
$addons = array(substr($item, 0, -5));
}
$this->where('name', $addons_name)->setField('addons', $addons);
$addons = array($addons_name);
}
$this->where('name', $item)->setField('addons', implode(',', $addons));
}
}
return true;
@@ -106,14 +105,20 @@ class Hooks extends Base {
$this->error = "未实现{$addons_name}插件的入口文件";
return false;
}
$row = $this->where(array('addons'=>array('like',$addons_name)))->select();
foreach ($row as $key => $value) {
$value['addons'] = explode(',', $info['addons']);
$key = array_search($addons_name, $value['addons']);
$row = $this->where(array('addons' => array('like', '%' . $addons_name . '%')))->select();
foreach ($row as $value) {
if ($addons_name === $value['addons']) {
$this->where('id', $value['id'])->delete();
} else {
$addons = explode(',', $value['addons']);
$key = array_search($addons_name, $addons);
if ($key) {
unset($value['addons'][$key]);
$addons = $value['addons'];
$addons = implode(',', $addons);
$this->where('id', $value['id'])->setField('addons', $addons);
}
}
}
return true;
}
}