aboutsummaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorWaqas Hussain <waqas20@gmail.com>2008-10-25 03:13:10 +0500
committerWaqas Hussain <waqas20@gmail.com>2008-10-25 03:13:10 +0500
commit9bd8c81c916f22ffb11ce4f11f74edc87002fbb2 (patch)
tree3e16509e770e96dd4eecd3cbf9ac2c4dd7c50979 /core
parent2ab824859d622653d405e8ea0515e3acca9180f4 (diff)
downloadprosody-9bd8c81c916f22ffb11ce4f11f74edc87002fbb2.tar.gz
prosody-9bd8c81c916f22ffb11ce4f11f74edc87002fbb2.zip
Inbound subscription request
Diffstat (limited to 'core')
-rw-r--r--core/rostermanager.lua6
-rw-r--r--core/stanza_router.lua11
2 files changed, 16 insertions, 1 deletions
diff --git a/core/rostermanager.lua b/core/rostermanager.lua
index 83bb379e..7d7fd061 100644
--- a/core/rostermanager.lua
+++ b/core/rostermanager.lua
@@ -135,4 +135,10 @@ function process_inbound_unsubscribe(username, host, jid)
end
end
+function is_contact_subscribed(username, host, jid)
+ local roster = load_roster(username, host);
+ local item = roster[jid];
+ return item and (item.subscription == "from" or item.subscription == "both");
+end
+
return _M; \ No newline at end of file
diff --git a/core/stanza_router.lua b/core/stanza_router.lua
index 16658f30..be4f9185 100644
--- a/core/stanza_router.lua
+++ b/core/stanza_router.lua
@@ -207,7 +207,16 @@ function core_route_stanza(origin, stanza)
send(origin, st.presence({from=to_bare, to=from_bare, type="unsubscribed"}));
end
elseif stanza.attr.type == "subscribe" then
- -- TODO
+ if rostermanager.is_contact_subscribed(node, host, from_bare) then
+ send(origin, st.presence(from=to_bare, to=from_bare, type="subscribed")); -- already subscribed
+ else
+ local pres = st.presence({from=from_bare}, type="subscribe");
+ for k in pairs(user.sessions) do -- return presence for all resources
+ if user.sessions[k].presence then
+ send(user.sessions[k], pres);
+ end
+ end
+ end
elseif stanza.attr.type == "unsubscribe" then
if rostermanager.process_inbound_unsubscribe(node, host, from_bare) then
rostermanager.roster_push(node, host, from_bare);