A webmail client. Forked from https://git.sr.ht/~migadu/alps
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

98 lines
2.1 KiB

  1. package main
  2. import (
  3. "context"
  4. "flag"
  5. "fmt"
  6. "os"
  7. "os/signal"
  8. "syscall"
  9. "time"
  10. "git.sr.ht/~migadu/alps"
  11. "github.com/fernet/fernet-go"
  12. "github.com/labstack/echo/v4"
  13. "github.com/labstack/echo/v4/middleware"
  14. "github.com/labstack/gommon/log"
  15. _ "git.sr.ht/~migadu/alps/plugins/base"
  16. _ "git.sr.ht/~migadu/alps/plugins/caldav"
  17. _ "git.sr.ht/~migadu/alps/plugins/carddav"
  18. _ "git.sr.ht/~migadu/alps/plugins/lua"
  19. _ "git.sr.ht/~migadu/alps/plugins/viewhtml"
  20. _ "git.sr.ht/~migadu/alps/plugins/viewtext"
  21. )
  22. func main() {
  23. var (
  24. addr string
  25. loginKey string
  26. options alps.Options
  27. )
  28. flag.StringVar(&options.Theme, "theme", "", "default theme")
  29. flag.StringVar(&addr, "addr", ":1323", "listening address")
  30. flag.BoolVar(&options.Debug, "debug", false, "enable debug logs")
  31. flag.StringVar(&loginKey, "login-key", "", "Fernet key for login persistence")
  32. flag.Usage = func() {
  33. fmt.Fprintf(flag.CommandLine.Output(), "usage: alps [options...] <upstream servers...>\n")
  34. flag.PrintDefaults()
  35. }
  36. flag.Parse()
  37. options.Upstreams = flag.Args()
  38. if len(options.Upstreams) == 0 {
  39. flag.Usage()
  40. return
  41. }
  42. if loginKey != "" {
  43. fernetKey, err := fernet.DecodeKey(loginKey)
  44. if err != nil {
  45. flag.Usage()
  46. return
  47. }
  48. options.LoginKey = fernetKey
  49. }
  50. e := echo.New()
  51. e.HideBanner = true
  52. if l, ok := e.Logger.(*log.Logger); ok {
  53. l.SetHeader("${time_rfc3339} ${level}")
  54. }
  55. s, err := alps.New(e, &options)
  56. if err != nil {
  57. e.Logger.Fatal(err)
  58. }
  59. e.Use(middleware.Recover())
  60. if options.Debug {
  61. e.Use(middleware.LoggerWithConfig(middleware.LoggerConfig{
  62. Format: "${time_rfc3339} method=${method}, uri=${uri}, status=${status}\n",
  63. }))
  64. e.Logger.SetLevel(log.DEBUG)
  65. }
  66. go e.Start(addr)
  67. sigs := make(chan os.Signal, 1)
  68. signal.Notify(sigs, syscall.SIGUSR1, syscall.SIGINT)
  69. for sig := range sigs {
  70. if sig == syscall.SIGUSR1 {
  71. if err := s.Reload(); err != nil {
  72. e.Logger.Errorf("Failed to reload server: %v", err)
  73. }
  74. } else if sig == syscall.SIGINT {
  75. break
  76. }
  77. }
  78. ctx, cancel := context.WithDeadline(context.Background(),
  79. time.Now().Add(30*time.Second))
  80. e.Shutdown(ctx)
  81. cancel()
  82. s.Close()
  83. }