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 | 	status := http.StatusUnauthorized | ||||||
| 	query := r.URL.Query() | 	query := r.URL.Query() | ||||||
| 	if len(query["token"]) != 0 && len(query["sendID"]) != 0 && len(query["platformID"]) != 0 { | 	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) | 			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") | 			w.Header().Set("Sec-Websocket-Version", "13") | ||||||
| 			http.Error(w, e.ErrMsg, int(e.ErrCode)) | 			http.Error(w, e.ErrMsg, int(e.ErrCode)) | ||||||
| 			return false | 			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 | 		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 | 	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 { | 	if claims.UID != uid { | ||||||
| 		return false, &constant.ErrTokenUnknown | 		return false, &constant.ErrTokenUnknown | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	log.NewDebug("", claims.UID, claims.Platform) | 	log.NewDebug("", claims.UID, claims.Platform) | ||||||
| 	return true, nil | 	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) | 					log.Debug("", "KeepAlive kresp ok", pv) | ||||||
| 				} else { | 				} else { | ||||||
| 					log.Error("", "KeepAlive kresp failed", pv) | 					log.Error("", "KeepAlive kresp failed", pv) | ||||||
| 					t := time.NewTicker(time.Duration(ttl) * time.Second) | 					t := time.NewTicker(time.Duration(ttl/2) * time.Second) | ||||||
| 					for { | 					for { | ||||||
| 						select { | 						select { | ||||||
| 						case <-t.C: | 						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 { | 						if _, err := cli.Put(ctx, serviceKey, serviceValue, clientv3.WithLease(resp.ID)); err != nil { | ||||||
| 							log.Error("", "etcd Put failed ", err.Error(), serviceKey, serviceValue, resp.ID) | 							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) | 	j, _ := strconv.ParseInt(i, 10, 64) | ||||||
| 	return j | 	return j | ||||||
| } | } | ||||||
|  | func StringToInt32(i string) int32 { | ||||||
|  | 	j, _ := strconv.ParseInt(i, 10, 64) | ||||||
|  | 	return int32(j) | ||||||
|  | } | ||||||
| func Int32ToString(i int32) string { | func Int32ToString(i int32) string { | ||||||
| 	return strconv.FormatInt(int64(i), 10) | 	return strconv.FormatInt(int64(i), 10) | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user