mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-05 19:41:44 +08:00
合并数据库文件
This commit is contained in:
parent
ad17150edb
commit
6f0f54845e
350
database/migrations/20221013031925_install_admin.php
Normal file
350
database/migrations/20221013031925_install_admin.php
Normal file
@ -0,0 +1,350 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统模块数据
|
||||
*/
|
||||
class InstallAdmin extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
$this->_auth();
|
||||
$this->_base();
|
||||
$this->_conf();
|
||||
$this->_data();
|
||||
$this->_file();
|
||||
$this->_menu();
|
||||
$this->_node();
|
||||
$this->_oplog();
|
||||
$this->_queue();
|
||||
$this->_user();
|
||||
}
|
||||
|
||||
private function _auth()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_auth';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-权限',
|
||||
])
|
||||
->addColumn('title', 'string', ['limit' => 80, 'default' => '', 'comment' => '权限名称'])
|
||||
->addColumn('utype', 'string', ['limit' => 50, 'default' => '', 'comment' => '身份权限'])
|
||||
->addColumn('desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '备注说明'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('sort', ['name' => 'idx_system_auth_sort'])
|
||||
->addIndex('title', ['name' => 'idx_system_auth_title'])
|
||||
->addIndex('status', ['name' => 'idx_system_auth_status'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _node()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_auth_node';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-授权',
|
||||
])
|
||||
->addColumn('auth', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '角色编号'])
|
||||
->addColumn('node', 'string', ['limit' => 200, 'default' => '', 'comment' => '节点路径'])
|
||||
->addIndex('auth', ['name' => 'idx_system_auth_node_auth'])
|
||||
->addIndex('node', ['name' => 'idx_system_auth_node_node'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _base()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_base';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-字典',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '数据类型'])
|
||||
->addColumn('code', 'string', ['limit' => 100, 'default' => '', 'comment' => '数据代码'])
|
||||
->addColumn('name', 'string', ['limit' => 500, 'default' => '', 'comment' => '数据名称'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '数据内容'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(0正常,1已删)'])
|
||||
->addColumn('deleted_at', 'string', ['limit' => 20, 'default' => '', 'comment' => '删除时间'])
|
||||
->addColumn('deleted_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '删除用户'])
|
||||
->addIndex('type', ['name' => 'idx_system_base_type'])
|
||||
->addIndex('code', ['name' => 'idx_system_base_code'])
|
||||
->addIndex('name', ['name' => 'idx_system_base_name'])
|
||||
->addIndex('sort', ['name' => 'idx_system_base_sort'])
|
||||
->addIndex('status', ['name' => 'idx_system_base_status'])
|
||||
->addIndex('deleted', ['name' => 'idx_system_base_deleted'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _conf()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_config';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-配置',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '配置分类'])
|
||||
->addColumn('name', 'string', ['limit' => 100, 'default' => '', 'comment' => '配置名称'])
|
||||
->addColumn('value', 'string', ['limit' => 2048, 'default' => '', 'comment' => '配置内容'])
|
||||
->addIndex('type', ['name' => 'idx_system_config_type'])
|
||||
->addIndex('name', ['name' => 'idx_system_config_name'])
|
||||
->save();
|
||||
|
||||
// 初始化配置信息
|
||||
$this->execute(<<<SQL
|
||||
INSERT INTO {$table} VALUES (1, 'base', 'app_name', 'ThinkAdmin');
|
||||
INSERT INTO {$table} VALUES (2, 'base', 'app_version', 'v6');
|
||||
INSERT INTO {$table} VALUES (3, 'base', 'beian', '');
|
||||
INSERT INTO {$table} VALUES (4, 'base', 'editor', 'ckeditor5');
|
||||
INSERT INTO {$table} VALUES (5, 'base', 'login_image', '');
|
||||
INSERT INTO {$table} VALUES (6, 'base', 'login_name', '系统管理');
|
||||
INSERT INTO {$table} VALUES (7, 'base', 'miitbeian', '');
|
||||
INSERT INTO {$table} VALUES (8, 'base', 'site_copy', '©版权所有 2014-2022 楚才科技');
|
||||
INSERT INTO {$table} VALUES (9, 'base', 'site_host', '');
|
||||
INSERT INTO {$table} VALUES (10, 'base', 'site_icon', 'https://v6.thinkadmin.top/upload/4b/5a423974e447d5502023f553ed370f.png');
|
||||
INSERT INTO {$table} VALUES (11, 'base', 'site_name', 'ThinkAdmin');
|
||||
INSERT INTO {$table} VALUES (12, 'base', 'site_theme', 'default');
|
||||
INSERT INTO {$table} VALUES (13, 'base', 'xpath', 'admin');
|
||||
INSERT INTO {$table} VALUES (14, 'storage', 'alioss_http_protocol', 'http');
|
||||
INSERT INTO {$table} VALUES (15, 'storage', 'allow_exts', 'doc,gif,ico,jpg,mp3,mp4,p12,pem,png,zip,rar,xls,xlsx');
|
||||
INSERT INTO {$table} VALUES (16, 'storage', 'link_type', 'none');
|
||||
INSERT INTO {$table} VALUES (17, 'storage', 'local_http_domain', '');
|
||||
INSERT INTO {$table} VALUES (18, 'storage', 'local_http_protocol', 'follow');
|
||||
INSERT INTO {$table} VALUES (19, 'storage', 'name_type', 'xmd5');
|
||||
INSERT INTO {$table} VALUES (20, 'storage', 'type', 'local');
|
||||
INSERT INTO {$table} VALUES (21, 'wechat', 'type', 'api');
|
||||
INSERT INTO {$table} VALUES (22, 'storage', 'qiniu_http_protocol', 'http');
|
||||
SQL
|
||||
);
|
||||
}
|
||||
|
||||
private function _data()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_data';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-数据',
|
||||
])
|
||||
->addColumn('name', 'string', ['limit' => 100, 'default' => '', 'comment' => '配置名'])
|
||||
->addColumn('value', 'text', ['default' => '', 'comment' => '配置值'])
|
||||
->addIndex('type', ['name' => 'idx_system_data_name'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _file()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_file';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-文件',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '上传类型'])
|
||||
->addColumn('hash', 'string', ['limit' => 32, 'default' => '', 'comment' => '文件哈希'])
|
||||
->addColumn('name', 'string', ['limit' => 200, 'default' => '', 'comment' => '文件名称'])
|
||||
->addColumn('xext', 'string', ['limit' => 100, 'default' => '', 'comment' => '文件后缀'])
|
||||
->addColumn('xurl', 'string', ['limit' => 500, 'default' => '', 'comment' => '访问链接'])
|
||||
->addColumn('xkey', 'string', ['limit' => 500, 'default' => '', 'comment' => '文件路径'])
|
||||
->addColumn('mime', 'string', ['limit' => 100, 'default' => '', 'comment' => '文件类型'])
|
||||
->addColumn('size', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '文件大小'])
|
||||
->addColumn('uuid', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '用户编号'])
|
||||
->addColumn('isfast', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '是否秒传'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'datetime', ['limit' => 20, 'default' => '', 'comment' => '创建时间'])
|
||||
->addColumn('update_at', 'datetime', ['limit' => 20, 'default' => 0, 'comment' => '更新时间'])
|
||||
->addIndex('type', ['name' => 'idx_system_file_type'])
|
||||
->addIndex('hash', ['name' => 'idx_system_file_hash'])
|
||||
->addIndex('uuid', ['name' => 'idx_system_file_uuid'])
|
||||
->addIndex('xext', ['name' => 'idx_system_file_xext'])
|
||||
->addIndex('status', ['name' => 'idx_system_file_status'])
|
||||
->addIndex('issafe', ['name' => 'idx_system_file_issafe'])
|
||||
->addIndex('isfast', ['name' => 'idx_system_file_isfast'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _menu()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_menu';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-菜单',
|
||||
])
|
||||
->addColumn('pid', 'integer', ['limit' => 20, 'default' => 1, 'comment' => '上级编号'])
|
||||
->addColumn('title', 'string', ['limit' => 100, 'default' => '', 'comment' => '菜单名称'])
|
||||
->addColumn('icon', 'string', ['limit' => 100, 'default' => '', 'comment' => '菜单图标'])
|
||||
->addColumn('node', 'string', ['limit' => 100, 'default' => '', 'comment' => '节点代码'])
|
||||
->addColumn('url', 'string', ['limit' => 500, 'default' => '', 'comment' => '链接节点'])
|
||||
->addColumn('params', 'string', ['limit' => 500, 'default' => '', 'comment' => '链接参数'])
|
||||
->addColumn('target', 'string', ['limit' => 20, 'default' => '_self', 'comment' => '打开方式'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('pid', ['name' => 'idx_system_menu_pid'])
|
||||
->addIndex('sort', ['name' => 'idx_system_menu_sort'])
|
||||
->addIndex('status', ['name' => 'idx_system_menu_status'])
|
||||
->save();
|
||||
|
||||
// 初始化菜单数据
|
||||
$this->execute(<<<SQL
|
||||
INSERT INTO {$table} VALUES (1, 0, '控制台', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (2, 1, '数据管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (3, 2, '数据统计报表', 'layui-icon layui-icon-theme', 'data/total.portal/index', 'data/total.portal/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (4, 2, '轮播图片管理', 'layui-icon layui-icon-carousel', 'data/base.slider/index', 'data/base.slider/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (5, 2, '页面内容管理', 'layui-icon layui-icon-read', 'data/base.pager/index', 'data/base.pager/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (6, 2, '文章内容管理', 'layui-icon layui-icon-template', 'data/news.item/index', 'data/news.item/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (7, 2, '支付参数管理', 'layui-icon layui-icon-rmb', 'data/base.payment/index', 'data/base.payment/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (8, 2, '系统通知管理', 'layui-icon layui-icon-notice', 'data/base.message/index', 'data/base.message/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (9, 2, '微信小程序配置', 'layui-icon layui-icon-set', 'data/base.config/wxapp', 'data/base.config/wxapp', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (10, 2, '邀请二维码设置', 'layui-icon layui-icon-cols', 'data/base.config/cropper', 'data/base.config/cropper', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (11, 1, '用户管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (12, 11, '会员用户管理', 'layui-icon layui-icon-user', 'data/user.admin/index', 'data/user.admin/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (13, 11, '余额充值管理', 'layui-icon layui-icon-rmb', 'data/user.balance/index', 'data/user.balance/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (14, 11, '用户返利管理', 'layui-icon layui-icon-transfer', 'data/user.rebate/index', 'data/user.rebate/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (15, 11, '用户提现管理', 'layui-icon layui-icon-component', 'data/user.transfer/index', 'data/user.transfer/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (16, 11, '用户等级管理', 'layui-icon layui-icon-senior', 'data/base.upgrade/index', 'data/base.upgrade/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (17, 11, '用户折扣方案', 'layui-icon layui-icon-set', 'data/base.discount/index', 'data/base.discount/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (18, 1, '商城管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (19, 18, '商品数据管理', 'layui-icon layui-icon-star', 'data/shop.goods/index', 'data/shop.goods/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (20, 18, '商品分类管理', 'layui-icon layui-icon-tabs', 'data/shop.cate/index', 'data/shop.cate/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (21, 18, '订单数据管理', 'layui-icon layui-icon-template', 'data/shop.order/index', 'data/shop.order/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (22, 18, '订单发货管理', 'layui-icon layui-icon-transfer', 'data/shop.send/index', 'data/shop.send/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (23, 18, '快递公司管理', 'layui-icon layui-icon-website', 'data/base.postage.company/index', 'data/base.postage.company/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (24, 18, '邮费模板管理', 'layui-icon layui-icon-template-1', 'data/base.postage.template/index', 'data/base.postage.template/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (25, 0, '微信管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (26, 25, '微信管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (27, 26, '微信接口配置', 'layui-icon layui-icon-set', '', 'wechat/config/options', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (28, 26, '微信支付配置', 'layui-icon layui-icon-rmb', '', 'wechat/config/payment', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (29, 25, '微信定制', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (30, 29, '微信粉丝管理', 'layui-icon layui-icon-username', '', 'wechat/fans/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (31, 29, '微信菜单配置', 'layui-icon layui-icon-cellphone', '', 'wechat/menu/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (32, 29, '微信图文管理', 'layui-icon layui-icon-template-1', '', 'wechat/news/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (33, 29, '回复规则管理', 'layui-icon layui-icon-engine', '', 'wechat/keys/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (34, 29, '关注自动回复', 'layui-icon layui-icon-release', 'wechat/auto/index', 'wechat/auto/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (35, 0, '系统管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (36, 35, '系统配置', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (37, 36, '系统参数配置', 'layui-icon layui-icon-set', '', 'admin/config/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (38, 36, '系统任务管理', 'layui-icon layui-icon-log', '', 'admin/queue/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (39, 36, '系统日志管理', 'layui-icon layui-icon-form', '', 'admin/oplog/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (40, 36, '数据字典管理', 'layui-icon layui-icon-code-circle', 'admin/base/index', 'admin/base/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (41, 36, '系统文件管理', 'layui-icon layui-icon-carousel', 'admin/file/index', 'admin/file/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (42, 36, '系统菜单管理', 'layui-icon layui-icon-layouts', '', 'admin/menu/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (43, 35, '权限管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (44, 43, '访问权限管理', 'layui-icon layui-icon-vercode', '', 'admin/auth/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (45, 43, '系统用户管理', 'layui-icon layui-icon-username', '', 'admin/user/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
SQL
|
||||
);
|
||||
}
|
||||
|
||||
private function _oplog()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_oplog';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-日志',
|
||||
])
|
||||
->addColumn('node', 'string', ['limit' => 200, 'default' => '', 'comment' => '当前操作节点'])
|
||||
->addColumn('geoip', 'string', ['limit' => 20, 'default' => '', 'comment' => '操作者IP地址'])
|
||||
->addColumn('action', 'string', ['limit' => 200, 'default' => '', 'comment' => '操作行为名称'])
|
||||
->addColumn('content', 'string', ['limit' => 1024, 'default' => '', 'comment' => '操作内容描述'])
|
||||
->addColumn('username', 'string', ['limit' => 50, 'default' => '', 'comment' => '操作人用户名'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _queue()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_queue';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-任务',
|
||||
])
|
||||
->addColumn('code', 'string', ['limit' => 20, 'default' => '', 'comment' => '任务编号'])
|
||||
->addColumn('title', 'string', ['limit' => 80, 'default' => '', 'comment' => '任务名称'])
|
||||
->addColumn('command', 'string', ['limit' => 500, 'default' => '', 'comment' => '执行指令'])
|
||||
->addColumn('exec_pid', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '执行进程'])
|
||||
->addColumn('exec_data', 'text', ['default' => '', 'comment' => '执行参数'])
|
||||
->addColumn('exec_time', 'decimal', ['precision' => 20, 'scale' => 4, 'default' => 0, 'comment' => '执行时间'])
|
||||
->addColumn('outer_time', 'decimal', ['precision' => 20, 'scale' => 4, 'default' => 0, 'comment' => '结束时间'])
|
||||
->addColumn('loops_time', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '循环时间'])
|
||||
->addColumn('attempts', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '执行次数'])
|
||||
->addColumn('rscript', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '任务类型(0单例,1多例)'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '任务状态(1新任务,2处理中,3成功,4失败)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('code', ['name' => 'idx_system_queue_code'])
|
||||
->addIndex('title', ['name' => 'idx_system_queue_title'])
|
||||
->addIndex('status', ['name' => 'idx_system_queue_status'])
|
||||
->addIndex('exec_time', ['name' => 'idx_system_queue_exec_time'])
|
||||
->addIndex('create_at', ['name' => 'idx_system_queue_create_at'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _user()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_user';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-用户',
|
||||
])->addColumn('usertype', 'string', ['limit' => 20, 'default' => '', 'comment' => '用户类型'])
|
||||
->addColumn('username', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户账号'])
|
||||
->addColumn('password', 'string', ['limit' => 32, 'default' => '', 'comment' => '用户密码'])
|
||||
->addColumn('nickname', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户昵称'])
|
||||
->addColumn('headimg', 'string', ['limit' => 500, 'default' => '', 'comment' => '头像地址'])
|
||||
->addColumn('authorize', 'string', ['limit' => 500, 'default' => '', 'comment' => '权限授权'])
|
||||
->addColumn('contact_qq', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系QQ'])
|
||||
->addColumn('contact_mail', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系邮箱'])
|
||||
->addColumn('contact_phone', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系手机'])
|
||||
->addColumn('login_ip', 'string', ['limit' => 20, 'default' => '', 'comment' => '登录地址'])
|
||||
->addColumn('login_at', 'string', ['limit' => 20, 'default' => '', 'comment' => '登录时间'])
|
||||
->addColumn('login_num', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '登录次数'])
|
||||
->addColumn('describe', 'string', ['limit' => 500, 'default' => '', 'comment' => '备注说明'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('is_deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(1删除,0未删)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('status', ['name' => 'idx_system_user_status'])
|
||||
->addIndex('username', ['name' => 'idx_system_user_username'])
|
||||
->addIndex('is_deleted', ['name' => 'idx_system_user_deleted'])
|
||||
->save();
|
||||
|
||||
// 初始化默认数据
|
||||
$data = [
|
||||
'id' => 10000,
|
||||
'username' => 'admin',
|
||||
'nickname' => '超级管理员',
|
||||
'password' => '21232f297a57a5a743894a0e4a801fc3',
|
||||
'headimg' => 'https://thinkadmin.top/static/img/icon.png',
|
||||
];
|
||||
$this->table($table)->insert($data)->saveData();
|
||||
}
|
||||
}
|
@ -1,30 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统权限数据
|
||||
*/
|
||||
class SystemAuth extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_auth';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-权限',
|
||||
])
|
||||
->addColumn('title', 'string', ['limit' => 80, 'default' => '', 'comment' => '权限名称'])
|
||||
->addColumn('utype', 'string', ['limit' => 50, 'default' => '', 'comment' => '身份权限'])
|
||||
->addColumn('desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '备注说明'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('sort', ['name' => 'idx_system_auth_sort'])
|
||||
->addIndex('title', ['name' => 'idx_system_auth_title'])
|
||||
->addIndex('status', ['name' => 'idx_system_auth_status'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,24 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统-授权
|
||||
*/
|
||||
class SystemAuthNode extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_auth_node';
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-授权',
|
||||
])
|
||||
->addColumn('auth', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '角色编号'])
|
||||
->addColumn('node', 'string', ['limit' => 200, 'default' => '', 'comment' => '节点路径'])
|
||||
->addIndex('auth', ['name' => 'idx_system_auth_node_auth'])
|
||||
->addIndex('node', ['name' => 'idx_system_auth_node_node'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,35 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统字典数据
|
||||
*/
|
||||
class SystemBase extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_base';
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-字典',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '数据类型'])
|
||||
->addColumn('code', 'string', ['limit' => 100, 'default' => '', 'comment' => '数据代码'])
|
||||
->addColumn('name', 'string', ['limit' => 500, 'default' => '', 'comment' => '数据名称'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '数据内容'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(0正常,1已删)'])
|
||||
->addColumn('deleted_at', 'string', ['limit' => 20, 'default' => '', 'comment' => '删除时间'])
|
||||
->addColumn('deleted_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '删除用户'])
|
||||
->addIndex('type', ['name' => 'idx_system_base_type'])
|
||||
->addIndex('code', ['name' => 'idx_system_base_code'])
|
||||
->addIndex('name', ['name' => 'idx_system_base_name'])
|
||||
->addIndex('sort', ['name' => 'idx_system_base_sort'])
|
||||
->addIndex('status', ['name' => 'idx_system_base_status'])
|
||||
->addIndex('deleted', ['name' => 'idx_system_base_deleted'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,54 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统配置数据
|
||||
*/
|
||||
class SystemConfig extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_config';
|
||||
// 创建数据表,存在则跳过
|
||||
if (!$this->hasTable($table)) {
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-配置',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '配置分类'])
|
||||
->addColumn('name', 'string', ['limit' => 100, 'default' => '', 'comment' => '配置名称'])
|
||||
->addColumn('value', 'string', ['limit' => 2048, 'default' => '', 'comment' => '配置内容'])
|
||||
->addIndex('type', ['name' => 'idx_system_config_type'])
|
||||
->addIndex('name', ['name' => 'idx_system_config_name'])
|
||||
->save();
|
||||
|
||||
// 初始化配置信息
|
||||
$this->execute(<<<SQL
|
||||
INSERT INTO {$table} VALUES (1, 'base', 'app_name', 'ThinkAdmin');
|
||||
INSERT INTO {$table} VALUES (2, 'base', 'app_version', 'v6');
|
||||
INSERT INTO {$table} VALUES (3, 'base', 'beian', '');
|
||||
INSERT INTO {$table} VALUES (4, 'base', 'editor', 'ckeditor5');
|
||||
INSERT INTO {$table} VALUES (5, 'base', 'login_image', '');
|
||||
INSERT INTO {$table} VALUES (6, 'base', 'login_name', '系统管理');
|
||||
INSERT INTO {$table} VALUES (7, 'base', 'miitbeian', '');
|
||||
INSERT INTO {$table} VALUES (8, 'base', 'site_copy', '©版权所有 2014-2022 楚才科技');
|
||||
INSERT INTO {$table} VALUES (9, 'base', 'site_host', '');
|
||||
INSERT INTO {$table} VALUES (10, 'base', 'site_icon', 'https://v6.thinkadmin.top/upload/4b/5a423974e447d5502023f553ed370f.png');
|
||||
INSERT INTO {$table} VALUES (11, 'base', 'site_name', 'ThinkAdmin');
|
||||
INSERT INTO {$table} VALUES (12, 'base', 'site_theme', 'default');
|
||||
INSERT INTO {$table} VALUES (13, 'base', 'xpath', 'admin');
|
||||
INSERT INTO {$table} VALUES (14, 'storage', 'alioss_http_protocol', 'http');
|
||||
INSERT INTO {$table} VALUES (15, 'storage', 'allow_exts', 'doc,gif,ico,jpg,mp3,mp4,p12,pem,png,zip,rar,xls,xlsx');
|
||||
INSERT INTO {$table} VALUES (16, 'storage', 'link_type', 'none');
|
||||
INSERT INTO {$table} VALUES (17, 'storage', 'local_http_domain', '');
|
||||
INSERT INTO {$table} VALUES (18, 'storage', 'local_http_protocol', 'follow');
|
||||
INSERT INTO {$table} VALUES (19, 'storage', 'name_type', 'xmd5');
|
||||
INSERT INTO {$table} VALUES (20, 'storage', 'type', 'local');
|
||||
INSERT INTO {$table} VALUES (21, 'wechat', 'type', 'api');
|
||||
INSERT INTO {$table} VALUES (22, 'storage', 'qiniu_http_protocol', 'http');
|
||||
SQL
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
@ -1,23 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统通用数据
|
||||
*/
|
||||
class SystemData extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_data';
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-数据',
|
||||
])
|
||||
->addColumn('name', 'string', ['limit' => 100, 'default' => '', 'comment' => '配置名'])
|
||||
->addColumn('value', 'text', ['default' => '', 'comment' => '配置值'])
|
||||
->addIndex('type', ['name' => 'idx_system_data_name'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,40 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统文件数据
|
||||
*/
|
||||
class SystemFile extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_file';
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-文件',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '上传类型'])
|
||||
->addColumn('hash', 'string', ['limit' => 32, 'default' => '', 'comment' => '文件哈希'])
|
||||
->addColumn('name', 'string', ['limit' => 200, 'default' => '', 'comment' => '文件名称'])
|
||||
->addColumn('xext', 'string', ['limit' => 100, 'default' => '', 'comment' => '文件后缀'])
|
||||
->addColumn('xurl', 'string', ['limit' => 500, 'default' => '', 'comment' => '访问链接'])
|
||||
->addColumn('xkey', 'string', ['limit' => 500, 'default' => '', 'comment' => '文件路径'])
|
||||
->addColumn('mime', 'string', ['limit' => 100, 'default' => '', 'comment' => '文件类型'])
|
||||
->addColumn('size', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '文件大小'])
|
||||
->addColumn('uuid', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '用户编号'])
|
||||
->addColumn('isfast', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '是否秒传'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'datetime', ['limit' => 20, 'default' => '', 'comment' => '创建时间'])
|
||||
->addColumn('update_at', 'datetime', ['limit' => 20, 'default' => 0, 'comment' => '更新时间'])
|
||||
->addIndex('type', ['name' => 'idx_system_file_type'])
|
||||
->addIndex('hash', ['name' => 'idx_system_file_hash'])
|
||||
->addIndex('uuid', ['name' => 'idx_system_file_uuid'])
|
||||
->addIndex('xext', ['name' => 'idx_system_file_xext'])
|
||||
->addIndex('status', ['name' => 'idx_system_file_status'])
|
||||
->addIndex('issafe', ['name' => 'idx_system_file_issafe'])
|
||||
->addIndex('isfast', ['name' => 'idx_system_file_isfast'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,87 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统菜单数据
|
||||
*/
|
||||
class SystemMenu extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_menu';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-菜单',
|
||||
])
|
||||
->addColumn('pid', 'integer', ['limit' => 20, 'default' => 1, 'comment' => '上级编号'])
|
||||
->addColumn('title', 'string', ['limit' => 100, 'default' => '', 'comment' => '菜单名称'])
|
||||
->addColumn('icon', 'string', ['limit' => 100, 'default' => '', 'comment' => '菜单图标'])
|
||||
->addColumn('node', 'string', ['limit' => 100, 'default' => '', 'comment' => '节点代码'])
|
||||
->addColumn('url', 'string', ['limit' => 500, 'default' => '', 'comment' => '链接节点'])
|
||||
->addColumn('params', 'string', ['limit' => 500, 'default' => '', 'comment' => '链接参数'])
|
||||
->addColumn('target', 'string', ['limit' => 20, 'default' => '_self', 'comment' => '打开方式'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('pid', ['name' => 'idx_system_menu_pid'])
|
||||
->addIndex('sort', ['name' => 'idx_system_menu_sort'])
|
||||
->addIndex('status', ['name' => 'idx_system_menu_status'])
|
||||
->save();
|
||||
|
||||
// 初始化菜单数据
|
||||
$this->execute(<<<SQL
|
||||
INSERT INTO {$table} VALUES (1, 0, '控制台', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (2, 1, '数据管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (3, 2, '数据统计报表', 'layui-icon layui-icon-theme', 'data/total.portal/index', 'data/total.portal/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (4, 2, '轮播图片管理', 'layui-icon layui-icon-carousel', 'data/base.slider/index', 'data/base.slider/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (5, 2, '页面内容管理', 'layui-icon layui-icon-read', 'data/base.pager/index', 'data/base.pager/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (6, 2, '文章内容管理', 'layui-icon layui-icon-template', 'data/news.item/index', 'data/news.item/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (7, 2, '支付参数管理', 'layui-icon layui-icon-rmb', 'data/base.payment/index', 'data/base.payment/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (8, 2, '系统通知管理', 'layui-icon layui-icon-notice', 'data/base.message/index', 'data/base.message/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (9, 2, '微信小程序配置', 'layui-icon layui-icon-set', 'data/base.config/wxapp', 'data/base.config/wxapp', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (10, 2, '邀请二维码设置', 'layui-icon layui-icon-cols', 'data/base.config/cropper', 'data/base.config/cropper', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (11, 1, '用户管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (12, 11, '会员用户管理', 'layui-icon layui-icon-user', 'data/user.admin/index', 'data/user.admin/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (13, 11, '余额充值管理', 'layui-icon layui-icon-rmb', 'data/user.balance/index', 'data/user.balance/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (14, 11, '用户返利管理', 'layui-icon layui-icon-transfer', 'data/user.rebate/index', 'data/user.rebate/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (15, 11, '用户提现管理', 'layui-icon layui-icon-component', 'data/user.transfer/index', 'data/user.transfer/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (16, 11, '用户等级管理', 'layui-icon layui-icon-senior', 'data/base.upgrade/index', 'data/base.upgrade/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (17, 11, '用户折扣方案', 'layui-icon layui-icon-set', 'data/base.discount/index', 'data/base.discount/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (18, 1, '商城管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (19, 18, '商品数据管理', 'layui-icon layui-icon-star', 'data/shop.goods/index', 'data/shop.goods/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (20, 18, '商品分类管理', 'layui-icon layui-icon-tabs', 'data/shop.cate/index', 'data/shop.cate/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (21, 18, '订单数据管理', 'layui-icon layui-icon-template', 'data/shop.order/index', 'data/shop.order/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (22, 18, '订单发货管理', 'layui-icon layui-icon-transfer', 'data/shop.send/index', 'data/shop.send/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (23, 18, '快递公司管理', 'layui-icon layui-icon-website', 'data/base.postage.company/index', 'data/base.postage.company/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (24, 18, '邮费模板管理', 'layui-icon layui-icon-template-1', 'data/base.postage.template/index', 'data/base.postage.template/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (25, 0, '微信管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (26, 25, '微信管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (27, 26, '微信接口配置', 'layui-icon layui-icon-set', '', 'wechat/config/options', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (28, 26, '微信支付配置', 'layui-icon layui-icon-rmb', '', 'wechat/config/payment', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (29, 25, '微信定制', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (30, 29, '微信粉丝管理', 'layui-icon layui-icon-username', '', 'wechat/fans/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (31, 29, '微信菜单配置', 'layui-icon layui-icon-cellphone', '', 'wechat/menu/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (32, 29, '微信图文管理', 'layui-icon layui-icon-template-1', '', 'wechat/news/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (33, 29, '回复规则管理', 'layui-icon layui-icon-engine', '', 'wechat/keys/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (34, 29, '关注自动回复', 'layui-icon layui-icon-release', 'wechat/auto/index', 'wechat/auto/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (35, 0, '系统管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (36, 35, '系统配置', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (37, 36, '系统参数配置', 'layui-icon layui-icon-set', '', 'admin/config/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (38, 36, '系统任务管理', 'layui-icon layui-icon-log', '', 'admin/queue/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (39, 36, '系统日志管理', 'layui-icon layui-icon-form', '', 'admin/oplog/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (40, 36, '数据字典管理', 'layui-icon layui-icon-code-circle', 'admin/base/index', 'admin/base/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (41, 36, '系统文件管理', 'layui-icon layui-icon-carousel', 'admin/file/index', 'admin/file/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (42, 36, '系统菜单管理', 'layui-icon layui-icon-layouts', '', 'admin/menu/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (43, 35, '权限管理', '', '', '#', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (44, 43, '访问权限管理', 'layui-icon layui-icon-vercode', '', 'admin/auth/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
INSERT INTO {$table} VALUES (45, 43, '系统用户管理', 'layui-icon layui-icon-username', '', 'admin/user/index', '', '_self', 0, 1, '2022-10-13 12:19:45');
|
||||
SQL
|
||||
);
|
||||
}
|
||||
}
|
@ -1,30 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统日志数据
|
||||
*/
|
||||
class SystemOplog extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_oplog';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-日志',
|
||||
])
|
||||
->addColumn('node', 'string', ['limit' => 200, 'default' => '', 'comment' => '当前操作节点'])
|
||||
->addColumn('geoip', 'string', ['limit' => 20, 'default' => '', 'comment' => '操作者IP地址'])
|
||||
->addColumn('action', 'string', ['limit' => 200, 'default' => '', 'comment' => '操作行为名称'])
|
||||
->addColumn('content', 'string', ['limit' => 1024, 'default' => '', 'comment' => '操作内容描述'])
|
||||
->addColumn('username', 'string', ['limit' => 50, 'default' => '', 'comment' => '操作人用户名'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,41 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统任务数据
|
||||
*/
|
||||
class SystemQueue extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_queue';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-任务',
|
||||
])
|
||||
->addColumn('code', 'string', ['limit' => 20, 'default' => '', 'comment' => '任务编号'])
|
||||
->addColumn('title', 'string', ['limit' => 80, 'default' => '', 'comment' => '任务名称'])
|
||||
->addColumn('command', 'string', ['limit' => 500, 'default' => '', 'comment' => '执行指令'])
|
||||
->addColumn('exec_pid', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '执行进程'])
|
||||
->addColumn('exec_data', 'text', ['default' => '', 'comment' => '执行参数'])
|
||||
->addColumn('exec_time', 'decimal', ['precision' => 20, 'scale' => 4, 'default' => 0, 'comment' => '执行时间'])
|
||||
->addColumn('outer_time', 'decimal', ['precision' => 20, 'scale' => 4, 'default' => 0, 'comment' => '结束时间'])
|
||||
->addColumn('loops_time', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '循环时间'])
|
||||
->addColumn('attempts', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '执行次数'])
|
||||
->addColumn('rscript', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '任务类型(0单例,1多例)'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '任务状态(1新任务,2处理中,3成功,4失败)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('code', ['name' => 'idx_system_queue_code'])
|
||||
->addIndex('title', ['name' => 'idx_system_queue_title'])
|
||||
->addIndex('status', ['name' => 'idx_system_queue_status'])
|
||||
->addIndex('exec_time', ['name' => 'idx_system_queue_exec_time'])
|
||||
->addIndex('create_at', ['name' => 'idx_system_queue_create_at'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,53 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 系统用户数据
|
||||
*/
|
||||
class SystemUser extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'system_user';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) return;
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '系统-用户',
|
||||
])->addColumn('usertype', 'string', ['limit' => 20, 'default' => '', 'comment' => '用户类型'])
|
||||
->addColumn('username', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户账号'])
|
||||
->addColumn('password', 'string', ['limit' => 32, 'default' => '', 'comment' => '用户密码'])
|
||||
->addColumn('nickname', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户昵称'])
|
||||
->addColumn('headimg', 'string', ['limit' => 500, 'default' => '', 'comment' => '头像地址'])
|
||||
->addColumn('authorize', 'string', ['limit' => 500, 'default' => '', 'comment' => '权限授权'])
|
||||
->addColumn('contact_qq', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系QQ'])
|
||||
->addColumn('contact_mail', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系邮箱'])
|
||||
->addColumn('contact_phone', 'string', ['limit' => 20, 'default' => '', 'comment' => '联系手机'])
|
||||
->addColumn('login_ip', 'string', ['limit' => 20, 'default' => '', 'comment' => '登录地址'])
|
||||
->addColumn('login_at', 'string', ['limit' => 20, 'default' => '', 'comment' => '登录时间'])
|
||||
->addColumn('login_num', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '登录次数'])
|
||||
->addColumn('describe', 'string', ['limit' => 500, 'default' => '', 'comment' => '备注说明'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('is_deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(1删除,0未删)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('status', ['name' => 'idx_system_user_status'])
|
||||
->addIndex('username', ['name' => 'idx_system_user_username'])
|
||||
->addIndex('is_deleted', ['name' => 'idx_system_user_deleted'])
|
||||
->save();
|
||||
|
||||
// 初始化默认数据
|
||||
$data = [
|
||||
'id' => 10000,
|
||||
'username' => 'admin',
|
||||
'nickname' => '超级管理员',
|
||||
'password' => '21232f297a57a5a743894a0e4a801fc3',
|
||||
'headimg' => 'https://thinkadmin.top/static/img/icon.png',
|
||||
];
|
||||
$this->table($table)->insert($data)->saveData();
|
||||
}
|
||||
}
|
210
database/migrations/20221013045829_install_wechat.php
Normal file
210
database/migrations/20221013045829_install_wechat.php
Normal file
@ -0,0 +1,210 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信模块数据表
|
||||
*/
|
||||
class InstallWechat extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
$this->_auto();
|
||||
$this->_article();
|
||||
$this->_fans();
|
||||
$this->_media();
|
||||
$this->_news();
|
||||
$this->_tags();
|
||||
$this->_keys();
|
||||
}
|
||||
|
||||
private function _auto()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_auto';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-回复',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '类型(text,image,news)'])
|
||||
->addColumn('time', 'string', ['limit' => 50, 'default' => '', 'comment' => '延迟时间'])
|
||||
->addColumn('code', 'string', ['limit' => 20, 'default' => '', 'comment' => '消息编号'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '文本内容'])
|
||||
->addColumn('image_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '图片链接'])
|
||||
->addColumn('voice_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '语音链接'])
|
||||
->addColumn('music_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐标题'])
|
||||
->addColumn('music_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐链接'])
|
||||
->addColumn('music_image', 'string', ['limit' => 500, 'default' => '', 'comment' => '缩略图片'])
|
||||
->addColumn('music_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐描述'])
|
||||
->addColumn('video_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频标题'])
|
||||
->addColumn('video_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频链接'])
|
||||
->addColumn('video_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频描述'])
|
||||
->addColumn('news_id', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '图文编号'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('code', ['name' => 'idx_wechat_auto_code'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_auto_type'])
|
||||
->addIndex('time', ['name' => 'idx_wechat_auto_time'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_auto_appid'])
|
||||
->addIndex('status', ['name' => 'idx_wechat_auto_status'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _fans()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_fans';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-粉丝',
|
||||
])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('unionid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'UNIONID'])
|
||||
->addColumn('openid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'OPENID'])
|
||||
->addColumn('tagid_list', 'string', ['limit' => 100, 'default' => '', 'comment' => '粉丝标签'])
|
||||
->addColumn('is_black', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '黑名单状态'])
|
||||
->addColumn('subscribe', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '黑名单状态'])
|
||||
->addColumn('nickname', 'string', ['limit' => 200, 'default' => '', 'comment' => '用户昵称'])
|
||||
->addColumn('sex', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '用户性别(1男性,2女性,0未知)'])
|
||||
->addColumn('country', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在国家'])
|
||||
->addColumn('province', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在省份'])
|
||||
->addColumn('city', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在城市'])
|
||||
->addColumn('language', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户的语言'])
|
||||
->addColumn('headimgurl', 'string', ['limit' => 500, 'default' => '', 'comment' => '用户头像'])
|
||||
->addColumn('subscribe_time', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '关注时间'])
|
||||
->addColumn('subscribe_at', 'datetime', ['limit' => 20, 'default' => null, 'comment' => '关注时间'])
|
||||
->addColumn('subscribe_scene', 'string', ['limit' => 200, 'default' => '', 'comment' => '扫码场景'])
|
||||
->addColumn('qr_scene', 'string', ['limit' => 200, 'default' => '', 'comment' => '场景数值'])
|
||||
->addColumn('qr_scene_str', 'string', ['limit' => 200, 'default' => '', 'comment' => '场景内容'])
|
||||
->addColumn('remark', 'string', ['limit' => 500, 'default' => '', 'comment' => '用户备注'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_fans_appid'])
|
||||
->addIndex('openid', ['name' => 'idx_wechat_fans_openid'])
|
||||
->addIndex('unionid', ['name' => 'idx_wechat_fans_unionid'])
|
||||
->addIndex('is_black', ['name' => 'idx_wechat_fans_black'])
|
||||
->addIndex('subscribe', ['name' => 'idx_wechat_fans_subscribe'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _tags()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_fans_tags';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-标签',
|
||||
])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('name', 'string', ['limit' => 50, 'default' => '', 'comment' => '标签名称'])
|
||||
->addColumn('openid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'OPENID'])
|
||||
->addColumn('count', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '粉丝数量'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_fans_appid'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _keys()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_keys';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-规则',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '类型(text,image,news)'])
|
||||
->addColumn('keys', 'string', ['limit' => 100, 'default' => '', 'comment' => '关键字'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '文本内容'])
|
||||
->addColumn('image_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '图片链接'])
|
||||
->addColumn('voice_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '语音链接'])
|
||||
->addColumn('music_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐标题'])
|
||||
->addColumn('music_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐链接'])
|
||||
->addColumn('music_image', 'string', ['limit' => 500, 'default' => '', 'comment' => '缩略图片'])
|
||||
->addColumn('music_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐描述'])
|
||||
->addColumn('video_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频标题'])
|
||||
->addColumn('video_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频链接'])
|
||||
->addColumn('video_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频描述'])
|
||||
->addColumn('news_id', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '图文编号'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '创建用户'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('sort', ['name' => 'idx_wechat_keys_sort'])
|
||||
->addIndex('keys', ['name' => 'idx_wechat_keys_keys'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_keys_type'])
|
||||
->addIndex('time', ['name' => 'idx_wechat_keys_time'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_keys_appid'])
|
||||
->addIndex('status', ['name' => 'idx_wechat_keys_status'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _media()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_media';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-素材',
|
||||
])
|
||||
->addColumn('md5', 'string', ['limit' => 32, 'default' => '', 'comment' => '文件哈希'])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '媒体类型'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('media_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '永久素材MediaID'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '本地文件链接'])
|
||||
->addColumn('media_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '远程图片链接'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('md5', ['name' => 'idx_wechat_media_md5'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_media_type'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_media_appid'])
|
||||
->addIndex('media_id', ['name' => 'idx_wechat_media_id'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _news()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_news';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-图文',
|
||||
])
|
||||
->addColumn('media_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '永久素材编号'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '本地文件链接'])
|
||||
->addColumn('article_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '关联文章编号(用英文逗号做分割)'])
|
||||
->addColumn('is_deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(1删除,0未删)'])
|
||||
->addColumn('create_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '创建用户'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('media_id', ['name' => 'idx_wechat_news_media_id'])
|
||||
->addIndex('article_id', ['name' => 'idx_wechat_news_article_id'])
|
||||
->addIndex('is_deleted', ['name' => 'idx_wechat_news_deleted'])
|
||||
->save();
|
||||
}
|
||||
|
||||
private function _article()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_news_article';
|
||||
|
||||
// 创建数据表,存在则跳过
|
||||
$this->hasTable($table) || $this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-文章',
|
||||
])
|
||||
->addColumn('title', 'string', ['limit' => 100, 'default' => '', 'comment' => '素材标题'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '素材链接'])
|
||||
->addColumn('show_cover_pic', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '显示封面(0隐藏,1显示)'])
|
||||
->addColumn('author', 'string', ['limit' => 20, 'default' => '', 'comment' => '文章作者'])
|
||||
->addColumn('digest', 'string', ['limit' => 300, 'default' => '', 'comment' => '摘要内容'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '图文内容'])
|
||||
->addColumn('content_source_url', 'string', ['limit' => 200, 'default' => '', 'comment' => '原文地址'])
|
||||
->addColumn('read_num', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '阅读数量'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,48 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信回复数据
|
||||
*/
|
||||
class WechatAuto extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_auto';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-回复',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '类型(text,image,news)'])
|
||||
->addColumn('time', 'string', ['limit' => 50, 'default' => '', 'comment' => '延迟时间'])
|
||||
->addColumn('code', 'string', ['limit' => 20, 'default' => '', 'comment' => '消息编号'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '文本内容'])
|
||||
->addColumn('image_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '图片链接'])
|
||||
->addColumn('voice_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '语音链接'])
|
||||
->addColumn('music_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐标题'])
|
||||
->addColumn('music_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐链接'])
|
||||
->addColumn('music_image', 'string', ['limit' => 500, 'default' => '', 'comment' => '缩略图片'])
|
||||
->addColumn('music_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐描述'])
|
||||
->addColumn('video_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频标题'])
|
||||
->addColumn('video_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频链接'])
|
||||
->addColumn('video_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频描述'])
|
||||
->addColumn('news_id', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '图文编号'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('code', ['name' => 'idx_wechat_auto_code'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_auto_type'])
|
||||
->addIndex('time', ['name' => 'idx_wechat_auto_time'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_auto_appid'])
|
||||
->addIndex('status', ['name' => 'idx_wechat_auto_status'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,51 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信粉丝数据
|
||||
*/
|
||||
class WechatFans extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_fans';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-粉丝',
|
||||
])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('unionid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'UNIONID'])
|
||||
->addColumn('openid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'OPENID'])
|
||||
->addColumn('tagid_list', 'string', ['limit' => 100, 'default' => '', 'comment' => '粉丝标签'])
|
||||
->addColumn('is_black', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '黑名单状态'])
|
||||
->addColumn('subscribe', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '黑名单状态'])
|
||||
->addColumn('nickname', 'string', ['limit' => 200, 'default' => '', 'comment' => '用户昵称'])
|
||||
->addColumn('sex', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '用户性别(1男性,2女性,0未知)'])
|
||||
->addColumn('country', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在国家'])
|
||||
->addColumn('province', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在省份'])
|
||||
->addColumn('city', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户所在城市'])
|
||||
->addColumn('language', 'string', ['limit' => 50, 'default' => '', 'comment' => '用户的语言'])
|
||||
->addColumn('headimgurl', 'string', ['limit' => 500, 'default' => '', 'comment' => '用户头像'])
|
||||
->addColumn('subscribe_time', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '关注时间'])
|
||||
->addColumn('subscribe_at', 'datetime', ['limit' => 20, 'default' => null, 'comment' => '关注时间'])
|
||||
->addColumn('subscribe_scene', 'string', ['limit' => 200, 'default' => '', 'comment' => '扫码场景'])
|
||||
->addColumn('qr_scene', 'string', ['limit' => 200, 'default' => '', 'comment' => '场景数值'])
|
||||
->addColumn('qr_scene_str', 'string', ['limit' => 200, 'default' => '', 'comment' => '场景内容'])
|
||||
->addColumn('remark', 'string', ['limit' => 500, 'default' => '', 'comment' => '用户备注'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_fans_appid'])
|
||||
->addIndex('openid', ['name' => 'idx_wechat_fans_openid'])
|
||||
->addIndex('unionid', ['name' => 'idx_wechat_fans_unionid'])
|
||||
->addIndex('is_black', ['name' => 'idx_wechat_fans_black'])
|
||||
->addIndex('subscribe', ['name' => 'idx_wechat_fans_subscribe'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,32 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信标签数据
|
||||
*/
|
||||
class WechatFansTags extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_fans_tags';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-标签',
|
||||
])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('name', 'string', ['limit' => 50, 'default' => '', 'comment' => '标签名称'])
|
||||
->addColumn('openid', 'string', ['limit' => 100, 'default' => '', 'comment' => 'OPENID'])
|
||||
->addColumn('count', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '粉丝数量'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_fans_appid'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,50 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信关键字数据
|
||||
*/
|
||||
class WechatKeys extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_keys';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-规则',
|
||||
])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '类型(text,image,news)'])
|
||||
->addColumn('keys', 'string', ['limit' => 100, 'default' => '', 'comment' => '关键字'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '文本内容'])
|
||||
->addColumn('image_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '图片链接'])
|
||||
->addColumn('voice_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '语音链接'])
|
||||
->addColumn('music_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐标题'])
|
||||
->addColumn('music_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐链接'])
|
||||
->addColumn('music_image', 'string', ['limit' => 500, 'default' => '', 'comment' => '缩略图片'])
|
||||
->addColumn('music_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '音乐描述'])
|
||||
->addColumn('video_title', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频标题'])
|
||||
->addColumn('video_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频链接'])
|
||||
->addColumn('video_desc', 'string', ['limit' => 500, 'default' => '', 'comment' => '视频描述'])
|
||||
->addColumn('news_id', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '图文编号'])
|
||||
->addColumn('sort', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '排序权重'])
|
||||
->addColumn('status', 'integer', ['limit' => 1, 'default' => 1, 'comment' => '状态(0禁用,1启用)'])
|
||||
->addColumn('create_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '创建用户'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('sort', ['name' => 'idx_wechat_keys_sort'])
|
||||
->addIndex('keys', ['name' => 'idx_wechat_keys_keys'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_keys_type'])
|
||||
->addIndex('time', ['name' => 'idx_wechat_keys_time'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_keys_appid'])
|
||||
->addIndex('status', ['name' => 'idx_wechat_keys_status'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,37 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信素材数据
|
||||
*/
|
||||
class WechatMedia extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_media';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-素材',
|
||||
])
|
||||
->addColumn('md5', 'string', ['limit' => 32, 'default' => '', 'comment' => '文件哈希'])
|
||||
->addColumn('type', 'string', ['limit' => 20, 'default' => '', 'comment' => '媒体类型'])
|
||||
->addColumn('appid', 'string', ['limit' => 50, 'default' => '', 'comment' => '公众号编号'])
|
||||
->addColumn('media_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '永久素材MediaID'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '本地文件链接'])
|
||||
->addColumn('media_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '远程图片链接'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('md5', ['name' => 'idx_wechat_media_md5'])
|
||||
->addIndex('type', ['name' => 'idx_wechat_media_type'])
|
||||
->addIndex('appid', ['name' => 'idx_wechat_media_appid'])
|
||||
->addIndex('media_id', ['name' => 'idx_wechat_media_id'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,35 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信图文数据
|
||||
*/
|
||||
class WechatNews extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_news';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-图文',
|
||||
])
|
||||
->addColumn('media_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '永久素材编号'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '本地文件链接'])
|
||||
->addColumn('article_id', 'string', ['limit' => 100, 'default' => '', 'comment' => '关联文章编号(用英文逗号做分割)'])
|
||||
->addColumn('is_deleted', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '删除(1删除,0未删)'])
|
||||
->addColumn('create_by', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '创建用户'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->addIndex('media_id', ['name' => 'idx_wechat_news_media_id'])
|
||||
->addIndex('article_id', ['name' => 'idx_wechat_news_article_id'])
|
||||
->addIndex('is_deleted', ['name' => 'idx_wechat_news_deleted'])
|
||||
->save();
|
||||
}
|
||||
}
|
@ -1,34 +0,0 @@
|
||||
<?php
|
||||
|
||||
use think\migration\Migrator;
|
||||
|
||||
/**
|
||||
* 微信文章数据
|
||||
*/
|
||||
class WechatNewsArticle extends Migrator
|
||||
{
|
||||
public function change()
|
||||
{
|
||||
// 当前操作
|
||||
$table = 'wechat_news_article';
|
||||
|
||||
// 存在则跳过
|
||||
if ($this->hasTable($table)) {
|
||||
return;
|
||||
}
|
||||
// 创建数据表
|
||||
$this->table($table, [
|
||||
'engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '微信-文章',
|
||||
])
|
||||
->addColumn('title', 'string', ['limit' => 100, 'default' => '', 'comment' => '素材标题'])
|
||||
->addColumn('local_url', 'string', ['limit' => 500, 'default' => '', 'comment' => '素材链接'])
|
||||
->addColumn('show_cover_pic', 'integer', ['limit' => 1, 'default' => 0, 'comment' => '显示封面(0隐藏,1显示)'])
|
||||
->addColumn('author', 'string', ['limit' => 20, 'default' => '', 'comment' => '文章作者'])
|
||||
->addColumn('digest', 'string', ['limit' => 300, 'default' => '', 'comment' => '摘要内容'])
|
||||
->addColumn('content', 'text', ['default' => '', 'comment' => '图文内容'])
|
||||
->addColumn('content_source_url', 'string', ['limit' => 200, 'default' => '', 'comment' => '原文地址'])
|
||||
->addColumn('read_num', 'integer', ['limit' => 20, 'default' => 0, 'comment' => '阅读数量'])
|
||||
->addColumn('create_at', 'timestamp', ['default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
|
||||
->save();
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user