1cabda64e2
The DTMF transmission for bridged calls has been problematic for some time now, particularly when the setting "bypass_media_after_bridge=true" is used. This issue arises when the destination PBX utilizes a different PT value for RFC2833 than what is configured in the sofia profile. To address this challenge, we have implemented a workaround that involves parsing the PT from the switch_r_sdp on the A leg and using a profile with the same value set as rfc2833-pt. For example, if the PT value is 101 on the A-Leg, we use the profile "sofia/outbound101", and if it is 103, we use "sofia/outbound103". This workaround has effectively resolved our DTMF transmission issues. However, this solution requires extensive configuration and coding on our end, which some customers may not find favorable. Additionally, each profile must utilize a different source UDP Port, further complicating the matter. It would be beneficial if there was a channel variable for "rtp_2833_payload" that takes precedence over the profile setting when it is set. |
||
---|---|---|
.github | ||
build | ||
clients/flex | ||
cmake_modules | ||
conf | ||
debian | ||
docker | ||
docs | ||
dtd | ||
fonts | ||
fscomm | ||
htdocs | ||
images | ||
libs | ||
scripts | ||
src | ||
support-d | ||
tests/unit | ||
w32 | ||
web | ||
yum | ||
.clang-format | ||
.drone.yml | ||
.gitattributes | ||
.gitconfig | ||
.gitignore | ||
.mailmap | ||
Freeswitch.2017.sln | ||
Freeswitch.2017.sln.bat | ||
INSTALL | ||
LICENSE | ||
Makefile.am | ||
README.md | ||
SECURITY.md | ||
acinclude.m4 | ||
bootstrap.sh | ||
cc.sh | ||
cluecon.tmpl | ||
cluecon2.tmpl | ||
cluecon2_small.tmpl | ||
cluecon_small.tmpl | ||
configure.ac | ||
devel-bootstrap.sh | ||
freeswitch-config-rayo.spec | ||
freeswitch-sounds-en-ca-june.spec | ||
freeswitch-sounds-en-us-allison.spec | ||
freeswitch-sounds-en-us-callie.spec | ||
freeswitch-sounds-fr-ca-june.spec | ||
freeswitch-sounds-music.spec | ||
freeswitch-sounds-pt-BR-karina.spec | ||
freeswitch-sounds-ru-RU-elena.spec | ||
freeswitch-sounds-sv-se-jakob.spec | ||
freeswitch.spec | ||
msbuild.cmd | ||
swig_common.i |
README.md
FreeSWITCH
FreeSWITCH is a Software Defined Telecom Stack enabling the digital transformation from proprietary telecom switches to a versatile software implementation that runs on any commodity hardware. From a Raspberry PI to a multi-core server, FreeSWITCH can unlock the telecommunications potential of any device. Combined with our hosted cloud platform, SignalWire, FreeSWITCH can interconnect with the outside world and scale to any size.
Visit https://signalwire.com or https://github.com/signalwire for more info.
Getting Started
FreeSWITCH is available on Github in source code format. You can checkout the development branch and build for many popular platforms including Linux, Windows, MacOSX and BSD. There is an issue tracker and pull request system available as part of the repo online.
See https://developer.signalwire.com/freeswitch/FreeSWITCH-Explained/ for more detailed instructions.
Additional Help
If you need assistance or have an interest in using a commercially supported build, you can contact coreteam@freeswitch.com to learn about professional services to support your project.
Voice-over-IP services - SIP / SMS - App Integrations
SignalWire is the primary sponsor of the FreeSWITCH project and was founded by the original developers of FreeSWITCH. SignalWire provides scalable services to enhance and scale your project such as SMS, SIP, Serverless Application hosting as well as programmable telecom. mod_signalwire which is distributed in this code base allows you to instantly pair with SignalWire and extend your FreeSWITCH.
Documentation
The main index for documentation is available at:
Release notes:
Install from packages
Step by step tutorials to install FreeSWITCH from packages:
- Debian [Recommended]
- Raspberry Pi
- CentOS 7
Build from source
Example Dockerfiles to build FreeSWITCH and dependencies from source:
Step by step tutorials to build FreeSWITCH with provided dependency packages:
- Debian [Recommended]
- Raspberry Pi
- CentOS 7
Downloads
Contributions
GitHub pull requests are the recommended way to contribute to the FreeSWITCH source code:
Community
Slack is our chat system where the developers, the FreeSWITCH team, and the most active users are present. This is the place to get answers faster and chat with other users in real time. All you need to do is enter your email and verify it on the Slack signup page and you are ready to join in the discussion!
Slack Community:
Mailing list (ARCHIVED):
Thank you for using FreeSWITCH!