From eca4d9c963c805743ed99cb05429d94b14638e83 Mon Sep 17 00:00:00 2001 From: Christophe Romain Date: Tue, 25 Aug 2009 16:35:43 +0000 Subject: [PATCH] resolve EJAB-1025, send notification when owner changed entity subscription SVN Revision: 2532 --- src/mod_pubsub/mod_pubsub.erl | 11 ++++++++++- src/mod_pubsub/mod_pubsub_odbc.erl | 11 ++++++++++- src/mod_pubsub/pubsub_odbc.patch | 24 ++++++++++++------------ 3 files changed, 32 insertions(+), 14 deletions(-) diff --git a/src/mod_pubsub/mod_pubsub.erl b/src/mod_pubsub/mod_pubsub.erl index 5bee62705..3469173fe 100644 --- a/src/mod_pubsub/mod_pubsub.erl +++ b/src/mod_pubsub/mod_pubsub.erl @@ -2672,6 +2672,15 @@ set_subscriptions(Host, Node, From, EntitiesEls) -> error -> {error, ?ERR_BAD_REQUEST}; _ -> + Notify = fun(JID, Sub, _SubId) -> + Stanza = {xmlelement, "message", [], + [{xmlelement, "pubsub", [{"xmlns", ?NS_PUBSUB}], + [{xmlelement, "subscription", + [{"jid", jlib:jid_to_string(JID)}, + %{"subid", SubId}, + {"subscription", subscription_to_string(Sub)} | nodeAttr(Node)], []}]}]}, + ejabberd_router ! {route, service_jid(Host), jlib:make_jid(JID), Stanza} + end, Action = fun(#pubsub_node{owners = Owners, type = Type, id = NodeId}) -> case lists:member(Owner, Owners) of true -> @@ -2679,7 +2688,7 @@ set_subscriptions(Host, Node, From, EntitiesEls) -> case node_call(Type, set_subscriptions, [NodeId, JID, Subscription, SubId]) of {error, Err} -> [{error, Err} | Acc]; - _ -> Acc + _ -> Notify(JID, Subscription, SubId), Acc end end, [], Entities), case Result of diff --git a/src/mod_pubsub/mod_pubsub_odbc.erl b/src/mod_pubsub/mod_pubsub_odbc.erl index 3bad02fb7..23c7daae0 100644 --- a/src/mod_pubsub/mod_pubsub_odbc.erl +++ b/src/mod_pubsub/mod_pubsub_odbc.erl @@ -2673,6 +2673,15 @@ set_subscriptions(Host, Node, From, EntitiesEls) -> error -> {error, ?ERR_BAD_REQUEST}; _ -> + Notify = fun(JID, Sub, _SubId) -> + Stanza = {xmlelement, "message", [], + [{xmlelement, "pubsub", [{"xmlns", ?NS_PUBSUB}], + [{xmlelement, "subscription", + [{"jid", jlib:jid_to_string(JID)}, + %{"subid", SubId}, + {"subscription", subscription_to_string(Sub)} | nodeAttr(Node)], []}]}]}, + ejabberd_router ! {route, service_jid(Host), jlib:make_jid(JID), Stanza} + end, Action = fun(#pubsub_node{type = Type, id = NodeId}) -> case lists:member(Owner, node_owners_call(Type, NodeId)) of true -> @@ -2680,7 +2689,7 @@ set_subscriptions(Host, Node, From, EntitiesEls) -> case node_call(Type, set_subscriptions, [NodeId, JID, Subscription, SubId]) of {error, Err} -> [{error, Err} | Acc]; - _ -> Acc + _ -> Notify(JID, Subscription, SubId), Acc end end, [], Entities), case Result of diff --git a/src/mod_pubsub/pubsub_odbc.patch b/src/mod_pubsub/pubsub_odbc.patch index 88f976b8f..ae4f13ae7 100644 --- a/src/mod_pubsub/pubsub_odbc.patch +++ b/src/mod_pubsub/pubsub_odbc.patch @@ -1,5 +1,5 @@ ---- mod_pubsub.erl 2009-08-25 16:10:58.000000000 +0200 -+++ mod_pubsub_odbc.erl 2009-08-25 16:12:30.000000000 +0200 +--- mod_pubsub.erl 2009-08-25 18:29:16.000000000 +0200 ++++ mod_pubsub_odbc.erl 2009-08-25 18:34:37.000000000 +0200 @@ -45,7 +45,7 @@ %%% TODO %%% plugin: generate Reply (do not use broadcast atom anymore) @@ -370,10 +370,10 @@ end, Entities), {result, []}; _ -> -@@ -2672,8 +2673,8 @@ - error -> - {error, ?ERR_BAD_REQUEST}; - _ -> +@@ -2681,8 +2682,8 @@ + {"subscription", subscription_to_string(Sub)} | nodeAttr(Node)], []}]}]}, + ejabberd_router ! {route, service_jid(Host), jlib:make_jid(JID), Stanza} + end, - Action = fun(#pubsub_node{owners = Owners, type = Type, id = NodeId}) -> - case lists:member(Owner, Owners) of + Action = fun(#pubsub_node{type = Type, id = NodeId}) -> @@ -381,7 +381,7 @@ true -> Result = lists:foldl(fun({JID, Subscription, SubId}, Acc) -> -@@ -3170,6 +3171,30 @@ +@@ -3179,6 +3180,30 @@ Result end. @@ -412,7 +412,7 @@ %% @spec (Host, Options) -> MaxItems %% Host = host() %% Options = [Option] -@@ -3543,7 +3568,13 @@ +@@ -3552,7 +3577,13 @@ tree_action(Host, Function, Args) -> ?DEBUG("tree_action ~p ~p ~p",[Host,Function,Args]), Fun = fun() -> tree_call(Host, Function, Args) end, @@ -427,7 +427,7 @@ %% @doc

node plugin call.

node_call(Type, Function, Args) -> -@@ -3563,13 +3594,13 @@ +@@ -3572,13 +3603,13 @@ node_action(Host, Type, Function, Args) -> ?DEBUG("node_action ~p ~p ~p ~p",[Host,Type,Function,Args]), @@ -443,7 +443,7 @@ case tree_call(Host, get_node, [Host, Node]) of N when is_record(N, pubsub_node) -> case Action(N) of -@@ -3582,8 +3613,14 @@ +@@ -3591,8 +3622,14 @@ end end, Trans). @@ -460,7 +460,7 @@ {result, Result} -> {result, Result}; {error, Error} -> {error, Error}; {atomic, {result, Result}} -> {result, Result}; -@@ -3591,6 +3628,15 @@ +@@ -3600,6 +3637,15 @@ {aborted, Reason} -> ?ERROR_MSG("transaction return internal error: ~p~n", [{aborted, Reason}]), {error, ?ERR_INTERNAL_SERVER_ERROR}; @@ -476,7 +476,7 @@ {'EXIT', Reason} -> ?ERROR_MSG("transaction return internal error: ~p~n", [{'EXIT', Reason}]), {error, ?ERR_INTERNAL_SERVER_ERROR}; -@@ -3599,6 +3645,17 @@ +@@ -3608,6 +3654,17 @@ {error, ?ERR_INTERNAL_SERVER_ERROR} end.