diff options
-rw-r--r-- | core/rostermanager.lua | 14 | ||||
-rw-r--r-- | core/stanza_router.lua | 4 |
2 files changed, 17 insertions, 1 deletions
diff --git a/core/rostermanager.lua b/core/rostermanager.lua index 3cdbbd3a..83bb379e 100644 --- a/core/rostermanager.lua +++ b/core/rostermanager.lua @@ -121,4 +121,18 @@ function process_inbound_subscription_cancellation(username, host, jid) end end +function process_inbound_unsubscribe(username, host, jid) + local roster = load_roster(username, host); + local item = roster[jid]; + if item and (item.subscription == "from" or item.subscription == "both") then + if item.subscription == "from" then + item.subscription = "none"; + else + item.subscription = "to"; + end + item.ask = nil; + return datamanager.store(username, host, "roster", roster); + end +end + return _M;
\ No newline at end of file diff --git a/core/stanza_router.lua b/core/stanza_router.lua index 3126bb75..16658f30 100644 --- a/core/stanza_router.lua +++ b/core/stanza_router.lua @@ -209,7 +209,9 @@ function core_route_stanza(origin, stanza) elseif stanza.attr.type == "subscribe" then -- TODO elseif stanza.attr.type == "unsubscribe" then - -- TODO + if rostermanager.process_inbound_unsubscribe(node, host, from_bare) then + rostermanager.roster_push(node, host, from_bare); + end elseif stanza.attr.type == "subscribed" then if rostermanager.process_inbound_subscription_approval(node, host, from_bare) then rostermanager.roster_push(node, host, from_bare); |