mirror of
https://gitee.com/apiadmin/ApiAdmin.git
synced 2025-04-06 03:58:00 +08:00
added 新增加接口管理功能
This commit is contained in:
parent
c14a92abc3
commit
ff90f574a0
@ -1,13 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @since 2018-02-11
|
|
||||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace app\admin\controller;
|
|
||||||
|
|
||||||
|
|
||||||
class ApiList extends Base {
|
|
||||||
|
|
||||||
}
|
|
134
application/admin/controller/InterfaceList.php
Normal file
134
application/admin/controller/InterfaceList.php
Normal file
@ -0,0 +1,134 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @since 2018-02-11
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace app\admin\controller;
|
||||||
|
|
||||||
|
|
||||||
|
use app\model\ApiList;
|
||||||
|
use app\util\ReturnCode;
|
||||||
|
|
||||||
|
class InterfaceList extends Base {
|
||||||
|
/**
|
||||||
|
* 获取接口列表
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
* @return array
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @throws \think\exception\DbException
|
||||||
|
*/
|
||||||
|
public function index() {
|
||||||
|
|
||||||
|
$limit = $this->request->get('size', config('apiAdmin.ADMIN_LIST_DEFAULT'));
|
||||||
|
$start = $limit * ($this->request->get('page', 1) - 1);
|
||||||
|
$keywords = $this->request->get('keywords', '');
|
||||||
|
$type = $this->request->get('type', '');
|
||||||
|
$status = $this->request->get('status', '');
|
||||||
|
|
||||||
|
$where = [];
|
||||||
|
if ($status === '1' || $status === '0') {
|
||||||
|
$where['status'] = $status;
|
||||||
|
}
|
||||||
|
if ($type) {
|
||||||
|
switch ($type) {
|
||||||
|
case 1:
|
||||||
|
$where['hash'] = $keywords;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
$where['info'] = ['like', "%{$keywords}%"];
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
$where['apiClass'] = ['like', "%{$keywords}%"];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$listInfo = (new ApiList())->where($where)->order('id', 'DESC')->limit($start, $limit)->select();
|
||||||
|
$count = (new ApiList())->where($where)->count();
|
||||||
|
$listInfo = $this->buildArrFromObj($listInfo);
|
||||||
|
|
||||||
|
return $this->buildSuccess([
|
||||||
|
'list' => $listInfo,
|
||||||
|
'count' => $count
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取接口唯一标识
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getHash() {
|
||||||
|
$res['hash'] = uniqid();
|
||||||
|
|
||||||
|
return $this->buildSuccess($res);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 新增接口
|
||||||
|
* @return array
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
*/
|
||||||
|
public function add() {
|
||||||
|
$postData = $this->request->post();
|
||||||
|
$res = ApiList::create($postData);
|
||||||
|
if ($res === false) {
|
||||||
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
||||||
|
} else {
|
||||||
|
return $this->buildSuccess([]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 接口状态编辑
|
||||||
|
* @return array
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
*/
|
||||||
|
public function changeStatus() {
|
||||||
|
$id = $this->request->get('id');
|
||||||
|
$status = $this->request->get('status');
|
||||||
|
$res = ApiList::update([
|
||||||
|
'status' => $status
|
||||||
|
], [
|
||||||
|
'id' => $id
|
||||||
|
]);
|
||||||
|
if ($res === false) {
|
||||||
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
||||||
|
} else {
|
||||||
|
return $this->buildSuccess([]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 编辑应用
|
||||||
|
* @return array
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
*/
|
||||||
|
public function edit() {
|
||||||
|
$postData = $this->request->post();
|
||||||
|
$res = ApiList::update($postData);
|
||||||
|
if ($res === false) {
|
||||||
|
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR, '操作失败');
|
||||||
|
} else {
|
||||||
|
return $this->buildSuccess([]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除接口
|
||||||
|
* @return array
|
||||||
|
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||||
|
*/
|
||||||
|
public function del() {
|
||||||
|
$id = $this->request->get('id');
|
||||||
|
if (!$id) {
|
||||||
|
return $this->buildFailed(ReturnCode::EMPTY_PARAMS, '缺少必要参数');
|
||||||
|
}
|
||||||
|
ApiList::destroy($id);
|
||||||
|
|
||||||
|
return $this->buildSuccess([]);
|
||||||
|
}
|
||||||
|
}
|
@ -111,6 +111,30 @@ return [
|
|||||||
'admin/App/del',
|
'admin/App/del',
|
||||||
['method' => 'get', 'after_behavior' => $afterBehavior]
|
['method' => 'get', 'after_behavior' => $afterBehavior]
|
||||||
],
|
],
|
||||||
|
'InterfaceList/index' => [
|
||||||
|
'admin/InterfaceList/index',
|
||||||
|
['method' => 'get', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
|
'InterfaceList/changeStatus' => [
|
||||||
|
'admin/InterfaceList/changeStatus',
|
||||||
|
['method' => 'get', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
|
'InterfaceList/getHash' => [
|
||||||
|
'admin/InterfaceList/getHash',
|
||||||
|
['method' => 'get', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
|
'InterfaceList/add' => [
|
||||||
|
'admin/InterfaceList/add',
|
||||||
|
['method' => 'post', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
|
'InterfaceList/edit' => [
|
||||||
|
'admin/InterfaceList/edit',
|
||||||
|
['method' => 'post', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
|
'InterfaceList/del' => [
|
||||||
|
'admin/InterfaceList/del',
|
||||||
|
['method' => 'get', 'after_behavior' => $afterBehavior]
|
||||||
|
],
|
||||||
'__miss__' => ['admin/Miss/index'],
|
'__miss__' => ['admin/Miss/index'],
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
@ -33,7 +33,7 @@ class ApiLog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static function setApiInfo($data) {
|
public static function setApiInfo($data) {
|
||||||
self::$apiInfo = isset($data['apiName']) ? $data['apiName'] : '' . self::$separator . isset($data['hash']) ? $data['hash'] : '';
|
self::$apiInfo = isset($data['apiClass']) ? $data['apiClass'] : '' . self::$separator . isset($data['hash']) ? $data['hash'] : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function setUserInfo($data) {
|
public static function setUserInfo($data) {
|
||||||
@ -106,4 +106,4 @@ class ApiLog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="twelve wide column">
|
<div class="twelve wide column">
|
||||||
<div class="ui floating message" id="detail" style="overflow: auto;">
|
<div class="ui floating message" id="detail" style="overflow: auto;">
|
||||||
<h2 class='ui header'>接口唯一标识:<a target="_blank" href="{$http_type}{$_SERVER['HTTP_HOST']}/api/{$hash}">{$hash}</a>({$detail['apiName']})</h2><br />
|
<h2 class='ui header'>接口唯一标识:<a target="_blank" href="{$http_type}{$_SERVER['HTTP_HOST']}/api/{$hash}">{$hash}</a>({$detail['apiClass']})</h2><br />
|
||||||
<div class="ui raised segment">
|
<div class="ui raised segment">
|
||||||
<span class="ui red ribbon large label">接口说明</span>
|
<span class="ui red ribbon large label">接口说明</span>
|
||||||
{if condition="$detail['status'] eq 0 "}
|
{if condition="$detail['status'] eq 0 "}
|
||||||
@ -196,4 +196,4 @@
|
|||||||
});
|
});
|
||||||
$('.ui .vertical').css('max-height', $('#detail').outerHeight(true));
|
$('.ui .vertical').css('max-height', $('#detail').outerHeight(true));
|
||||||
</script>
|
</script>
|
||||||
</html>
|
</html>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user