178 lines
5.0 KiB
PHP
178 lines
5.0 KiB
PHP
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | saiadmin [ saiadmin快速开发框架 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Author: sai <1430792918@qq.com>
|
|
// +----------------------------------------------------------------------
|
|
namespace plugin\saiadmin\app\controller\tool;
|
|
|
|
use plugin\saiadmin\basic\BaseController;
|
|
use plugin\saiadmin\app\logic\tool\GenerateTablesLogic;
|
|
use plugin\saiadmin\app\validate\tool\GenerateTablesValidate;
|
|
use plugin\saiadmin\app\cache\UserMenuCache;
|
|
use plugin\saiadmin\service\Permission;
|
|
use support\Request;
|
|
use support\Response;
|
|
|
|
/**
|
|
* 代码生成控制器
|
|
*/
|
|
class GenerateTablesController extends BaseController
|
|
{
|
|
/**
|
|
* 构造
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->logic = new GenerateTablesLogic();
|
|
$this->validate = new GenerateTablesValidate;
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* 数据列表
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成列表', 'tool:code:index')]
|
|
public function index(Request $request): Response
|
|
{
|
|
$where = $request->more([
|
|
['table_name', ''],
|
|
]);
|
|
$query = $this->logic->search($where);
|
|
$data = $this->logic->getList($query);
|
|
return $this->success($data);
|
|
}
|
|
|
|
/**
|
|
* 读取数据
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成列表', 'tool:code:index')]
|
|
public function read(Request $request): Response
|
|
{
|
|
$id = $request->input('id', '');
|
|
$model = $this->logic->read($id);
|
|
if ($model) {
|
|
$data = is_array($model) ? $model : $model->toArray();
|
|
return $this->success($data);
|
|
} else {
|
|
return $this->fail('not found');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 修改数据
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成修改', 'tool:code:edit')]
|
|
public function update(Request $request): Response
|
|
{
|
|
$data = $request->post();
|
|
$this->validate('update', $data);
|
|
$result = $this->logic->edit($data['id'], $data);
|
|
if ($result) {
|
|
return $this->success('update success');
|
|
} else {
|
|
return $this->fail('update failed');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 删除数据
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成删除', 'tool:code:edit')]
|
|
public function destroy(Request $request): Response
|
|
{
|
|
$ids = $request->post('ids', '');
|
|
if (empty($ids)) {
|
|
return $this->fail('please select data to delete');
|
|
}
|
|
$result = $this->logic->destroy($ids);
|
|
if ($result) {
|
|
return $this->success('delete success');
|
|
} else {
|
|
return $this->fail('delete failed');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 装载数据表
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成装载', 'tool:code:edit')]
|
|
public function loadTable(Request $request): Response
|
|
{
|
|
$names = $request->input('names', []);
|
|
$source = $request->input('source', '');
|
|
$this->logic->loadTable($names, $source);
|
|
return $this->success('operation success');
|
|
}
|
|
|
|
/**
|
|
* 同步数据表字段信息
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成同步表结构', 'tool:code:edit')]
|
|
public function sync(Request $request): Response
|
|
{
|
|
$id = $request->input('id', '');
|
|
$this->logic->sync($id);
|
|
return $this->success('operation success');
|
|
}
|
|
|
|
/**
|
|
* 代码预览
|
|
*/
|
|
#[Permission('代码生成预览', 'tool:code:edit')]
|
|
public function preview(Request $request): Response
|
|
{
|
|
$id = $request->input('id', '');
|
|
$data = $this->logic->preview($id);
|
|
return $this->success($data);
|
|
}
|
|
|
|
/**
|
|
* 代码生成
|
|
*/
|
|
#[Permission('代码生成文件', 'tool:code:edit')]
|
|
public function generate(Request $request): Response
|
|
{
|
|
$ids = $request->input('ids', '');
|
|
$data = $this->logic->generate($ids);
|
|
return response()->download($data['download'], $data['filename']);
|
|
}
|
|
|
|
/**
|
|
* 生成到模块
|
|
*/
|
|
#[Permission('代码生成到模块', 'tool:code:edit')]
|
|
public function generateFile(Request $request): Response
|
|
{
|
|
$id = $request->input('id', '');
|
|
$this->logic->generateFile($id);
|
|
UserMenuCache::clearMenuCache();
|
|
return $this->success('operation success');
|
|
}
|
|
|
|
/**
|
|
* 获取数据表字段信息
|
|
* @param Request $request
|
|
* @return Response
|
|
*/
|
|
#[Permission('代码生成读取表字段', 'tool:code:index')]
|
|
public function getTableColumns(Request $request): Response
|
|
{
|
|
$table_id = $request->input('table_id', '');
|
|
$data = $this->logic->getTableColumns($table_id);
|
|
return $this->success($data);
|
|
}
|
|
|
|
} |