THE PJPROJECT
Introduction
The PJPROJECT is a free and open source multimedia communication library written in C language implementing standard based protocols such as SIP, SDP, RTP, STUN, TURN, and ICE. It combines signaling protocol (SIP) with rich multimedia framework and NAT traversal functionality into high level API that is portable and suitable for almost any type of systems ranging from desktops, embedded systems, to mobile handsets.
Contents
- Rust bindings for pjsua
- Pip-installable pjsua2 python module
- Installing pjsip on Debian
- Pjsua usage examples in
c
andrust
- Pjsua2 usage examples in
c++
andpython3
- A ready to use docker image with pjsua and pjsua2 installed
- A ready to use docker image with a dev
kamailio
sip server
Dependencies
- For the Installation of pjsip on Debian, you need to install
gcc
,g++
andmake
sudo apt install -y gcc g++ make
- For generating the rust bindings for pjsau, you need to install
rust
andclang
sudo apt install -y curl clang
sudo curl https://sh.rustup.rs -sSf | sh -s -- -y
- For building the pjsua2 python module, you need to install
python3
,python3-dev
andswig
sudo apt install -y swig python3 python3-dev
Installing pjsip on Debian
- Navigate to pjproject directory
cd pjproject
- Configure the build
./configure --enable-shared
- Build the project
make dep
make
- Install the project
sudo make install
Installing pjsua2 python module
- Navigate to pjsua2 swig python directory
cd pjproject/pjsip-apps/src/swig/python
- Build the module
make
- Install the module
make install
Installing pjsua2 python module using pip
sudo pip3 install git+https://github.com/JadKHaddad/THE-PJPROJECT.git --verbose
Running the examples
- C
cd c
make
./out
make clean
- C++
cd cpp
make
./out
make clean
- Rust
cd rust
cargo run
cargo clean
- Python3
cd python3
python3 main.py
Libraries not found?
- Set the environment variable
LD_LIBRARY_PATH
to the directory where the libraries are located
export LD_LIBRARY_PATH=/usr/local/lib
Don't know where the libraries are located?
- Run the following command to collect your libraries and headers
chmod u+x ./copy-lib-include.sh
./copy-lib-include.sh
- Now you can set the environment variable
LD_LIBRARY_PATH
to the directory where the libraries are located
Don't have a sip server or Debian?
- Create a docker network
docker network create net
- Build and run the kamailio docker image
docker build -t kamailio5.5.0-trusty -f dockerfiles/Dockerfile.kamailio .
docker run -it --rm --name kamailio5.5.0-trusty --network net -p 5060:5060/udp kamailio5.5.0-trusty
- Build and run the debian docker image
docker build -t pjsip -f dockerfiles/Dockerfile.debian .
docker run -it --rm --name pjsip --network net --add-host=host.docker.internal:host-gateway pjsip
- Inside the pjsip container, run the examples using
kamailio5.5.0-trusty:5060
as a sip domain
References
Notes
- pjproject cloned from the official repository on 2022-09-22
PJSUA_MAX_CALLS
,PJSUA_MAX_ACC
,PJSUA_MAX_PLAYERS
andPJSUA_MAX_RECORDERS
are set inpjproject/pjsip/include/pjsua-lib/pjsua.h
to32
. You can change them to any value less than 32 to save memory.PJ_IOQUEUE_MAX_HANDLES
is set inpjproject/pjlib/include/pj/config.h
to128
.RTP_RETRY
is set inpjproject/pjsip/src/pjsua-lib/pjsua_media.c
to10000
to try bind to5000
ports when establishing calls.- You have to recompile the project after changing any value.