A python library for Collecting RTCP-XR (RFC 3611) SIP quality packets
Project description
rtcpxr_collector
A python library for Collecting RTCP-XR (RFC 3611) SIP quality packets
Predecessor
Much thank to the project at: https://github.com/pbertera/vq-collector The core concepts and processing core were taken from there. Most code has been refactored and stripped down.
Basic usage
This is meant to be part of a larger project (hence a library.) I highly suggest you configure your phones to send to your collector with the "name" set to the mac address of the handset. This is the only way to uniquely identify a handset (that I've found at least.)
To run the code with all the defaults:
#!/usr/bin/python3
from rtcpxr_collector import vqcollector
vqs = vqcollector.CollectorServer()
vqs.listen()
Generally you will use a custom handler, so here's an example:
#!/usr/bin/python3
import datetime
from rtcpxr_collector import vqcollector
def logHandler(r):
print("%s %s %s CQ:%s LQ:%s Local:%s Remote:%s"%(datetime.datetime.now(),
r['Handset']['MAC'],
r['CallID'],
r['QualityEst']['MOSCQ'],
r['QualityEst']['MOSLQ'],
"%s %s"%(r['LocalID']['name'],r['LocalID']['desc']),
"%s %s"%(r['RemoteID']['name'],r['RemoteID']['desc']) ))
return True
vqs = vqcollector.CollectorServer(handler=logHandler)
vqs.listen()
Maybe you want to run on a non-stadard IP or port:
#!/usr/bin/python3
from rtcpxr_collector import vqcollector
vqs = vqcollector.CollectorServer(local_ip=10.10.10.15, port=5061)
vqs.listen()
All the options
The CollectorServer object opens a SIP socket to receive RTCP-XR packets,
parses them, then sends the data to a handler.
Attributes:
local_ip (ipV4 address): [None] Local IPV4 address to bind to (None: Autodetect)
port (int) : [5060] Local Port to bind to
reply_to_socket (bool) : [False] Should we reply to the address from the socket, or the SIP Header
debug (bool) : [False] Print Debugging information
handler (func) : [None] Handler function for recieved data (None: pprint res data)
timeout (int) : [10] Select Timeout in seconds
timeout_handler (func) : [None] Handler for select timeout event
Handler Function:
Takes 1 arg that is the parsed data structure.
Returns: Send Response Packet? True or False
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file rtcpxr_collector-0.1.7.tar.gz
.
File metadata
- Download URL: rtcpxr_collector-0.1.7.tar.gz
- Upload date:
- Size: 19.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.22.0 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d595356352c34e44ce7ebd0222929865e16d420564d1458640b86ac58253904b |
|
MD5 | ccbab4d6e08a5ea5e889fa904f1d8a92 |
|
BLAKE2b-256 | 41a9de2ae4b28af533ea8af2fa9955ff6c51a64fe2cee58397f281dfbf061601 |
File details
Details for the file rtcpxr_collector-0.1.7-py3-none-any.whl
.
File metadata
- Download URL: rtcpxr_collector-0.1.7-py3-none-any.whl
- Upload date:
- Size: 19.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.22.0 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e7017bfc6e54c4bd076e274ca8b982ed94a43c8ef5fce4bb472d8ee73e4fa848 |
|
MD5 | ec4b7660736d7c32bd31989f15f4c562 |
|
BLAKE2b-256 | 4a579f9cd4aa4a7381ec71f1dc7bfce0a09e70b1b7efe3d0d2e625014693312e |