mirror of https://github.com/sipwise/db-schema.git
Change-Id: Id54389a7043080875b9c6a580e4a1f9f321b6868changes/74/674/3
parent
c0fdacbe32
commit
8a0addfaad
@ -0,0 +1,78 @@
|
||||
USE provisioning;
|
||||
|
||||
DROP TRIGGER IF EXISTS voip_phost_crepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER voip_phost_crepl_trig AFTER INSERT ON voip_peer_hosts
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
INSERT INTO kamailio.lcr_gw (lcr_id, gw_name, ip_addr, hostname, port, uri_scheme, transport, strip, flags, group_id)
|
||||
VALUES(1, NEW.name, NEW.ip, NEW.host, NEW.port, 1, NEW.transport, 0, NEW.id, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT rule.lcr_id, rule.id, LAST_INSERT_ID(), vpg.priority, NEW.weight
|
||||
FROM kamailio.lcr_rule rule
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = rule.group_id
|
||||
WHERE vpg.id <=> NEW.group_id;
|
||||
|
||||
INSERT INTO voip_peer_preferences (peer_host_id, attribute_id, value)
|
||||
SELECT NEW.id, p.id, pe.value
|
||||
FROM voip_preferences p, voip_preferences_enum pe
|
||||
WHERE p.id <=> preference_id AND p.peer_pref=1 AND pe.peer_pref=1 AND pe.default_val=1 AND pe.value IS NOT NULL;
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER IF EXISTS voip_phost_urepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER voip_phost_urepl_trig AFTER UPDATE ON voip_peer_hosts
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
UPDATE kamailio.lcr_gw
|
||||
SET gw_name = NEW.name, ip_addr = NEW.ip, hostname = NEW.host, port = NEW.port, transport = NEW.transport, flags = NEW.id
|
||||
WHERE lcr_id = 1 AND ip_addr <=> OLD.ip;
|
||||
|
||||
UPDATE kamailio.lcr_rule_target rt, kamailio.lcr_gw gw
|
||||
SET rt.weight = NEW.weight
|
||||
WHERE gw.id <=> rt.gw_id
|
||||
AND gw.lcr_id = 1
|
||||
AND gw.group_id <=> NEW.group_id
|
||||
AND gw.ip_addr <=> NEW.ip;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER provisioning.voip_prul_crepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER provisioning.voip_prul_crepl_trig AFTER INSERT ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
INSERT INTO kamailio.lcr_rule (lcr_id, prefix, request_uri, from_uri, stopper, enabled, group_id)
|
||||
VALUES(1, NEW.callee_prefix, NEW.callee_pattern, NEW.caller_pattern,
|
||||
0, 1, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT gw.lcr_id, LAST_INSERT_ID(), gw.id, vpg.priority, vph.weight
|
||||
FROM kamailio.lcr_gw gw
|
||||
INNER JOIN provisioning.voip_peer_hosts vph ON vph.ip = gw.ip_addr
|
||||
AND gw.lcr_id = 1
|
||||
AND vph.group_id = gw.group_id
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = vph.group_id
|
||||
WHERE vph.group_id <=> NEW.group_id;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER provisioning.voip_prul_urepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER provisioning.voip_prul_urepl_trig AFTER UPDATE ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
UPDATE kamailio.lcr_rule
|
||||
SET prefix = NEW.callee_prefix, request_uri = NEW.callee_pattern,
|
||||
from_uri = NEW.caller_pattern
|
||||
WHERE prefix <=> OLD.callee_prefix
|
||||
AND request_uri <=> OLD.callee_pattern
|
||||
AND from_uri <=> OLD.caller_pattern
|
||||
AND group_id <=> OLD.group_id;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
@ -0,0 +1,124 @@
|
||||
USE provisioning;
|
||||
|
||||
DROP TRIGGER IF EXISTS voip_phost_crepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER voip_phost_crepl_trig AFTER INSERT ON voip_peer_hosts
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
IF NEW.enabled THEN
|
||||
INSERT INTO kamailio.lcr_gw (lcr_id, gw_name, ip_addr, hostname, port, uri_scheme, transport, strip, flags, group_id)
|
||||
VALUES(1, NEW.name, NEW.ip, NEW.host, NEW.port, 1, NEW.transport, 0, NEW.id, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT rule.lcr_id, rule.id, LAST_INSERT_ID(), vpg.priority, NEW.weight
|
||||
FROM kamailio.lcr_rule rule
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = rule.group_id
|
||||
WHERE vpg.id <=> NEW.group_id;
|
||||
|
||||
INSERT INTO voip_peer_preferences (peer_host_id, attribute_id, value)
|
||||
SELECT NEW.id, p.id, pe.value
|
||||
FROM voip_preferences p, voip_preferences_enum pe
|
||||
WHERE p.id <=> preference_id AND p.peer_pref=1 AND pe.peer_pref=1 AND pe.default_val=1 AND pe.value IS NOT NULL;
|
||||
|
||||
END IF;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER IF EXISTS voip_phost_urepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER voip_phost_urepl_trig AFTER UPDATE ON voip_peer_hosts
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
IF OLD.enabled = 1 AND NEW.enabled = 1 THEN
|
||||
UPDATE kamailio.lcr_gw
|
||||
SET gw_name = NEW.name, ip_addr = NEW.ip, hostname = NEW.host, port = NEW.port, transport = NEW.transport, flags = NEW.id
|
||||
WHERE lcr_id = 1 AND ip_addr <=> OLD.ip;
|
||||
|
||||
UPDATE kamailio.lcr_rule_target rt, kamailio.lcr_gw gw
|
||||
SET rt.weight = NEW.weight
|
||||
WHERE gw.id <=> rt.gw_id
|
||||
AND gw.lcr_id = 1
|
||||
AND gw.group_id <=> NEW.group_id
|
||||
AND gw.ip_addr <=> NEW.ip;
|
||||
ELSEIF OLD.enabled = 0 AND NEW.enabled = 1 THEN
|
||||
INSERT INTO kamailio.lcr_gw (lcr_id, gw_name, ip_addr, hostname, port, uri_scheme, transport, strip, flags, group_id)
|
||||
VALUES(1, NEW.name, NEW.ip, NEW.host, NEW.port, 1, NEW.transport, 0, NEW.id, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT rule.lcr_id, rule.id, LAST_INSERT_ID(), vpg.priority, NEW.weight
|
||||
FROM kamailio.lcr_rule rule
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = rule.group_id
|
||||
WHERE vpg.id <=> NEW.group_id;
|
||||
|
||||
INSERT INTO voip_peer_preferences (peer_host_id, attribute_id, value)
|
||||
SELECT NEW.id, p.id, pe.value
|
||||
FROM voip_preferences p, voip_preferences_enum pe
|
||||
WHERE p.id <=> preference_id AND p.peer_pref=1 AND pe.peer_pref=1 AND pe.default_val=1 AND pe.value IS NOT NULL;
|
||||
ELSEIF OLD.enabled = 1 AND NEW.enabled = 0 THEN
|
||||
DELETE FROM kamailio.lcr_gw
|
||||
WHERE lcr_id = 1
|
||||
AND group_id <=> OLD.group_id
|
||||
AND ip_addr <=> OLD.ip;
|
||||
END IF;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER IF EXISTS provisioning.voip_prul_crepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER provisioning.voip_prul_crepl_trig AFTER INSERT ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
IF NEW.enabled = 1 THEN
|
||||
INSERT INTO kamailio.lcr_rule (lcr_id, prefix, request_uri, from_uri, stopper, enabled, group_id)
|
||||
VALUES(1, NEW.callee_prefix, NEW.callee_pattern, NEW.caller_pattern, 0, 1, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT gw.lcr_id, LAST_INSERT_ID(), gw.id, vpg.priority, vph.weight
|
||||
FROM kamailio.lcr_gw gw
|
||||
INNER JOIN provisioning.voip_peer_hosts vph ON vph.ip = gw.ip_addr
|
||||
AND gw.lcr_id = 1
|
||||
AND vph.group_id = gw.group_id
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = vph.group_id
|
||||
WHERE vph.group_id <=> NEW.group_id;
|
||||
END IF;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
DROP TRIGGER IF EXISTS provisioning.voip_prul_urepl_trig;
|
||||
DELIMITER ;;
|
||||
/*!50003 CREATE*/ /*!50017 DEFINER=`sipwise`@`localhost`*/ /*!50003 TRIGGER provisioning.voip_prul_urepl_trig AFTER UPDATE ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
IF OLD.enabled = 1 AND NEW.enabled = 1 THEN
|
||||
UPDATE kamailio.lcr_rule
|
||||
SET prefix = NEW.callee_prefix, request_uri = NEW.callee_pattern,
|
||||
from_uri = NEW.caller_pattern
|
||||
WHERE prefix <=> OLD.callee_prefix
|
||||
AND request_uri <=> OLD.callee_pattern
|
||||
AND from_uri <=> OLD.caller_pattern
|
||||
AND group_id <=> OLD.group_id;
|
||||
ELSEIF OLD.enabled = 0 AND NEW.enabled = 1 THEN
|
||||
INSERT INTO kamailio.lcr_rule (lcr_id, prefix, request_uri, from_uri, stopper, enabled, group_id)
|
||||
VALUES(1, NEW.callee_prefix, NEW.callee_pattern, NEW.caller_pattern, 0, 1, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT gw.lcr_id, LAST_INSERT_ID(), gw.id, vpg.priority, vph.weight
|
||||
FROM kamailio.lcr_gw gw
|
||||
INNER JOIN provisioning.voip_peer_hosts vph ON vph.ip = gw.ip_addr
|
||||
AND gw.lcr_id = 1
|
||||
AND vph.group_id = gw.group_id
|
||||
INNER JOIN provisioning.voip_peer_groups vpg ON vpg.id = vph.group_id
|
||||
WHERE vph.group_id <=> NEW.group_id;
|
||||
ELSEIF OLD.enabled = 1 AND NEW.enabled = 0 THEN
|
||||
DELETE FROM kamailio.lcr_rule
|
||||
WHERE prefix <=> OLD.callee_prefix
|
||||
AND request_uri <=> OLD.callee_pattern
|
||||
AND from_uri <=> OLD.caller_pattern
|
||||
AND group_id <=> OLD.group_id;
|
||||
END IF;
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
Loading…
Reference in new issue