You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
db-schema/db_scripts/diff/8467.down

55 lines
1.8 KiB

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 ;