mirror of
https://github.com/jambonz/sbc-sip-sidecar.git
synced 2026-01-24 22:27:52 +00:00
Merge pull request #19 from jambonz/feat/carrier_register_status
feat: update voip carriers register status
This commit is contained in:
6
app.js
6
app.js
@@ -25,7 +25,8 @@ const {
|
||||
lookupSipGatewaysByCarrier,
|
||||
lookupAccountBySipRealm,
|
||||
lookupAccountCapacitiesBySid,
|
||||
addSbcAddress
|
||||
addSbcAddress,
|
||||
updateVoipCarriersRegisterStatus
|
||||
} = require('@jambonz/db-helpers')({
|
||||
host: process.env.JAMBONES_MYSQL_HOST,
|
||||
user: process.env.JAMBONES_MYSQL_USER,
|
||||
@@ -69,7 +70,8 @@ srf.locals = {
|
||||
lookupAllVoipCarriers,
|
||||
lookupSipGatewaysByCarrier,
|
||||
lookupAccountBySipRealm,
|
||||
lookupAccountCapacitiesBySid
|
||||
lookupAccountCapacitiesBySid,
|
||||
updateVoipCarriersRegisterStatus
|
||||
},
|
||||
realtimeDbHelpers: {
|
||||
addKey,
|
||||
|
||||
@@ -18,7 +18,8 @@ class Regbot {
|
||||
|
||||
['ipv4', 'port', 'username', 'password', 'sip_realm'].forEach((prop) => this[prop] = opts[prop]);
|
||||
|
||||
logger.debug({opts}, 'Regbot');
|
||||
logger.debug({ opts }, 'Regbot');
|
||||
this.voip_carrier_sid = opts.voip_carrier_sid;
|
||||
this.username = opts.username;
|
||||
this.password = opts.password;
|
||||
this.sip_realm = opts.sip_realm || opts.ipv4;
|
||||
@@ -44,6 +45,7 @@ class Regbot {
|
||||
|
||||
toJSON() {
|
||||
return {
|
||||
voip_carrier_sid: this.voip_carrier_sid,
|
||||
username: this.username,
|
||||
sip_realm: this.sip_realm,
|
||||
ipv4: this.ipv4,
|
||||
@@ -54,6 +56,7 @@ class Regbot {
|
||||
}
|
||||
|
||||
async register(srf) {
|
||||
const { updateVoipCarriersRegisterStatus } = srf.locals.dbHelpers;
|
||||
try {
|
||||
const contactAddress = this.use_public_ip_in_contact ?
|
||||
`${this.username}@${srf.locals.sbcPublicIpAddress}` : this.aor;
|
||||
@@ -90,18 +93,29 @@ class Regbot {
|
||||
debug(`setting timer for next register to ${expires} seconds`);
|
||||
this.timer = setTimeout(this.register.bind(this, srf), (expires - 5) * 1000);
|
||||
}
|
||||
updateVoipCarriersRegisterStatus(this.voip_carrier_sid, JSON.stringify({
|
||||
status: res.status === 200 ? 'ok' : 'fail',
|
||||
reason: `${res.status} ${res.reason}`,
|
||||
cseq: req.get('Cseq'),
|
||||
callId: req.get('Call-Id')
|
||||
}));
|
||||
});
|
||||
} catch (err) {
|
||||
this.logger.error({ err }, `Regbot Error registering to ${this.ipv4}:${this.port}`);
|
||||
this.timer = setTimeout(this.register.bind(this, srf), 60 * 1000);
|
||||
updateVoipCarriersRegisterStatus(this.voip_carrier_sid, JSON.stringify({
|
||||
status: 'fail',
|
||||
reason: err
|
||||
}));
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = async(logger, srf) => {
|
||||
if (initialized) return;
|
||||
initialized = true;
|
||||
const {addKeyNx} = srf.locals.realtimeDbHelpers;
|
||||
const { addKeyNx } = srf.locals.realtimeDbHelpers;
|
||||
const myToken = short.generate();
|
||||
srf.locals.regbot = {
|
||||
myToken,
|
||||
@@ -130,7 +144,7 @@ module.exports = async(logger, srf) => {
|
||||
if (srf.locals.regbot.active) {
|
||||
updateCarrierRegbots(logger, srf)
|
||||
.catch((err) => {
|
||||
logger.error({err}, 'updateCarrierRegbots failure');
|
||||
logger.error({ err }, 'updateCarrierRegbots failure');
|
||||
});
|
||||
}
|
||||
|
||||
@@ -138,10 +152,10 @@ module.exports = async(logger, srf) => {
|
||||
};
|
||||
|
||||
const checkStatus = async(logger, srf) => {
|
||||
const {addKeyNx, addKey, retrieveKey} = srf.locals.realtimeDbHelpers;
|
||||
const {myToken, active} = srf.locals.regbot;
|
||||
const { addKeyNx, addKey, retrieveKey } = srf.locals.realtimeDbHelpers;
|
||||
const { myToken, active } = srf.locals.regbot;
|
||||
|
||||
logger.info({active, myToken}, 'checking in on regbot status');
|
||||
logger.info({ active, myToken }, 'checking in on regbot status');
|
||||
try {
|
||||
const token = await retrieveKey(regbotKey);
|
||||
let grabForTheWheel = false;
|
||||
@@ -152,7 +166,7 @@ const checkStatus = async(logger, srf) => {
|
||||
addKey(regbotKey, myToken, REGBOT_STATUS_CHECK_INTERVAL + 10)
|
||||
.then(updateCarrierRegbots.bind(null, logger, srf))
|
||||
.catch((err) => {
|
||||
logger.error({err}, 'updateCarrierRegbots failure');
|
||||
logger.error({ err }, 'updateCarrierRegbots failure');
|
||||
});
|
||||
}
|
||||
else if (token && token !== myToken) {
|
||||
@@ -183,7 +197,7 @@ const checkStatus = async(logger, srf) => {
|
||||
logger.info(`successfully claimed regbot responsibility with token ${myToken}`);
|
||||
updateCarrierRegbots(logger, srf)
|
||||
.catch((err) => {
|
||||
logger.error({err}, 'updateCarrierRegbots failure');
|
||||
logger.error({ err }, 'updateCarrierRegbots failure');
|
||||
});
|
||||
}
|
||||
else {
|
||||
@@ -192,7 +206,7 @@ const checkStatus = async(logger, srf) => {
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
logger.error({err}, 'checkStatus: ERROR');
|
||||
logger.error({ err }, 'checkStatus: ERROR');
|
||||
}
|
||||
};
|
||||
|
||||
@@ -238,6 +252,7 @@ const updateCarrierRegbots = async(logger, srf) => {
|
||||
// start new regbots
|
||||
for (const gw of gateways) {
|
||||
const rb = new Regbot(logger, {
|
||||
voip_carrier_sid: gw.carrier.voip_carrier_sid,
|
||||
ipv4: gw.ipv4,
|
||||
port: gw.port,
|
||||
username: gw.carrier.register_username,
|
||||
|
||||
18
package-lock.json
generated
18
package-lock.json
generated
@@ -9,7 +9,7 @@
|
||||
"version": "0.8.1",
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@jambonz/db-helpers": "^0.7.3",
|
||||
"@jambonz/db-helpers": "^0.7.5",
|
||||
"@jambonz/http-authenticator": "^0.2.2",
|
||||
"@jambonz/mw-registrar": "^0.2.3",
|
||||
"@jambonz/realtimedb-helpers": "^0.4.34",
|
||||
@@ -711,12 +711,12 @@
|
||||
}
|
||||
},
|
||||
"node_modules/@jambonz/db-helpers": {
|
||||
"version": "0.7.3",
|
||||
"resolved": "https://registry.npmjs.org/@jambonz/db-helpers/-/db-helpers-0.7.3.tgz",
|
||||
"integrity": "sha512-FXQPnl5AGV3P6RhvdSKfjIOdEXShYe7aKJayJjaPARPTCTGqLTDhV2tfsWirCrpQhn+vanJHAiOyzOTmbDIfzA==",
|
||||
"version": "0.7.5",
|
||||
"resolved": "https://registry.npmjs.org/@jambonz/db-helpers/-/db-helpers-0.7.5.tgz",
|
||||
"integrity": "sha512-Zqq4LSsW76VxQiqXMGeVCkSqXCNwUyLN86PD0ejWQO5x+pA2GaBhLX+SHTdCiHhQ3t29SCyOoSi5MJ96LZwI4w==",
|
||||
"dependencies": {
|
||||
"cidr-matcher": "^2.1.1",
|
||||
"debug": "^4.3.3",
|
||||
"debug": "^4.3.4",
|
||||
"mysql2": "^2.3.3",
|
||||
"node-object-hash": "^2.3.10",
|
||||
"uuid": "^8.3.2"
|
||||
@@ -5913,12 +5913,12 @@
|
||||
"dev": true
|
||||
},
|
||||
"@jambonz/db-helpers": {
|
||||
"version": "0.7.3",
|
||||
"resolved": "https://registry.npmjs.org/@jambonz/db-helpers/-/db-helpers-0.7.3.tgz",
|
||||
"integrity": "sha512-FXQPnl5AGV3P6RhvdSKfjIOdEXShYe7aKJayJjaPARPTCTGqLTDhV2tfsWirCrpQhn+vanJHAiOyzOTmbDIfzA==",
|
||||
"version": "0.7.5",
|
||||
"resolved": "https://registry.npmjs.org/@jambonz/db-helpers/-/db-helpers-0.7.5.tgz",
|
||||
"integrity": "sha512-Zqq4LSsW76VxQiqXMGeVCkSqXCNwUyLN86PD0ejWQO5x+pA2GaBhLX+SHTdCiHhQ3t29SCyOoSi5MJ96LZwI4w==",
|
||||
"requires": {
|
||||
"cidr-matcher": "^2.1.1",
|
||||
"debug": "^4.3.3",
|
||||
"debug": "^4.3.4",
|
||||
"mysql2": "^2.3.3",
|
||||
"node-object-hash": "^2.3.10",
|
||||
"uuid": "^8.3.2"
|
||||
|
||||
@@ -27,7 +27,7 @@
|
||||
},
|
||||
"homepage": "https://github.com/xquanluu/sbc-outbound-handler#readme",
|
||||
"dependencies": {
|
||||
"@jambonz/db-helpers": "^0.7.3",
|
||||
"@jambonz/db-helpers": "^0.7.5",
|
||||
"@jambonz/http-authenticator": "^0.2.2",
|
||||
"@jambonz/mw-registrar": "^0.2.3",
|
||||
"@jambonz/realtimedb-helpers": "^0.4.34",
|
||||
|
||||
Reference in New Issue
Block a user