| Slony-I 2.2.10 Documentation | ||||
|---|---|---|---|---|
| Prev | Fast Backward | Chapter 8. Schema schemadoc | Fast Forward | Next |
Function Properties
Language: PLPGSQL
Return Type: bigint
unsubscribeSet (sub_set, sub_receiver,force) Unsubscribe node sub_receiver from subscription set sub_set. This is invoked on the receiver node. It verifies that this does not break any chains (e.g. - where sub_receiver is a provider for another node), then restores tables, drops Slony-specific keys, drops table entries for the set, drops the subscription, and generates an UNSUBSCRIBE_SET node to publish that the node is being dropped.declare
v_tab_row record;
begin
-- ----
-- Grab the central configuration lock
-- ----
lock table sl_config_lock;
-- ----
-- Check that this is called on the receiver node
-- ----
if p_sub_receiver != getLocalNodeId('_schemadoc') then
raise exception 'Slony-I: unsubscribeSet() must be called on receiver';
end if;
-- ----
-- Check that this does not break any chains
-- ----
if p_force=false and exists (select true from sl_subscribe
where sub_set = p_sub_set
and sub_provider = p_sub_receiver)
then
raise exception 'Slony-I: Cannot unsubscribe set % while being provider',
p_sub_set;
end if;
if exists (select true from sl_subscribe
where sub_set = p_sub_set
and sub_provider = p_sub_receiver)
then
--delete the receivers of this provider.
--unsubscribeSet_int() will generate the event
--when it runs on the receiver.
delete from sl_subscribe
where sub_set=p_sub_set
and sub_provider=p_sub_receiver;
end if;
-- ----
-- Remove the replication triggers.
-- ----
for v_tab_row in select tab_id from sl_table
where tab_set = p_sub_set
order by tab_id
loop
perform alterTableDropTriggers(v_tab_row.tab_id);
end loop;
-- ----
-- Remove the setsync status. This will also cause the
-- worker thread to ignore the set and stop replicating
-- right now.
-- ----
delete from sl_setsync
where ssy_setid = p_sub_set;
-- ----
-- Remove all sl_table and sl_sequence entries for this set.
-- Should we ever subscribe again, the initial data
-- copy process will create new ones.
-- ----
delete from sl_table
where tab_set = p_sub_set;
delete from sl_sequence
where seq_set = p_sub_set;
-- ----
-- Call the internal procedure to drop the subscription
-- ----
perform unsubscribeSet_int(p_sub_set, p_sub_receiver);
-- Rewrite sl_listen table
perform RebuildListenEntries();
-- ----
-- Create the UNSUBSCRIBE_SET event
-- ----
return createEvent('_schemadoc', 'UNSUBSCRIBE_SET',
p_sub_set::text, p_sub_receiver::text);
end;