25
1
mirror of https://github.com/processone/ejabberd.git synced 2024-11-22 16:20:52 +01:00
xmpp.chapril.org-ejabberd/src/node_mix_sql.erl

189 lines
6.2 KiB
Erlang
Raw Normal View History

2016-03-13 13:38:50 +01:00
%%%-------------------------------------------------------------------
2016-12-27 10:44:07 +01:00
%%% File : node_mix_sql.erl
%%% Author : Evgeny Khramtsov <ekhramtsov@process-one.net>
2016-03-13 13:38:50 +01:00
%%% Created : 8 Mar 2016 by Evgeny Khramtsov <ekhramtsov@process-one.net>
2016-12-27 10:44:07 +01:00
%%%
%%%
%%% ejabberd, Copyright (C) 2002-2017 ProcessOne
2016-12-27 10:44:07 +01:00
%%%
%%% This program is free software; you can redistribute it and/or
%%% modify it under the terms of the GNU General Public License as
%%% published by the Free Software Foundation; either version 2 of the
%%% License, or (at your option) any later version.
%%%
%%% This program is distributed in the hope that it will be useful,
%%% but WITHOUT ANY WARRANTY; without even the implied warranty of
%%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
%%% General Public License for more details.
%%%
%%% You should have received a copy of the GNU General Public License along
%%% with this program; if not, write to the Free Software Foundation, Inc.,
%%% 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
%%%
%%%----------------------------------------------------------------------
2016-04-20 11:27:32 +02:00
-module(node_mix_sql).
2016-03-13 13:38:50 +01:00
-behaviour(gen_pubsub_node).
%% API
-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/7, delete_item/4, remove_extra_items/3,
2016-03-13 13:38:50 +01:00
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/7, get_items/3, get_item/7,
get_item/2, set_item/1, get_item_name/3, node_to_path/1,
path_to_node/1, get_entity_subscriptions_for_send_last/2]).
-include("pubsub.hrl").
%%%===================================================================
%%% API
%%%===================================================================
init(Host, ServerHost, Opts) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:init(Host, ServerHost, Opts).
2016-03-13 13:38:50 +01:00
terminate(Host, ServerHost) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:terminate(Host, ServerHost).
2016-03-13 13:38:50 +01:00
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, []},
{publish_model, open},
{notification_type, headline},
{max_payload_size, ?MAX_PAYLOAD_SIZE},
{send_last_published_item, never},
{deliver_notifications, true},
{broadcast_all_resources, true},
{presence_based_delivery, false},
{itemreply, none}].
2016-03-13 13:38:50 +01:00
features() ->
[<<"create-nodes">>,
<<"delete-nodes">>,
<<"delete-items">>,
<<"instant-nodes">>,
<<"item-ids">>,
<<"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) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:create_node_permission(Host, ServerHost, Node, ParentNode, Owner, Access).
2016-03-13 13:38:50 +01:00
create_node(Nidx, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:create_node(Nidx, Owner).
2016-03-13 13:38:50 +01:00
delete_node(Removed) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:delete_node(Removed).
2016-03-13 13:38:50 +01:00
subscribe_node(Nidx, Sender, Subscriber, AccessModel,
SendLast, PresenceSubscription, RosterGroup, Options) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:subscribe_node(Nidx, Sender, Subscriber, AccessModel, SendLast,
2016-03-13 13:38:50 +01:00
PresenceSubscription, RosterGroup, Options).
unsubscribe_node(Nidx, Sender, Subscriber, SubId) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:unsubscribe_node(Nidx, Sender, Subscriber, SubId).
2016-03-13 13:38:50 +01:00
publish_item(Nidx, Publisher, Model, MaxItems, ItemId, Payload, PubOpts) ->
node_flat_sql:publish_item(Nidx, Publisher, Model, MaxItems, ItemId,
Payload, PubOpts).
2016-03-13 13:38:50 +01:00
remove_extra_items(Nidx, MaxItems, ItemIds) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:remove_extra_items(Nidx, MaxItems, ItemIds).
2016-03-13 13:38:50 +01:00
delete_item(Nidx, Publisher, PublishModel, ItemId) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:delete_item(Nidx, Publisher, PublishModel, ItemId).
2016-03-13 13:38:50 +01:00
purge_node(Nidx, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:purge_node(Nidx, Owner).
2016-03-13 13:38:50 +01:00
get_entity_affiliations(Host, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_entity_affiliations(Host, Owner).
2016-03-13 13:38:50 +01:00
get_node_affiliations(Nidx) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_node_affiliations(Nidx).
2016-03-13 13:38:50 +01:00
get_affiliation(Nidx, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_affiliation(Nidx, Owner).
2016-03-13 13:38:50 +01:00
set_affiliation(Nidx, Owner, Affiliation) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:set_affiliation(Nidx, Owner, Affiliation).
2016-03-13 13:38:50 +01:00
get_entity_subscriptions(Host, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_entity_subscriptions(Host, Owner).
2016-03-13 13:38:50 +01:00
get_node_subscriptions(Nidx) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_node_subscriptions(Nidx).
2016-03-13 13:38:50 +01:00
get_subscriptions(Nidx, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_subscriptions(Nidx, Owner).
2016-03-13 13:38:50 +01:00
set_subscriptions(Nidx, Owner, Subscription, SubId) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:set_subscriptions(Nidx, Owner, Subscription, SubId).
2016-03-13 13:38:50 +01:00
get_pending_nodes(Host, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_pending_nodes(Host, Owner).
2016-03-13 13:38:50 +01:00
get_states(Nidx) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_states(Nidx).
2016-03-13 13:38:50 +01:00
get_state(Nidx, JID) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_state(Nidx, JID).
2016-03-13 13:38:50 +01:00
set_state(State) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:set_state(State).
2016-03-13 13:38:50 +01:00
get_items(Nidx, From, RSM) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_items(Nidx, From, RSM).
2016-03-13 13:38:50 +01:00
get_items(Nidx, JID, AccessModel, PresenceSubscription, RosterGroup, SubId, RSM) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_items(Nidx, JID, AccessModel,
2016-03-13 13:38:50 +01:00
PresenceSubscription, RosterGroup, SubId, RSM).
get_item(Nidx, ItemId) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_item(Nidx, ItemId).
2016-03-13 13:38:50 +01:00
get_item(Nidx, ItemId, JID, AccessModel, PresenceSubscription, RosterGroup, SubId) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_item(Nidx, ItemId, JID, AccessModel,
2016-03-13 13:38:50 +01:00
PresenceSubscription, RosterGroup, SubId).
set_item(Item) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:set_item(Item).
2016-03-13 13:38:50 +01:00
get_item_name(Host, Node, Id) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_item_name(Host, Node, Id).
2016-03-13 13:38:50 +01:00
node_to_path(Node) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:node_to_path(Node).
2016-03-13 13:38:50 +01:00
path_to_node(Path) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:path_to_node(Path).
2016-03-13 13:38:50 +01:00
get_entity_subscriptions_for_send_last(Host, Owner) ->
2016-04-20 11:27:32 +02:00
node_flat_sql:get_entity_subscriptions_for_send_last(Host, Owner).
2016-03-13 13:38:50 +01:00
%%%===================================================================
%%% Internal functions
%%%===================================================================