command.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  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=utf8mb4&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. new(models.MemberToken),
  40. )
  41. }
  42. //初始化数据
  43. func Initialization() {
  44. o := orm.NewOrm()
  45. _,err := o.Raw(`INSERT INTO md_options (option_title, option_name, option_value) SELECT '是否启用注册','ENABLED_REGISTER','false' FROM dual WHERE NOT exists(SELECT * FROM md_options WHERE option_name = 'ENABLED_REGISTER');`).Exec()
  46. if err != nil {
  47. panic("ENABLED_REGISTER => " + err.Error())
  48. os.Exit(1)
  49. }
  50. _,err = o.Raw(`INSERT INTO md_options (option_title, option_name, option_value) SELECT '是否启用验证码','ENABLED_CAPTCHA','false' FROM dual WHERE NOT exists(SELECT * FROM md_options WHERE option_name = 'ENABLED_CAPTCHA');`).Exec()
  51. if err != nil {
  52. panic("ENABLED_CAPTCHA => " + err.Error())
  53. os.Exit(1)
  54. }
  55. _,err = o.Raw(`INSERT INTO md_options (option_title, option_name, option_value) SELECT '启用匿名访问','ENABLE_ANONYMOUS','true' FROM dual WHERE NOT exists(SELECT * FROM md_options WHERE option_name = 'ENABLE_ANONYMOUS');`).Exec()
  56. if err != nil {
  57. panic("ENABLE_ANONYMOUS => " + err.Error())
  58. os.Exit(1)
  59. }
  60. _,err = o.Raw(`INSERT INTO md_options (option_title, option_name, option_value) SELECT '站点名称','SITE_NAME','MinDoc' FROM dual WHERE NOT exists(SELECT * FROM md_options WHERE option_name = 'SITE_NAME');`).Exec()
  61. if err != nil {
  62. panic("SITE_NAME => " + err.Error())
  63. os.Exit(1)
  64. }
  65. member,err := models.NewMember().FindByFieldFirst("account","admin")
  66. if err == orm.ErrNoRows {
  67. member.Account = "admin"
  68. member.Avatar = "/static/images/headimgurl.jpg"
  69. member.Password = "123456"
  70. member.Role = 0
  71. member.Email = "[email protected]"
  72. if err := member.Add(); err != nil {
  73. panic("Member.Add => " + err.Error())
  74. os.Exit(0)
  75. }
  76. book := models.NewBook()
  77. book.MemberId = member.MemberId
  78. book.BookName = "MinDoc演示项目"
  79. book.Status = 0
  80. book.Description = "这是一个MinDoc演示项目,该项目是由系统初始化时自动创建。"
  81. book.CommentCount = 0
  82. book.PrivatelyOwned = 0
  83. book.CommentStatus = "closed"
  84. book.Identify = "mindoc"
  85. book.DocCount = 0
  86. book.CommentCount = 0
  87. book.Version = time.Now().Unix()
  88. book.Cover = conf.GetDefaultCover()
  89. book.Editor = "markdown"
  90. book.Theme = "default"
  91. if err := book.Insert(); err != nil {
  92. panic("Book.Insert => " + err.Error())
  93. os.Exit(0)
  94. }
  95. }
  96. }
  97. // RegisterLogger 注册日志
  98. func RegisterLogger() {
  99. logs.SetLogFuncCall(true)
  100. logs.SetLogger("console")
  101. logs.EnableFuncCallDepth(true)
  102. logs.Async()
  103. if _,err := os.Stat("logs/log.log"); os.IsNotExist(err) {
  104. os.MkdirAll("./logs",0777)
  105. if f,err := os.Create("logs/log.log");err == nil {
  106. f.Close()
  107. beego.SetLogger("file",`{"filename":"logs/log.log"}`)
  108. }
  109. }
  110. beego.SetLogFuncCall(true)
  111. beego.BeeLogger.Async()
  112. }
  113. // RunCommand 注册orm命令行工具
  114. func RegisterCommand() {
  115. if _,err := os.Stat("install.lock"); os.IsNotExist(err){
  116. err = orm.RunSyncdb("default",false,true)
  117. if err == nil {
  118. Initialization()
  119. f, _ := os.Create("install.lock")
  120. defer f.Close()
  121. }else{
  122. panic(err.Error())
  123. os.Exit(0)
  124. }
  125. }
  126. CheckUpdate()
  127. }
  128. func RegisterFunction() {
  129. beego.AddFuncMap("config",models.GetOptionValue)
  130. }
  131. func init() {
  132. gocaptcha.ReadFonts("./static/fonts", ".ttf")
  133. gob.Register(models.Member{})
  134. }