aboutsummaryrefslogtreecommitdiff
path: root/worker
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2019-05-14 16:34:42 -0400
committerDrew DeVault <sir@cmpwn.com>2019-05-14 16:44:59 -0400
commitdb213fd0aed98a79ecb1be2c7b7d61c7d983bedf (patch)
tree7570d4934a2de9e5c50a8d1d133792710d98bc66 /worker
parentb0b3287bbdadad47757f3543a6560494af9175a8 (diff)
Implement :copy (aka :cp)
Diffstat (limited to 'worker')
-rw-r--r--worker/imap/movecopy.go16
-rw-r--r--worker/imap/worker.go2
-rw-r--r--worker/types/messages.go12
3 files changed, 30 insertions, 0 deletions
diff --git a/worker/imap/movecopy.go b/worker/imap/movecopy.go
new file mode 100644
index 0000000..8c42a2e
--- /dev/null
+++ b/worker/imap/movecopy.go
@@ -0,0 +1,16 @@
+package imap
+
+import (
+ "git.sr.ht/~sircmpwn/aerc2/worker/types"
+)
+
+func (imapw *IMAPWorker) handleCopyMessages(msg *types.CopyMessages) {
+ if err := imapw.client.UidCopy(&msg.Uids, msg.Destination); err != nil {
+ imapw.worker.PostMessage(&types.Error{
+ Message: types.RespondTo(msg),
+ Error: err,
+ }, nil)
+ } else {
+ imapw.worker.PostMessage(&types.Done{types.RespondTo(msg)}, nil)
+ }
+}
diff --git a/worker/imap/worker.go b/worker/imap/worker.go
index d0b0e71..1fab3bb 100644
--- a/worker/imap/worker.go
+++ b/worker/imap/worker.go
@@ -174,6 +174,8 @@ func (w *IMAPWorker) handleMessage(msg types.WorkerMessage) error {
w.handleFetchFullMessages(msg)
case *types.DeleteMessages:
w.handleDeleteMessages(msg)
+ case *types.CopyMessages:
+ w.handleCopyMessages(msg)
default:
return errUnsupported
}
diff --git a/worker/types/messages.go b/worker/types/messages.go
index b17d53d..fdd3263 100644
--- a/worker/types/messages.go
+++ b/worker/types/messages.go
@@ -97,6 +97,18 @@ type DeleteMessages struct {
Uids imap.SeqSet
}
+type CopyMessages struct {
+ Message
+ Destination string
+ Uids imap.SeqSet
+}
+
+type MoveMessages struct {
+ Message
+ Destination string
+ Uids imap.SeqSet
+}
+
// Messages
type CertificateApprovalRequest struct {