0d645bcebd
I'm not sure what are the implications but it seems required. Link: https://github.com/golang/go/issues/20883 Signed-off-by: Robin Jarry <robin@jarry.cc>
56 lines
1.2 KiB
Go
56 lines
1.2 KiB
Go
package config
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/google/shlex"
|
|
|
|
"git.sr.ht/~rjarry/aerc/lib/format"
|
|
"git.sr.ht/~rjarry/aerc/models"
|
|
)
|
|
|
|
func (trig *TriggersConfig) ExecTrigger(triggerCmd string,
|
|
triggerFmt func(string) (string, error)) error {
|
|
|
|
if len(triggerCmd) == 0 {
|
|
return errors.New("Trigger command empty")
|
|
}
|
|
triggerCmdParts, err := shlex.Split(triggerCmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
var command []string
|
|
for _, part := range triggerCmdParts {
|
|
formattedPart, err := triggerFmt(part)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
command = append(command, formattedPart)
|
|
}
|
|
return trig.ExecuteCommand(command)
|
|
}
|
|
|
|
func (trig *TriggersConfig) ExecNewEmail(account *AccountConfig,
|
|
conf *AercConfig, msg *models.MessageInfo) {
|
|
err := trig.ExecTrigger(trig.NewEmail,
|
|
func(part string) (string, error) {
|
|
formatstr, args, err := format.ParseMessageFormat(
|
|
part, conf.Ui.TimestampFormat,
|
|
conf.Ui.ThisDayTimeFormat,
|
|
conf.Ui.ThisYearTimeFormat,
|
|
format.Ctx{
|
|
FromAddress: account.From,
|
|
AccountName: account.Name,
|
|
MsgInfo: msg},
|
|
)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return fmt.Sprintf(formatstr, args...), nil
|
|
})
|
|
if err != nil {
|
|
fmt.Printf("Error from the new-email trigger: %s\n", err)
|
|
}
|
|
}
|