package v1 import ( "errors" "fmt" "gin-vue-admin/global" "gin-vue-admin/model" "gin-vue-admin/model/request" "gin-vue-admin/model/response" "gin-vue-admin/service" "gin-vue-admin/utils" "net/url" "os" "github.com/gin-gonic/gin" "go.uber.org/zap" ) // @Tags AutoCode // @Summary 查询回滚记录 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Param data body request.SysAutoHistory true "查询回滚记录" // @Success 200 {string} string "{"success":true,"data":{},"msg":"回滚成功"}" // @Router /autoCode/preview [post] func GetSysHistory(c *gin.Context) { var search request.SysAutoHistory _ = c.ShouldBindJSON(&search) err, list, total := service.GetSysHistoryPage(search.PageInfo) if err != nil { global.GVA_LOG.Error("获取失败!", zap.Any("err", err)) response.FailWithMessage("获取失败", c) } else { response.OkWithDetailed(response.PageResult{ List: list, Total: total, Page: search.Page, PageSize: search.PageSize, }, "获取成功", c) } } // @Tags AutoCode // @Summary 回滚 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Param data body request.AutoHistoryByID true "回滚自动生成代码" // @Success 200 {string} string "{"success":true,"data":{},"msg":"回滚成功"}" // @Router /autoCode/preview [post] func RollBack(c *gin.Context) { var id request.AutoHistoryByID _ = c.ShouldBindJSON(&id) if err := service.RollBack(id.ID); err != nil { response.FailWithMessage(err.Error(), c) return } response.OkWithMessage("回滚成功", c) } // @Tags AutoCode // @Summary 预览创建后的代码 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Param data body model.AutoCodeStruct true "预览创建代码" // @Success 200 {string} string "{"success":true,"data":{},"msg":"创建成功"}" // @Router /autoCode/preview [post] func PreviewTemp(c *gin.Context) { var a model.AutoCodeStruct _ = c.ShouldBindJSON(&a) if err := utils.Verify(a, utils.AutoCodeVerify); err != nil { response.FailWithMessage(err.Error(), c) return } autoCode, err := service.PreviewTemp(a) if err != nil { global.GVA_LOG.Error("预览失败!", zap.Any("err", err)) response.FailWithMessage("预览失败", c) } else { response.OkWithDetailed(gin.H{"autoCode": autoCode}, "预览成功", c) } } // @Tags AutoCode // @Summary 自动代码模板 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Param data body model.AutoCodeStruct true "创建自动代码" // @Success 200 {string} string "{"success":true,"data":{},"msg":"创建成功"}" // @Router /autoCode/createTemp [post] func CreateTemp(c *gin.Context) { var a model.AutoCodeStruct _ = c.ShouldBindJSON(&a) if err := utils.Verify(a, utils.AutoCodeVerify); err != nil { response.FailWithMessage(err.Error(), c) return } var apiIds []uint if a.AutoCreateApiToSql { if ids, err := service.AutoCreateApi(&a); err != nil { global.GVA_LOG.Error("自动化创建失败!请自行清空垃圾数据!", zap.Any("err", err)) c.Writer.Header().Add("success", "false") c.Writer.Header().Add("msg", url.QueryEscape("自动化创建失败!请自行清空垃圾数据!")) return } else { apiIds = ids } } err := service.CreateTemp(a, apiIds...) if err != nil { if errors.Is(err, model.AutoMoveErr) { c.Writer.Header().Add("success", "false") c.Writer.Header().Add("msgtype", "success") c.Writer.Header().Add("msg", url.QueryEscape(err.Error())) } else { c.Writer.Header().Add("success", "false") c.Writer.Header().Add("msg", url.QueryEscape(err.Error())) _ = os.Remove("./ginvueadmin.zip") } } else { c.Writer.Header().Add("Content-Disposition", fmt.Sprintf("attachment; filename=%s", "ginvueadmin.zip")) // fmt.Sprintf("attachment; filename=%s", filename)对下载的文件重命名 c.Writer.Header().Add("Content-Type", "application/json") c.Writer.Header().Add("success", "true") c.File("./ginvueadmin.zip") _ = os.Remove("./ginvueadmin.zip") } } // @Tags AutoCode // @Summary 获取当前数据库所有表 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Success 200 {string} string "{"success":true,"data":{},"msg":"获取成功"}" // @Router /autoCode/getTables [get] func GetTables(c *gin.Context) { dbName := c.DefaultQuery("dbName", global.GVA_CONFIG.Mysql.Dbname) err, tables := service.GetTables(dbName) if err != nil { global.GVA_LOG.Error("查询table失败!", zap.Any("err", err)) response.FailWithMessage("查询table失败", c) } else { response.OkWithDetailed(gin.H{"tables": tables}, "获取成功", c) } } // @Tags AutoCode // @Summary 获取当前所有数据库 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Success 200 {string} string "{"success":true,"data":{},"msg":"获取成功"}" // @Router /autoCode/getDatabase [get] func GetDB(c *gin.Context) { if err, dbs := service.GetDB(); err != nil { global.GVA_LOG.Error("获取失败!", zap.Any("err", err)) response.FailWithMessage("获取失败", c) } else { response.OkWithDetailed(gin.H{"dbs": dbs}, "获取成功", c) } } // @Tags AutoCode // @Summary 获取当前表所有字段 // @Security ApiKeyAuth // @accept application/json // @Produce application/json // @Success 200 {string} string "{"success":true,"data":{},"msg":"获取成功"}" // @Router /autoCode/getColumn [get] func GetColumn(c *gin.Context) { dbName := c.DefaultQuery("dbName", global.GVA_CONFIG.Mysql.Dbname) tableName := c.Query("tableName") if err, columns := service.GetColumn(tableName, dbName); err != nil { global.GVA_LOG.Error("获取失败!", zap.Any("err", err)) response.FailWithMessage("获取失败", c) } else { response.OkWithDetailed(gin.H{"columns": columns}, "获取成功", c) } }