diff options
author | laodc <github@laodc.com> | 2023-08-21 15:45:58 +0700 |
---|---|---|
committer | laodc <github@laodc.com> | 2023-08-21 15:45:58 +0700 |
commit | 75fdc829bacbdc767b20d3f0e40b91215fce14fe (patch) | |
tree | 209d8d53e71cd5a92deb69fcb740bb2649bb66ee /src/rspamadm | |
parent | 1931487b17059d6c63adf2245c9632384657f89e (diff) | |
download | rspamd-75fdc829bacbdc767b20d3f0e40b91215fce14fe.tar.gz rspamd-75fdc829bacbdc767b20d3f0e40b91215fce14fe.zip |
Added support for Redis 6 ACL (username/password)
Diffstat (limited to 'src/rspamadm')
-rw-r--r-- | src/rspamadm/fuzzy_convert.c | 8 | ||||
-rw-r--r-- | src/rspamadm/stat_convert.c | 9 |
2 files changed, 17 insertions, 0 deletions
diff --git a/src/rspamadm/fuzzy_convert.c b/src/rspamadm/fuzzy_convert.c index 1b2866b59..5d967a64c 100644 --- a/src/rspamadm/fuzzy_convert.c +++ b/src/rspamadm/fuzzy_convert.c @@ -21,6 +21,7 @@ static gchar *source_db = NULL; static gchar *redis_host = NULL; static gchar *redis_db = NULL; +static gchar *redis_username = NULL; static gchar *redis_password = NULL; static int64_t fuzzy_expiry = 0; @@ -46,6 +47,8 @@ static GOptionEntry entries[] = { "Output redis ip (in format ip:port)", NULL}, {"dbname", 'D', 0, G_OPTION_ARG_STRING, &redis_db, "Database in redis (should be numeric)", NULL}, + {"username", 'u', 0, G_OPTION_ARG_STRING, &redis_username, + "Username to connect to redis", NULL}, {"password", 'p', 0, G_OPTION_ARG_STRING, &redis_password, "Password to connect to redis", NULL}, {NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL}}; @@ -63,6 +66,7 @@ rspamadm_fuzzyconvert_help(gboolean full_help, const struct rspamadm_command *cm "-d: input sqlite\n" "-h: output redis ip (in format ip:port)\n" "-D: output redis database\n" + "-u: redis username\n"; "-p: redis password\n"; } else { @@ -117,6 +121,10 @@ rspamadm_fuzzyconvert(gint argc, gchar **argv, const struct rspamadm_command *cm ucl_object_insert_key(obj, ucl_object_fromint(fuzzy_expiry), "expiry", 0, false); + if (redis_username) { + ucl_object_insert_key(obj, ucl_object_fromstring(redis_username), + "redis_username", 0, false); + } if (redis_password) { ucl_object_insert_key(obj, ucl_object_fromstring(redis_password), "redis_password", 0, false); diff --git a/src/rspamadm/stat_convert.c b/src/rspamadm/stat_convert.c index ba2c4efb9..0741279aa 100644 --- a/src/rspamadm/stat_convert.c +++ b/src/rspamadm/stat_convert.c @@ -34,6 +34,7 @@ static gchar *cache_db = NULL; /* Outputs */ static gchar *redis_host = NULL; static gchar *redis_db = NULL; +static gchar *redis_username = NULL; static gchar *redis_password = NULL; static gboolean reset_previous = FALSE; @@ -70,6 +71,8 @@ static GOptionEntry entries[] = { "Input learn cache", NULL}, {"redis-host", 'h', 0, G_OPTION_ARG_STRING, &redis_host, "Output redis ip (in format ip:port)", NULL}, + {"redis-username", 'u', 0, G_OPTION_ARG_STRING, &redis_username, + "Username to connect to redis", NULL}, {"redis-password", 'p', 0, G_OPTION_ARG_STRING, &redis_password, "Password to connect to redis", NULL}, {"redis-db", 'd', 0, G_OPTION_ARG_STRING, &redis_db, @@ -92,6 +95,7 @@ rspamadm_statconvert_help(gboolean full_help, const struct rspamadm_command *cmd "** Or specify options directly **\n" "--redis-host: output redis ip (in format ip:port)\n" "--redis-db: output redis database\n" + "--redis-username: redis username\n" "--redis-password: redis password\n" "--cache: sqlite3 file for learn cache\n" "--spam-db: sqlite3 input file for spam data\n" @@ -229,6 +233,11 @@ rspamadm_statconvert(gint argc, gchar **argv, const struct rspamadm_command *cmd "dbname", 0, false); } + if (redis_username) { + ucl_object_insert_key(redis, ucl_object_fromstring(redis_username), + "username", 0, false); + } + if (redis_password) { ucl_object_insert_key(redis, ucl_object_fromstring(redis_password), "password", 0, false); |