blob: f1d195db1b263d0a58fa7f92bad30a16568a5742 (
plain) (
tree)
|
|
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())
}
}
|