diff options
Diffstat (limited to 'src/mod_pubsub/node_mb.erl')
-rw-r--r-- | src/mod_pubsub/node_mb.erl | 158 |
1 files changed, 68 insertions, 90 deletions
diff --git a/src/mod_pubsub/node_mb.erl b/src/mod_pubsub/node_mb.erl index c83b445e..b93a57eb 100644 --- a/src/mod_pubsub/node_mb.erl +++ b/src/mod_pubsub/node_mb.erl @@ -5,11 +5,13 @@ %%% 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-2013, ProcessOne %%% All Rights Reserved.'' @@ -22,7 +24,6 @@ %%% @end %%% ==================================================================== - %%% @doc The module <strong>{@module}</strong> is the pep microblog PubSub plugin. %%% <p> To be used, mod_pubsub must be configured : %%% {mod_pubsub, [ % requires mod_caps @@ -34,66 +35,43 @@ %%% <p>PubSub plugin nodes are using the {@link gen_pubsub_node} behaviour.</p> -module(node_mb). + -author('eric@ohmforce.com'). -include("ejabberd.hrl"). + -include("pubsub.hrl"). + -include("jlib.hrl"). -behaviour(gen_pubsub_node). %% 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_pep:init(Host, ServerHost, Opts). terminate(Host, ServerHost) -> - node_pep:terminate(Host, ServerHost), - ok. + node_pep:terminate(Host, ServerHost), ok. options() -> - [{deliver_payloads, true}, - {notify_config, false}, - {notify_delete, false}, - {notify_retract, false}, - {purge_offline, false}, - {persist_items, true}, - {max_items, ?MAXITEMS}, - {subscribe, true}, - {access_model, presence}, - {roster_groups_allowed, []}, + [{deliver_payloads, true}, {notify_config, false}, + {notify_delete, false}, {notify_retract, false}, + {purge_offline, false}, {persist_items, true}, + {max_items, ?MAXITEMS}, {subscribe, true}, + {access_model, presence}, {roster_groups_allowed, []}, {publish_model, publishers}, {notification_type, headline}, {max_payload_size, ?MAX_PAYLOAD_SIZE}, @@ -102,50 +80,51 @@ options() -> {presence_based_delivery, true}]. features() -> - ["create-nodes", %* - "auto-create", %* - "auto-subscribe", %* - "delete-nodes", %* - "delete-items", %* - "filtered-notifications", %* - "modify-affiliations", - "outcast-affiliation", - "persistent-items", - "publish", %* - "purge-nodes", - "retract-items", - "retrieve-affiliations", - "retrieve-items", %* - "retrieve-subscriptions", - "subscribe" %* - ]. - -create_node_permission(Host, ServerHost, Node, ParentNode, Owner, Access) -> - node_pep:create_node_permission(Host, ServerHost, Node, ParentNode, Owner, Access). + [<<"create-nodes">>, %* + <<"auto-create">>, %* + <<"auto-subscribe">>, %* + <<"delete-nodes">>, %* + <<"delete-items">>, %* + <<"filtered-notifications">>, %* + <<"modify-affiliations">>, <<"outcast-affiliation">>, + <<"persistent-items">>, + <<"publish">>, %* + <<"purge-nodes">>, <<"retract-items">>, + <<"retrieve-affiliations">>, + <<"retrieve-items">>, %* + <<"retrieve-subscriptions">>, <<"subscribe">>]. + +create_node_permission(Host, ServerHost, Node, + ParentNode, Owner, Access) -> + node_pep:create_node_permission(Host, ServerHost, Node, + ParentNode, Owner, Access). create_node(NodeId, Owner) -> node_pep:create_node(NodeId, Owner). -delete_node(Removed) -> - node_pep:delete_node(Removed). +delete_node(Removed) -> node_pep:delete_node(Removed). subscribe_node(NodeId, Sender, Subscriber, AccessModel, SendLast, PresenceSubscription, RosterGroup, Options) -> - node_pep:subscribe_node( - NodeId, Sender, Subscriber, AccessModel, SendLast, - PresenceSubscription, RosterGroup, Options). + node_pep:subscribe_node(NodeId, Sender, Subscriber, + AccessModel, SendLast, PresenceSubscription, + RosterGroup, Options). unsubscribe_node(NodeId, Sender, Subscriber, SubID) -> - node_pep:unsubscribe_node(NodeId, Sender, Subscriber, SubID). + node_pep:unsubscribe_node(NodeId, Sender, Subscriber, + SubID). -publish_item(NodeId, Publisher, Model, MaxItems, ItemId, Payload) -> - node_pep:publish_item(NodeId, Publisher, Model, MaxItems, ItemId, Payload). +publish_item(NodeId, Publisher, Model, MaxItems, ItemId, + Payload) -> + node_pep:publish_item(NodeId, Publisher, Model, + MaxItems, ItemId, Payload). remove_extra_items(NodeId, MaxItems, ItemIds) -> node_pep:remove_extra_items(NodeId, MaxItems, ItemIds). delete_item(NodeId, Publisher, PublishModel, ItemId) -> - node_pep:delete_item(NodeId, Publisher, PublishModel, ItemId). + node_pep:delete_item(NodeId, Publisher, PublishModel, + ItemId). purge_node(NodeId, Owner) -> node_pep:purge_node(NodeId, Owner). @@ -172,41 +151,40 @@ get_subscriptions(NodeId, Owner) -> node_pep:get_subscriptions(NodeId, Owner). set_subscriptions(NodeId, Owner, Subscription, SubId) -> - node_pep:set_subscriptions(NodeId, Owner, Subscription, SubId). + node_pep:set_subscriptions(NodeId, Owner, Subscription, + SubId). get_pending_nodes(Host, Owner) -> node_hometree:get_pending_nodes(Host, Owner). -get_states(NodeId) -> - node_pep:get_states(NodeId). +get_states(NodeId) -> node_pep:get_states(NodeId). get_state(NodeId, JID) -> node_pep:get_state(NodeId, JID). -set_state(State) -> - node_pep:set_state(State). +set_state(State) -> node_pep:set_state(State). get_items(NodeId, From) -> node_pep:get_items(NodeId, From). -get_items(NodeId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId) -> - node_pep:get_items(NodeId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId). +get_items(NodeId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId) -> + node_pep:get_items(NodeId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId). get_item(NodeId, ItemId) -> node_pep:get_item(NodeId, ItemId). -get_item(NodeId, ItemId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId) -> - node_pep:get_item(NodeId, ItemId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId). +get_item(NodeId, ItemId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId) -> + node_pep:get_item(NodeId, ItemId, JID, AccessModel, + PresenceSubscription, RosterGroup, SubId). -set_item(Item) -> - node_pep:set_item(Item). +set_item(Item) -> node_pep:set_item(Item). get_item_name(Host, Node, Id) -> node_pep:get_item_name(Host, Node, Id). -node_to_path(Node) -> - node_pep:node_to_path(Node). - -path_to_node(Path) -> - node_pep:path_to_node(Path). +node_to_path(Node) -> node_pep:node_to_path(Node). +path_to_node(Path) -> node_pep:path_to_node(Path). |