sys_autocode_history.go 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package service
  2. import (
  3. "errors"
  4. "gin-vue-admin/global"
  5. "gin-vue-admin/model"
  6. "gin-vue-admin/utils"
  7. "strings"
  8. "go.uber.org/zap"
  9. )
  10. // CreateAutoCodeHistory RouterPath : RouterPath@RouterString;RouterPath2@RouterString2
  11. func CreateAutoCodeHistory(autoCodeMeta string, injectionMeta string, tableName string, apiIds string) error {
  12. return global.GVA_DB.Create(&model.SysAutoCodeHistory{
  13. AutoCodeMeta: autoCodeMeta,
  14. InjectionMeta: injectionMeta,
  15. TableName: tableName,
  16. ApiIDs: apiIds,
  17. }).Error
  18. }
  19. func RollBack(id uint) error {
  20. md := model.SysAutoCodeHistory{}
  21. if err := global.GVA_DB.First(&md, id).Error; err != nil {
  22. return err
  23. }
  24. // 清除API表
  25. err := DeleteApiByIds(strings.Split(md.ApiIDs, ";"))
  26. if err != nil {
  27. global.GVA_LOG.Error("ClearTag DeleteApiByIds:", zap.Error(err))
  28. }
  29. // 获取全部表名
  30. err, dbNames := GetTables(global.GVA_CONFIG.Mysql.Dbname)
  31. if err != nil {
  32. global.GVA_LOG.Error("ClearTag GetTables:", zap.Error(err))
  33. }
  34. // 删除表
  35. for _, name := range dbNames {
  36. if strings.Contains(strings.ToUpper(strings.Replace(name.TableName, "_", "", -1)), strings.ToUpper(md.TableName)) {
  37. // 删除表
  38. if err = DropTable(name.TableName); err != nil {
  39. global.GVA_LOG.Error("ClearTag DropTable:", zap.Error(err))
  40. }
  41. }
  42. }
  43. // 删除文件
  44. for _, path := range strings.Split(md.AutoCodeMeta, ";") {
  45. _ = utils.DeLFile(path)
  46. }
  47. // 清除注入
  48. for _, v := range strings.Split(md.InjectionMeta, ";") {
  49. // RouterPath@functionName@RouterString
  50. meta := strings.Split(v, "@")
  51. if len(meta) != 3 {
  52. return errors.New("split InjectionMeta Err")
  53. }
  54. _ = utils.AutoClearCode(meta[0], meta[2])
  55. }
  56. md.Flag = 1
  57. return global.GVA_DB.Save(&md).Error
  58. }