projects
/
prosody.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
sessionmanager, mod_tls: Mark a session as secure when TLS is active
[prosody.git]
/
plugins
/
mod_vcard.lua
diff --git
a/plugins/mod_vcard.lua
b/plugins/mod_vcard.lua
index 67c8309ac9b4950d6d9bf38006ae93ecdb9644c7..2e8aea02b41f50f0ef58472140543c0ae971aeac 100644
(file)
--- a/
plugins/mod_vcard.lua
+++ b/
plugins/mod_vcard.lua
@@
-1,15
+1,25
@@
+-- Prosody IM v0.4
+-- 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 st = require "util.stanza"
-local send = require "core.sessionmanager".send_to_session
local t_concat, t_insert = table.concat, table.insert;
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;
@@
-18,35
+28,36
@@
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
end
if vCard then
- se
nd(session,
st.reply(stanza):add_child(vCard)); -- send vCard!
+ se
ssion.send(
st.reply(stanza):add_child(vCard)); -- send vCard!
else
else
- se
nd(session,
st.error_reply(stanza, "cancel", "item-not-found"));
+ se
ssion.send(
st.error_reply(stanza, "cancel", "item-not-found"));
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
- se
nd(session,
st.reply(stanza));
+ if datamanager.store(session.username, session.host, "v
c
ard", st.preserialize(stanza.tags[1])) then
+ se
ssion.send(
st.reply(stanza));
else
-- TODO unable to write file, file may be locked, etc, what's the correct error?
else
-- TODO unable to write file, file may be locked, etc, what's the correct error?
- se
nd(session,
st.error_reply(stanza, "wait", "internal-server-error"));
+ se
ssion.send(
st.error_reply(stanza, "wait", "internal-server-error"));
end
else
end
else
- se
nd(session,
st.error_reply(stanza, "auth", "forbidden"));
+ se
ssion.send(
st.error_reply(stanza, "auth", "forbidden"));
end
end
return true;
end
end);
end
end
return true;
end
end);
-add_event_hook("stream-features",
- function (session, features)
+local feature_vcard_attr = { var='vcard-temp' };
+module:add_event_hook("stream-features",
+ function (session, features)
if session.type == "c2s" then
if session.type == "c2s" then
-
t_insert(features, "<feature var='vcard-temp'/>"
);
+
features:tag("feature", feature_vcard_attr):up(
);
end
end);
end
end);