aboutsummaryrefslogtreecommitdiffstats
path: root/lualib/lua_redis.lua
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2023-08-07 14:52:12 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2023-08-07 14:52:12 +0100
commit0e3bc7a86a600b88c57207a0a4442cbe9840d081 (patch)
tree2168a9dcca6259c6be67870a13d4528c819e7cf0 /lualib/lua_redis.lua
parentb9fb73ce0ba993c9873cf0022be7bb68766c8d83 (diff)
downloadrspamd-0e3bc7a86a600b88c57207a0a4442cbe9840d081.tar.gz
rspamd-0e3bc7a86a600b88c57207a0a4442cbe9840d081.zip
[Fix] Fix lua schema enrichment logic for Redis params
Diffstat (limited to 'lualib/lua_redis.lua')
-rw-r--r--lualib/lua_redis.lua42
1 files changed, 21 insertions, 21 deletions
diff --git a/lualib/lua_redis.lua b/lualib/lua_redis.lua
index 47da29899..6d2a9e4f1 100644
--- a/lualib/lua_redis.lua
+++ b/lualib/lua_redis.lua
@@ -24,19 +24,19 @@ local exports = {}
local E = {}
local N = "lua_redis"
-local common_schema = ts.shape {
- timeout = (ts.number + ts.string / lutil.parse_time_interval):is_optional(),
- db = ts.string:is_optional(),
- database = ts.string:is_optional(),
- dbname = ts.string:is_optional(),
- prefix = ts.string:is_optional(),
- password = ts.string:is_optional(),
- expand_keys = ts.boolean:is_optional(),
- sentinels = (ts.string + ts.array_of(ts.string)):is_optional(),
- sentinel_watch_time = (ts.number + ts.string / lutil.parse_time_interval):is_optional(),
- sentinel_masters_pattern = ts.string:is_optional(),
- sentinel_master_maxerrors = (ts.number + ts.string / tonumber):is_optional(),
- sentinel_password = ts.string:is_optional(),
+local common_schema = {
+ timeout = (ts.number + ts.string / lutil.parse_time_interval):is_optional():describe("Connection timeout"),
+ db = ts.string:is_optional():describe("Database number"),
+ database = ts.string:is_optional():describe("Database number"),
+ dbname = ts.string:is_optional():describe("Database number"),
+ prefix = ts.string:is_optional():describe("Key prefix"),
+ password = ts.string:is_optional():describe("Password"),
+ expand_keys = ts.boolean:is_optional():describe("Expand keys"),
+ sentinels = (ts.string + ts.array_of(ts.string)):is_optional():describe("Sentinel servers"),
+ sentinel_watch_time = (ts.number + ts.string / lutil.parse_time_interval):is_optional():describe("Sentinel watch time"),
+ sentinel_masters_pattern = ts.string:is_optional():describe("Sentinel masters pattern"),
+ sentinel_master_maxerrors = (ts.number + ts.string / tonumber):is_optional():describe("Sentinel master max errors"),
+ sentinel_password = ts.string:is_optional():describe("Sentinel password"),
}
local read_schema = lutil.table_merge({
@@ -60,18 +60,18 @@ local server_schema = lutil.table_merge({
server = ts.string + ts.array_of(ts.string),
}, common_schema)
-local generate_schema = function(external)
+local enrich_schema = function(external)
return ts.one_of {
- ts.shape(external),
- ts.shape(lutil.table_merge(read_schema, external)),
- ts.shape(lutil.table_merge(write_schema, external)),
- ts.shape(lutil.table_merge(rw_schema, external)),
- ts.shape(lutil.table_merge(servers_schema, external)),
- ts.shape(lutil.table_merge(server_schema, external)),
+ ts.shape(external), -- no specific redis parameters
+ ts.shape(lutil.table_merge(read_schema, external)), -- read_servers specified
+ ts.shape(lutil.table_merge(write_schema, external)), -- write_servers specified
+ ts.shape(lutil.table_merge(rw_schema, external)), -- both read and write servers defined
+ ts.shape(lutil.table_merge(servers_schema, external)), -- just servers for both ops
+ ts.shape(lutil.table_merge(server_schema, external)), -- legacy `server` attribute
}
end
-exports.generate_schema = generate_schema
+exports.enrich_schema = enrich_schema
local function redis_query_sentinel(ev_base, params, initialised)
local function flatten_redis_table(tbl)