mox/export.go

80 lines
2.5 KiB
Go
Raw Permalink Normal View History

2023-01-30 16:27:06 +03:00
package main
import (
"context"
"log"
2023-01-30 16:27:06 +03:00
"path/filepath"
"time"
"github.com/mjl-/bstore"
"github.com/mjl-/mox/store"
)
func cmdExportMaildir(c *cmd) {
c.params = "[-single] dst-dir account-path [mailbox]"
2023-01-30 16:27:06 +03:00
c.help = `Export one or all mailboxes from an account in maildir format.
Export bypasses a running mox instance. It opens the account mailbox/message
database file directly. This may block if a running mox instance also has the
database open, e.g. for IMAP connections. To export from a running instance, use
the accounts web page or webmail.
2023-01-30 16:27:06 +03:00
`
var single bool
c.flag.BoolVar(&single, "single", false, "export single mailbox, without any children. disabled if mailbox isn't specified.")
2023-01-30 16:27:06 +03:00
args := c.Parse()
xcmdExport(false, single, args, c)
2023-01-30 16:27:06 +03:00
}
func cmdExportMbox(c *cmd) {
c.params = "[-single] dst-dir account-path [mailbox]"
2023-01-30 16:27:06 +03:00
c.help = `Export messages from one or all mailboxes in an account in mbox format.
Using mbox is not recommended. Maildir is a better format.
Export bypasses a running mox instance. It opens the account mailbox/message
database file directly. This may block if a running mox instance also has the
database open, e.g. for IMAP connections. To export from a running instance, use
the accounts web page or webmail.
2023-01-30 16:27:06 +03:00
For mbox export, "mboxrd" is used where message lines starting with the magic
"From " string are escaped by prepending a >. All ">*From " are escaped,
2023-01-30 16:27:06 +03:00
otherwise reconstructing the original could lose a ">".
`
var single bool
c.flag.BoolVar(&single, "single", false, "export single mailbox, without any children. disabled if mailbox isn't specified.")
2023-01-30 16:27:06 +03:00
args := c.Parse()
xcmdExport(true, single, args, c)
2023-01-30 16:27:06 +03:00
}
func xcmdExport(mbox, single bool, args []string, c *cmd) {
2023-01-30 16:27:06 +03:00
if len(args) != 2 && len(args) != 3 {
c.Usage()
}
dst := args[0]
accountDir := args[1]
var mailbox string
if len(args) == 3 {
mailbox = args[2]
} else {
single = false
2023-01-30 16:27:06 +03:00
}
dbpath := filepath.Join(accountDir, "index.db")
opts := bstore.Options{Timeout: 5 * time.Second, Perm: 0660, RegisterLogger: c.log.Logger}
db, err := bstore.Open(context.Background(), dbpath, &opts, store.DBTypes...)
2023-01-30 16:27:06 +03:00
xcheckf(err, "open database %q", dbpath)
defer func() {
if err := db.Close(); err != nil {
log.Printf("closing db after export: %v", err)
}
}()
2023-01-30 16:27:06 +03:00
a := store.DirArchiver{Dir: dst}
err = store.ExportMessages(context.Background(), c.log, db, accountDir, a, !mbox, mailbox, !single)
xcheckf(err, "exporting messages")
err = a.Close()
xcheckf(err, "closing archiver")
2023-01-30 16:27:06 +03:00
}