projects
/
prosody.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
mod_uptime: Fix bad uptime if module is loaded at startup
[prosody.git]
/
plugins
/
mod_vcard.lua
diff --git
a/plugins/mod_vcard.lua
b/plugins/mod_vcard.lua
index d2f2c7ba2873dd062774d3a099abecbcf80ba06b..db67d9e51f30b8c01f981dbfedfce14926fdf06d 100644
(file)
--- a/
plugins/mod_vcard.lua
+++ b/
plugins/mod_vcard.lua
@@
-1,14
+1,25
@@
+-- Prosody IM
+-- Copyright (C) 2008-2009 Matthew Wild
+-- Copyright (C) 2008-2009 Waqas Hussain
+--
+-- This project is MIT/X11 licensed. Please see the
+-- COPYING file in the source package for more information.
+--
-require "util.datamanager"
-local datamanager = datamanager;
+
+
+local hosts = _G.hosts;
+local datamanager = require "util.datamanager"
local st = require "util.stanza"
local t_concat, t_insert = table.concat, table.insert;
local st = require "util.stanza"
local t_concat, t_insert = table.concat, table.insert;
-require "util.jid"
+
local jid =
require "util.jid"
local jid_split = jid.split;
local jid_split = jid.split;
-add_iq_handler({"c2s", "s2sin"}, "vcard-temp",
+module:add_feature("vcard-temp");
+
+module:add_iq_handler({"c2s", "s2sin"}, "vcard-temp",
function (session, stanza)
if stanza.tags[1].name == "vCard" then
local to = stanza.attr.to;
function (session, stanza)
if stanza.tags[1].name == "vCard" then
local to = stanza.attr.to;
@@
-17,10
+28,10
@@
add_iq_handler({"c2s", "s2sin"}, "vcard-temp",
if to then
local node, host = jid_split(to);
if hosts[host] and hosts[host].type == "local" then
if to then
local node, host = jid_split(to);
if hosts[host] and hosts[host].type == "local" then
- vCard = st.deserialize(datamanager.load(node, host, "v
C
ard")); -- load vCard for user or server
+ vCard = st.deserialize(datamanager.load(node, host, "v
c
ard")); -- load vCard for user or server
end
else
end
else
- vCard = st.deserialize(datamanager.load(session.username, session.host, "v
C
ard"));-- load user's own vCard
+ vCard = st.deserialize(datamanager.load(session.username, session.host, "v
c
ard"));-- load user's own vCard
end
if vCard then
session.send(st.reply(stanza):add_child(vCard)); -- send vCard!
end
if vCard then
session.send(st.reply(stanza):add_child(vCard)); -- send vCard!
@@
-29,7
+40,7
@@
add_iq_handler({"c2s", "s2sin"}, "vcard-temp",
end
elseif stanza.attr.type == "set" then
if not to or to == session.username.."@"..session.host then
end
elseif stanza.attr.type == "set" then
if not to or to == session.username.."@"..session.host then
- if datamanager.store(session.username, session.host, "v
C
ard", st.preserialize(stanza.tags[1])) then
+ if datamanager.store(session.username, session.host, "v
c
ard", st.preserialize(stanza.tags[1])) then
session.send(st.reply(stanza));
else
-- TODO unable to write file, file may be locked, etc, what's the correct error?
session.send(st.reply(stanza));
else
-- TODO unable to write file, file may be locked, etc, what's the correct error?
@@
-44,8
+55,8
@@
add_iq_handler({"c2s", "s2sin"}, "vcard-temp",
end);
local feature_vcard_attr = { var='vcard-temp' };
end);
local feature_vcard_attr = { var='vcard-temp' };
-add_event_hook("stream-features",
- function (session, features)
+module:add_event_hook("stream-features",
+ function (session, features)
if session.type == "c2s" then
features:tag("feature", feature_vcard_attr):up();
end
if session.type == "c2s" then
features:tag("feature", feature_vcard_attr):up();
end