mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 04:32:10 +08:00 
			
		
		
		
	Merge pull request #3500 from withchao/pre-release-v3.8.4
fix: admin token in standalone mode (#3499)
This commit is contained in:
		
						commit
						56fe999b60
					
				| @ -97,6 +97,11 @@ func newGinRouter(ctx context.Context, client discovery.SvcDiscoveryRegistry, cf | |||||||
| 	case BestSpeed: | 	case BestSpeed: | ||||||
| 		r.Use(gzip.Gzip(gzip.BestSpeed)) | 		r.Use(gzip.Gzip(gzip.BestSpeed)) | ||||||
| 	} | 	} | ||||||
|  | 	if config.Standalone() { | ||||||
|  | 		r.Use(func(c *gin.Context) { | ||||||
|  | 			c.Set(authverify.CtxAdminUserIDsKey, cfg.Share.IMAdminUser.UserIDs) | ||||||
|  | 		}) | ||||||
|  | 	} | ||||||
| 	r.Use(api.GinLogger(), prommetricsGin(), gin.RecoveryWithWriter(gin.DefaultErrorWriter, mw.GinPanicErr), mw.CorsHandler(), | 	r.Use(api.GinLogger(), prommetricsGin(), gin.RecoveryWithWriter(gin.DefaultErrorWriter, mw.GinPanicErr), mw.CorsHandler(), | ||||||
| 		mw.GinParseOperationID(), GinParseToken(rpcli.NewAuthClient(authConn)), setGinIsAdmin(cfg.Share.IMAdminUser.UserIDs)) | 		mw.GinParseOperationID(), GinParseToken(rpcli.NewAuthClient(authConn)), setGinIsAdmin(cfg.Share.IMAdminUser.UserIDs)) | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										9
									
								
								pkg/common/storage/cache/redis/token.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								pkg/common/storage/cache/redis/token.go
									
									
									
									
										vendored
									
									
								
							| @ -165,16 +165,15 @@ func (c *tokenCache) DeleteTokenByTokenMap(ctx context.Context, userID string, t | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *tokenCache) DeleteAndSetTemporary(ctx context.Context, userID string, platformID int, fields []string) error { | func (c *tokenCache) DeleteAndSetTemporary(ctx context.Context, userID string, platformID int, fields []string) error { | ||||||
| 	key := cachekey.GetTokenKey(userID, platformID) |  | ||||||
| 	if err := c.rdb.HDel(ctx, key, fields...).Err(); err != nil { |  | ||||||
| 		return errs.Wrap(err) |  | ||||||
| 	} |  | ||||||
| 	for _, f := range fields { | 	for _, f := range fields { | ||||||
| 		k := cachekey.GetTemporaryTokenKey(userID, platformID, f) | 		k := cachekey.GetTemporaryTokenKey(userID, platformID, f) | ||||||
| 		if err := c.rdb.Set(ctx, k, "", time.Minute*5).Err(); err != nil { | 		if err := c.rdb.Set(ctx, k, "", time.Minute*5).Err(); err != nil { | ||||||
| 			return errs.Wrap(err) | 			return errs.Wrap(err) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 	key := cachekey.GetTokenKey(userID, platformID) | ||||||
|  | 	if err := c.rdb.HDel(ctx, key, fields...).Err(); err != nil { | ||||||
|  | 		return errs.Wrap(err) | ||||||
|  | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user