Merge dev to main #1
76
index.js
76
index.js
|
|
@ -21,20 +21,78 @@ const cfTypes = {
|
|||
CFU: "Unavailable",
|
||||
}
|
||||
|
||||
sock.on('event', async (event) => {
|
||||
console.log(event)
|
||||
})
|
||||
const main = () => {
|
||||
var respData = [];
|
||||
|
||||
const startup = async () => {
|
||||
sock.connect().then(() => {
|
||||
console.log(sock.amiVersion)
|
||||
// getList for CF, CFB, CFU
|
||||
sock.getList({
|
||||
action: 'DBGetTree',
|
||||
family: 'CF'
|
||||
}).then(async (response) => {
|
||||
console.log(response)
|
||||
})
|
||||
})
|
||||
// Responses are an array of objects. The first should always have eventlist: 'start', and last should have eventlist: 'complete'. Remove these, make an array of objects {key, val} based on the rest of the response objects.
|
||||
let entries = response.filter(r => r.eventlist !== 'start' && r.eventlist !== 'complete').map(r => ({ key: r.key, val: r.val }));
|
||||
for (let entry of entries) {
|
||||
let [type, ext] = entry.key.split('/');
|
||||
if (cfTypes[type]) {
|
||||
respData.push({
|
||||
extension: ext,
|
||||
type: type,
|
||||
target: entry.val
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
}).then(() => {
|
||||
sock.getList({
|
||||
action: 'DBGetTree',
|
||||
family: 'CFB'
|
||||
}).then(async (response) => {
|
||||
let entries = response.filter(r => r.eventlist !== 'start' && r.eventlist !== 'complete').map(r => ({ key: r.key, val: r.val }));
|
||||
for (let entry of entries) {
|
||||
let [type, ext] = entry.key.split('/');
|
||||
if (cfTypes[type]) {
|
||||
respData.push({
|
||||
extension: ext,
|
||||
type: type,
|
||||
target: entry.val
|
||||
});
|
||||
}
|
||||
}
|
||||
}).then(() => {
|
||||
sock.getList({
|
||||
action: 'DBGetTree',
|
||||
family: 'CFU'
|
||||
}).then(async (response) => {
|
||||
let entries = response.filter(r => r.eventlist !== 'start' && r.eventlist !== 'complete').map(r => ({ key: r.key, val: r.val }));
|
||||
for (let entry of entries) {
|
||||
let [type, ext] = entry.key.split('/');
|
||||
if (cfTypes[type]) {
|
||||
respData.push({
|
||||
extension: ext,
|
||||
type: type,
|
||||
target: entry.val
|
||||
});
|
||||
}
|
||||
}
|
||||
}).then(() => {
|
||||
console.log(`Found ${respData.length} call forwards.`);
|
||||
for (let cf of respData) {
|
||||
console.log(`Extension ${cf.extension} has ${cfTypes[cf.type]} call forward to ${cf.target}`);
|
||||
}
|
||||
setTimeout(main, 60000); // Repeat every 60 seconds
|
||||
});
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
const startup = async () => {
|
||||
sock.connect().then(() => {
|
||||
console.log(sock.amiVersion)
|
||||
main();
|
||||
}).catch((err) => {
|
||||
console.error('Error connecting to AMI:', err);
|
||||
setTimeout(startup, 10000); // Retry after 10 seconds
|
||||
});
|
||||
}
|
||||
|
||||
startup();
|
||||
Loading…
Reference in a new issue