SIP (Session Initiation Protocol) is the IETF (Internet Engineering Task Force) signaling standard for managing multimedia session initiation defined in RFC 3261 commonly used in VOIP communication. SIP can be used to initiate voice, video and multimedia sessions, for both interactive applications (e.g. an VOIP phone calls or a video conference applications) and non-interactive ones (e.g. video streaming).
The mjSIP stack has been used in research activities by Dept. of Engineering and Architecture at University of Parma and by DIE - University of Roma "Tor Vergata" and several commercial products.
mjSIP includes all classes and methods for creating SIP-based applications. It implements the complete layered stack architecture as defined in RFC 3261 (Transport, Transaction, and Dialog layers), and is fully compliant with RFC 3261 and successive standard RFCs. Moreover it includes higher level interfaces for Call Control and User Agent implementations. mjSIP comes with a core package implementation that includes:
- all standard SIP layers and components,
- various SIP extensions (already defined within IETF),
- some useful call control APIs (e.g. Call-Control, UserAgent, etc.),
- a reference implementation of some SIP systems (Proxy Server, Session Border Controlleer, and User Agent).
You can import this library through a Maven dependency to your own project. Since it is not distributed to MavenCentral, you have to add a custom repository section:
<repositories>
<repository>
<id>github</id>
<name>GitHub haumacher/mjSIP Apache Maven Packages</name>
<url>https://maven.pkg.github.com/haumacher/mjSIP</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
Then you can import the modules with the following dependency:
The client part (user-agent) to initiate calls:
<dependency>
<groupId>org.mjsip</groupId>
<artifactId>mjsip-ua</artifactId>
<version>2.0.0</version>
</dependency>
The server part to implement VOIP servers:
<dependency>
<groupId>org.mjsip</groupId>
<artifactId>mjsip-server</artifactId>
<version>2.0.0</version>
</dependency>
Note that the GitHub hosted repositories require authentication (no anonymous download as from Maven-Central).
Therefore, you need to provide your GitHub access token in the Maven settings to make the download work (in ~/.m2/settings.xml
):
<servers>
<server>
<id>github</id>
<username>YOUR_USERNAME</username>
<password>YOUR_AUTH_TOKEN</password>
</server>
</servers>
The library consists of the following modules, which can also be imported separately:
- mjsip-examples
- mjsip-net
- mjsip-phone
- mjsip-server
- mjsip-sip
- mjsip-sound
- mjsip-ua
- mjsip-util
To get an idea how to start, you can have a look into the examples module.
This library was forked from version 1.8 distributed at http://mjsip.org/. Since this fork, the following changes were made:
- Added Maven build.
- Split source into core modules
sip
,server
,ua
, and supporting modulesnet
,sound
, andutil
. Extracted examples into modulesexamples
andphone
. - Code cleanup: Added type parameter, added override annotations, reduced excessive logging, made fields private final
where possible, removed mutable static fields, replaced lazy initialization with defined initialization order, reduced
number of constructors, use Java resource management "try-with-resources" and
AutoClosable
, enhanced configuration file parsing withargs4j
, applied Java naming conventions, encapsulated fields. Access configuration from production code through read-only interfaces. Reduction of legacy Java APIs such asVector
andStringBuffer
. Added Junit5 tests. - Replaced self-made logging with
slf4j
overtinylog
. - Clarified transaction timeout handling with separate handler methods for each timeout.
- Modernized scheduling using ScheduledThreadPoolExecutor.
- Implemented listening on
DTMF
info messages. - Implemented port pool for
RTP
media streams. - Fixed parsing of
SDP
messages with well-known formats that are not explained inrtpmap
fields. - Separated creation of concrete media streams from user agent handling. Removed audio file configuration (for steaming and recording) from core components.
- Pulled out system audio sounds played when calls are incoming, accepted, or terminated to client code.
- Added audio filter for silence stripping.
- Added IPv6 support.
- Added Java module support.
mjSIP is available open source under the terms of the GNU GPL license (General Public Licence) as published by the Free Software Foundation.
The project's original home page is at: http://mjsip.org/
There are several independent forks of the project on Github:
- https://github.com/mjsip/mjSIP - A new release (1.9) from the original author published to GitHub after this fork was created. Unfortunatelly not very responsive.
- https://github.com/VovaSokol/mjsip (1.8) - Added support for Opus and H264 codec.
- https://github.com/mrichardsdb/mjsip (1.8) - Turned into a maven project.
- https://github.com/inckie/mjsip (1.8)
- https://github.com/opentelecoms-org/MjSIP-fork (1.6)
- https://github.com/moki80/OpenComm/tree/master/sipvoip