features:new-in-5.4.x
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
features:new-in-5.4.x [2020/07/09 08:56] – update new for 5.4.x doc henningw | features:new-in-5.4.x [2020/07/09 12:00] (current) – henningw | ||
---|---|---|---|
Line 7: | Line 7: | ||
<fc # | <fc # | ||
+ | |||
+ | ===== Documentation ===== | ||
+ | |||
+ | Many fixes were done to the modules, missing parameter were added, wrong parameter or function names fixed and explanation or clarifications added. Furthermore many debug messages in the core and modules were extended, to help analyzing problems or bugs. The full details can be found in the release Changelog or with the "git log" command. | ||
+ | |||
+ | ===== Bugfixes ===== | ||
+ | |||
+ | Countless bugfixes were implemented for this release in core, tools and modules. Furthermore the code base was scanned with several static analyzers, to detect otherwise hard to find bugs. The full details can be found in the release Changelog or with the "git log" command. | ||
===== New Modules ===== | ===== New Modules ===== | ||
Line 24: | Line 32: | ||
==== secsipid ==== | ==== secsipid ==== | ||
- | * new module implementing STIR and SKAKEN | + | * new module implementing STIR and SHAKEN |
==== systemdops ==== | ==== systemdops ==== | ||
Line 31: | Line 39: | ||
* https:// | * https:// | ||
+ | |||
+ | ==== dlgs ==== | ||
+ | |||
+ | New module to enable lightwight, stateless dialog tracking and statistics | ||
+ | |||
+ | * https:// | ||
===== New in existing Modules ===== | ===== New in existing Modules ===== | ||
Line 37: | Line 51: | ||
* adding CDR engine functionality, | * adding CDR engine functionality, | ||
+ | * new skip_cdr modparam to prevent cdr generation for certain calls | ||
+ | |||
+ | ==== auth_db ==== | ||
+ | |||
+ | * add force_generate_avps parameter, to fetch DB attributes even when authentication failed | ||
==== avpops ==== | ==== avpops ==== | ||
- | * add avp_subst_pv(), | + | * add avp_subst_pv(), |
+ | * export avp_check and avp_copy functions to KEMI | ||
+ | |||
+ | ==== app_python ==== | ||
+ | |||
+ | * update Python3 detection mechanism | ||
+ | |||
+ | ==== app_lua ==== | ||
+ | |||
+ | * add support for ARRAY and DICT types | ||
==== app_ruby ==== | ==== app_ruby ==== | ||
* option to use internal KSR::PV module and skip returning xval str, controlled with the xval_mode parameter | * option to use internal KSR::PV module and skip returning xval str, controlled with the xval_mode parameter | ||
+ | |||
+ | ==== app_jsdt ==== | ||
+ | |||
+ | * internal duktape interpreter upgraded to v2.5.0 | ||
==== acc_json ==== | ==== acc_json ==== | ||
Line 57: | Line 89: | ||
==== carrierroute ==== | ==== carrierroute ==== | ||
- | * organize and add new rpc commands, cr.add_host, | + | * organize and add new RPC commands, cr.add_host, |
+ | * remove obselete FIFO commands implementation | ||
+ | |||
+ | ==== cdt ==== | ||
+ | |||
+ | * better compatiblity with certain Diameter servers that lacks Supported-Vendor-Id in their reply | ||
==== cfgt ==== | ==== cfgt ==== | ||
Line 66: | Line 103: | ||
* https:// | * https:// | ||
* switch from deprecated /var/run to /run | * switch from deprecated /var/run to /run | ||
+ | |||
+ | ==== corex ==== | ||
+ | |||
+ | * add functions to set socket by name | ||
+ | * new function is_faked_msg() | ||
+ | * new param dns_cache to add values to the internal dns cache | ||
+ | * export file read/write functions to kemi | ||
==== ctl ==== | ==== ctl ==== | ||
* switch from deprecated /var/run to /run | * switch from deprecated /var/run to /run | ||
+ | |||
+ | ==== crypto ==== | ||
+ | |||
+ | * add event route to allow encrypting/ | ||
+ | |||
+ | ==== drouting ==== | ||
+ | |||
+ | * update to new keepalive interface, using custom pinging interval per destination | ||
+ | |||
+ | ==== db_cluster ==== | ||
+ | |||
+ | * support for insert_async DB API | ||
==== db_mysql ==== | ==== db_mysql ==== | ||
* switch from deprecated /var/run to /run | * switch from deprecated /var/run to /run | ||
+ | * new parameter opt_ssl_mode - allow controling ssl mode, can disable or enforce use of SSL | ||
+ | |||
==== db_redis ==== | ==== db_redis ==== | ||
Line 86: | Line 144: | ||
* option to set add socket as string in the dst xavp | * option to set add socket as string in the dst xavp | ||
* new variable $dsv(...) to access attributes related to response code when executing event routes | * new variable $dsv(...) to access attributes related to response code when executing event routes | ||
+ | * add new parameter ds_default_sockname, | ||
+ | * add new gateway attribute " | ||
+ | * add RPC command dispatcher.hash, | ||
+ | * new RPC command dispatcher.set_duid_state, | ||
+ | * add attrs param to RPC ' | ||
==== dialog ==== | ==== dialog ==== | ||
* adding dlg.set_state command, which can be used e.g. to force the killing of active dialogs | * adding dlg.set_state command, which can be used e.g. to force the killing of active dialogs | ||
- | * dialog: added dlg.briefing | + | * add dlg.briefing |
- | * new dlg_reset_property() function is added to disable the previously enabled dialog module behaviour, e.g. stop sending keep-alive OPTIONS messages | + | * customizable list of fields for dlg.briefing rpc command, it can take an optional parameter to specify what fields to be add |
+ | * new dlg_reset_property() function is add to disable the previously enabled dialog module behaviour, e.g. stop sending keep-alive OPTIONS messages | ||
* export dlg_reset_property() to KEMI | * export dlg_reset_property() to KEMI | ||
+ | * add RCP command dlg.dump, an alternative command to output dialogs data to file, far much faster than dlg.list | ||
+ | |||
+ | ==== dmq ==== | ||
+ | |||
+ | * set 202 response for empty_peer_callback() handling | ||
==== dmq_usrloc ==== | ==== dmq_usrloc ==== | ||
* replicate_socket_info using dmq, useful for anycast scenarios | * replicate_socket_info using dmq, useful for anycast scenarios | ||
+ | * add new parameter `usrloc_delete` to disable synchronizing delete actions | ||
==== htable ==== | ==== htable ==== | ||
* export sht_is_null() function to KEMI | * export sht_is_null() function to KEMI | ||
- | * exported | + | * export |
- | * exported | + | * export |
+ | * new RPC command htable.store, | ||
==== http_client ==== | ==== http_client ==== | ||
Line 116: | Line 187: | ||
* send processed logs via UDP | * send processed logs via UDP | ||
- | ==== pv ==== | + | ==== lost ==== |
- | Added new pseudo-variables: | + | * add civic address parsing via xpath, with fallback to point or circle attributes |
+ | * new module parameters to set HeLD request attributes, parameters are exact_type, response_time, | ||
+ | ==== mqueue ==== | ||
+ | |||
+ | * add support for db persistency | ||
+ | |||
+ | ==== mqtt ==== | ||
+ | |||
+ | * add TLS support | ||
+ | * expose received message QOS level over PV | ||
+ | |||
+ | ==== permissions ==== | ||
+ | |||
+ | * permissions: | ||
+ | |||
+ | ==== path ===== | ||
+ | |||
+ | * new param sockname_mode, | ||
+ | |||
+ | ==== presence ==== | ||
+ | |||
+ | * new parameter pres_subs_mode, | ||
+ | * add delete_same_subs module parameter, to enable deleting of subscriptions with the same presence uri and callid | ||
+ | * timer_mode, new module parameter to control what timer process to use | ||
+ | * add support to keep presentity records in memory instead of DB | ||
+ | * add new parameter publ_cache parameter to define caching mode | ||
+ | * add RCP command presence.presentity_list [mode] to print all attributes of the presentity record | ||
+ | |||
+ | ==== presence_xml ==== | ||
+ | |||
+ | * adds option to aggregate xml body with priorities | ||
+ | |||
+ | ==== pua_dialoginfo ==== | ||
+ | |||
+ | * add missing module parameter include_req_uri | ||
+ | |||
+ | ==== pv ==== | ||
+ | |||
+ | Add new pseudo-variables: | ||
* **[[https:// | * **[[https:// | ||
* **[[https:// | * **[[https:// | ||
Line 125: | Line 234: | ||
* new transformations s.encode.base64t and s.decode.base64t, | * new transformations s.encode.base64t and s.decode.base64t, | ||
* new transformation {s.rmsw} - remove whitespaces from value, removes all occurences of ' ', ' | * new transformation {s.rmsw} - remove whitespaces from value, removes all occurences of ' ', ' | ||
+ | * KEMI functions for $shv(...) management | ||
+ | * export xavp copy variants to KEMI | ||
+ | * export functions for $var(...) management to KEMI | ||
+ | * add transformations for base64-url encode/ | ||
+ | * add config and kemi functions to print xavu vars | ||
+ | * new config variable $fsn - forced send socket name | ||
+ | * add KEMI functions pvx.xavp_get_keys and pvx.xavp_getd | ||
+ | * add $xavi(...) config variables implementation, | ||
+ | * new var $mts, return msg type as string | ||
+ | * add vars to get the length for o-uri/ | ||
- | ==== mqtt ==== | + | ==== p_usrloc |
- | * add TLS support | + | * add matching_mode modparam, to specify the Contact matching |
- | * expose received message QOS level over PV | + | * add a new uniq column to support |
+ | * change " | ||
+ | |||
+ | ==== ratelimit ==== | ||
+ | |||
+ | * increase number of queues and pipes | ||
==== registrar ==== | ==== registrar ==== | ||
- | Added **path** value to xavp_rcd location record | + | Add **path** value to xavp_rcd location record |
* https:// | * https:// | ||
- | Added **xavp_rcd_mask** parameter to control what values to skip | + | Add **xavp_rcd_mask** parameter to control what values to skip |
* https:// | * https:// | ||
* control what values to add to xavp_rcd via xavp_rcd_mask parameter | * control what values to add to xavp_rcd via xavp_rcd_mask parameter | ||
* option to send 423 when expires less than min_expires with the min_expires_mode parameter | * option to send 423 when expires less than min_expires with the min_expires_mode parameter | ||
+ | * add use_expired_contacts config param to allow or disallow the usage of the expired contacts | ||
==== rr ==== | ==== rr ==== | ||
- | * exported | + | * export |
* new function rr_next_hop_route(), | * new function rr_next_hop_route(), | ||
+ | * new param sockname_mode, | ||
+ | * new convenience function loose_route_preloaded() | ||
+ | * export record_route_advertised_address() to KEMI | ||
==== rtpengine ==== | ==== rtpengine ==== | ||
Line 153: | Line 281: | ||
* update/fix via-branch=next ID generation, via-branch=next should not use a hard-coded branch index of zero, but instead use the actual branch index from the tm module | * update/fix via-branch=next ID generation, via-branch=next should not use a hard-coded branch index of zero, but instead use the actual branch index from the tm module | ||
* adds via-branch=auto-next and via-branch=auto-extra for easier processing in scripts | * adds via-branch=auto-next and via-branch=auto-extra for easier processing in scripts | ||
+ | * add support for new T.38 options | ||
+ | * enable handling of PRACK requests | ||
+ | * add kemi support for block/ | ||
==== sdpops ==== | ==== sdpops ==== | ||
- | * exported | + | * export |
+ | |||
+ | ==== siputils ==== | ||
+ | |||
+ | * contact encoding functions export to KEMI | ||
+ | * new function contact_param_rm(" | ||
+ | * new function uri_param_rm(pname), | ||
+ | * new function uri_param_any(param), | ||
+ | |||
+ | |||
+ | ==== sipcapture ==== | ||
+ | |||
+ | * add new capture_bad_msgs modparam, to enable the parsing and capturing of broken SIP messages | ||
==== sipdump ==== | ==== sipdump ==== | ||
Line 164: | Line 307: | ||
* KEMI functions to return buf and tag values | * KEMI functions to return buf and tag values | ||
* KEMI exports to get src/dst ip of the message | * KEMI exports to get src/dst ip of the message | ||
+ | |||
+ | ==== siptrace ==== | ||
+ | |||
+ | * add functionality to duplicate via HEP with any protocol | ||
+ | * the trace_mode can now be used to automatically store traffic to db or mirror via SIP URI | ||
+ | * add parameter trace_init_mode, | ||
+ | * use the send socket also for duplication via SIP | ||
+ | * send_sock_name, | ||
+ | * support for using async-insert to store records to database, new parameter trace_db_mode to control the mode | ||
==== sqlops ==== | ==== sqlops ==== | ||
- | * exported | + | * export |
+ | * add functions to get null result value as empty or zer | ||
+ | |||
+ | ==== textops ==== | ||
+ | |||
+ | * addfunctions to remove or test headers with var parameters | ||
==== tcpops ==== | ==== tcpops ==== | ||
* new variabale $tcp(key), return attributes related to tcp connection | * new variabale $tcp(key), return attributes related to tcp connection | ||
+ | * add function to control use of outbound tcp connection id, tcp_set_otcpid() and tcp_set_otcpid_flag() | ||
==== tm ==== | ==== tm ==== | ||
* add support for dropping messages in local-request event route | * add support for dropping messages in local-request event route | ||
- | * new weight-based call-termination distribution, | + | * new weight-based call-termination distribution, |
+ | * add new t_clean() script function, as low-level helper to cleanup transactions in certain situations, also export it to KEMI | ||
+ | * add support for using socket names in UAC | ||
+ | * new parameter exec_time_check for safety checks on lenghtly callbacks, try to detect when failure callbacks execution take too long and do safety check of the transaction | ||
==== tls ==== | ==== tls ==== | ||
Line 185: | Line 346: | ||
* set default tls method (version) to 1+ | * set default tls method (version) to 1+ | ||
* add verify_client support parameter | * add verify_client support parameter | ||
+ | * add support for urlencoded cert PVs and select, | ||
+ | - new PVs: $tls_peer_raw_cert, | ||
+ | - new selects: @tls.peer.raw_cert, | ||
+ | * add select for tls verified cert chain (requires OpenSSL 1.1+) | ||
+ | * add support to link against static libraries in Makefile | ||
+ | |||
+ | ==== ims_charging ==== | ||
+ | |||
+ | * add support for Application-Provided-Called-Party-Address AVP | ||
+ | * add support for destination_host parameter, implementation was incomplete | ||
+ | |||
+ | ==== ims_usrloc_pcscf ==== | ||
+ | |||
+ | * change " | ||
==== ims_ipsec_pcscf ==== | ==== ims_ipsec_pcscf ==== | ||
Line 214: | Line 389: | ||
==== jsonrpcs ==== | ==== jsonrpcs ==== | ||
- | * KEMI function to get the rpc command | + | * KEMI function to get the RPCcommand |
+ | |||
+ | ==== kazoo ==== | ||
+ | |||
+ | * add basic kemi support | ||
==== keepalive ==== | ==== keepalive ==== | ||
- | * add new function del_destination and added cfg functions | + | * add new function del_destination and add cfg functions |
- | * added keepalive.add, | + | * add keepalive.add, |
+ | * add custom pinging interval per destination | ||
+ | * add early start of OPTIONS checking | ||
==== kex ==== | ==== kex ==== | ||
- | *new rpc command stats.fetchn, | + | *new RPC command stats.fetchn, |
==== kemix ==== | ==== kemix ==== | ||
- | * exported | + | * export |
- | * exported | + | * export |
- | + | * convenience function KS.is_proto() | |
- | ==== presence ==== | + | * export get_conid() function |
- | + | ||
- | * new parameter pres_subs_mode, | + | |
- | + | ||
- | ==== presence_xml ==== | + | |
- | + | ||
- | * adds option | + | |
==== nathelper ==== | ==== nathelper ==== | ||
* add new function set_alias_to_avp | * add new function set_alias_to_avp | ||
+ | * add new parameter nat_addr_mode, | ||
+ | * add optional set_contact_alias([trim]) parameter | ||
==== nat_traversal ==== | ==== nat_traversal ==== | ||
Line 246: | Line 423: | ||
* switch from deprecated /var/run to /run | * switch from deprecated /var/run to /run | ||
* remove redundant str trim implementation and use the one from core | * remove redundant str trim implementation and use the one from core | ||
+ | * new parameter contact_match, | ||
+ | |||
+ | ==== ndb_redis ==== | ||
+ | |||
+ | * add sentinel support to reconnection logic | ||
==== mediaproxy ==== | ==== mediaproxy ==== | ||
Line 256: | Line 438: | ||
* extended use of mode param for uac_reg_request_to(), | * extended use of mode param for uac_reg_request_to(), | ||
* optional param for uac_auth() to specify auth mode, to support password in HA1 format | * optional param for uac_auth() to specify auth mode, to support password in HA1 format | ||
+ | |||
+ | ==== usrloc ==== | ||
+ | |||
+ | * add the ability to send keep alive requests | ||
+ | * add options to do keepalive for natted or udp contacts only, similar to nathelper module | ||
+ | * add internal keepalive support for db only mode | ||
+ | * change " | ||
==== userblacklist ==== | ==== userblacklist ==== | ||
Line 274: | Line 463: | ||
* add two new string handling functions to copy chars and str | * add two new string handling functions to copy chars and str | ||
* internal flag to mark sip request if there is a route for next hop | * internal flag to mark sip request if there is a route for next hop | ||
+ | * add support functions to encode/ | ||
+ | * strutils - add urlencode and urldecode functions | ||
+ | * core parser - new internal flag FL_USE_OTCPID | ||
+ | * new conditional lump types SUBST_RCV_ALL_EX and SUBST_SND_ALL_EX | ||
+ | * functions for light comparison of uri values | ||
==== Command line arguments ==== | ==== Command line arguments ==== | ||
- | * new command line parameter | + | * add --loadmodule=name, |
- | * new command line parameter | + | * add --modparam, to allow setting a module parameter via command line |
- | * new command line parameter | + | * add --log-engine, |
+ | * add --debug=val command line parameter to control the value for debug global parameter as alternative to -d switch | ||
==== Interpreter ==== | ==== Interpreter ==== | ||
Line 295: | Line 491: | ||
==== Architecture ==== | ==== Architecture ==== | ||
- | * added internal cryptographic algorithm implementation (MD5, SHA, AES, Fortuna PRNG) | + | * add internal cryptographic algorithm implementation (MD5, SHA, AES, Fortuna PRNG) |
* moved lib/srutils functions to core/utils | * moved lib/srutils functions to core/utils | ||
* further migration of many modules to use core SHM_MEM_ERROR and PKG_MEM_ERROR defines | * further migration of many modules to use core SHM_MEM_ERROR and PKG_MEM_ERROR defines | ||
Line 304: | Line 500: | ||
* add option to print callid as attribute in structure json logging | * add option to print callid as attribute in structure json logging | ||
* log macro to print message without function name (dprint) with LOG_FN(...) | * log macro to print message without function name (dprint) with LOG_FN(...) | ||
+ | * duplicated parameter definition cleanups in many modules | ||
+ | * add description columns and id column to version table | ||
+ | * better support for compilation on NetBSD | ||
+ | * add module prefix to internal functions and structures in many modules | ||
+ | * add core support for xavi and xavu PVs | ||
+ | * add core support to assign names to listen sockets | ||
+ | * KEMI suport for ARRAY and DICT types | ||
+ | * implementation for executing route blocks on send out events moved to onsend.c | ||
==== kamailio.cfg ==== | ==== kamailio.cfg ==== | ||
Line 311: | Line 515: | ||
- define WITH_NAT | - define WITH_NAT | ||
- define WITH_RTPENGINE | - define WITH_RTPENGINE | ||
- | * update IMS kamailio.cfg examples | + | |
+ | | ||
===== Tools ===== | ===== Tools ===== | ||
* pdbt: switch from deprecated /var/run to /run | * pdbt: switch from deprecated /var/run to /run | ||
+ | * pdbt: add pdb server message check | ||
* Makefile: add better support for EMACS | * Makefile: add better support for EMACS | ||
* Makefile: use pgk-config if xml2-config can not be found for certain modules | * Makefile: use pgk-config if xml2-config can not be found for certain modules | ||
+ | * kemi: add script to generate mock api for kemi python testing | ||
+ | * kemi: add support for invoking function pointers in tool | ||
==== kamcmd ==== | ==== kamcmd ==== | ||
Line 323: | Line 531: | ||
==== kamctl ==== | ==== kamctl ==== | ||
+ | * add trap command output to TXT file, to help with debugging over e-mail or ticket | ||
* kamctl: switch from deprecated /var/run to /run | * kamctl: switch from deprecated /var/run to /run | ||
+ | * adjustment to RPC fifo file to match default naming | ||
+ | * try to locate RPC fifo file in /var/run/ or /run/ folders, to cope better with old or non-linux systems | ||
+ | * added pstrap command, use ps to get list of PIDs for Kamailio instance, instead of RPC core.psx | ||
==== kamdbctl ==== | ==== kamdbctl ==== | ||
Line 329: | Line 541: | ||
* add support for DB creation on MySQL 8 | * add support for DB creation on MySQL 8 | ||
* new option DBINITASK to control the steps for db init | * new option DBINITASK to control the steps for db init | ||
+ | * removed kamailio-extensions.xml file from DB schema sources | ||
==== kamcli ==== | ==== kamcli ==== | ||
features/new-in-5.4.x.1594284976.txt.gz · Last modified: 2020/07/09 08:56 by henningw