2017-12-03 15:58:24 +02:00
|
|
|
package imap
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
imapbackend "github.com/emersion/go-imap/backend"
|
|
|
|
|
|
|
|
"github.com/emersion/hydroxide/auth"
|
2018-01-12 14:20:17 +02:00
|
|
|
"github.com/emersion/hydroxide/events"
|
2017-12-03 15:58:24 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var errNotYetImplemented = errors.New("not yet implemented")
|
|
|
|
|
|
|
|
type backend struct {
|
|
|
|
sessions *auth.Manager
|
2018-01-12 14:20:17 +02:00
|
|
|
eventsManager *events.Manager
|
2018-01-12 16:16:26 +02:00
|
|
|
updates chan interface{}
|
2017-12-03 15:58:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (be *backend) Login(username, password string) (imapbackend.User, error) {
|
|
|
|
c, privateKeys, err := be.sessions.Auth(username, password)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
u, err := c.GetCurrentUser()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: decrypt private keys in u.Addresses
|
|
|
|
|
2018-01-12 14:20:17 +02:00
|
|
|
return newUser(be, c, u, privateKeys)
|
2017-12-03 15:58:24 +02:00
|
|
|
}
|
|
|
|
|
2018-01-12 16:16:26 +02:00
|
|
|
func (be *backend) Updates() <-chan interface{} {
|
|
|
|
return be.updates
|
|
|
|
}
|
|
|
|
|
2018-01-12 14:20:17 +02:00
|
|
|
func New(sessions *auth.Manager, eventsManager *events.Manager) imapbackend.Backend {
|
2018-01-12 16:16:26 +02:00
|
|
|
return &backend{sessions, eventsManager, make(chan interface{}, 50)}
|
2017-12-03 15:58:24 +02:00
|
|
|
}
|