diff options
author | Kim Alvefur <zash@zash.se> | 2018-09-06 23:33:44 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2018-09-06 23:33:44 +0200 |
commit | 309fbca999898f2a0bb28cef4697280fb6d6aac9 (patch) | |
tree | dca6b0a1da8e2f4dc4c3b19e7c1c5419d076f22c | |
parent | f9378c55afdb182c4a285e68d06ac8898a1a2ebf (diff) | |
download | prosody-309fbca999898f2a0bb28cef4697280fb6d6aac9.tar.gz prosody-309fbca999898f2a0bb28cef4697280fb6d6aac9.zip |
mod_vcard_legacy: Factor out error handling into a function
This is a lite version of pubsub_error_reply() in mod_pubsub
-rw-r--r-- | plugins/mod_vcard_legacy.lua | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/plugins/mod_vcard_legacy.lua b/plugins/mod_vcard_legacy.lua index 4320d96c..f52306f4 100644 --- a/plugins/mod_vcard_legacy.lua +++ b/plugins/mod_vcard_legacy.lua @@ -13,6 +13,16 @@ module:hook("account-disco-info", function (event) event.reply:tag("feature", { var = "urn:xmpp:pep-vcard-conversion:0" }):up(); end); +local function handle_error(origin, stanza, err) + if err == "forbidden" then + origin.send(st.error_reply(stanza, "auth", "forbidden")); + elseif err == "internal-server-error" then + origin.send(st.error_reply(stanza, "wait", "internal-server-error")); + else + origin.send(st.error_reply(stanza, "modify", "undefined-condition", err)); + end +end + -- Simple translations -- <foo><text>hey</text></foo> -> <FOO>hey</FOO> local simple_map = { @@ -240,12 +250,8 @@ module:hook("iq-set/self/vcard-temp:vCard", function (event) local ok, err = pep_service:publish("urn:xmpp:vcard4", origin.full_jid, "current", vcard4); if ok then origin.send(st.reply(stanza)); - elseif err == "forbidden" then - origin.send(st.error_reply(stanza, "auth", "forbidden")); - elseif err == "internal-server-error" then - origin.send(st.error_reply(stanza, "wait", "internal-server-error")); else - origin.send(st.error_reply(stanza, "modify", "undefined-condition", err)); + handle_error(origin, stanza, err); end return true; |