Compare commits
	
		
			No commits in common. "f90be904e43a4189a192bcc076c033d5f460febd" and "4269f34670ba62422b592df6f0eae762184cdd2d" have entirely different histories.
		
	
	
		
			f90be904e4
			...
			4269f34670
		
	
		
| @ -73,9 +73,6 @@ func (k ReplyWhenUserJoinSession) Hit(eventType ws.EventType, record *accountFie | ||||
| 	if eventType != ws.EventUserJoin { | ||||
| 		return | ||||
| 	} | ||||
| 	if record == nil { | ||||
| 		return | ||||
| 	} | ||||
| 	queryRes, err := service.AccountFieeProvider.GetChatRecordList(context.Background(), &accountFiee.GetChatRecordListRequest{ | ||||
| 		Query: &accountFiee.ChatRecordData{ | ||||
| 			SessionId: record.SessionId, | ||||
| @ -108,18 +105,15 @@ func (k ReplyWhenUserJoinSession) Hit(eventType ws.EventType, record *accountFie | ||||
| } | ||||
| 
 | ||||
| // 客服
 | ||||
| func NewReplyWhenWaiterNoAction(delaySecond time.Duration) *ReplyWhenWaiterNoAction { | ||||
| 	return &ReplyWhenWaiterNoAction{ | ||||
| 		DelaySecond: delaySecond, | ||||
| 	} | ||||
| func NewReplyWhenWaiterNoAction() *ReplyWhenWaiterNoAction { | ||||
| 	return &ReplyWhenWaiterNoAction{} | ||||
| } | ||||
| 
 | ||||
| type ReplyWhenWaiterNoAction struct { | ||||
| 	DelaySecond time.Duration | ||||
| } | ||||
| 
 | ||||
| func (k *ReplyWhenWaiterNoAction) Hit(eventType ws.EventType, record *accountFiee.ChatRecordData, robotId int64) (hit bool, runTime time.Time, logic func() error) { | ||||
| 	runTime = time.Now().Add(k.DelaySecond * time.Second) | ||||
| func (k ReplyWhenWaiterNoAction) Hit(eventType ws.EventType, record *accountFiee.ChatRecordData, robotId int64) (hit bool, runTime time.Time, logic func() error) { | ||||
| 
 | ||||
| 	logic = func() error { | ||||
| 		var notice = dto.MessageListType{} | ||||
| 		notice.BuildMessage(record) | ||||
|  | ||||
| @ -157,7 +157,7 @@ func (r *Robot) Run() { | ||||
| 				if now.After(task.RunTime) { | ||||
| 					// 执行任务
 | ||||
| 					go func() { | ||||
| 						err := task.Run() | ||||
| 						err := task.Run(r.Info.ID, task.Response) | ||||
| 						if err != nil { | ||||
| 							log.Printf("聊天机器人[%d]回复消息失败:%v", r.Info.ID, err) | ||||
| 						} | ||||
| @ -178,17 +178,11 @@ func (r *Robot) Run() { | ||||
| 				for _, ruleResponse := range r.Rules { | ||||
| 					hit, runtime, logic := ruleResponse.Hit(ws.EventUserJoin, nil, r.Info.ID) | ||||
| 					if hit { | ||||
| 						if runtime.IsZero() { | ||||
| 						if !runtime.IsZero() { | ||||
| 							err := logic() | ||||
| 							if err != nil { | ||||
| 								log.Printf("robot 执行任务失败:%v\n", err) | ||||
| 							} | ||||
| 						} else { | ||||
| 							r.DelayTask = append(r.DelayTask, RobotTask{ | ||||
| 								RunTime:  runtime, | ||||
| 								Run:      logic, | ||||
| 								Response: ruleResponse.Response, | ||||
| 							}) | ||||
| 						} | ||||
| 						break | ||||
| 					} | ||||
|  | ||||
| @ -11,7 +11,6 @@ import ( | ||||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| // 自动回复规则结构转换
 | ||||
| func ParseReplyRule(data *dto.ChatAutoReplyData) (r Reply) { | ||||
| 	r.Response = data.Response | ||||
| 	for ruleName, v := range data.Rules { | ||||
| @ -30,10 +29,7 @@ func ParseReplyRule(data *dto.ChatAutoReplyData) (r Reply) { | ||||
| 		case "joinSession": //加入聊天后回复
 | ||||
| 			r.Rules = append(r.Rules, NewReplyWhenUserJoinSession()) | ||||
| 		case "noReplyAfter": //指定时间没有回复则自动回复
 | ||||
| 			if v.SecondDuration == 0 { | ||||
| 				continue | ||||
| 			} | ||||
| 			r.Rules = append(r.Rules, NewReplyWhenWaiterNoAction(v.SecondDuration)) | ||||
| 			r.Rules = append(r.Rules, NewReplyWhenWaiterNoAction()) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
|  | ||||
| @ -10,6 +10,6 @@ import "time" | ||||
| 
 | ||||
| type RobotTask struct { | ||||
| 	RunTime  time.Time | ||||
| 	Run      func() error | ||||
| 	Run      func(robotId int64, response string) error | ||||
| 	Response string | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user