mirror of
https://github.com/mjl-/mox.git
synced 2025-01-27 14:55:56 +03:00
5b20cba50a
we don't want external software to include internal details like mlog. slog.Logger is/will be the standard. we still have mlog for its helper functions, and its handler that logs in concise logfmt used by mox. packages that are not meant for reuse still pass around mlog.Log for convenience. we use golang.org/x/exp/slog because we also support the previous Go toolchain version. with the next Go release, we'll switch to the builtin slog.
30 lines
873 B
Go
30 lines
873 B
Go
package store
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/mjl-/mox/mlog"
|
|
"github.com/mjl-/mox/mox-"
|
|
)
|
|
|
|
// CreateMessageTemp creates a temporary file, e.g. for delivery. The is created in
|
|
// subdirectory tmp of the data directory, so the file is on the same file system
|
|
// as the accounts directory, so renaming files can succeed. The caller is
|
|
// responsible for closing and possibly removing the file. The caller should ensure
|
|
// the contents of the file are synced to disk before attempting to deliver the
|
|
// message.
|
|
func CreateMessageTemp(log mlog.Log, pattern string) (*os.File, error) {
|
|
dir := mox.DataDirPath("tmp")
|
|
os.MkdirAll(dir, 0770)
|
|
f, err := os.CreateTemp(dir, pattern)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
err = f.Chmod(0660)
|
|
if err != nil {
|
|
xerr := f.Close()
|
|
log.Check(xerr, "closing temp message file after chmod error")
|
|
return nil, err
|
|
}
|
|
return f, err
|
|
}
|