mirror of https://github.com/sipwise/db-schema.git
parent
8d0694581e
commit
3392003d50
@ -0,0 +1,54 @@
|
||||
ALTER TABLE provisioning.voip_peer_rules DROP COLUMN callee_pattern;
|
||||
ALTER TABLE provisioning.voip_peer_rules CHANGE COLUMN caller_pattern caller_prefix VARCHAR(64) DEFAULT NULL;
|
||||
|
||||
DROP TRIGGER provisioning.voip_prul_crepl_trig;
|
||||
DROP TRIGGER provisioning.voip_prul_urepl_trig;
|
||||
DROP TRIGGER provisioning.voip_prul_drepl_trig;
|
||||
|
||||
DELIMITER |
|
||||
|
||||
CREATE TRIGGER provisioning.voip_prul_crepl_trig AFTER INSERT ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
INSERT INTO kamailio.lcr_rule (lcr_id, prefix, from_uri, stopper, enabled, group_id)
|
||||
VALUES(1, NEW.callee_prefix, NEW.caller_prefix,
|
||||
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;
|
||||
|
|
||||
|
||||
CREATE 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, from_uri = NEW.caller_prefix
|
||||
WHERE prefix = OLD.callee_prefix
|
||||
AND from_uri = OLD.caller_prefix
|
||||
AND group_id = OLD.group_id;
|
||||
|
||||
END;
|
||||
|
|
||||
|
||||
CREATE TRIGGER provisioning.voip_prul_drepl_trig AFTER DELETE ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
DELETE FROM kamailio.lcr_rule
|
||||
WHERE prefix = OLD.callee_prefix
|
||||
AND from_uri = OLD.caller_prefix
|
||||
AND group_id = OLD.group_id;
|
||||
|
||||
-- foreign key will delete from kamailio.lcr_rule_target
|
||||
|
||||
END;
|
||||
|
|
||||
|
||||
DELIMITER ;
|
@ -0,0 +1,57 @@
|
||||
ALTER TABLE provisioning.voip_peer_rules ADD COLUMN callee_pattern VARCHAR(64) DEFAULT NULL AFTER callee_prefix;
|
||||
ALTER TABLE provisioning.voip_peer_rules CHANGE COLUMN caller_prefix caller_pattern VARCHAR(64) DEFAULT NULL;
|
||||
|
||||
DROP TRIGGER provisioning.voip_prul_crepl_trig;
|
||||
DROP TRIGGER provisioning.voip_prul_urepl_trig;
|
||||
DROP TRIGGER provisioning.voip_prul_drepl_trig;
|
||||
|
||||
DELIMITER |
|
||||
|
||||
CREATE 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;
|
||||
|
|
||||
|
||||
CREATE 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;
|
||||
|
|
||||
|
||||
CREATE TRIGGER provisioning.voip_prul_drepl_trig AFTER DELETE ON voip_peer_rules
|
||||
FOR EACH ROW BEGIN
|
||||
|
||||
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;
|
||||
|
||||
-- foreign key will delete from kamailio.lcr_rule_target
|
||||
|
||||
END;
|
||||
|
|
||||
|
||||
DELIMITER ;
|
Loading…
Reference in new issue