engine.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package engine
  2. import (
  3. "net/http"
  4. "os"
  5. "strings"
  6. "golang-fave/assets"
  7. "golang-fave/engine/wrapper"
  8. "golang-fave/logger"
  9. "golang-fave/modules"
  10. "golang-fave/utils"
  11. "github.com/vladimirok5959/golang-server-sessions/session"
  12. )
  13. type Engine struct {
  14. Wrap *wrapper.Wrapper
  15. Mods *modules.Modules
  16. }
  17. func Response(l *logger.Logger, m *modules.Modules, w http.ResponseWriter, r *http.Request, s *session.Session, host, port, dirConfig, dirHtdocs, dirLogs, dirTemplate, dirTmp string) bool {
  18. wrap := wrapper.New(l, w, r, s, host, port, dirConfig, dirHtdocs, dirLogs, dirTemplate, dirTmp)
  19. eng := &Engine{
  20. Wrap: wrap,
  21. Mods: m,
  22. }
  23. return eng.Process()
  24. }
  25. func (this *Engine) Process() bool {
  26. // Check and set session user
  27. if !this.Wrap.S.IsSetInt("UserId") {
  28. this.Wrap.S.SetInt("UserId", 0)
  29. }
  30. this.Wrap.IsBackend = this.Wrap.R.URL.Path == "/cp" || strings.HasPrefix(this.Wrap.R.URL.Path, "/cp/")
  31. this.Wrap.ConfMysqlExists = utils.IsMySqlConfigExists(this.Wrap.DConfig + string(os.PathSeparator) + "mysql.json")
  32. this.Wrap.UrlArgs = append(this.Wrap.UrlArgs, utils.UrlToArray(this.Wrap.R.URL.Path)...)
  33. if this.Wrap.IsBackend && len(this.Wrap.UrlArgs) >= 1 && this.Wrap.UrlArgs[0] == "cp" {
  34. this.Wrap.UrlArgs = this.Wrap.UrlArgs[1:]
  35. }
  36. // Action
  37. if this.Mods.XXXActionFire(this.Wrap) {
  38. return true
  39. }
  40. // Redirect to CP for creating MySQL config file
  41. if !this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  42. this.Wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
  43. http.Redirect(this.Wrap.W, this.Wrap.R, this.Wrap.R.URL.Scheme+"://"+this.Wrap.R.Host+"/cp/", 302)
  44. return true
  45. }
  46. // Display MySQL install page on backend
  47. if this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  48. utils.SystemRenderTemplate(this.Wrap.W, assets.TmplCpMySql, nil)
  49. return true
  50. }
  51. // Separated logic
  52. if !this.Wrap.IsBackend {
  53. // Render frontend
  54. return this.Mods.XXXFrontEnd(this.Wrap)
  55. }
  56. // Backend must use MySQL anyway, so, check and connect
  57. err := this.Wrap.UseDatabase()
  58. if err != nil {
  59. utils.SystemErrorPageEngine(this.Wrap.W, err)
  60. return true
  61. }
  62. defer this.Wrap.DB.Close()
  63. // Show add first user form if no any user in database
  64. var count int
  65. err = this.Wrap.DB.QueryRow("SELECT COUNT(*) FROM `users`;").Scan(&count)
  66. if err != nil {
  67. utils.SystemErrorPageEngine(this.Wrap.W, err)
  68. return true
  69. }
  70. if count <= 0 {
  71. utils.SystemRenderTemplate(this.Wrap.W, assets.TmplCpFirstUser, nil)
  72. return true
  73. }
  74. // Show login page if need
  75. if this.Wrap.S.GetInt("UserId", 0) <= 0 {
  76. utils.SystemRenderTemplate(this.Wrap.W, assets.TmplCpLogin, nil)
  77. return true
  78. }
  79. // Try load current user data
  80. if !this.Wrap.LoadSessionUser() {
  81. http.Redirect(this.Wrap.W, this.Wrap.R, "/", 302)
  82. return true
  83. }
  84. // Render backend
  85. return this.Mods.XXXBackEnd(this.Wrap)
  86. }