diff options
author | Robert Günzler <r@gnzler.io> | 2019-06-08 19:41:56 +0200 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-06-09 11:33:50 -0400 |
commit | acfe7d7625192bc856d5d696f741e35ce38cab25 (patch) | |
tree | 64f76ab6927cbb25be95c0ff2e65e063791593a6 /worker/imap | |
parent | 35f57321f8d53dba2c1a2480aaa5860333e1c269 (diff) |
Add archive command
Adds an archive command that moves the current message into the folder
specified in the account config entry.
Supports three layouts at this point:
- flat: puts all messages next to each other
- year: creates a folder per year
- month: same as above, plus folders per month
This also adds a "-p" argument to "cp" and "mv" that works like
"--parents" on mkdir(1). We use this to auto-create the directories
for the archive layout.
Diffstat (limited to 'worker/imap')
-rw-r--r-- | worker/imap/create.go | 22 | ||||
-rw-r--r-- | worker/imap/worker.go | 2 |
2 files changed, 24 insertions, 0 deletions
diff --git a/worker/imap/create.go b/worker/imap/create.go new file mode 100644 index 0000000..3cc71c5 --- /dev/null +++ b/worker/imap/create.go @@ -0,0 +1,22 @@ +package imap + +import ( + "strings" + + "git.sr.ht/~sircmpwn/aerc/worker/types" +) + +func (imapw *IMAPWorker) handleCreateDirectory(msg *types.CreateDirectory) { + if err := imapw.client.Create(msg.Directory); err != nil { + if strings.HasPrefix(err.Error(), "Mailbox already exists") { + // ignore "already exists" error + return + } + 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 125fba8..f71a950 100644 --- a/worker/imap/worker.go +++ b/worker/imap/worker.go @@ -127,6 +127,8 @@ func (w *IMAPWorker) handleMessage(msg types.WorkerMessage) error { w.handleOpenDirectory(msg) case *types.FetchDirectoryContents: w.handleFetchDirectoryContents(msg) + case *types.CreateDirectory: + w.handleCreateDirectory(msg) case *types.FetchMessageHeaders: w.handleFetchMessageHeaders(msg) case *types.FetchMessageBodyPart: |