diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-12-02 13:25:50 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-12-02 13:25:50 +0000 |
commit | 5b1a87305b3c8fde5db68b191f1ac239343d01a4 (patch) | |
tree | 8c5944d4e525f0e939bad8a4a34823859c317b04 | |
parent | 1953688d8d11fd560912691494f7584ba3b7bc20 (diff) | |
download | rspamd-5b1a87305b3c8fde5db68b191f1ac239343d01a4.tar.gz rspamd-5b1a87305b3c8fde5db68b191f1ac239343d01a4.zip |
[Minor] Allow to read passphrase from Lua
-rw-r--r-- | src/lua/lua_util.c | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/src/lua/lua_util.c b/src/lua/lua_util.c index 6ca9f35ab..c6c339033 100644 --- a/src/lua/lua_util.c +++ b/src/lua/lua_util.c @@ -378,11 +378,18 @@ LUA_FUNCTION_DEF (util, is_valid_utf8); /*** * @function util.readline([prompt]) * Returns string read from stdin with history and editing support - * @return {boolean} true if a string is spoofed + * @return {string} string read from the input (with line endings stripped) */ LUA_FUNCTION_DEF (util, readline); /*** + * @function util.readpassphrase([prompt]) + * Returns string read from stdin disabling echo + * @return {string} string read from the input (with line endings stripped) + */ +LUA_FUNCTION_DEF (util, readpassphrase); + +/*** * @function util.file_exists(file) * Checks if a specified file exists and is available for reading * @return {boolean} true if file exists @@ -533,6 +540,7 @@ static const struct luaL_reg utillib_f[] = { LUA_INTERFACE_DEF (util, is_utf_spoofed), LUA_INTERFACE_DEF (util, is_valid_utf8), LUA_INTERFACE_DEF (util, readline), + LUA_INTERFACE_DEF (util, readpassphrase), LUA_INTERFACE_DEF (util, file_exists), LUA_INTERFACE_DEF (util, get_hostname), LUA_INTERFACE_DEF (util, pack), @@ -2094,6 +2102,32 @@ lua_util_readline (lua_State *L) } static gint +lua_util_readpassphrase (lua_State *L) +{ + const gchar *prompt = NULL; + gchar test_password[8192]; + gsize r; + + if (lua_type (L, 1) == LUA_TSTRING) { + prompt = lua_tostring (L, 1); + } + + r = rspamd_read_passphrase (test_password, sizeof (test_password), 0, NULL); + + if (r > 0) { + lua_pushlstring (L, test_password, r); + } + else { + lua_pushnil (L); + } + + /* In fact, we still pass it to Lua which is not very safe */ + rspamd_explicit_memzero (test_password, sizeof (test_password)); + + return 1; +} + +static gint lua_util_file_exists (lua_State *L) { const gchar *fname = luaL_checkstring (L, 1); |