mirror of https://github.com/sipwise/db-schema.git
* fix peering hosts weight update to be correctly performed
only for the same peering host (was for the whole peering group).
Change-Id: Iaca327b1d49f2e50f9aa258e72392ffafe271fd3
(cherry picked from commit fa6ececa59
)
mr13.2
parent
f1b28e4345
commit
bcd9312d4e
@ -0,0 +1,78 @@
|
||||
USE provisioning;
|
||||
SET autocommit=0;
|
||||
|
||||
|
||||
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
|
||||
|
||||
DECLARE m_proto CHAR(4);
|
||||
DECLARE m_probechange INTEGER;
|
||||
|
||||
IF NEW.transport = 2 THEN
|
||||
SET m_proto := 'TCP';
|
||||
ELSEIF NEW.transport = 3 THEN
|
||||
SET m_proto := 'TLS';
|
||||
ELSE
|
||||
SET m_proto := 'UDP';
|
||||
END IF;
|
||||
|
||||
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
|
||||
WHERE lcr_id = 1
|
||||
AND id <=> NEW.id;
|
||||
|
||||
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;
|
||||
|
||||
IF OLD.probe = 1 AND (OLD.ip != NEW.ip OR OLD.port != NEW.port OR OLD.transport != NEW.transport OR OLD.name != NEW.name OR OLD.group_id != NEW.group_id) THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', OLD.id, ';%');
|
||||
SET m_probechange := 1;
|
||||
ELSEIF OLD.probe = 1 and NEW.probe = 0 THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', OLD.id, ';%');
|
||||
END IF;
|
||||
IF NEW.probe = 1 AND (m_probechange = 1 OR OLD.probe = 0) THEN
|
||||
INSERT INTO kamailio.dispatcher (setid, destination, flags, priority, attrs, description)
|
||||
VALUES(100, CONCAT('sip:', NEW.ip, ':', NEW.port, ';transport=', m_proto), 8, 0, CONCAT('peerid=', NEW.id, ';peername="', NEW.name, '";peergid=', NEW.group_id, ';'), 'Peer Probe');
|
||||
END IF;
|
||||
|
||||
ELSEIF OLD.enabled = 0 AND NEW.enabled = 1 THEN
|
||||
|
||||
INSERT INTO kamailio.lcr_gw (id, lcr_id, gw_name, ip_addr, hostname, port, uri_scheme, transport, strip, group_id)
|
||||
VALUES(NEW.id, 1, NEW.name, NEW.ip, NEW.host, NEW.port, 1, NEW.transport, 0, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT rule.lcr_id, rule.id, NEW.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;
|
||||
|
||||
IF NEW.probe = 1 THEN
|
||||
INSERT INTO kamailio.dispatcher (setid, destination, flags, priority, attrs, description)
|
||||
VALUES(100, CONCAT('sip:', NEW.ip, ':', NEW.port, ';transport=', m_proto), 8, 0, CONCAT('peerid=', NEW.id, ';peername="', NEW.name, '";peergid=', NEW.group_id, ';'), 'Peer Probe');
|
||||
END IF;
|
||||
|
||||
ELSEIF OLD.enabled = 1 AND NEW.enabled = 0 THEN
|
||||
|
||||
DELETE FROM kamailio.lcr_gw
|
||||
WHERE lcr_id = 1
|
||||
AND id <=> NEW.id;
|
||||
|
||||
IF OLD.probe = 1 THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', NEW.id, ';%');
|
||||
END IF;
|
||||
|
||||
END IF;
|
||||
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
|
||||
COMMIT;
|
@ -0,0 +1,78 @@
|
||||
USE provisioning;
|
||||
SET autocommit=0;
|
||||
|
||||
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
|
||||
|
||||
DECLARE m_proto CHAR(4);
|
||||
DECLARE m_probechange INTEGER;
|
||||
|
||||
IF NEW.transport = 2 THEN
|
||||
SET m_proto := 'TCP';
|
||||
ELSEIF NEW.transport = 3 THEN
|
||||
SET m_proto := 'TLS';
|
||||
ELSE
|
||||
SET m_proto := 'UDP';
|
||||
END IF;
|
||||
|
||||
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
|
||||
WHERE lcr_id = 1
|
||||
AND id <=> NEW.id;
|
||||
|
||||
UPDATE kamailio.lcr_rule_target rt
|
||||
JOIN kamailio.lcr_gw as gw ON gw.id = rt.gw_id
|
||||
SET rt.weight = NEW.weight
|
||||
WHERE gw.id <=> NEW.id
|
||||
AND gw.id <=> rt.gw_id
|
||||
AND gw.lcr_id = 1
|
||||
AND gw.group_id <=> NEW.group_id;
|
||||
|
||||
IF OLD.probe = 1 AND (OLD.ip != NEW.ip OR OLD.port != NEW.port OR OLD.transport != NEW.transport OR OLD.name != NEW.name OR OLD.group_id != NEW.group_id) THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', OLD.id, ';%');
|
||||
SET m_probechange := 1;
|
||||
ELSEIF OLD.probe = 1 and NEW.probe = 0 THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', OLD.id, ';%');
|
||||
END IF;
|
||||
IF NEW.probe = 1 AND (m_probechange = 1 OR OLD.probe = 0) THEN
|
||||
INSERT INTO kamailio.dispatcher (setid, destination, flags, priority, attrs, description)
|
||||
VALUES(100, CONCAT('sip:', NEW.ip, ':', NEW.port, ';transport=', m_proto), 8, 0, CONCAT('peerid=', NEW.id, ';peername="', NEW.name, '";peergid=', NEW.group_id, ';'), 'Peer Probe');
|
||||
END IF;
|
||||
|
||||
ELSEIF OLD.enabled = 0 AND NEW.enabled = 1 THEN
|
||||
|
||||
INSERT INTO kamailio.lcr_gw (id, lcr_id, gw_name, ip_addr, hostname, port, uri_scheme, transport, strip, group_id)
|
||||
VALUES(NEW.id, 1, NEW.name, NEW.ip, NEW.host, NEW.port, 1, NEW.transport, 0, NEW.group_id);
|
||||
|
||||
INSERT INTO kamailio.lcr_rule_target (lcr_id, rule_id, gw_id, priority, weight)
|
||||
SELECT rule.lcr_id, rule.id, NEW.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;
|
||||
|
||||
IF NEW.probe = 1 THEN
|
||||
INSERT INTO kamailio.dispatcher (setid, destination, flags, priority, attrs, description)
|
||||
VALUES(100, CONCAT('sip:', NEW.ip, ':', NEW.port, ';transport=', m_proto), 8, 0, CONCAT('peerid=', NEW.id, ';peername="', NEW.name, '";peergid=', NEW.group_id, ';'), 'Peer Probe');
|
||||
END IF;
|
||||
|
||||
ELSEIF OLD.enabled = 1 AND NEW.enabled = 0 THEN
|
||||
|
||||
DELETE FROM kamailio.lcr_gw
|
||||
WHERE lcr_id = 1
|
||||
AND id <=> NEW.id;
|
||||
|
||||
IF OLD.probe = 1 THEN
|
||||
DELETE FROM kamailio.dispatcher WHERE attrs LIKE CONCAT('%peerid=', NEW.id, ';%');
|
||||
END IF;
|
||||
|
||||
END IF;
|
||||
|
||||
|
||||
END */;;
|
||||
DELIMITER ;
|
||||
|
||||
COMMIT;
|
Loading…
Reference in new issue