aboutsummaryrefslogtreecommitdiff
path: root/serve_imap.go
blob: f1d195db1b263d0a58fa7f92bad30a16568a5742 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package main

import (
	"crypto/tls"

	"github.com/emersion/go-imap/v2"
	"github.com/emersion/go-imap/v2/imapserver"
	"go.lindenii.runxiyu.org/lindenii-common/clog"
)

func serve_imap() {
	var tls_config *tls.Config
	var imap_net, imap_addr string
	config_consistent_run(func() {
		tls_config = config._tls_config
		imap_net = config.IMAP.Net
		imap_addr = config.IMAP.Addr
	})
	listener, err := tls.Listen(imap_net, imap_addr, tls_config)
	if err != nil {
		clog.Fatal(1, "IMAP: Cannot listen TLS: "+err.Error())
	}
	clog.Info("IMAP: Listening via " + imap_net + " on " + imap_addr)


	server := imapserver.New(&imapserver.Options{
		NewSession: func(conn *imapserver.Conn) (imapserver.Session, *imapserver.GreetingData, error) {
			return nil, nil, nil
		},
		Caps: imap.CapSet{
			imap.CapIMAP4rev1: {},
			imap.CapIMAP4rev2: {},
		},
		DebugWriter:  nil, // TODO
	})
	err = server.Serve(listener)
	if err != nil {
		clog.Fatal(1, "IMAP: Failed serving: "+err.Error())
	}
}