From 67e8c5edc7278fe6202cfba0fd42302a2932f1ce Mon Sep 17 00:00:00 2001 From: ZhenYi <434836402@qq.com> Date: Mon, 20 Apr 2026 09:32:10 +0800 Subject: [PATCH] fix(admin): use Redis as type annotation, RedisCluster as runtime value Fix TypeScript type error with ioredis 5.x default export pattern --- admin/src/lib/redis.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/admin/src/lib/redis.ts b/admin/src/lib/redis.ts index c70b47b..42b364d 100644 --- a/admin/src/lib/redis.ts +++ b/admin/src/lib/redis.ts @@ -3,7 +3,7 @@ * 支持单节点和集群模式 * 前缀:admin:* */ -import Redis, { RedisCluster } from "ioredis"; +import Redis, { default as RedisCluster } from "ioredis"; import { REDIS_URL, REDIS_CLUSTER_URLS } from "./env"; // Admin 专用的 Redis 前缀 @@ -11,7 +11,7 @@ const ADMIN_PREFIX = "admin:session:"; // 平台用户 Session 前缀(与 Rust 主应用一致) const PLATFORM_SESSION_PREFIX = "session:user_uid:"; -let redis: Redis | RedisCluster | null = null; +let redis: Redis | null = null; function createSingleClient(): Redis { return new Redis(REDIS_URL, { @@ -23,7 +23,7 @@ function createSingleClient(): Redis { }); } -function createClusterClient(): Redis | RedisCluster { +function createClusterClient(): Redis { if (REDIS_CLUSTER_URLS.length === 0) { return createSingleClient(); } @@ -50,7 +50,7 @@ function createClusterClient(): Redis | RedisCluster { return cluster as unknown as Redis; } -export function getRedis(): Redis | RedisCluster { +export function getRedis(): Redis { if (!redis) { redis = REDIS_CLUSTER_URLS.length > 1 ? createClusterClient() : createSingleClient();