插件功能更新

This commit is contained in:
2016-09-17 17:54:14 +08:00
parent f0df1f13e4
commit 4ee9156229
7 changed files with 172 additions and 164 deletions

View File

@@ -7,7 +7,6 @@
// | Author: yangweijie <yangweijiester@gmail.com> <code-tech.diandian.com>
// +----------------------------------------------------------------------
namespace addons\systeminfo;
use app\common\controller\Addons;
@@ -16,62 +15,63 @@ use app\common\controller\Addons;
* @author thinkphp
*/
class Systeminfo extends Addons{
class Systeminfo extends Addons {
public $info = array(
'name'=>'Systeminfo',
'title'=>'系统环境信息',
'description'=>'用于显示一些服务器的信息',
'status'=>1,
'author'=>'molong',
'version'=>'0.1'
);
public $info = array(
'name' => 'Systeminfo',
'title' => '系统环境信息',
'description' => '用于显示一些服务器的信息',
'status' => 1,
'author' => 'molong',
'version' => '0.1',
);
public function install(){
return true;
}
public function install() {
return true;
}
public function uninstall(){
return true;
}
public function uninstall() {
return true;
}
//实现的AdminIndex钩子方法
public function AdminIndex($param){
$config = $this->getConfig();
if(false){//extension_loaded('curl')
$url = 'http://www.tensent.cn/index.php?m=home&c=version&a=check_version';
$params = array(
'version' => ONETHINK_VERSION,
'domain' => $_SERVER['HTTP_HOST'],
'auth' => sha1(config('DATA_AUTH_KEY')),
);
//实现的AdminIndex钩子方法
public function AdminIndex($param) {
$config = $this->getConfig();
$vars = http_build_query($params);
$opts = array(
CURLOPT_TIMEOUT => 5,
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_URL => $url,
CURLOPT_POST => 1,
CURLOPT_POSTFIELDS => $vars,
CURLOPT_USERAGENT => $_SERVER['HTTP_USER_AGENT'],
);
if (false) {
//extension_loaded('curl')
$url = 'http://www.tensent.cn/index.php?m=home&c=version&a=check_version';
$params = array(
'version' => ONETHINK_VERSION,
'domain' => $_SERVER['HTTP_HOST'],
'auth' => sha1(config('DATA_AUTH_KEY')),
);
/* 初始化并执行curl请求 */
$ch = curl_init();
curl_setopt_array($ch, $opts);
$data = curl_exec($ch);
$error = curl_error($ch);
curl_close($ch);
}
$vars = http_build_query($params);
$opts = array(
CURLOPT_TIMEOUT => 5,
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_URL => $url,
CURLOPT_POST => 1,
CURLOPT_POSTFIELDS => $vars,
CURLOPT_USERAGENT => $_SERVER['HTTP_USER_AGENT'],
);
if(!empty($data) && strlen($data)<400 ){
$config['new_version'] = $data;
}
/* 初始化并执行curl请求 */
$ch = curl_init();
curl_setopt_array($ch, $opts);
$data = curl_exec($ch);
$error = curl_error($ch);
curl_close($ch);
}
$this->assign('addons_config', $config);
if($config['display']){
$this->template('widget');
}
}
if (!empty($data) && strlen($data) < 400) {
$config['new_version'] = $data;
}
$this->assign('addons_config', $config);
if ($config['display']) {
$this->template('widget');
}
}
}

View File

@@ -9,6 +9,7 @@
<h2>{$meta_title}</h2>
</div>
<div class="pull-right">
<a class="btn btn-info" href="{:url('index?refresh=1')}">更 新</a>
<a class="btn btn-primary" href="{:url('add')}">新 增</a>
<button class="btn btn-danger ajax-post confirm" url="{:url('del')}" target-form="ids">删 除</button>
</div>
@@ -41,7 +42,7 @@
<td>{$item['author']}</td>
<td>{$item['version']}</td>
<td>
{if $item['uninstall']}
{if !$item['isinstall']}
<a href="{:url('install?addon_name='.$item['name'])}" class="ajax-get">安装</a>
{else/}
<a href="{:url('uninstall?id='.$item['id'])}" class="confirm ajax-get">卸载</a>

View File

@@ -207,7 +207,7 @@
{if $meta_title}
<span>{$meta_title}</span>
{else/}
<span>{:lang($Request->controller().'_'.$Request->action())}</span>
<span>{:lang(request()->controller().'_'.request()->action())}</span>
{/if}
</li>
</ol>

View File

@@ -34,7 +34,7 @@ class Addons extends Base {
public function template($template) {
$mc = $this->getAddonsName();
$ac = input('get.ac', '', 'trim,strtolower');
$ac = input('ac', '', 'trim,strtolower');
$parse_str = \think\Config::get('parse_str');
$parse_str['__ADDONROOT__'] = ROOT_PATH . "/addons/{$mc}";
\think\Config::set('parse_str', $parse_str);
@@ -52,7 +52,7 @@ class Addons extends Base {
}
final public function getAddonsName() {
$mc = input('get.mc', '', 'trim,strtolower');
$mc = input('mc', '', 'trim,strtolower');
if ($mc) {
return $mc;
} else {

View File

@@ -201,6 +201,7 @@ class Admin extends Base {
$model = db('Addons');
$list = array();
$map = array(
'isinstall' => array('gt', 0),
'status' => array('gt', 0),
);
$list = $model->field("name,id,title,'' as 'style'")->where($map)->select();

View File

@@ -16,123 +16,120 @@ namespace app\common\model;
*/
class Addons extends \app\common\model\Base {
protected $auto = array('status');
protected $insert = array('create_time');
protected $auto = array('status', 'isinstall', 'update_time');
protected $insert = array('create_time');
protected function setStatusAttr($value){
return 1;
}
protected function setStatusAttr($value) {
return $value ? $value : 0;
}
protected function setIsinstallAttr($value){
return 0;
}
protected function setIsinstallAttr($value) {
return $value ? $value : 0;
}
protected function getStatusTextAttr($value, $data){
return $data['status'] ? "启用" : "禁用";
}
protected function getStatusTextAttr($value, $data) {
return $data['status'] ? "启用" : "禁用";
}
protected function getUninstallAttr($value, $data){
return 0;
}
protected function getUninstallAttr($value, $data) {
return 0;
}
/**
* 更新插件列表
* @param string $addon_dir
*/
public function refresh($addon_dir = ''){
if(!$addon_dir){
$addon_dir = SENT_ADDON_PATH;
}
$dirs = array_map('basename',glob($addon_dir.'*', GLOB_ONLYDIR));
if($dirs === FALSE || !file_exists($addon_dir)){
$this->error = '插件目录不可读或者不存在';
return FALSE;
}
$where['name'] = array('in',$dirs);
$addons = $this->where($where)->select();
foreach ($dirs as $value) {
$value = ucfirst($value);
if(!isset($addons[$value])){
/**
* 更新插件列表
* @param string $addon_dir
*/
public function refresh($addon_dir = '') {
if (!$addon_dir) {
$addon_dir = SENT_ADDON_PATH;
}
$dirs = array_map('basename', glob($addon_dir . '*', GLOB_ONLYDIR));
if ($dirs === FALSE || !file_exists($addon_dir)) {
$this->error = '插件目录不可读或者不存在';
return FALSE;
}
$where['name'] = array('in', $dirs);
$addons = $this->where($where)->column('*', 'name');
foreach ($dirs as $value) {
$value = ucfirst($value);
if (!isset($addons[$value])) {
$class = get_addon_class($value);
if(!class_exists($class)){
// 实例化插件失败忽略执行
\think\Log::record('插件'.$value.'的入口文件不存在!');
if (!class_exists($class)) {
// 实例化插件失败忽略执行
\think\Log::record('插件' . $value . '的入口文件不存在!');
continue;
}
$obj = new $class;
$addons[$value] = $obj->info;
if($addons[$value]){
$addons[$value]['id'] = 0;
$addons[$value]['uninstall'] = 1;
unset($addons[$value]['status']);
}
$obj = new $class;
$save = $obj->info;
self::create($save);
}
}
}
}
}
/**
* 获取插件的后台列表
*/
public function getAdminList(){
$admin = array();
$db_addons = db('Addons')->where("status=1 AND has_adminlist=1")->field('title,name')->select();
if($db_addons){
foreach ($db_addons as $value) {
$admin[] = array('title'=>$value['title'],'url'=>"Addons/adminList?name={$value['name']}");
}
}
return $admin;
}
/**
* 获取插件的后台列表
*/
public function getAdminList() {
$admin = array();
$db_addons = db('Addons')->where("status=1 AND has_adminlist=1")->field('title,name')->select();
if ($db_addons) {
foreach ($db_addons as $value) {
$admin[] = array('title' => $value['title'], 'url' => "Addons/adminList?name={$value['name']}");
}
}
return $admin;
}
public function install($data){
if ($data) {
$info = $this->where('name', $data['name'])->find();
if (null == $info) {
$result = $this->save($data);
if ($result) {
return model('Hooks')->addHooks($data['name']);
}else{
return false;
}
}else{
$this->error = "已安装!";
return false;
}
}else{
return false;
}
}
public function install($data) {
if ($data) {
$info = $this->where('name', $data['name'])->value('id');
if ($info) {
$result = $this->save(array('isinstall'=>1, 'status'=>1), array('id'=>$info));
}else{
$data['isinstall'] = 1;
$data['status'] = 1;
$result = $this->save($data);
}
if (false !== $result) {
return model('Hooks')->addHooks($data['name']);
}else{
return false;
}
} else {
return false;
}
}
public function uninstall($id){
$info = $this->get($id);
if (!$info) {
$this->error = "无此插件!";
return false;
}
$class = get_addon_class($info['name']);
if (class_exists($class)) {
//插件卸载方法
$addons = new $class;
if (!method_exists($addons,'uninstall')) {
$this->error = "插件卸载方法!";
return false;
}
$result = $addons->uninstall();
if ($result) {
//卸载挂载点中的插件
$result = model('Hooks')->removeHooks($info['name']);
//删除插件表中数据
$this->where(array('id'=>$id))->delete();
return true;
}else{
$this->error = "无法卸载插件!";
return false;
}
}
}
public function uninstall($id) {
$info = $this->get($id);
if (!$info) {
$this->error = "无此插件!";
return false;
}
$class = get_addon_class($info['name']);
if (class_exists($class)) {
//插件卸载方法
$addons = new $class;
if (!method_exists($addons, 'uninstall')) {
$this->error = "插件卸载方法!";
return false;
}
$result = $addons->uninstall();
if ($result) {
//卸载挂载点中的插件
$result = model('Hooks')->removeHooks($info['name']);
//删除插件表中数据
$this->where(array('id' => $id))->delete();
return true;
} else {
$this->error = "无法卸载插件!";
return false;
}
}
}
public function build(){
public function build() {
}
}
}

View File

@@ -85,12 +85,13 @@ class Hooks extends Base {
'update_time' => time(),
'status' => 1
);
$this->save($save);
self::create($save);
}else{
if ($info['addons']) {
# code...
$addons = explode(',', $info['addons']);
array_push($addons, substr($item, 0, -5));
}else{
$addons = substr($item, 0, -5);
$addons = array(substr($item, 0, -5));
}
$this->where('name', $addons_name)->setField('addons', $addons);
}
@@ -105,6 +106,14 @@ class Hooks extends Base {
$this->error = "未实现{$addons_name}插件的入口文件";
return false;
}
$methods = get_class_methods($addons_class);
$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']);
unset($value['addons'][$key]);
$addons = $value['addons'];
$this->where('id', $value['id'])->setField('addons', $addons);
}
return true;
}
}