mod_tokenauth: Fix parsing binary part of tokens

Fixes parsing of tokens that happen to have a `;` in their secret part,
otherwise it splits there and the later bit goes into the username and
hitting the "Invalid token in storage" condition.
This commit is contained in:
Kim Alvefur 2023-04-12 11:43:32 +02:00
parent 816d0819f2
commit a68169b93e

View file

@ -120,7 +120,7 @@ local function parse_token(encoded_token)
if not encoded_data then return nil; end
local token = base64.decode(encoded_data);
if not token then return nil; end
local token_id, token_secret, token_jid = token:match("^2;([^;]+);([^;]+);(.+)$");
local token_id, token_secret, token_jid = token:match("^2;([^;]+);(..................);(.+)$");
if not token_id then return nil; end
local token_user, token_host = jid.split(token_jid);
return token_id, token_user, token_host, token_secret;