Upgrade zap to the 1.0.0 release.
[mailpopbox.git] / mailpopbox.go
1 // mailpopbox
2 // Copyright 2020 Blue Static <https://www.bluestatic.org>
3 // This program is free software licensed under the GNU General Public License,
4 // version 3.0. The full text of the license can be found in LICENSE.txt.
5 // SPDX-License-Identifier: GPL-3.0-only
6
7 package main
8
9 import (
10 "encoding/json"
11 "fmt"
12 "os"
13
14 "go.uber.org/zap"
15 )
16
17 func main() {
18 if len(os.Args) != 2 {
19 fmt.Fprintf(os.Stderr, "Usage: %s config.json\n", os.Args[0])
20 os.Exit(1)
21 }
22
23 configFile, err := os.Open(os.Args[1])
24 if err != nil {
25 fmt.Fprintf(os.Stderr, "config file: %s\n", err)
26 os.Exit(2)
27 }
28
29 var config Config
30 if err := json.NewDecoder(configFile).Decode(&config); err != nil {
31 fmt.Fprintf(os.Stderr, "config file: %s\n", err)
32 os.Exit(3)
33 }
34 configFile.Close()
35
36 logConfig := zap.NewDevelopmentConfig()
37 logConfig.Development = false
38 logConfig.DisableStacktrace = true
39 logConfig.Level.SetLevel(zap.DebugLevel)
40 log, err := logConfig.Build()
41 if err != nil {
42 fmt.Fprintf(os.Stderr, "create logger: %v\n", err)
43 os.Exit(4)
44 }
45
46 pop3 := runPOP3Server(config, log)
47 smtp := runSMTPServer(config, log)
48
49 for {
50 select {
51 case cm := <-pop3:
52 if cm == ServerControlRestart {
53 pop3 = runPOP3Server(config, log)
54 } else {
55 break
56 }
57 case <-smtp:
58 // smtp never reloads.
59 break
60 }
61 }
62 }