Compare commits
	
		
			No commits in common. "301e94808d172280d9f04b7440e4e366b74f0cba" and "17e3b6513f5d80c12b8f50ff7892f94c2823d3a8" have entirely different histories.
		
	
	
		
			301e94808d
			...
			17e3b6513f
		
	
		
| @ -54,7 +54,7 @@ func ParseToChatUser(c *gin.Context) (chatUserInfo *accountFiee.ChatUserData, co | |||||||
| 		originId = int64(fieeJwtInfo.ID) | 		originId = int64(fieeJwtInfo.ID) | ||||||
| 		newChatUser = &accountFiee.ChatUserData{ | 		newChatUser = &accountFiee.ChatUserData{ | ||||||
| 			NickName: fieeJwtInfo.NickName, | 			NickName: fieeJwtInfo.NickName, | ||||||
| 			Account:  fieeJwtInfo.Phone, | 			Account:  fieeJwtInfo.Account, | ||||||
| 			Role:     1, | 			Role:     1, | ||||||
| 			Origin:   config.AppConfig.System.Domain, | 			Origin:   config.AppConfig.System.Domain, | ||||||
| 			OriginId: int64(fieeJwtInfo.ID), | 			OriginId: int64(fieeJwtInfo.ID), | ||||||
|  | |||||||
| @ -18,40 +18,17 @@ import ( | |||||||
| 	"fonchain-fiee/pkg/service/asChat/dto" | 	"fonchain-fiee/pkg/service/asChat/dto" | ||||||
| 	"go.uber.org/zap" | 	"go.uber.org/zap" | ||||||
| 	"log" | 	"log" | ||||||
| 	"sync" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var cacheMap = make(map[int64]dto.NewMessageRequest) |  | ||||||
| var newMessageLocker sync.Mutex |  | ||||||
| 
 |  | ||||||
| func NewMessage(ctx context.Context, cache *chatCache.ChatCache, sender *accountFiee.ChatUserData, request dto.NewMessageRequest) (err error) { | func NewMessage(ctx context.Context, cache *chatCache.ChatCache, sender *accountFiee.ChatUserData, request dto.NewMessageRequest) (err error) { | ||||||
| 	newMessageLocker.Lock() |  | ||||||
| 	defer newMessageLocker.Unlock() |  | ||||||
| 	if request.SessionId == "" { | 	if request.SessionId == "" { | ||||||
| 		return errors.New("sessionId不能为空") | 		return errors.New("sessionId不能为空") | ||||||
| 	} | 	} | ||||||
| 	if request.MsgType == 0 { | 	if request.MsgType == 0 { | ||||||
| 		return errors.New("msgType不能为空") | 		return errors.New("msgType不能为空") | ||||||
| 	} | 	} | ||||||
| 	//短时间重复消息不发送
 | 	fmt.Println("NewMessage 1111111111111111111111111111111") | ||||||
| 	if request.AtUserId != 0 && request.Robot { | 	fmt.Println("NewMessage 22222222222222222222222222222222222") | ||||||
| 		if msgRecord, ok := cacheMap[request.AtUserId]; ok { |  | ||||||
| 			if msgRecord.SessionId == "" { |  | ||||||
| 				cacheMap[request.AtUserId] = request |  | ||||||
| 			} else { |  | ||||||
| 				fmt.Println(request.LocalStamp - msgRecord.LocalStamp) |  | ||||||
| 				if msgRecord.Message.Text == request.Message.Text && request.LocalStamp-msgRecord.LocalStamp < 1 { //秒级
 |  | ||||||
| 					cacheMap[request.AtUserId] = request |  | ||||||
| 					return nil |  | ||||||
| 				} else { |  | ||||||
| 					cacheMap[request.AtUserId] = request |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} else { |  | ||||||
| 			cacheMap[request.AtUserId] = request |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	//存储入库
 | 	//存储入库
 | ||||||
| 	if sender.NickName == "" { | 	if sender.NickName == "" { | ||||||
| 		sender.NickName = fmt.Sprintf("未知用户(%d)", sender.ID) | 		sender.NickName = fmt.Sprintf("未知用户(%d)", sender.ID) | ||||||
|  | |||||||
| @ -27,3 +27,220 @@ func (r *Reply) Hit(event ws.ListenEventData, robotInfo *accountFiee.ChatUserDat | |||||||
| 	} | 	} | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | //
 | ||||||
|  | //// 规则接口
 | ||||||
|  | //type IRule interface {
 | ||||||
|  | //	Hit(event ws.ListenEventData, robotInfo *accountFiee.ChatUserData) (hit bool, task RobotTask)
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //// KeywordsRuleChecker 关键字回复
 | ||||||
|  | //type ReplyWhenHitKeywords struct {
 | ||||||
|  | //	Keywords []string `json:"keywords"`
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //func NewReplyWhenHitKeywords(keywords []string) IRule {
 | ||||||
|  | //	return &ReplyWhenHitKeywords{Keywords: keywords}
 | ||||||
|  | //}
 | ||||||
|  | //func (k ReplyWhenHitKeywords) Hit(event ws.ListenEventData, robotInfo *accountFiee.ChatUserData) (hit bool, task RobotTask) {
 | ||||||
|  | //	if event.EventType != ws.EventChatMessage || event.Msg == "" || event.Client == nil || event.ChatUser == nil {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	if event.ChatUser.Role != 1 {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	for _, v := range k.Keywords {
 | ||||||
|  | //		if strings.Contains(event.Msg, v) {
 | ||||||
|  | //			hit = true
 | ||||||
|  | //			break
 | ||||||
|  | //		}
 | ||||||
|  | //	}
 | ||||||
|  | //	atUserId := event.Client.UserId
 | ||||||
|  | //	task = RobotTask{
 | ||||||
|  | //		ChatUser: event.ChatUser,
 | ||||||
|  | //		Run: func(msg string, cache *chatCache.ChatCache, Sender *accountFiee.ChatUserData) error {
 | ||||||
|  | //			return logic.NewMessage(context.Background(), cache, Sender, dto.NewMessageRequest{
 | ||||||
|  | //				Waiter:    true,
 | ||||||
|  | //				Robot:     true,
 | ||||||
|  | //				AtUserId:  atUserId,
 | ||||||
|  | //				SessionId: event.Client.SessionId,
 | ||||||
|  | //				Message: dto.Message{
 | ||||||
|  | //					MsgType:    1,
 | ||||||
|  | //					Text:       msg,
 | ||||||
|  | //					LocalStamp: time.Now().Unix(),
 | ||||||
|  | //				},
 | ||||||
|  | //			})
 | ||||||
|  | //		},
 | ||||||
|  | //	}
 | ||||||
|  | //	return
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //// 用户打开聊天会话直接发送
 | ||||||
|  | //type ReplyWhenUserJoinSession struct {
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //func NewReplyWhenUserJoinSession() IRule {
 | ||||||
|  | //	return &ReplyWhenUserJoinSession{}
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //func (k ReplyWhenUserJoinSession) Hit(event ws.ListenEventData, robotInfo *accountFiee.ChatUserData) (hit bool, task RobotTask) {
 | ||||||
|  | //	if event.EventType != ws.EventUserJoin {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	if event.Client == nil {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	clientSessionId := event.Client.SessionId
 | ||||||
|  | //	atUserId := event.Client.UserId
 | ||||||
|  | //	ctx := context.Background()
 | ||||||
|  | //	queryRes, err := service.AccountFieeProvider.GetChatRecordList(ctx, &accountFiee.GetChatRecordListRequest{
 | ||||||
|  | //		Query: &accountFiee.ChatRecordData{
 | ||||||
|  | //			SessionId: event.Client.SessionId,
 | ||||||
|  | //		},
 | ||||||
|  | //		Page:     1,
 | ||||||
|  | //		PageSize: 1,
 | ||||||
|  | //		Order:    "created_at desc",
 | ||||||
|  | //	})
 | ||||||
|  | //	if err != nil {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	//如果最近一次的消息也是机器人发送的,就不再发送了
 | ||||||
|  | //	for i, v := range queryRes.List {
 | ||||||
|  | //		if i == 0 {
 | ||||||
|  | //			if v.UserId == robotInfo.ID {
 | ||||||
|  | //				return
 | ||||||
|  | //			} else {
 | ||||||
|  | //				break
 | ||||||
|  | //			}
 | ||||||
|  | //		}
 | ||||||
|  | //	}
 | ||||||
|  | //	hit = true
 | ||||||
|  | //	if event.ChatUser == nil {
 | ||||||
|  | //		event.ChatUser, err = service.AccountFieeProvider.GetChatUserDetail(context.Background(), &accountFiee.GetChatUserByIdRequest{Id: event.Client.UserId})
 | ||||||
|  | //		if err != nil {
 | ||||||
|  | //			return
 | ||||||
|  | //		}
 | ||||||
|  | //	}
 | ||||||
|  | //	task = RobotTask{
 | ||||||
|  | //		ChatUser: event.ChatUser,
 | ||||||
|  | //		Run: func(msg string, cache *chatCache.ChatCache, Sender *accountFiee.ChatUserData) error {
 | ||||||
|  | //			return logic.NewMessage(ctx, cache, Sender, dto.NewMessageRequest{
 | ||||||
|  | //				Waiter:    true,
 | ||||||
|  | //				Robot:     true,
 | ||||||
|  | //				AtUserId:  atUserId,
 | ||||||
|  | //				SessionId: clientSessionId,
 | ||||||
|  | //				Message: dto.Message{
 | ||||||
|  | //					MsgType:    1,
 | ||||||
|  | //					Text:       msg,
 | ||||||
|  | //					LocalStamp: time.Now().Unix(),
 | ||||||
|  | //				},
 | ||||||
|  | //			})
 | ||||||
|  | //		},
 | ||||||
|  | //	}
 | ||||||
|  | //	//logicFunc = func(msg string, cache *chatCache.ChatCache, chatUser *accountFiee.ChatUserData) error {
 | ||||||
|  | //	//	//var notice = dto.MessageListType{}
 | ||||||
|  | //	//	//newRecord := &accountFiee.ChatRecordData{
 | ||||||
|  | //	//	//	SessionId: wsClient.SessionId,
 | ||||||
|  | //	//	//	UserId:    wsClient.UserId,
 | ||||||
|  | //	//	//	Name:      wsClient.SessionId,
 | ||||||
|  | //	//	//	Avatar:    robotInfo.Avatar,
 | ||||||
|  | //	//	//	MsgType:   1,
 | ||||||
|  | //	//	//	Content:   msg,
 | ||||||
|  | //	//	//}
 | ||||||
|  | //	//	//notice.BuildMessage(newRecord)
 | ||||||
|  | //	//	//_, err = consts.ChatRoom.SendSessionMessage(robotInfo, wsClient.SessionId, ws.NewChatMsgType, notice)
 | ||||||
|  | //	//	err = logic.NewMessage(ctx, cache, chatUser, dto.NewMessageRequest{
 | ||||||
|  | //	//		Waiter:    true,
 | ||||||
|  | //	//		SessionId: wsClient.SessionId,
 | ||||||
|  | //	//		Message: dto.Message{
 | ||||||
|  | //	//			MsgType:    1,
 | ||||||
|  | //	//			Text:       msg,
 | ||||||
|  | //	//			LocalStamp: time.Now().Unix(),
 | ||||||
|  | //	//		},
 | ||||||
|  | //	//	})
 | ||||||
|  | //	//	return err
 | ||||||
|  | //	//}
 | ||||||
|  | //	return
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | //// 客服指定时间不回复则自动回复
 | ||||||
|  | //
 | ||||||
|  | //type ReplyWhenWaiterNoAction struct {
 | ||||||
|  | //	DelaySecond time.Duration
 | ||||||
|  | //}
 | ||||||
|  | //
 | ||||||
|  | ////func NewReplyWhenWaiterNoAction(delaySecond time.Duration) *ReplyWhenWaiterNoAction {
 | ||||||
|  | ////	return &ReplyWhenWaiterNoAction{
 | ||||||
|  | ////		DelaySecond: delaySecond,
 | ||||||
|  | ////	}
 | ||||||
|  | ////}
 | ||||||
|  | //
 | ||||||
|  | //func (k *ReplyWhenWaiterNoAction) Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool, task RobotTask) {
 | ||||||
|  | //	if event.Client == nil || event.EventType != ws.EventChatMessage {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	//客服和机器人的的消息不需要处理
 | ||||||
|  | //	if event.ChatUser.Role != 1 {
 | ||||||
|  | //		return
 | ||||||
|  | //	}
 | ||||||
|  | //	hit = true // 立即保存SessionId的值
 | ||||||
|  | //
 | ||||||
|  | //	clientSessionId := event.Client.SessionId
 | ||||||
|  | //	atUserId := event.Client.UserId
 | ||||||
|  | //	fmt.Printf("闭包前: clientSessionId=%s\n", clientSessionId)
 | ||||||
|  | //	task = RobotTask{
 | ||||||
|  | //		RunTime: time.Now().Add(k.DelaySecond * time.Second),
 | ||||||
|  | //		Run: func(content string, cache *chatCache.ChatCache, Sender *accountFiee.ChatUserData) error {
 | ||||||
|  | //			// 记录闭包执行时的Client状态
 | ||||||
|  | //			fmt.Printf("闭包执行: clientSessionId=%s\n", clientSessionId)
 | ||||||
|  | //
 | ||||||
|  | //			//如果客服已经回复则不发送消息
 | ||||||
|  | //			chatRecordListRes, err := service.AccountFieeProvider.GetChatRecordList(context.Background(), &accountFiee.GetChatRecordListRequest{
 | ||||||
|  | //				Query: &accountFiee.ChatRecordData{
 | ||||||
|  | //					SessionId: event.Client.SessionId,
 | ||||||
|  | //				},
 | ||||||
|  | //				Page:     1,
 | ||||||
|  | //				PageSize: 1,
 | ||||||
|  | //				Order:    "created_at desc",
 | ||||||
|  | //			})
 | ||||||
|  | //			if err != nil || chatRecordListRes.Total == 0 {
 | ||||||
|  | //				return err
 | ||||||
|  | //			}
 | ||||||
|  | //			checkUserId := chatRecordListRes.List[0].UserId
 | ||||||
|  | //			checkChatUser, err := service.AccountFieeProvider.GetChatUserDetail(context.Background(), &accountFiee.GetChatUserByIdRequest{Id: checkUserId})
 | ||||||
|  | //			if err != nil || checkChatUser.Role != 1 {
 | ||||||
|  | //				return err
 | ||||||
|  | //			}
 | ||||||
|  | //
 | ||||||
|  | //			//var notice = dto.MessageListType{}
 | ||||||
|  | //			//newRecord := &accountFiee.ChatRecordData{
 | ||||||
|  | //			//	SessionId: wsClient.SessionId,
 | ||||||
|  | //			//	UserId:    wsClient.UserId,
 | ||||||
|  | //			//	Name:      chatUser.NickName,
 | ||||||
|  | //			//	Avatar:    robotInfo.Avatar,
 | ||||||
|  | //			//	MsgType:   1,
 | ||||||
|  | //			//	Content:   content,
 | ||||||
|  | //			//}
 | ||||||
|  | //			//notice.BuildMessage(newRecord)
 | ||||||
|  | //			//_, err = consts.ChatRoom.SendSessionMessage(robotInfo, wsClient.SessionId, ws.NewChatMsgType, notice)
 | ||||||
|  | //			//return err
 | ||||||
|  | //			fmt.Println("延时回复 sessionID:", clientSessionId)
 | ||||||
|  | //			err = logic.NewMessage(context.Background(), cache, sender, dto.NewMessageRequest{
 | ||||||
|  | //				Waiter:    true,
 | ||||||
|  | //				Robot:     true,
 | ||||||
|  | //				AtUserId:  atUserId,
 | ||||||
|  | //				SessionId: clientSessionId,
 | ||||||
|  | //				Message: dto.Message{
 | ||||||
|  | //					MsgType:    1,
 | ||||||
|  | //					Text:       content,
 | ||||||
|  | //					LocalStamp: time.Now().Unix(),
 | ||||||
|  | //				},
 | ||||||
|  | //			})
 | ||||||
|  | //			return err
 | ||||||
|  | //		},
 | ||||||
|  | //		Response: "",
 | ||||||
|  | //		ChatUser: event.ChatUser,
 | ||||||
|  | //	}
 | ||||||
|  | //	return
 | ||||||
|  | //
 | ||||||
|  | //}
 | ||||||
|  | |||||||
| @ -65,8 +65,8 @@ func NewRobot(cache *chatCache.ChatCache) *Robot { | |||||||
| 
 | 
 | ||||||
| type Robot struct { | type Robot struct { | ||||||
| 	Info      *accountFiee.ChatUserData //机器人信息
 | 	Info      *accountFiee.ChatUserData //机器人信息
 | ||||||
| 	joinSessionRules, keywordsRules, noReplyAfterRules []IRobotTask              //自动回复规则
 | 	Rules     []Reply                   //回复规则
 | ||||||
| 	DelayTask                                          []IRobotTask              //延时任务
 | 	DelayTask []IRobotTask              //演示任务
 | ||||||
| 	ticker    *time.Ticker              //定时器
 | 	ticker    *time.Ticker              //定时器
 | ||||||
| 	stopChan  chan struct{}             //停止管道
 | 	stopChan  chan struct{}             //停止管道
 | ||||||
| 	isRunning bool                      //运行状态
 | 	isRunning bool                      //运行状态
 | ||||||
| @ -164,57 +164,22 @@ func (r *Robot) Run() { | |||||||
| 		case event := <-r.EventListener.Chan: | 		case event := <-r.EventListener.Chan: | ||||||
| 			fmt.Printf("robot listen event:%#v\n", event) | 			fmt.Printf("robot listen event:%#v\n", event) | ||||||
| 			r.mu.Lock() | 			r.mu.Lock() | ||||||
| 			//加入聊天室规则
 | 			for _, ruleResponse := range r.Rules { | ||||||
| 			hasHit := false | 				hit, task := ruleResponse.Hit(event, r.Info) | ||||||
| 			for _, rule := range r.joinSessionRules { |  | ||||||
| 				hit := rule.Hit(event, r.Info) |  | ||||||
| 				fmt.Printf("规则【%s】校验结果:%v\n", rule.GetTitle(), hit) |  | ||||||
| 				if hit { | 				if hit { | ||||||
| 					hasHit = true | 					fmt.Println("命中规则:", ruleResponse.Title) | ||||||
| 					if rule.RunTime().IsZero() { | 					if task.RunTime().IsZero() { | ||||||
| 						err := rule.Run(r.cache) | 						task.SetResponse(ruleResponse.Response) | ||||||
|  | 						err := task.Run(r.cache) | ||||||
| 						if err != nil { | 						if err != nil { | ||||||
| 							log.Printf("robot 执行任务失败:%v\n", err) | 							log.Printf("robot 执行任务失败:%v\n", err) | ||||||
| 						} | 						} | ||||||
| 					} else { | 					} else { | ||||||
| 						r.RegisterDelayTask(rule) | 						ruleResponse := ruleResponse | ||||||
| 					} | 						task.SetResponse(ruleResponse.Response) | ||||||
| 				} | 						r.RegisterDelayTask(task) | ||||||
| 			} |  | ||||||
| 			if !hasHit { |  | ||||||
| 				for _, rule := range r.keywordsRules { |  | ||||||
| 					hit := rule.Hit(event, r.Info) |  | ||||||
| 					fmt.Printf("规则【%s】校验结果:%v\n", rule.GetTitle(), hit) |  | ||||||
| 					if hit { |  | ||||||
| 						hasHit = true |  | ||||||
| 						fmt.Println("命中规则:", rule.GetTitle()) |  | ||||||
| 						if rule.RunTime().IsZero() { |  | ||||||
| 							err := rule.Run(r.cache) |  | ||||||
| 							if err != nil { |  | ||||||
| 								log.Printf("robot 执行任务失败:%v\n", err) |  | ||||||
| 							} |  | ||||||
| 						} else { |  | ||||||
| 							r.RegisterDelayTask(rule) |  | ||||||
| 						} |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 			if !hasHit { |  | ||||||
| 				for _, rule := range r.noReplyAfterRules { |  | ||||||
| 					hit := rule.Hit(event, r.Info) |  | ||||||
| 					fmt.Printf("规则【%s】校验结果:%v\n", rule.GetTitle(), hit) |  | ||||||
| 					if hit { |  | ||||||
| 						hasHit = true |  | ||||||
| 						fmt.Println("命中规则:", rule.GetTitle()) |  | ||||||
| 						if rule.RunTime().IsZero() { |  | ||||||
| 							err := rule.Run(r.cache) |  | ||||||
| 							if err != nil { |  | ||||||
| 								log.Printf("robot 执行任务失败:%v\n", err) |  | ||||||
| 							} |  | ||||||
| 						} else { |  | ||||||
| 							r.RegisterDelayTask(rule) |  | ||||||
| 						} |  | ||||||
| 					} | 					} | ||||||
|  | 					break | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 			r.mu.Unlock() | 			r.mu.Unlock() | ||||||
| @ -241,9 +206,7 @@ func (r *Robot) RegisterDelayTask(task IRobotTask) { | |||||||
| func (r *Robot) ReloadRules(ctx context.Context) error { | func (r *Robot) ReloadRules(ctx context.Context) error { | ||||||
| 	r.mu.Lock() | 	r.mu.Lock() | ||||||
| 	defer r.mu.Unlock() | 	defer r.mu.Unlock() | ||||||
| 	r.joinSessionRules = []IRobotTask{} | 	r.Rules = []Reply{} | ||||||
| 	r.keywordsRules = []IRobotTask{} |  | ||||||
| 	r.noReplyAfterRules = []IRobotTask{} |  | ||||||
| 	ruleListRes, err := service.AccountFieeProvider.GetChatAutoReplyRulerList(ctx, &accountFiee.GetChatAutoReplyRulerListRequest{ | 	ruleListRes, err := service.AccountFieeProvider.GetChatAutoReplyRulerList(ctx, &accountFiee.GetChatAutoReplyRulerListRequest{ | ||||||
| 		Query:    &accountFiee.ChatAutoReplyRulerData{Status: 1}, | 		Query:    &accountFiee.ChatAutoReplyRulerData{Status: 1}, | ||||||
| 		Page:     1, | 		Page:     1, | ||||||
| @ -259,7 +222,10 @@ func (r *Robot) ReloadRules(ctx context.Context) error { | |||||||
| 			tmp.Parse(v) | 			tmp.Parse(v) | ||||||
| 			data = append(data, &tmp) | 			data = append(data, &tmp) | ||||||
| 		} | 		} | ||||||
| 		r.joinSessionRules, r.keywordsRules, r.noReplyAfterRules = ParseReplyRule(data) | 		for _, v := range data { | ||||||
|  | 			reply := ParseReplyRule(v) | ||||||
|  | 			r.Rules = append(r.Rules, reply) | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | |||||||
| @ -8,29 +8,15 @@ package robot | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"fonchain-fiee/api/accountFiee" |  | ||||||
| 	"fonchain-fiee/pkg/common/ws" |  | ||||||
| 	"fonchain-fiee/pkg/service/asChat/chatCache" |  | ||||||
| 	"fonchain-fiee/pkg/service/asChat/dto" | 	"fonchain-fiee/pkg/service/asChat/dto" | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"time" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type IRobotTask interface { |  | ||||||
| 	Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) |  | ||||||
| 	Run(cache *chatCache.ChatCache) error |  | ||||||
| 	RunTime() time.Time |  | ||||||
| 	SetResponse(response string) |  | ||||||
| 	GetResponse() string |  | ||||||
| 	SetTitle(title string) |  | ||||||
| 	GetTitle() string |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 自动回复规则结构转换
 | // 自动回复规则结构转换
 | ||||||
| func ParseReplyRule(data []*dto.ChatAutoReplyData) (joinSessionRules, keywordsRules, noReplyAfterRules []IRobotTask) { | func ParseReplyRule(data *dto.ChatAutoReplyData) (r Reply) { | ||||||
| 	for _, responseRules := range data { | 	r.Response = data.Response | ||||||
| 		responseRules := responseRules | 	r.Title = data.Title | ||||||
| 		for ruleName, v := range responseRules.Rules { | 	for ruleName, v := range data.Rules { | ||||||
| 		if !v.Enable { | 		if !v.Enable { | ||||||
| 			continue | 			continue | ||||||
| 		} | 		} | ||||||
| @ -43,21 +29,14 @@ func ParseReplyRule(data []*dto.ChatAutoReplyData) (joinSessionRules, keywordsRu | |||||||
| 				keywords = strings.Split(v.Content, ",") | 				keywords = strings.Split(v.Content, ",") | ||||||
| 			} | 			} | ||||||
| 			fmt.Println("ParseReplyRule 解析keywords:", keywords) | 			fmt.Println("ParseReplyRule 解析keywords:", keywords) | ||||||
| 				r := NewReplyWhenHitKeywords(responseRules.Title+"-keywords", keywords) | 			r.Rules = append(r.Rules, NewReplyWhenHitKeywords(keywords)) | ||||||
| 				r.SetResponse(responseRules.Response) |  | ||||||
| 				keywordsRules = append(keywordsRules, r) |  | ||||||
| 		case "joinSession": //加入聊天后回复
 | 		case "joinSession": //加入聊天后回复
 | ||||||
| 				r := NewReplyWhenUserJoinSession(responseRules.Title + "-joinSession") | 			r.Rules = append(r.Rules, NewReplyWhenUserJoinSession()) | ||||||
| 				r.SetResponse(responseRules.Response) |  | ||||||
| 				joinSessionRules = append(joinSessionRules, r) |  | ||||||
| 		case "noReplyAfter": //指定时间没有回复则自动回复
 | 		case "noReplyAfter": //指定时间没有回复则自动回复
 | ||||||
| 			if v.SecondDuration == 0 { | 			if v.SecondDuration == 0 { | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
| 				r := NewReplyWhenWaiterNoAction(responseRules.Title+"-noReplyAfter", v.SecondDuration) | 			r.Rules = append(r.Rules, NewReplyWhenWaiterNoAction(v.SecondDuration)) | ||||||
| 				r.SetResponse(responseRules.Response) |  | ||||||
| 				noReplyAfterRules = append(noReplyAfterRules, r) |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	return | 	return | ||||||
|  | |||||||
| @ -18,16 +18,21 @@ import ( | |||||||
| 	"time" | 	"time" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | type IRobotTask interface { | ||||||
|  | 	Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) | ||||||
|  | 	Run(cache *chatCache.ChatCache) error | ||||||
|  | 	RunTime() time.Time | ||||||
|  | 	SetResponse(response string) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // 客服指定时间不回复则自动回复
 | // 客服指定时间不回复则自动回复
 | ||||||
| func NewReplyWhenWaiterNoAction(title string, delaySecond time.Duration) IRobotTask { | func NewReplyWhenWaiterNoAction(delaySecond time.Duration) IRobotTask { | ||||||
| 	return &RobotTaskReplyWhenWaiterNoAction{ | 	return &RobotTaskReplyWhenWaiterNoAction{ | ||||||
| 		delaySecond: delaySecond, | 		delaySecond: delaySecond, | ||||||
| 		title:       title, |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type RobotTaskReplyWhenWaiterNoAction struct { | type RobotTaskReplyWhenWaiterNoAction struct { | ||||||
| 	title       string |  | ||||||
| 	runTime     time.Time | 	runTime     time.Time | ||||||
| 	Response    string | 	Response    string | ||||||
| 	Receiver    *accountFiee.ChatUserData | 	Receiver    *accountFiee.ChatUserData | ||||||
| @ -91,12 +96,3 @@ func (r *RobotTaskReplyWhenWaiterNoAction) RunTime() time.Time { | |||||||
| func (r *RobotTaskReplyWhenWaiterNoAction) SetResponse(response string) { | func (r *RobotTaskReplyWhenWaiterNoAction) SetResponse(response string) { | ||||||
| 	r.Resp = response | 	r.Resp = response | ||||||
| } | } | ||||||
| func (r *RobotTaskReplyWhenWaiterNoAction) GetResponse() string { |  | ||||||
| 	return r.Response |  | ||||||
| } |  | ||||||
| func (r *RobotTaskReplyWhenWaiterNoAction) SetTitle(title string) { |  | ||||||
| 	r.title = title |  | ||||||
| } |  | ||||||
| func (r *RobotTaskReplyWhenWaiterNoAction) GetTitle() string { |  | ||||||
| 	return r.title |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -13,7 +13,6 @@ import ( | |||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type RobotTaskWithKeyworkds struct { | type RobotTaskWithKeyworkds struct { | ||||||
| 	title    string |  | ||||||
| 	runTime  time.Time | 	runTime  time.Time | ||||||
| 	Response string | 	Response string | ||||||
| 	Receiver *accountFiee.ChatUserData | 	Receiver *accountFiee.ChatUserData | ||||||
| @ -23,8 +22,8 @@ type RobotTaskWithKeyworkds struct { | |||||||
| 	keywords []string | 	keywords []string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewReplyWhenHitKeywords(title string, keywords []string) IRobotTask { | func NewReplyWhenHitKeywords(keywords []string) IRobotTask { | ||||||
| 	return &RobotTaskWithKeyworkds{title: title, keywords: keywords} | 	return &RobotTaskWithKeyworkds{keywords: keywords} | ||||||
| } | } | ||||||
| func (r *RobotTaskWithKeyworkds) Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) { | func (r *RobotTaskWithKeyworkds) Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) { | ||||||
| 	if event.EventType != ws.EventChatMessage || event.Msg == "" || event.Client == nil || event.ChatUser == nil { | 	if event.EventType != ws.EventChatMessage || event.Msg == "" || event.Client == nil || event.ChatUser == nil { | ||||||
| @ -68,13 +67,3 @@ func (r *RobotTaskWithKeyworkds) RunTime() time.Time { | |||||||
| func (r *RobotTaskWithKeyworkds) SetResponse(response string) { | func (r *RobotTaskWithKeyworkds) SetResponse(response string) { | ||||||
| 	r.Resp = response | 	r.Resp = response | ||||||
| } | } | ||||||
| 
 |  | ||||||
| func (r *RobotTaskWithKeyworkds) GetResponse() string { |  | ||||||
| 	return r.Response |  | ||||||
| } |  | ||||||
| func (r *RobotTaskWithKeyworkds) SetTitle(title string) { |  | ||||||
| 	r.title = title |  | ||||||
| } |  | ||||||
| func (r *RobotTaskWithKeyworkds) GetTitle() string { |  | ||||||
| 	return r.title |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -12,8 +12,8 @@ import ( | |||||||
| 	"time" | 	"time" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func NewReplyWhenUserJoinSession(title string) IRobotTask { | func NewReplyWhenUserJoinSession() IRobotTask { | ||||||
| 	return &ReplyWhenUserJoinSession{title: title} | 	return &ReplyWhenUserJoinSession{} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type ReplyWhenUserJoinSession struct { | type ReplyWhenUserJoinSession struct { | ||||||
| @ -23,7 +23,6 @@ type ReplyWhenUserJoinSession struct { | |||||||
| 	Resp      string | 	Resp      string | ||||||
| 	sessionId string | 	sessionId string | ||||||
| 	atUserId  int | 	atUserId  int | ||||||
| 	title     string |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (r *ReplyWhenUserJoinSession) Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) { | func (r *ReplyWhenUserJoinSession) Hit(event ws.ListenEventData, sender *accountFiee.ChatUserData) (hit bool) { | ||||||
| @ -84,12 +83,3 @@ func (r *ReplyWhenUserJoinSession) RunTime() time.Time { | |||||||
| func (r *ReplyWhenUserJoinSession) SetResponse(response string) { | func (r *ReplyWhenUserJoinSession) SetResponse(response string) { | ||||||
| 	r.Resp = response | 	r.Resp = response | ||||||
| } | } | ||||||
| func (r *ReplyWhenUserJoinSession) GetResponse() string { |  | ||||||
| 	return r.Response |  | ||||||
| } |  | ||||||
| func (r *ReplyWhenUserJoinSession) SetTitle(title string) { |  | ||||||
| 	r.title = title |  | ||||||
| } |  | ||||||
| func (r *ReplyWhenUserJoinSession) GetTitle() string { |  | ||||||
| 	return r.title |  | ||||||
| } |  | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user