2018-10-25 21:51:47 +08:00
|
|
|
package messenger
|
|
|
|
|
2019-07-18 15:10:48 +08:00
|
|
|
import "net/textproto"
|
|
|
|
|
2018-10-25 21:51:47 +08:00
|
|
|
// Messenger is an interface for a generic messaging backend,
|
|
|
|
// for instance, e-mail, SMS etc.
|
|
|
|
type Messenger interface {
|
|
|
|
Name() string
|
|
|
|
|
2019-07-18 15:10:48 +08:00
|
|
|
Push(fromAddr string, toAddr []string, subject string, message []byte, atts []*Attachment) error
|
2018-10-25 21:51:47 +08:00
|
|
|
Flush() error
|
|
|
|
}
|
2019-07-18 15:10:48 +08:00
|
|
|
|
|
|
|
// Attachment represents a file or blob attachment that can be
|
|
|
|
// sent along with a message by a Messenger.
|
|
|
|
type Attachment struct {
|
|
|
|
Name string
|
|
|
|
Header textproto.MIMEHeader
|
|
|
|
Content []byte
|
|
|
|
}
|
2019-07-21 15:00:51 +08:00
|
|
|
|
|
|
|
// MakeAttachmentHeader is a helper function that returns a
|
|
|
|
// textproto.MIMEHeader tailored for attachments, primarily
|
|
|
|
// email. If no encoding is given, base64 is assumed.
|
|
|
|
func MakeAttachmentHeader(filename, encoding string) textproto.MIMEHeader {
|
|
|
|
if encoding == "" {
|
|
|
|
encoding = "base64"
|
|
|
|
}
|
|
|
|
h := textproto.MIMEHeader{}
|
|
|
|
h.Set("Content-Disposition", "attachment; filename="+filename)
|
|
|
|
h.Set("Content-Type", "application/json; name=\""+filename+"\"")
|
2019-10-25 13:41:47 +08:00
|
|
|
h.Set("Content-Transfer-Encoding", encoding)
|
2019-07-21 15:00:51 +08:00
|
|
|
return h
|
|
|
|
}
|