bbgo_origin/pkg/notifier/telegramnotifier/telegram.go

93 lines
1.7 KiB
Go
Raw Normal View History

2020-12-05 06:20:27 +00:00
package telegramnotifier
import (
"fmt"
2020-12-11 07:58:05 +00:00
"github.com/c9s/bbgo/pkg/types"
2020-12-05 06:20:27 +00:00
)
type Notifier struct {
interaction *Interaction
2021-10-15 08:10:25 +00:00
broadcast bool
2020-12-05 06:20:27 +00:00
}
2021-10-15 08:10:25 +00:00
type Option func(notifier *Notifier)
func UseBroadcast() Option {
return func(notifier *Notifier) {
notifier.broadcast = true
}
}
2020-12-05 06:20:27 +00:00
// New
// TODO: register interaction with channel, so that we can route message to the specific telegram bot
2021-10-15 08:10:25 +00:00
func New(interaction *Interaction, options ...Option) *Notifier {
notifier := &Notifier{
interaction: interaction,
}
for _, o := range options {
o(notifier)
}
2020-12-05 06:20:27 +00:00
return notifier
}
func (n *Notifier) Notify(obj interface{}, args ...interface{}) {
n.NotifyTo("", obj, args...)
2020-12-05 06:20:27 +00:00
}
func filterPlaintextMessages(args []interface{}) (texts []string, pureArgs []interface{}) {
2021-05-15 01:59:17 +00:00
var firstObjectOffset = -1
2020-12-11 07:58:05 +00:00
for idx, arg := range args {
switch a := arg.(type) {
case types.PlainText:
texts = append(texts, a.PlainText())
2021-05-15 01:59:17 +00:00
if firstObjectOffset == -1 {
firstObjectOffset = idx
2021-05-14 06:57:22 +00:00
}
2020-12-11 07:58:05 +00:00
case types.Stringer:
texts = append(texts, a.String())
2021-05-15 01:59:17 +00:00
if firstObjectOffset == -1 {
firstObjectOffset = idx
2021-05-14 06:57:22 +00:00
}
2020-12-11 07:58:05 +00:00
}
}
pureArgs = args
2021-05-15 01:59:17 +00:00
if firstObjectOffset > -1 {
pureArgs = args[:firstObjectOffset]
2020-12-05 06:20:27 +00:00
}
return texts, pureArgs
}
2020-12-05 06:20:27 +00:00
func (n *Notifier) NotifyTo(channel string, obj interface{}, args ...interface{}) {
var texts, pureArgs = filterPlaintextMessages(args)
var message string
switch a := obj.(type) {
case string:
log.Infof(a, pureArgs...)
message = fmt.Sprintf(a, pureArgs...)
2020-12-11 07:58:05 +00:00
case types.PlainText:
message = a.PlainText()
case types.Stringer:
message = a.String()
default:
log.Errorf("unsupported notification format: %T %+v", a, a)
}
n.interaction.SendToOwner(message)
2020-12-11 07:58:05 +00:00
for _, text := range texts {
n.interaction.SendToOwner(text)
}
2020-12-05 06:20:27 +00:00
}