source: code/trunk/cmd/jounce/main.go@ 70

Last change on this file since 70 was 70, checked in by contact, 5 years ago

cmd/jounce: fix non-TLS listener address

File size: 1.5 KB
Line 
1package main
2
3import (
4 "crypto/tls"
5 "flag"
6 "log"
7 "net"
8
9 "git.sr.ht/~emersion/jounce"
10 "git.sr.ht/~emersion/jounce/config"
11)
12
13func main() {
14 var addr, configPath string
15 var debug bool
16 flag.StringVar(&addr, "listen", "", "listening address")
17 flag.StringVar(&configPath, "config", "", "path to configuration file")
18 flag.BoolVar(&debug, "debug", false, "enable debug logging")
19 flag.Parse()
20
21 var cfg *config.Server
22 if configPath != "" {
23 var err error
24 cfg, err = config.Load(configPath)
25 if err != nil {
26 log.Fatalf("failed to load config file: %v", err)
27 }
28 } else {
29 cfg = config.Defaults()
30 }
31
32 if addr != "" {
33 cfg.Addr = addr
34 }
35
36 var ln net.Listener
37 if cfg.TLS != nil {
38 cert, err := tls.LoadX509KeyPair(cfg.TLS.CertPath, cfg.TLS.KeyPath)
39 if err != nil {
40 log.Fatalf("failed to load TLS certificate and key: %v", err)
41 }
42
43 tlsCfg := &tls.Config{Certificates: []tls.Certificate{cert}}
44 ln, err = tls.Listen("tcp", cfg.Addr, tlsCfg)
45 if err != nil {
46 log.Fatalf("failed to start TLS listener: %v", err)
47 }
48 } else {
49 var err error
50 ln, err = net.Listen("tcp", cfg.Addr)
51 if err != nil {
52 log.Fatalf("failed to start listener: %v", err)
53 }
54 }
55
56 srv := jounce.NewServer()
57 // TODO: load from config/DB
58 srv.Hostname = cfg.Hostname
59 srv.Debug = debug
60 srv.Upstreams = []jounce.Upstream{{
61 Addr: "chat.freenode.net:6697",
62 Nick: "jounce",
63 Username: "jounce",
64 Realname: "jounce",
65 Channels: []string{"#jounce"},
66 }}
67
68 log.Printf("server listening on %q", cfg.Addr)
69 go srv.Run()
70 log.Fatal(srv.Serve(ln))
71}
Note: See TracBrowser for help on using the repository browser.