From ea44253c02ad6f0cd1cc531dd2bbd3cff9d338d4 Mon Sep 17 00:00:00 2001 From: Lykin <137850705+tiny-craft@users.noreply.github.com> Date: Mon, 1 Jul 2024 17:28:35 +0800 Subject: [PATCH] fix: disable type filter when redis server below 5.x (#274) --- backend/services/browser_service.go | 16 +++++++++++++--- .../src/components/common/RedisTypeSelector.vue | 6 ++++++ frontend/src/components/sidebar/BrowserPane.vue | 12 +++++++++++- frontend/src/objects/redisServerState.js | 3 +++ frontend/src/stores/browser.js | 17 +++++++++++++++-- frontend/src/utils/version.js | 11 ++++++++--- 6 files changed, 56 insertions(+), 9 deletions(-) diff --git a/backend/services/browser_service.go b/backend/services/browser_service.go index 515a9d57..86a84347 100644 --- a/backend/services/browser_service.go +++ b/backend/services/browser_service.go @@ -23,6 +23,7 @@ import ( "tinyrdm/backend/types" "tinyrdm/backend/utils/coll" convutil "tinyrdm/backend/utils/convert" + maputil "tinyrdm/backend/utils/map" redis2 "tinyrdm/backend/utils/redis" sliceutil "tinyrdm/backend/utils/slice" strutil "tinyrdm/backend/utils/string" @@ -222,11 +223,20 @@ func (b *browserService) OpenConnection(name string) (resp types.JSResp) { } } + // get redis server version + var version string + if res, err := client.Info(ctx, "server").Result(); err == nil || errors.Is(err, redis.Nil) { + info := b.parseInfo(res) + serverInfo := maputil.Get(info, "Server", map[string]string{}) + version = maputil.Get(serverInfo, "redis_version", "1.0.0") + } + resp.Success = true resp.Data = map[string]any{ - "db": dbs, - "view": selConn.KeyView, - "lastDB": selConn.LastDB, + "db": dbs, + "view": selConn.KeyView, + "lastDB": selConn.LastDB, + "version": version, } return } diff --git a/frontend/src/components/common/RedisTypeSelector.vue b/frontend/src/components/common/RedisTypeSelector.vue index a18ed858..6cba5fb7 100644 --- a/frontend/src/components/common/RedisTypeSelector.vue +++ b/frontend/src/components/common/RedisTypeSelector.vue @@ -14,6 +14,10 @@ const props = defineProps({ type: String, default: 'bottom-start', }, + disabled: { + type: Boolean, + default: false, + }, }) const emit = defineEmits(['update:value', 'select']) @@ -83,6 +87,7 @@ const handleSelect = (select) => {