Skip to content
forked from bjq/gotools

gotools是一个带角色、权限、用户管理的Go脚手架生成工具,可一键生成开箱即用的源码程序,一键生成基础的增删改查前后端代码

Notifications You must be signed in to change notification settings

ansoda/gotools-1

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

92 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gotools

  1. gotools一键生成自由灵活配置角色、权限、用户管理脚手架代码的生成工具
  2. gotools可一键生成开箱即用的源码程序,一键生成基础的增删改查前后端代码
  3. 生成的前端代码使用Vue、ElementUI、vue-element-admin等开源项目
  4. 生成的后端代码使用gin、xormplus、casbin、gf、jwt等开源项目

多层级权限架构

  1. 例如我的系统层级结构是:平台->银行->服务商->商家,我们暂且叫这四个层级为机构类型,如下图: 权限架构

  2. 例如现在平台下有10个银行,每个银行有20个服务商,每个服务商有30个商户,并且要求每个银行、服务商、商户都有自己的角色、权限、用户管理

按上面这种业务层级机构来使用gotools完成权限管理,使用步骤如下:

  1. git clone https://github.com/gopark001/gotools
  2. cd gotools/configs
  3. 修改mysql.toml,将mysql配置信息改为你的数据库信息,数据库名称可随意
  4. 修改casbin.toml,将mysql配置信息改为你的数据库信息,且数据库名称必须为casbin
  5. 修改org_type.json, 这个文件中存的是机构类型,有层级关系,配置如下:
[
  { "id":1, "parent_id":0, "name":"平台",   "code":"platform" },
  { "id":2, "parent_id":1, "name":"银行",   "code":"bank" },
  { "id":3, "parent_id":2, "name":"服务商", "code":"service_provider" },
  { "id":4, "parent_id":3, "name":"商户",   "code":"shop" }
]
  1. 修改org.json, 这个文件中存的是机构的数据库字段定义,配置如下:
// "code": "string,50,银行编码,1"
// code为数据库字段名称,string是golang中的数据类型,50是字段长度,银行编码是字段描述,1是字段顺序
{
  "bank": {
    "code":           "string,50,银行编码,1",
    "name":           "string,80,银行名称,2",
    "contact_name":   "string,40,联系人,3",
    "service_phone":  "string,20,联系电话,4",
    "org_type_id":    "int64, 20,所属机构类型ID,5",
    "org_type_name":  "string,40,所属机构类型名称,6",
    "account":        "string,40,管理员账号,7"
  },
  "service_provider": {
    "name":           "string,80,服务商名称,1",
    "contact_name":   "string,40,联系人,2",
    "service_phone":  "string,20,联系电话,3",
    "address":        "string,80,联系地址,4",
    "org_type_id":    "int64, 20,所属机构类型ID,5",
    "org_type_name":  "string,40,所属机构类型名称,6",
    "account":        "string,40,管理员账号,7"
  },
  "shop": {
    "name":           "string,80,商家名称,1",
    "contact_name":   "string,40,联系人,2",
    "service_phone":  "string,20,服务电话,3",
    "address":        "string,80,商家地址,4",
    "org_type_id":    "int64, 20,所属机构类型ID,5",
    "org_type_name":  "string,40,所属机构类型名称,6",
    "account":        "string,40,管理员账号,7"
  },
  "desc": {
    "bank": "银行",
    "service_provider": "服务商",
    "shop": "商家"
  }
}
  1. 创建hello项目
cd gotools/cmd

go build gotools.go

// MacOS/Linux
./gotools -newProject hello

// Windows  windows系统下建议使用git bash命令行工具,下载地址:https://git-scm.com/download/win
./gotools.exe -newProject hello
  1. 查看并启动生成的代码
// 启动生成的go程序
cd gotools/output

// 进入项目根目录
cd hello-go

// 下载依赖包
go mod tidy

// 运行
cd cmd && go run main.go


// 启动生成的前端Vue程序
cd gotools/output

cd hello-admin

npm install && npm run dev
  1. 初始化超级管理员账号密码为:super_admin/111111 有疑问可以加我微信:
    微信二维码

About

gotools是一个带角色、权限、用户管理的Go脚手架生成工具,可一键生成开箱即用的源码程序,一键生成基础的增删改查前后端代码

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Vue 37.2%
  • Go 32.2%
  • JavaScript 21.9%
  • Smarty 4.5%
  • CSS 3.8%
  • HTML 0.4%