command.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. package commands
  2. import (
  3. "fmt"
  4. "net/url"
  5. "time"
  6. "os"
  7. "encoding/gob"
  8. "github.com/lifei6671/godoc/models"
  9. "github.com/astaxie/beego"
  10. "github.com/astaxie/beego/orm"
  11. "github.com/astaxie/beego/logs"
  12. "github.com/lifei6671/godoc/conf"
  13. "github.com/lifei6671/gocaptcha"
  14. )
  15. // RegisterDataBase 注册数据库
  16. func RegisterDataBase() {
  17. host := beego.AppConfig.String("db_host")
  18. database := beego.AppConfig.String("db_database")
  19. username := beego.AppConfig.String("db_username")
  20. password := beego.AppConfig.String("db_password")
  21. timezone := beego.AppConfig.String("timezone")
  22. port := beego.AppConfig.String("db_port")
  23. dataSource := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=true&loc=%s",username,password,host,port,database,url.QueryEscape(timezone))
  24. orm.RegisterDataBase("default", "mysql", dataSource)
  25. orm.DefaultTimeLoc, _ = time.LoadLocation(timezone)
  26. }
  27. // RegisterModel 注册Model
  28. func RegisterModel() {
  29. orm.RegisterModelWithPrefix(conf.GetDatabasePrefix(),
  30. new(models.Member),
  31. new(models.Book),
  32. new(models.Relationship),
  33. new(models.Comment),
  34. new(models.Option),
  35. new(models.Document),
  36. new(models.Attachment),
  37. new(models.Logger),
  38. new(models.CommentVote),
  39. )
  40. }
  41. func Initialization() {
  42. o := orm.NewOrm()
  43. o.Raw("alter table "+models.NewMember().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  44. o.Raw("alter table "+models.NewBook().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  45. o.Raw("alter table "+models.NewRelationship().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  46. o.Raw("alter table "+models.NewComment().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  47. o.Raw("alter table " +models.NewOption().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  48. o.Raw("alter table "+models.NewDocument().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  49. o.Raw("alter table "+models.NewAttachment().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  50. o.Raw("alter table "+models.NewLogger().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  51. o.Raw("alter table "+models.NewCommentVote().TableNameWithPrefix()+" convert to character set utf8mb4_general_ci;").Exec()
  52. options := []models.Option {
  53. { OptionName: "ENABLED_CAPTCHA", OptionValue: "false", OptionTitle:"是否启用验证码"},
  54. { OptionName: "ENABLED_REGISTER",OptionValue:"false",OptionTitle:"是否启用注册"},
  55. { OptionName: "ENABLE_ANONYMOUS" , OptionValue:"false", OptionTitle:"启用匿名访问"},
  56. { OptionName: "SITE_NAME", OptionValue:"MinDoc", OptionTitle: "站点名称"},
  57. }
  58. models.NewOption().InsertMulti(options...)
  59. member := models.NewMember()
  60. member.Account = "admin"
  61. member.Avatar = "/static/images/headimgurl.jpg"
  62. member.Password = "123456"
  63. member.Role = 0
  64. member.Add()
  65. }
  66. // RegisterLogger 注册日志
  67. func RegisterLogger() {
  68. logs.SetLogFuncCall(true)
  69. logs.SetLogger("console")
  70. logs.EnableFuncCallDepth(true)
  71. logs.Async()
  72. //beego.BeeLogger.DelLogger("console")
  73. if _,err := os.Stat("logs/log.log"); os.IsNotExist(err) {
  74. if f,err := os.Create("logs/log.log");err == nil {
  75. f.Close()
  76. beego.SetLogger("file",`{"filename":"logs/log.log"}`)
  77. }
  78. }
  79. beego.SetLogFuncCall(true)
  80. beego.BeeLogger.Async()
  81. }
  82. // RunCommand 注册orm命令行工具
  83. func RegisterCommand() {
  84. if _,err := os.Stat("install.lock"); os.IsNotExist(err){
  85. err = orm.RunSyncdb("default",true,false)
  86. if err == nil {
  87. Initialization()
  88. f, _ := os.Create("install.lock")
  89. defer f.Close()
  90. }else{
  91. logs.Info("初始化数据库失败 =>",err)
  92. os.Exit(2)
  93. }
  94. }
  95. }
  96. func RegisterFunction() {
  97. beego.AddFuncMap("config",models.GetOptionValue)
  98. }
  99. func init() {
  100. gocaptcha.ReadFonts("./static/fonts", ".ttf")
  101. gob.Register(models.Member{})
  102. }