Table of Contents
List of Tables
List of Examples
This module can be used to efficiently run Python code directly from the OpenSIPS script, without executing the python interpreter.
The module provides the means to load a python module and run its functions. Each function has to receive the SIP message as parameter, and optionally some extra arguments passed from the script.
In order to run Python functions, one has to load the module that contains them, by specifying the script name using the script_name parameter. The module has to contain the following components:
A class that contains all the methods that can be invoked from the script.
A method within the class that is called when a SIP child is created. The method should receive an integer parameter, which represents the rank of the child, and must return 0 or positive in case the function was executed successfully, or negative otherwise. The name of this method is specified by the child_init_method parameter.
A global function that initializes the Python module and returns an object from the class whose functions will be invoked by the script. The name of the global function is indicated by the mod_init_method parameter.
A minimal example of a Python script that satisfies these requirements is:
def mod_init(): return SIPMsg() class SIPMsg: def child_init(self, rank): return 0
A function from the object returned above can be executed from the script using the python_exec() script function. The python method has to receive the following parameters:
The SIP message, that has the structure detailed below
Optionally, a string passed from the script
The SIP message received as parameter by the function has the following fields and methods:
Type - the type of the message, either SIP_REQUEST or SIP_REPLY
Method - the method of the message
Status - the status of the message, available only for replies
RURI - the R-URI of the message, available only for requests
src_address - the (IP, port) tuple representing source address of the message
dst_address - the (IP, port) tuple representing the destination address (OpenSIPS address) of the message
copy() - copies the current SIP message in a new object
rewrite_ruri() - changes the R-URI of the message; available only for requests
set_dst_uri() - sets the destination URI of the message; available only for requests
getHeader() - returns the header of a message the destination address (OpenSIPS address) of the message
call_function() - calls a function from the script
The script that contains the Python module.
Default value is “/usr/local/etc/opensips/handler.py”.
Example 1.1. Set
... modparam("python", "script_name", "/usr/local/bin/opensips_handler.py") ...
The method used to initialize the Python module and return the object.
Default value is “mod_init”.
Example 1.2. Set
... modparam("python", "mod_init_function", "module_initializer") ...
Thhis function is used to execute a method from the Python module loaded.
This function can be used from REQUEST_ROUTE, ONREPLY_ROUTE, FAILURE_ROUTE and BRANCH_ROUTE.
Meaning of the parameters is as follows:
method_name (string) - name of the method called
extra_args (string, optional) - extra arguments that can be passed from the script to the python function.
Table 2.1. Top contributors by DevScore(1), authored commits(2) and lines added/removed(3)
(1) DevScore = author_commits + author_lines_added / (project_lines_added / project_commits) + author_lines_deleted / (project_lines_deleted / project_commits)
(2) including any documentation-related commits, excluding merge commits. Regarding imported patches/code, we do our best to count the work on behalf of the proper owner, as per the "fix_authors" and "mod_renames" arrays in opensips/doc/build-contrib.sh. If you identify any patches/commits which do not get properly attributed to you, please submit a pull request which extends "fix_authors" and/or "mod_renames".
(3) ignoring whitespace edits, renamed files and auto-generated files
Table 2.2. Most recently active contributors(1) to this module
|1.||Liviu Chircu (@liviuchircu)||Jul 2014 - Jan 2020|
|2.||Vlad Patrascu (@rvlad-patrascu)||May 2017 - Nov 2019|
|3.||Peter Lemenkov (@lemenkov)||Jun 2018 - Oct 2019|
|4.||Razvan Crainea (@razvancrainea)||Mar 2015 - Oct 2019|
|5.||Bogdan-Andrei Iancu (@bogdan-iancu)||Oct 2014 - Apr 2019|
|6.||Maksym Sobolyev (@sobomax)||Dec 2009 - Feb 2017|
(1) including any documentation-related commits, excluding merge commits
Copyright © 2009 Sippy Software, Inc.