mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 05:02:11 +08:00 
			
		
		
		
	fix: redis save error when KickTokens (#3002)
This commit is contained in:
		
							parent
							
								
									3e872d6c5a
								
							
						
					
					
						commit
						52052a9165
					
				
							
								
								
									
										9
									
								
								pkg/common/storage/cache/redis/token.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								pkg/common/storage/cache/redis/token.go
									
									
									
									
										vendored
									
									
								
							| @ -2,13 +2,14 @@ package redis | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"strconv" | ||||||
|  | 	"sync" | ||||||
|  | 	"time" | ||||||
|  | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/cachekey" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/cachekey" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/redis/go-redis/v9" | 	"github.com/redis/go-redis/v9" | ||||||
| 	"strconv" |  | ||||||
| 	"sync" |  | ||||||
| 	"time" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type tokenCache struct { | type tokenCache struct { | ||||||
| @ -99,7 +100,7 @@ func (c *tokenCache) SetTokenMapByUidPid(ctx context.Context, userID string, pla | |||||||
| 	return errs.Wrap(c.rdb.HSet(ctx, cachekey.GetTokenKey(userID, platformID), mm).Err()) | 	return errs.Wrap(c.rdb.HSet(ctx, cachekey.GetTokenKey(userID, platformID), mm).Err()) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *tokenCache) BatchSetTokenMapByUidPid(ctx context.Context, tokens map[string]map[string]int) error { | func (c *tokenCache) BatchSetTokenMapByUidPid(ctx context.Context, tokens map[string]map[string]any) error { | ||||||
| 	pipe := c.rdb.Pipeline() | 	pipe := c.rdb.Pipeline() | ||||||
| 	for k, v := range tokens { | 	for k, v := range tokens { | ||||||
| 		pipe.HSet(ctx, k, v) | 		pipe.HSet(ctx, k, v) | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								pkg/common/storage/cache/token.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								pkg/common/storage/cache/token.go
									
									
									
									
										vendored
									
									
								
							| @ -11,6 +11,6 @@ type TokenModel interface { | |||||||
| 	GetTokensWithoutError(ctx context.Context, userID string, platformID int) (map[string]int, error) | 	GetTokensWithoutError(ctx context.Context, userID string, platformID int) (map[string]int, error) | ||||||
| 	GetAllTokensWithoutError(ctx context.Context, userID string) (map[int]map[string]int, error) | 	GetAllTokensWithoutError(ctx context.Context, userID string) (map[int]map[string]int, error) | ||||||
| 	SetTokenMapByUidPid(ctx context.Context, userID string, platformID int, m map[string]int) error | 	SetTokenMapByUidPid(ctx context.Context, userID string, platformID int, m map[string]int) error | ||||||
| 	BatchSetTokenMapByUidPid(ctx context.Context, tokens map[string]map[string]int) error | 	BatchSetTokenMapByUidPid(ctx context.Context, tokens map[string]map[string]any) error | ||||||
| 	DeleteTokenByUidPid(ctx context.Context, userID string, platformID int, fields []string) error | 	DeleteTokenByUidPid(ctx context.Context, userID string, platformID int, fields []string) error | ||||||
| } | } | ||||||
|  | |||||||
| @ -56,7 +56,7 @@ func (a *authDatabase) SetTokenMapByUidPid(ctx context.Context, userID string, p | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (a *authDatabase) BatchSetTokenMapByUidPid(ctx context.Context, tokens []string) error { | func (a *authDatabase) BatchSetTokenMapByUidPid(ctx context.Context, tokens []string) error { | ||||||
| 	setMap := make(map[string]map[string]int) | 	setMap := make(map[string]map[string]any) | ||||||
| 	for _, token := range tokens { | 	for _, token := range tokens { | ||||||
| 		claims, err := tokenverify.GetClaimFromToken(token, authverify.Secret(a.accessSecret)) | 		claims, err := tokenverify.GetClaimFromToken(token, authverify.Secret(a.accessSecret)) | ||||||
| 		key := cachekey.GetTokenKey(claims.UserID, claims.PlatformID) | 		key := cachekey.GetTokenKey(claims.UserID, claims.PlatformID) | ||||||
| @ -66,7 +66,7 @@ func (a *authDatabase) BatchSetTokenMapByUidPid(ctx context.Context, tokens []st | |||||||
| 			if v, ok := setMap[key]; ok { | 			if v, ok := setMap[key]; ok { | ||||||
| 				v[token] = constant.KickedToken | 				v[token] = constant.KickedToken | ||||||
| 			} else { | 			} else { | ||||||
| 				setMap[key] = map[string]int{ | 				setMap[key] = map[string]any{ | ||||||
| 					token: constant.KickedToken, | 					token: constant.KickedToken, | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user