mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	Merge branch 'tuoyun' of github.com:OpenIMSDK/Open-IM-Server into tuoyun
This commit is contained in:
		
						commit
						604de144b9
					
				| @ -263,9 +263,9 @@ func (ws *WServer) headerCheck(w http.ResponseWriter, r *http.Request) bool { | ||||
| 	status := http.StatusUnauthorized | ||||
| 	query := r.URL.Query() | ||||
| 	if len(query["token"]) != 0 && len(query["sendID"]) != 0 && len(query["platformID"]) != 0 { | ||||
| 		if ok, err := token_verify.VerifyToken(query["token"][0], query["sendID"][0]); !ok { | ||||
| 		if ok, err, msg := token_verify.WsVerifyToken(query["token"][0], query["sendID"][0], query["platformID"][0]); !ok { | ||||
| 			e := err.(*constant.ErrInfo) | ||||
| 			log.ErrorByKv("Token verify failed", "", "query", query) | ||||
| 			log.ErrorByKv("Token verify failed", "", "query", query, msg) | ||||
| 			w.Header().Set("Sec-Websocket-Version", "13") | ||||
| 			http.Error(w, e.ErrMsg, int(e.ErrCode)) | ||||
| 			return false | ||||
|  | ||||
| @ -51,7 +51,7 @@ func (rpc *rpcAuth) UserToken(_ context.Context, req *pbAuth.UserTokenReq) (*pbA | ||||
| 		return &pbAuth.UserTokenResp{CommonResp: &pbAuth.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil | ||||
| 	} | ||||
| 
 | ||||
| 	log.NewInfo(req.OperationID, "rpc UserToken return ") | ||||
| 	log.NewInfo(req.OperationID, "rpc UserToken return ", tokens, expTime) | ||||
| 	return &pbAuth.UserTokenResp{CommonResp: &pbAuth.CommonResp{}, Token: tokens, ExpiredTime: expTime}, nil | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -202,6 +202,21 @@ func VerifyToken(token, uid string) (bool, error) { | ||||
| 	if claims.UID != uid { | ||||
| 		return false, &constant.ErrTokenUnknown | ||||
| 	} | ||||
| 
 | ||||
| 	log.NewDebug("", claims.UID, claims.Platform) | ||||
| 	return true, nil | ||||
| } | ||||
| func WsVerifyToken(token, uid string, platformID string) (bool, error, string) { | ||||
| 	claims, err := ParseToken(token) | ||||
| 	if err != nil { | ||||
| 		return false, err, "parse token err" | ||||
| 	} | ||||
| 	if claims.UID != uid { | ||||
| 		return false, &constant.ErrTokenUnknown, "uid is not same to token uid" | ||||
| 	} | ||||
| 	if claims.Platform != constant.PlatformIDToName(utils.StringToInt32(platformID)) { | ||||
| 		return false, &constant.ErrTokenUnknown, "platform is not same to token platform" | ||||
| 	} | ||||
| 	log.NewDebug("", claims.UID, claims.Platform) | ||||
| 	return true, nil, "" | ||||
| } | ||||
|  | ||||
| @ -78,15 +78,25 @@ func RegisterEtcd(schema, etcdAddr, myHost string, myPort int, serviceName strin | ||||
| 					log.Debug("", "KeepAlive kresp ok", pv) | ||||
| 				} else { | ||||
| 					log.Error("", "KeepAlive kresp failed", pv) | ||||
| 					t := time.NewTicker(time.Duration(ttl) * time.Second) | ||||
| 					t := time.NewTicker(time.Duration(ttl/2) * time.Second) | ||||
| 					for { | ||||
| 						select { | ||||
| 						case <-t.C: | ||||
| 						} | ||||
| 						ctx, _ := context.WithCancel(context.Background()) | ||||
| 						resp, err := cli.Grant(ctx, int64(ttl)) | ||||
| 						if err != nil { | ||||
| 							log.Error("", "Grant failed ", err.Error()) | ||||
| 							continue | ||||
| 						} | ||||
| 
 | ||||
| 						if _, err := cli.Put(ctx, serviceKey, serviceValue, clientv3.WithLease(resp.ID)); err != nil { | ||||
| 							log.Error("", "etcd Put failed ", err.Error(), serviceKey, serviceValue, resp.ID) | ||||
| 							continue | ||||
| 						} else { | ||||
| 							log.Info("", "etcd Put ok", serviceKey, serviceValue, resp.ID) | ||||
| 						} | ||||
| 						log.Info("", "etcd Put ok", serviceKey, serviceValue, resp.ID) | ||||
| 
 | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| @ -25,6 +25,10 @@ func StringToInt64(i string) int64 { | ||||
| 	j, _ := strconv.ParseInt(i, 10, 64) | ||||
| 	return j | ||||
| } | ||||
| func StringToInt32(i string) int32 { | ||||
| 	j, _ := strconv.ParseInt(i, 10, 64) | ||||
| 	return int32(j) | ||||
| } | ||||
| func Int32ToString(i int32) string { | ||||
| 	return strconv.FormatInt(int64(i), 10) | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user