diff options
Diffstat (limited to 'src/mod_pubsub/node_dispatch.erl')
-rw-r--r-- | src/mod_pubsub/node_dispatch.erl | 172 |
1 files changed, 69 insertions, 103 deletions
diff --git a/src/mod_pubsub/node_dispatch.erl b/src/mod_pubsub/node_dispatch.erl index 0edfe0a70..79c692e72 100644 --- a/src/mod_pubsub/node_dispatch.erl +++ b/src/mod_pubsub/node_dispatch.erl @@ -4,12 +4,12 @@ %%% compliance with the License. You should have received a copy of the %%% Erlang Public License along with this software. If not, it can be %%% retrieved via the world wide web at http://www.erlang.org/. -%%% +%%% %%% Software distributed under the License is distributed on an "AS IS" %%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See %%% the License for the specific language governing rights and limitations %%% under the License. -%%% +%%% %%% The Initial Developer of the Original Code is ProcessOne. %%% Portions created by ProcessOne are Copyright 2006-2012, ProcessOne %%% All Rights Reserved.'' @@ -24,9 +24,11 @@ %%% ==================================================================== -module(node_dispatch). + -author('christophe.romain@process-one.net'). -include("pubsub.hrl"). + -include("jlib.hrl"). -behaviour(gen_pubsub_node). @@ -38,39 +40,18 @@ %%% This module can not work with virtual nodetree %% API definition --export([init/3, terminate/2, - options/0, features/0, - create_node_permission/6, - create_node/2, - delete_node/1, - purge_node/2, - subscribe_node/8, - unsubscribe_node/4, - publish_item/6, - delete_item/4, - remove_extra_items/3, - get_entity_affiliations/2, - get_node_affiliations/1, - get_affiliation/2, - set_affiliation/3, - get_entity_subscriptions/2, - get_node_subscriptions/1, - get_subscriptions/2, - set_subscriptions/4, - get_pending_nodes/2, - get_states/1, - get_state/2, - set_state/1, - get_items/6, - get_items/2, - get_item/7, - get_item/2, - set_item/1, - get_item_name/3, - node_to_path/1, - path_to_node/1 - ]). - +-export([init/3, terminate/2, options/0, features/0, + create_node_permission/6, create_node/2, delete_node/1, + purge_node/2, subscribe_node/8, unsubscribe_node/4, + publish_item/6, delete_item/4, remove_extra_items/3, + get_entity_affiliations/2, get_node_affiliations/1, + get_affiliation/2, set_affiliation/3, + get_entity_subscriptions/2, get_node_subscriptions/1, + get_subscriptions/2, set_subscriptions/4, + get_pending_nodes/2, get_states/1, get_state/2, + set_state/1, get_items/6, get_items/2, get_item/7, + get_item/2, set_item/1, get_item_name/3, node_to_path/1, + path_to_node/1]). init(Host, ServerHost, Opts) -> node_hometree:init(Host, ServerHost, Opts). @@ -79,16 +60,11 @@ terminate(Host, ServerHost) -> node_hometree:terminate(Host, ServerHost). options() -> - [{deliver_payloads, true}, - {notify_config, false}, - {notify_delete, false}, - {notify_retract, true}, - {purge_offline, false}, - {persist_items, true}, - {max_items, ?MAXITEMS}, - {subscribe, true}, - {access_model, open}, - {roster_groups_allowed, []}, + [{deliver_payloads, true}, {notify_config, false}, + {notify_delete, false}, {notify_retract, true}, + {purge_offline, false}, {persist_items, true}, + {max_items, ?MAXITEMS}, {subscribe, true}, + {access_model, open}, {roster_groups_allowed, []}, {publish_model, publishers}, {notification_type, headline}, {max_payload_size, ?MAX_PAYLOAD_SIZE}, @@ -97,23 +73,15 @@ options() -> {presence_based_delivery, false}]. features() -> - ["create-nodes", - "delete-nodes", - "instant-nodes", - "outcast-affiliation", - "persistent-items", - "publish", - %%"purge-nodes", - %%"retract-items", - %%"retrieve-affiliations", - "retrieve-items" - %%"retrieve-subscriptions", - %%"subscribe", - %%"subscription-notifications", - ]. - -create_node_permission(Host, ServerHost, Node, ParentNode, Owner, Access) -> - node_hometree:create_node_permission(Host, ServerHost, Node, ParentNode, Owner, Access). + [<<"create-nodes">>, <<"delete-nodes">>, + <<"instant-nodes">>, <<"outcast-affiliation">>, + <<"persistent-items">>, <<"publish">>, + <<"retrieve-items">>]. + +create_node_permission(Host, ServerHost, Node, + ParentNode, Owner, Access) -> + node_hometree:create_node_permission(Host, ServerHost, + Node, ParentNode, Owner, Access). create_node(NodeId, Owner) -> node_hometree:create_node(NodeId, Owner). @@ -121,88 +89,86 @@ create_node(NodeId, Owner) -> delete_node(Removed) -> node_hometree:delete_node(Removed). -subscribe_node(_NodeId, _Sender, _Subscriber, _AccessModel, - _SendLast, _PresenceSubscription, _RosterGroup, _Options) -> +subscribe_node(_NodeId, _Sender, _Subscriber, + _AccessModel, _SendLast, _PresenceSubscription, + _RosterGroup, _Options) -> {error, ?ERR_FORBIDDEN}. -unsubscribe_node(_NodeId, _Sender, _Subscriber, _SubID) -> +unsubscribe_node(_NodeId, _Sender, _Subscriber, + _SubID) -> {error, ?ERR_FORBIDDEN}. -publish_item(NodeId, Publisher, Model, MaxItems, ItemId, Payload) -> - lists:foreach(fun(SubNode) -> - node_hometree:publish_item( - SubNode#pubsub_node.id, Publisher, Model, - MaxItems, ItemId, Payload) - end, nodetree_tree:get_subnodes(NodeId, Publisher, Publisher)). +publish_item(NodeId, Publisher, Model, MaxItems, ItemId, + Payload) -> + lists:foreach(fun (SubNode) -> + node_hometree:publish_item(SubNode#pubsub_node.id, + Publisher, Model, MaxItems, + ItemId, Payload) + end, + nodetree_tree:get_subnodes(NodeId, Publisher, + Publisher)). remove_extra_items(_NodeId, _MaxItems, ItemIds) -> {result, {ItemIds, []}}. -delete_item(_NodeId, _Publisher, _PublishModel, _ItemId) -> +delete_item(_NodeId, _Publisher, _PublishModel, + _ItemId) -> {error, ?ERR_ITEM_NOT_FOUND}. -purge_node(_NodeId, _Owner) -> - {error, ?ERR_FORBIDDEN}. +purge_node(_NodeId, _Owner) -> {error, ?ERR_FORBIDDEN}. -get_entity_affiliations(_Host, _Owner) -> - {result, []}. +get_entity_affiliations(_Host, _Owner) -> {result, []}. -get_node_affiliations(_NodeId) -> - {result, []}. +get_node_affiliations(_NodeId) -> {result, []}. -get_affiliation(_NodeId, _Owner) -> - {result, []}. +get_affiliation(_NodeId, _Owner) -> {result, []}. set_affiliation(NodeId, Owner, Affiliation) -> - node_hometree:set_affiliation(NodeId, Owner, Affiliation). + node_hometree:set_affiliation(NodeId, Owner, + Affiliation). -get_entity_subscriptions(_Host, _Owner) -> - {result, []}. +get_entity_subscriptions(_Host, _Owner) -> {result, []}. get_node_subscriptions(NodeId) -> - %% note: get_node_subscriptions is used for broadcasting - %% DO NOT REMOVE node_hometree:get_node_subscriptions(NodeId). -get_subscriptions(_NodeId, _Owner) -> - {result, []}. +get_subscriptions(_NodeId, _Owner) -> {result, []}. set_subscriptions(NodeId, Owner, Subscription, SubId) -> - node_hometree:set_subscriptions(NodeId, Owner, Subscription, SubId). + node_hometree:set_subscriptions(NodeId, Owner, + Subscription, SubId). get_pending_nodes(Host, Owner) -> node_hometree:get_pending_nodes(Host, Owner). -get_states(NodeId) -> - node_hometree:get_states(NodeId). +get_states(NodeId) -> node_hometree:get_states(NodeId). get_state(NodeId, JID) -> node_hometree:get_state(NodeId, JID). -set_state(State) -> - node_hometree:set_state(State). +set_state(State) -> node_hometree:set_state(State). get_items(NodeId, From) -> node_hometree:get_items(NodeId, From). -get_items(NodeId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId) -> - node_hometree:get_items(NodeId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId). +get_items(NodeId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId) -> + node_hometree:get_items(NodeId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId). get_item(NodeId, ItemId) -> node_hometree:get_item(NodeId, ItemId). -get_item(NodeId, ItemId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId) -> - node_hometree:get_item(NodeId, ItemId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId). +get_item(NodeId, ItemId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId) -> + node_hometree:get_item(NodeId, ItemId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId). -set_item(Item) -> - node_hometree:set_item(Item). +set_item(Item) -> node_hometree:set_item(Item). get_item_name(Host, Node, Id) -> node_hometree:get_item_name(Host, Node, Id). -node_to_path(Node) -> - node_flat:node_to_path(Node). - -path_to_node(Path) -> - node_flat:path_to_node(Path). +node_to_path(Node) -> node_flat:node_to_path(Node). +path_to_node(Path) -> node_flat:path_to_node(Path). |