main.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package main
  2. import (
  3. "github.com/kataras/iris"
  4. "github.com/kataras/go-template/html"
  5. "fmt"
  6. "errors"
  7. "git.mmnx.de/Moe/usermanager"
  8. "git.mmnx.de/Moe/databaseutils"
  9. "git.mmnx.de/Moe/configutils"
  10. "git.mmnx.de/Moe/errorhelpers"
  11. "git.mmnx.de/Moe/templatehelpers"
  12. )
  13. func main() {
  14. conf := configutils.ReadConfig("config.json") // read config
  15. configutils.Conf = &conf // store conf globally accessible
  16. databaseutils.DBUtil = &databaseutils.DBUtils{configutils.Conf.DBUser, configutils.Conf.DBPass, configutils.Conf.DBHost, configutils.Conf.DBName, nil} // init dbutils
  17. databaseutils.DBUtil.Connect() // connect to db
  18. users := make([]usermanager.User, 0) // users slice
  19. usermanager.Users = &users // store globally accessible
  20. fmt.Print("") // for not needing to remove fmt ...
  21. iris.Config.IsDevelopment = true
  22. //iris.Config.Render.Template.Gzip = true
  23. /** HELPER FUNCTION EXAMPLE **/
  24. /*config := html.DefaultConfig()
  25. config.Layout = "layouts/main.html"
  26. config.Helpers["boldme"] = func(input string) raymond.SafeString {
  27. return raymond.SafeString("<b> " + input + "</b>")
  28. }*/
  29. /** ROUTING **/
  30. iris.UseTemplate(html.New(html.Config{ // main layout for all pages (like a wrapper for boxes we register downwards)
  31. Layout: "layouts/main.html",
  32. }))
  33. iris.UseFunc(templatehelpers.InitPageParams) // dynamic page params, initialization
  34. iris.Static("/js", "./static/js", 1) // make js files in static/js available via /js
  35. iris.Static("/css", "./static/css", 1)
  36. iris.Static("/img", "./static/img", 1)
  37. iris.Static("/static", "./static/static", 1)
  38. iris.Post("/login", usermanager.LoginHandler, usermanager.AuthHandler, templateHandler) // login form handler
  39. iris.Post("/register", usermanager.CanBeAuthedHandler, usermanager.RegisterHandler, usermanager.LogoutHandler) // handles registration, logs user out
  40. iris.Post("/account", usermanager.AuthHandler, usermanager.AccountUpdateHandler, usermanager.LogoutHandler) // account management
  41. iris.Post("/admin", usermanager.AuthHandler, usermanager.AdminHandler, adminPostHandler) // admin panel
  42. iris.Get("/login", usermanager.CanBeAuthedHandler, templateHandler)
  43. iris.Get("/logout", usermanager.AuthHandler, usermanager.LogoutHandler)
  44. iris.Get("/register", templateHandler)
  45. iris.Get("/", usermanager.AuthHandler, templateHandler)
  46. iris.Get("/account", usermanager.AuthHandler, templateHandler)
  47. iris.Get("/help", usermanager.AuthHandler, templateHandler)
  48. iris.Get("/admin", usermanager.AuthHandler, usermanager.AdminHandler, templateHandler)
  49. /** OTHER **/
  50. iris.Listen(":8080")
  51. }
  52. func adminPostHandler(ctx *iris.Context) {
  53. _, err := usermanager.GenerateTokens(5) // generate tokens and store in db, we don't need them now
  54. if err != nil {
  55. errorhelpers.HandleError(err, ctx)
  56. } else {
  57. err = errors.New(errorhelpers.SUCCESS_TOKENS_GENERATED)
  58. errorhelpers.HandleError(err, ctx)
  59. }
  60. }
  61. func templateHandler(ctx *iris.Context) {
  62. params := ctx.Get("params").(map[string]string)
  63. switch params["reqDir"] {
  64. case "admin":
  65. tokens, err := usermanager.GetTokensAsString(false)
  66. errorhelpers.HandleError(err, ctx)
  67. params["tokens"] = tokens
  68. ctx.Set("params", params)
  69. case "login":
  70. if params["username"] != "" { // redirect logged in users to home
  71. params["reqDir"] = "home"
  72. }
  73. }
  74. ctx.MustRender(params["reqDir"] + "_box.html", params)
  75. }