插件功能更新

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> // | Author: yangweijie <yangweijiester@gmail.com> <code-tech.diandian.com>
// +---------------------------------------------------------------------- // +----------------------------------------------------------------------
namespace addons\systeminfo; namespace addons\systeminfo;
use app\common\controller\Addons; use app\common\controller\Addons;
@@ -24,7 +23,7 @@ class Systeminfo extends Addons{
'description' => '用于显示一些服务器的信息', 'description' => '用于显示一些服务器的信息',
'status' => 1, 'status' => 1,
'author' => 'molong', 'author' => 'molong',
'version'=>'0.1' 'version' => '0.1',
); );
public function install() { public function install() {
@@ -39,7 +38,8 @@ class Systeminfo extends Addons{
public function AdminIndex($param) { public function AdminIndex($param) {
$config = $this->getConfig(); $config = $this->getConfig();
if(false){//extension_loaded('curl') if (false) {
//extension_loaded('curl')
$url = 'http://www.tensent.cn/index.php?m=home&c=version&a=check_version'; $url = 'http://www.tensent.cn/index.php?m=home&c=version&a=check_version';
$params = array( $params = array(
'version' => ONETHINK_VERSION, 'version' => ONETHINK_VERSION,

View File

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

View File

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

View File

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

View File

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

View File

@@ -16,15 +16,15 @@ namespace app\common\model;
*/ */
class Addons extends \app\common\model\Base { class Addons extends \app\common\model\Base {
protected $auto = array('status'); protected $auto = array('status', 'isinstall', 'update_time');
protected $insert = array('create_time'); protected $insert = array('create_time');
protected function setStatusAttr($value) { protected function setStatusAttr($value) {
return 1; return $value ? $value : 0;
} }
protected function setIsinstallAttr($value) { protected function setIsinstallAttr($value) {
return 0; return $value ? $value : 0;
} }
protected function getStatusTextAttr($value, $data) { protected function getStatusTextAttr($value, $data) {
@@ -49,7 +49,7 @@ class Addons extends \app\common\model\Base {
return FALSE; return FALSE;
} }
$where['name'] = array('in', $dirs); $where['name'] = array('in', $dirs);
$addons = $this->where($where)->select(); $addons = $this->where($where)->column('*', 'name');
foreach ($dirs as $value) { foreach ($dirs as $value) {
$value = ucfirst($value); $value = ucfirst($value);
@@ -61,12 +61,8 @@ class Addons extends \app\common\model\Base {
continue; continue;
} }
$obj = new $class; $obj = new $class;
$addons[$value] = $obj->info; $save = $obj->info;
if($addons[$value]){ self::create($save);
$addons[$value]['id'] = 0;
$addons[$value]['uninstall'] = 1;
unset($addons[$value]['status']);
}
} }
} }
} }
@@ -87,18 +83,19 @@ class Addons extends \app\common\model\Base {
public function install($data) { public function install($data) {
if ($data) { if ($data) {
$info = $this->where('name', $data['name'])->find(); $info = $this->where('name', $data['name'])->value('id');
if (null == $info) { 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 = $this->save($data);
if ($result) { }
if (false !== $result) {
return model('Hooks')->addHooks($data['name']); return model('Hooks')->addHooks($data['name']);
}else{ }else{
return false; return false;
} }
}else{
$this->error = "已安装!";
return false;
}
} else { } else {
return false; return false;
} }

View File

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