engine.go 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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/modules"
  11. "golang-fave/utils"
  12. "github.com/vladimirok5959/golang-server-sessions/session"
  13. )
  14. type Engine struct {
  15. Wrap *wrapper.Wrapper
  16. Mods *modules.Modules
  17. }
  18. 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 {
  19. wrap := wrapper.New(l, w, r, s, host, port, dirConfig, dirHtdocs, dirLogs, dirTemplate, dirTmp)
  20. eng := &Engine{
  21. Wrap: wrap,
  22. Mods: m,
  23. }
  24. return eng.Process()
  25. }
  26. func (this *Engine) Process() bool {
  27. this.Wrap.IsBackend = this.Wrap.R.URL.Path == "/cp" || strings.HasPrefix(this.Wrap.R.URL.Path, "/cp/")
  28. this.Wrap.ConfMysqlExists = utils.IsMySqlConfigExists(this.Wrap.DConfig + string(os.PathSeparator) + "mysql.json")
  29. this.Wrap.UrlArgs = append(this.Wrap.UrlArgs, utils.UrlToArray(this.Wrap.R.URL.Path)...)
  30. // Action
  31. if this.Mods.XXXActionFire(this.Wrap) {
  32. return true
  33. }
  34. // Redirect to CP for creating MySQL config file
  35. if !this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  36. this.Wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
  37. http.Redirect(this.Wrap.W, this.Wrap.R, this.Wrap.R.URL.Scheme+"://"+this.Wrap.R.Host+"/cp/", 302)
  38. return true
  39. }
  40. // Display MySQL install page on backend
  41. if this.Wrap.IsBackend && !this.Wrap.ConfMysqlExists {
  42. utils.SystemRenderTemplate(this.Wrap.W, assets.TmplCpMySql, nil)
  43. return true
  44. }
  45. /*
  46. // Read MySQL settings file
  47. mc, err := utils.MySqlConfigRead(this.Wrap.DConfig + string(os.PathSeparator) + "mysql.json")
  48. if err != nil {
  49. utils.SystemErrorPageEngine(this.Wrap.W, err)
  50. return true
  51. }
  52. // Connect to MySQL server
  53. db, err := sql.Open("mysql", mc.User+":"+mc.Password+"@tcp("+mc.Host+":"+mc.Port+")/"+mc.Name)
  54. if err != nil {
  55. utils.SystemErrorPageEngine(this.Wrap.W, err)
  56. return true
  57. }
  58. this.Wrap.DB = db
  59. defer db.Close()
  60. err = db.Ping()
  61. // Check if MySQL server alive
  62. if err != nil {
  63. utils.SystemErrorPageEngine(this.Wrap.W, err)
  64. return true
  65. }
  66. */
  67. // Separated logic
  68. if this.Wrap.IsBackend {
  69. return this.Mods.XXXBackEnd(this.Wrap)
  70. }
  71. return this.Mods.XXXFrontEnd(this.Wrap)
  72. }