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.
 
 
 
 

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