mirror of
https://github.com/mt-mods/mail.git
synced 2025-04-30 08:21:44 -04:00
Fix server hanging for certain recipient names
This commit is contained in:
parent
851fa9f12a
commit
0799a245d6
1 changed files with 23 additions and 21 deletions
38
storage.lua
38
storage.lua
|
@ -404,30 +404,32 @@ function mail.delete_maillist(playername, listname)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function mail.extractMaillists(receivers_string, maillists_owner)
|
function mail.extractMaillists(receivers, maillists_owner)
|
||||||
local receivers = mail.parse_player_list(receivers_string) -- extracted receivers
|
if type(receivers) == "string" then
|
||||||
|
local list = mail.parse_player_list(receivers)
|
||||||
|
if not string.find(receivers, "@") then
|
||||||
|
return list
|
||||||
|
end
|
||||||
|
receivers = list
|
||||||
|
end
|
||||||
|
|
||||||
-- extract players from mailing lists
|
local expanded_receivers = {}
|
||||||
while string.find(receivers_string, "@") do
|
for _, receiver in pairs(receivers) do
|
||||||
local globalReceivers = mail.parse_player_list(receivers_string) -- receivers including maillists
|
if string.find(receiver, "^@") then
|
||||||
receivers = {}
|
local listname = string.sub(receiver, 2)
|
||||||
for _, receiver in ipairs(globalReceivers) do
|
local maillist = mail.get_maillist_by_name(maillists_owner, listname)
|
||||||
local receiverInfo = receiver:split("@") -- @maillist
|
|
||||||
if receiverInfo[1] and receiver == "@" .. receiverInfo[1] then
|
|
||||||
local maillist = mail.get_maillist_by_name(maillists_owner, receiverInfo[1])
|
|
||||||
if maillist then
|
if maillist then
|
||||||
for _, playername in ipairs(maillist.players) do
|
for _, entry in ipairs(maillist.players) do
|
||||||
table.insert(receivers, playername)
|
for _, recipient in ipairs(mail.extractMaillists(entry, maillists_owner)) do
|
||||||
|
table.insert(expanded_receivers, recipient)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else -- in case of player
|
end
|
||||||
table.insert(receivers, receiver)
|
else
|
||||||
|
table.insert(expanded_receivers, receiver)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
receivers_string = mail.concat_player_list(receivers)
|
return expanded_receivers
|
||||||
end
|
|
||||||
|
|
||||||
return receivers
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function mail.get_setting_default_value(key)
|
function mail.get_setting_default_value(key)
|
||||||
|
|
Loading…
Add table
Reference in a new issue