|
@@ -1,11 +1,15 @@
|
|
|
package crontask
|
|
|
|
|
|
import (
|
|
|
+ "encoding/json"
|
|
|
+ "net/url"
|
|
|
+ "path"
|
|
|
"strings"
|
|
|
"time"
|
|
|
"wechat-api/ent"
|
|
|
"wechat-api/ent/batchmsg"
|
|
|
"wechat-api/ent/contact"
|
|
|
+ "wechat-api/ent/custom_types"
|
|
|
"wechat-api/ent/label"
|
|
|
"wechat-api/ent/labelrelationship"
|
|
|
"wechat-api/ent/msg"
|
|
@@ -64,19 +68,37 @@ func (l *CronTask) sendMsg() {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+
|
|
|
msgs := make([]*ent.MsgCreate, 0)
|
|
|
|
|
|
- for _, user := range userlist {
|
|
|
-
|
|
|
- msg := l.svcCtx.DB.Msg.Create().
|
|
|
- SetNotNilFromwxid(&batch.Fromwxid).
|
|
|
- SetNotNilToid(&user.Wxid).
|
|
|
- SetMsgtype(1).
|
|
|
- SetNotNilMsg(&batch.Msg).
|
|
|
- SetStatus(0).
|
|
|
- SetNotNilBatchNo(&batch.BatchNo)
|
|
|
+
|
|
|
+ msgArray := make([]custom_types.Action, 0)
|
|
|
+ err := json.Unmarshal([]byte(batch.Msg), &msgArray)
|
|
|
+ l.Logger.Infof("msgArray length= %v, err:%v", len(msgArray), err)
|
|
|
+ if err != nil {
|
|
|
+
|
|
|
+ msgArray = make([]custom_types.Action, 0)
|
|
|
+ }
|
|
|
|
|
|
- msgs = append(msgs, msg)
|
|
|
+ for _, user := range userlist {
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ if len(msgArray) > 0 {
|
|
|
+
|
|
|
+ for _, msgItem := range msgArray {
|
|
|
+ msgRow := l.svcCtx.DB.Msg.Create().
|
|
|
+ SetNotNilFromwxid(&batch.Fromwxid).
|
|
|
+ SetNotNilToid(&user.Wxid).
|
|
|
+ SetMsgtype(int32(msgItem.Type)).
|
|
|
+ SetNotNilMsg(&msgItem.Content).
|
|
|
+ SetStatus(0).
|
|
|
+ SetNotNilBatchNo(&batch.BatchNo)
|
|
|
+
|
|
|
+ msgs = append(msgs, msgRow)
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
if len(msgs) > 0 {
|
|
@@ -128,7 +150,15 @@ func (l *CronTask) sendMsg() {
|
|
|
|
|
|
|
|
|
for _, msg := range msglist {
|
|
|
- err = hookClient.SendTextMsg(msg.Toid, msg.Msg)
|
|
|
+
|
|
|
+
|
|
|
+ if msg.Msgtype == 1 {
|
|
|
+ err = hookClient.SendTextMsg(msg.Toid, msg.Msg)
|
|
|
+ } else {
|
|
|
+ diyfilename := getFileName(msg.Msg)
|
|
|
+ err = hookClient.SendPicMsg(msg.Toid, msg.Msg, diyfilename)
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
time.Sleep(time.Second)
|
|
|
if err != nil {
|
|
@@ -174,3 +204,12 @@ func (l *CronTask) sendMsg() {
|
|
|
}
|
|
|
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+func getFileName(photoUrl string) string {
|
|
|
+ u, err := url.Parse(photoUrl)
|
|
|
+ if err != nil {
|
|
|
+ return ""
|
|
|
+ }
|
|
|
+ return path.Base(u.Path)
|
|
|
+}
|