// site config
const remoteAudio = document.getElementById("audio");
let session; // the active session needs to be stored somewhere to be accessible by the handlers.
// global config, same for all agents for this client
const teleforgePbxAddress = "<????>.forge-cloud.com";
// per agent config, each agent has their own credentials
const agentExtension = "9000";
const agentExtensionPass = "supersecret";
const agentDisplayName = "0120001234"; // either a CLID or a name, it's not used but does add some additional info.
// demo
example,
you will provide this yourself in some way.
const destination = "0820001234";
// Creates the user agent
const userAgent = new SIP.UA({
uri: agentExtension + "@" + teleforgePbxAddress,
authorizationUser: agentExtension,
password: agentExtensionPass,
displayName: agentDisplayName,
transportOptions: {
wsServers: ["wss://" + teleforgePbxAddress + ":8089/ws"]
},
//hackIpInContact: true, // may or may not be needed, try without first.
register: true,
sessionDescriptionHandlerFactoryOptions: {
constraints: {
audio: true,
video: false
}
},
});
userAgent.on("registrationFailed", function (response, cause) {
// Normally either bad user credentials or PBX issues, if the latter then mail support@teleforge.co.za
console.error("registrationFailed cause", cause);
console.error("registrationFailed response", response);
});
userAgent.on("registered", function (response, cause) {
// credentials are good
console.info("registered");
});
userAgent.on("unregistered", function (response, cause) {
// not normally a problem but could indicate one.
console.warn("unregistered cause", cause);
console.warn("unregistered response", response);
});
function onFailedCall(request) {
//http://sipjs.com/api/0.11.0/causes/
console.error("Call Failed");
//We send back special error messages for validation errors.
const validationErrors = request.getHeaders("X-Platforma-Error");
if (0 < validationErrors.length) {
validationErrors.forEach(function(error) {
console.error("Validation Error: ", error);
});
}
}
function onIncomingCall(session) {
const confirmation = confirm("Incoming call from " + session.remoteIdentity.displayName);
if (confirmation) {
session.accept();
} else {
session.reject();
}
}
function handleMedia(session) {
const pc = session.sessionDescriptionHandler.peerConnection;
const remoteStream = new MediaStream();
pc.getReceivers().forEach(function(receiver) {
remoteStream.addTrack(receiver.track);
});
remoteAudio.srcObject = remoteStream;
remoteAudio.play();
}
// Listen for the invite: inbound calls
userAgent.on("invite", onIncomingCall);function makeOutboundCall() {
// Outbound API Call options
const outboundOptions = {
extraHeaders : [
"X-Platforma-Outbound-ID: 27101100729<outbound_id>",
"X-Platforma-Contact-Ref: test<custom_refcall_123ref>"
] };
// UI const makeButton = document.getElementById("makeCall");
const endButton = document.getElementById("endCall");
makeButton.addEventListener("click", function() {]
};
session = userAgent.invite("sip:" + destination<callee> + "@" + teleforgePbxAddress, outboundOptions);
// Error while placing a call
session.on("failed", onFailedCall);
session.on("trackAdded", function() {
handleMedia(session);
});
console.info("Call started");
console.debug("session:" + session);
});
endButton.addEventListener("click", function
function hangupCall() {
session.bye();
session = null;
remoteAudio.srcObject = null;
console.info("Hangup Call...");
}
// Listen for the invite: inbound calls
userAgent.on("invite", onIncomingCall);
// UI
const makeButton = document.getElementById("makeCall");
const endButton = document.getElementById("endCall");
makeButton.addEventListener("click", makeOutboundCall);
endButton.addEventListener("click", hangupCall, false); |