config.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package server
  2. import (
  3. "io/fs"
  4. "net/netip"
  5. "time"
  6. )
  7. // Defines default config settings (excluding limits, see below)
  8. const (
  9. DefaultListenHTTP = ":80"
  10. DefaultCacheDuration = 12 * time.Hour
  11. DefaultKeepaliveInterval = 45 * time.Second // Not too frequently to save battery (Android read timeout used to be 77s!)
  12. DefaultManagerInterval = time.Minute
  13. DefaultDelayedSenderInterval = 10 * time.Second
  14. DefaultMinDelay = 10 * time.Second
  15. DefaultMaxDelay = 3 * 24 * time.Hour
  16. DefaultFirebaseKeepaliveInterval = 3 * time.Hour // ~control topic (Android), not too frequently to save battery
  17. DefaultFirebasePollInterval = 20 * time.Minute // ~poll topic (iOS), max. 2-3 times per hour (see docs)
  18. DefaultFirebaseQuotaExceededPenaltyDuration = 10 * time.Minute // Time that over-users are locked out of Firebase if it returns "quota exceeded"
  19. )
  20. // Defines all global and per-visitor limits
  21. // - message size limit: the max number of bytes for a message
  22. // - total topic limit: max number of topics overall
  23. // - various attachment limits
  24. const (
  25. DefaultMessageLengthLimit = 4096 // Bytes
  26. DefaultTotalTopicLimit = 15000
  27. DefaultAttachmentTotalSizeLimit = int64(5 * 1024 * 1024 * 1024) // 5 GB
  28. DefaultAttachmentFileSizeLimit = int64(15 * 1024 * 1024) // 15 MB
  29. DefaultAttachmentExpiryDuration = 3 * time.Hour
  30. )
  31. // Defines all per-visitor limits
  32. // - per visitor subscription limit: max number of subscriptions (active HTTP connections) per per-visitor/IP
  33. // - per visitor request limit: max number of PUT/GET/.. requests (here: 60 requests bucket, replenished at a rate of one per 5 seconds)
  34. // - per visitor email limit: max number of emails (here: 16 email bucket, replenished at a rate of one per hour)
  35. // - per visitor attachment size limit: total per-visitor attachment size in bytes to be stored on the server
  36. // - per visitor attachment daily bandwidth limit: number of bytes that can be transferred to/from the server
  37. const (
  38. DefaultVisitorSubscriptionLimit = 30
  39. DefaultVisitorRequestLimitBurst = 60
  40. DefaultVisitorRequestLimitReplenish = 5 * time.Second
  41. DefaultVisitorEmailLimitBurst = 16
  42. DefaultVisitorEmailLimitReplenish = time.Hour
  43. DefaultVisitorAttachmentTotalSizeLimit = 100 * 1024 * 1024 // 100 MB
  44. DefaultVisitorAttachmentDailyBandwidthLimit = 500 * 1024 * 1024 // 500 MB
  45. )
  46. // Config is the main config struct for the application. Use New to instantiate a default config struct.
  47. type Config struct {
  48. BaseURL string
  49. ListenHTTP string
  50. ListenHTTPS string
  51. ListenUnix string
  52. ListenUnixMode fs.FileMode
  53. KeyFile string
  54. CertFile string
  55. FirebaseKeyFile string
  56. CacheFile string
  57. CacheDuration time.Duration
  58. CacheStartupQueries string
  59. AuthFile string
  60. AuthDefaultRead bool
  61. AuthDefaultWrite bool
  62. AttachmentCacheDir string
  63. AttachmentTotalSizeLimit int64
  64. AttachmentFileSizeLimit int64
  65. AttachmentExpiryDuration time.Duration
  66. KeepaliveInterval time.Duration
  67. ManagerInterval time.Duration
  68. WebRootIsApp bool
  69. DelayedSenderInterval time.Duration
  70. FirebaseKeepaliveInterval time.Duration
  71. FirebasePollInterval time.Duration
  72. FirebaseQuotaExceededPenaltyDuration time.Duration
  73. UpstreamBaseURL string
  74. SMTPSenderAddr string
  75. SMTPSenderUser string
  76. SMTPSenderPass string
  77. SMTPSenderFrom string
  78. SMTPServerListen string
  79. SMTPServerDomain string
  80. SMTPServerAddrPrefix string
  81. MessageLimit int
  82. MinDelay time.Duration
  83. MaxDelay time.Duration
  84. TotalTopicLimit int
  85. TotalAttachmentSizeLimit int64
  86. VisitorSubscriptionLimit int
  87. VisitorAttachmentTotalSizeLimit int64
  88. VisitorAttachmentDailyBandwidthLimit int
  89. VisitorRequestLimitBurst int
  90. VisitorRequestLimitReplenish time.Duration
  91. VisitorRequestExemptIPAddrs []netip.Prefix
  92. VisitorEmailLimitBurst int
  93. VisitorEmailLimitReplenish time.Duration
  94. BehindProxy bool
  95. EnableWeb bool
  96. Version string // injected by App
  97. }
  98. // NewConfig instantiates a default new server config
  99. func NewConfig() *Config {
  100. return &Config{
  101. BaseURL: "",
  102. ListenHTTP: DefaultListenHTTP,
  103. ListenHTTPS: "",
  104. ListenUnix: "",
  105. ListenUnixMode: 0,
  106. KeyFile: "",
  107. CertFile: "",
  108. FirebaseKeyFile: "",
  109. CacheFile: "",
  110. CacheDuration: DefaultCacheDuration,
  111. AuthFile: "",
  112. AuthDefaultRead: true,
  113. AuthDefaultWrite: true,
  114. AttachmentCacheDir: "",
  115. AttachmentTotalSizeLimit: DefaultAttachmentTotalSizeLimit,
  116. AttachmentFileSizeLimit: DefaultAttachmentFileSizeLimit,
  117. AttachmentExpiryDuration: DefaultAttachmentExpiryDuration,
  118. KeepaliveInterval: DefaultKeepaliveInterval,
  119. ManagerInterval: DefaultManagerInterval,
  120. MessageLimit: DefaultMessageLengthLimit,
  121. MinDelay: DefaultMinDelay,
  122. MaxDelay: DefaultMaxDelay,
  123. DelayedSenderInterval: DefaultDelayedSenderInterval,
  124. FirebaseKeepaliveInterval: DefaultFirebaseKeepaliveInterval,
  125. FirebasePollInterval: DefaultFirebasePollInterval,
  126. FirebaseQuotaExceededPenaltyDuration: DefaultFirebaseQuotaExceededPenaltyDuration,
  127. TotalTopicLimit: DefaultTotalTopicLimit,
  128. VisitorSubscriptionLimit: DefaultVisitorSubscriptionLimit,
  129. VisitorAttachmentTotalSizeLimit: DefaultVisitorAttachmentTotalSizeLimit,
  130. VisitorAttachmentDailyBandwidthLimit: DefaultVisitorAttachmentDailyBandwidthLimit,
  131. VisitorRequestLimitBurst: DefaultVisitorRequestLimitBurst,
  132. VisitorRequestLimitReplenish: DefaultVisitorRequestLimitReplenish,
  133. VisitorRequestExemptIPAddrs: make([]netip.Prefix, 0),
  134. VisitorEmailLimitBurst: DefaultVisitorEmailLimitBurst,
  135. VisitorEmailLimitReplenish: DefaultVisitorEmailLimitReplenish,
  136. BehindProxy: false,
  137. EnableWeb: true,
  138. Version: "",
  139. }
  140. }