A webmail client. Forked from https://git.sr.ht/~migadu/alps
25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

89 lines
1.9 KiB

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