添加群发消息暂停功能

This commit is contained in:
eatMoreApple 2021-04-25 10:09:41 +08:00
parent b00708e811
commit 688cf74bd6

View File

@ -5,6 +5,7 @@ import (
"fmt"
"os"
"strings"
"time"
)
type Friend struct{ *User }
@ -108,8 +109,11 @@ func (f Friends) Search(limit int, condFuncList ...func(friend *Friend) bool) (r
}
// 向slice的好友依次发送消息
func (f Friends) SendMsg(msg *SendMessage) error {
func (f Friends) SendMsg(msg *SendMessage, delay ...time.Duration) error {
for _, friend := range f {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := friend.SendMsg(msg); err != nil {
return err
}
@ -118,8 +122,11 @@ func (f Friends) SendMsg(msg *SendMessage) error {
}
// 向slice的好友依次发送文本消息
func (f Friends) SendText(text string) error {
func (f Friends) SendText(text string, delay ...time.Duration) error {
for _, friend := range f {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := friend.SendText(text); err != nil {
return err
}
@ -127,6 +134,18 @@ func (f Friends) SendText(text string) error {
return nil
}
func (f Friends) SendImage(file *os.File, delay ...time.Duration) error {
for _, friend := range f {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := friend.SendImage(file); err != nil {
return err
}
}
return nil
}
type Group struct{ *User }
// implement fmt.Stringer
@ -227,6 +246,42 @@ func (g Groups) Last() *Group {
return nil
}
func (g Groups) SendMsg(msg *SendMessage, delay ...time.Duration) error {
for _, group := range g {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := group.SendMsg(msg); err != nil {
return err
}
}
return nil
}
func (g Groups) SendText(text string, delay ...time.Duration) error {
for _, group := range g {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := group.SendText(text); err != nil {
return err
}
}
return nil
}
func (g Groups) SendImage(file *os.File, delay ...time.Duration) error {
for _, group := range g {
if len(delay) != 0 {
time.Sleep(delay[0])
}
if err := group.SendImage(file); err != nil {
return err
}
}
return nil
}
func (g Groups) SearchByUserName(limit int, username string) (results Groups) {
return g.Search(limit, func(group *Group) bool { return group.UserName == username })
}