engine.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package engine
  2. import (
  3. "database/sql"
  4. "net/http"
  5. "os"
  6. "strings"
  7. "golang-fave/assets"
  8. "golang-fave/engine/wrapper"
  9. "golang-fave/logger"
  10. "golang-fave/utils"
  11. "github.com/vladimirok5959/golang-server-sessions/session"
  12. )
  13. type Engine struct {
  14. Wrap *wrapper.Wrapper
  15. // Actions
  16. // Front-end or Back-end
  17. }
  18. func Response(l *logger.Logger, w http.ResponseWriter, r *http.Request, s *session.Session, host, port, dirConfig, dirHtdocs, dirLogs, dirTemplate, dirTmp string) bool {
  19. wrap := wrapper.New(l, w, r, s, host, port, dirConfig, dirHtdocs, dirLogs, dirTemplate, dirTmp)
  20. eng := &Engine{Wrap: wrap}
  21. return eng.Process()
  22. }
  23. func (this *Engine) Process() bool {
  24. this.Wrap.IsBackend = this.Wrap.R.URL.Path == "/cp" || strings.HasPrefix(this.Wrap.R.URL.Path, "/cp/")
  25. this.Wrap.ConfMysqlExists = utils.IsMySqlConfigExists(this.Wrap.DConfig + string(os.PathSeparator) + "mysql.json")
  26. // All actions here...
  27. // MySQL install
  28. // MySQL first user
  29. // User login
  30. // User logout
  31. // Redirect to CP for creating MySQL config file
  32. if !this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  33. this.Wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
  34. http.Redirect(this.Wrap.W, this.Wrap.R, this.Wrap.R.URL.Scheme+"://"+this.Wrap.R.Host+"/cp/", 302)
  35. return true
  36. }
  37. // Display MySQL install page on backend
  38. if this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  39. utils.SystemRenderTemplate(this.Wrap.W, assets.TmplCpMySql, nil)
  40. return true
  41. }
  42. // Read MySQL settings file
  43. mc, err := utils.MySqlConfigRead(this.Wrap.DConfig + string(os.PathSeparator) + "mysql.json")
  44. if err != nil {
  45. utils.SystemErrorPageEngine(this.Wrap.W, err)
  46. return true
  47. }
  48. // Connect to MySQL server
  49. db, err := sql.Open("mysql", mc.User+":"+mc.Password+"@tcp("+mc.Host+":"+mc.Port+")/"+mc.Name)
  50. if err != nil {
  51. utils.SystemErrorPageEngine(this.Wrap.W, err)
  52. return true
  53. }
  54. this.Wrap.DB = db
  55. defer db.Close()
  56. err = db.Ping()
  57. // Check if MySQL server alive
  58. if err != nil {
  59. utils.SystemErrorPageEngine(this.Wrap.W, err)
  60. return true
  61. }
  62. // Separated logic
  63. if this.Wrap.IsBackend {
  64. return this.BackEnd()
  65. }
  66. return this.FrontEnd()
  67. }