From d131d0dec6a6c7f0af3511bd908cda8a3d910237 Mon Sep 17 00:00:00 2001 From: René 'Necoro' Neumann Date: Sun, 3 May 2020 02:19:40 +0200 Subject: Use UIDPLUS Imap extension --- internal/imap/client.go | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) (limited to 'internal/imap/client.go') diff --git a/internal/imap/client.go b/internal/imap/client.go index 24cc3f1..731e35b 100644 --- a/internal/imap/client.go +++ b/internal/imap/client.go @@ -1,6 +1,7 @@ package imap import ( + uidplus "github.com/emersion/go-imap-uidplus" imapClient "github.com/emersion/go-imap/client" "github.com/Necoro/feed2imap-go/pkg/log" @@ -37,19 +38,21 @@ func (client *Client) Disconnect() { } } -func (client *Client) createConnection(c *imapClient.Client) *connection { - if client.nextFreeIndex >= len(client.connections) { +func (cl *Client) createConnection(c *imapClient.Client) *connection { + if cl.nextFreeIndex >= len(cl.connections) { panic("Too many connections") } + client := &client{c, uidplus.NewClient(c)} + conn := &connection{ - connConf: &client.connConf, - mailboxes: client.mailboxes, - c: c, + connConf: &cl.connConf, + mailboxes: cl.mailboxes, + c: client, } - client.connections[client.nextFreeIndex] = conn - client.nextFreeIndex++ + cl.connections[cl.nextFreeIndex] = conn + cl.nextFreeIndex++ return conn } -- cgit v1.2.3-54-g00ecf