You are viewing an old version of this page. View the current version.
Compare with Current
View Page History
Version 1
Next »
Problem
You want to use WebRTC to integrate into the Teleforge PBX, but since SIP.js 0.8 the APi has become a lot harder to use, how do we handle it?
Solution
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="sip-0.11.2.js"></script>
<script src="basic_webrtc.js"></script>
</style></head>
<body cz-shortcut-listen="true">
<audio autoplay="autoplay" id="audio"></audio>
<div>
<button id="makeCall">Make call</button>
<button id="endCall">End call</button>
</div>
</body>
</html>
// 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"],
traceSip: true
},
log: { level: "debug" },
//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;
// Gets remote tracks
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);
// Call options
const outboundOptions = {
extraHeaders : [
"X-Platforma-Outbound-ID: 27101100729",
"X-Platforma-Contact-Ref: test_ref_123"
]
};
// UI
// Outbound call:
const makeButton = document.getElementById("makeCall");
const endButton = document.getElementById("endCall");
makeButton.addEventListener("click", function() {
session = userAgent.invite("sip:" + destination + "@" + 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() {
session.bye();
session = null;
remoteAudio.srcObject = null;
console.info("Hangup Call...");
}, false);
- use the latest 0.11.x SIP.js (newer should be supported)
- ensure you create the UserAgent with the defined parameters
- ensure you handle the media as shown.
Related articles
-
Page:
-
Page:
-
Page:
-
Page:
-
Page: