UAC Module

Ramona-Elena Modroiu

Daniel-Constantin Mierla

Edited by

Ramona-Elena Modroiu


Table of Contents

1. Admin Guide
1. Overview
2. Dependencies
2.1. Kamailio Modules
2.2. External Libraries or Applications
3. Parameters
3.1. rr_from_store_param (string)
3.2. rr_to_store_param (string)
3.3. restore_mode (string)
3.4. restore_passwd (string)
3.5. restore_from_avp (string)
3.6. restore_to_avp (string)
3.7. credential (string)
3.8. auth_realm_avp (string)
3.9. auth_username_avp (string)
3.10. auth_password_avp (string)
3.11. reg_db_url (string)
3.12. reg_timer_interval (string)
4. reg_contact_addr (string)
5. Functions
5.1. uac_replace_from(display,uri)
5.2. uac_replace_from(uri)
5.3. uac_restore_from()
5.4. uac_replace_to(display,uri)
5.5. uac_replace_to(uri)
5.6. uac_restore_to()
5.7. uac_auth()
5.8. uac_req_send()
5.9. uac_reg_lookup(uuid, dst)
5.10. uac_reg_request_to(user, mode)
6. Exported pseudo-variables
7. Remote Registration

List of Examples

1.1. Set rr_from_store_param parameter
1.2. Set rr_to_store_param parameter
1.3. Set restore_mode parameter
1.4. Set restore_passwd parameter
1.5. Set restore_from_avp parameter
1.6. Set restore_to_avp parameter
1.7. Set credential parameter
1.8. Set auth_realm_avp parameter
1.9. Set auth_username_avp parameter
1.10. Set auth_password_avp parameter
1.11. Set reg_db_url parameter
1.12. Set reg_timer_inteval parameter
1.13. Set reg_contact_addr parameter
1.14. uac_replace_from usage
1.15. uac_replace_from usage
1.16. uac_restore_from usage
1.17. uac_replace_to usage
1.18. uac_replace_to usage
1.19. uac_restore_to usage
1.20. uac_auth usage
1.21. uac_req_send usage
1.22. uac_reg_lookup usage
1.23. uac_reg_request_to usage
1.24. lookup remote registrations usage

Chapter 1. Admin Guide

1. Overview

UAC (User Agent Client) module provides some basic UAC functionalities like FROM header manipulation (anonymization) or client authentication.

From version 1.5.0 it has function to send SIP message from configuration file. See variable $uac_req(name) and the function uac_req_send().

Version 3.1.0 adds user registration functionality. See uac_reg_lookup() function and dedicated section for remote registration configuration.

Known limitations in this version:

  • authentication does not support qop auth-int, just qop auth;

  • CSeq not increased during authentication - the response may be rejected.

2. Dependencies

2.1. Kamailio Modules

The following modules must be loaded before this module:

  • TM - Transaction Module

  • RR - Record-Route Module, but only if restore mode for FROM URI is set to auto.

2.2. External Libraries or Applications

The following libraries or applications must be installed before running Kamailio with this module loaded:

  • None

3. Parameters

3.1. rr_from_store_param (string)

Name of Record-Route header parameter that will be used to store (encoded) the original FROM URI.

This parameter is optional, it's default value being vsf.

Example 1.1. Set rr_from_store_param parameter

...
modparam("uac","rr_from_store_param","my_param")
...

3.2. rr_to_store_param (string)

Name of Record-Route header parameter that will be used to store (encoded) the original TO URI.

This parameter is optional, it's default value being vst.

Example 1.2. Set rr_to_store_param parameter

...
modparam("uac","rr_to_store_param","my_param")
...

3.3. restore_mode (string)

There are 3 mode of restoring the original FROM URI and the original TO URI:

  • none - no information about original URI is stored; restoration is not possible.

  • manual - all following replies will be restored, but not also the sequential requests - this must be manually updated based on original URI.

  • auto - all sequential requests and replies will be automatically updated based on stored original URI.

This parameter is optional, it's default value being auto.

Example 1.3. Set restore_mode parameter

...
modparam("uac","restore_mode","auto")
...

3.4. restore_passwd (string)

String password to be used to encrypt the RR storing parameters. If empty, no encryption will be used.

Default value of this parameter is empty.

Example 1.4. Set restore_passwd parameter

...
modparam("uac","restore_passwd","my_secret_passwd")
...

3.5. restore_from_avp (string)

If defined and restore_mode is manual or auto, the avp is used to save the original from uri in order to be able to restore it in replies. That makes sense, if the original-uri can not be extracted from the original request, e.g. if msg_apply_changes() was used after calling uac_replace_from()

Default value of this parameter is empty.

Example 1.5. Set restore_from_avp parameter

...
modparam("uac","restore_from_avp","$avp(s:original_uri_from)")
...

3.6. restore_to_avp (string)

If defined and restore_mode is manual or auto, the avp is used to save the original to uri in order to be able to restore it in replies. That makes sense, if the original-uri can not be extracted from the original request, e.g. if msg_apply_changes() was used after calling uac_replace_to()

Default value of this parameter is empty.

Example 1.6. Set restore_to_avp parameter

...
modparam("uac","restore_to_avp","$avp(s:original_uri_to)")
...

3.7. credential (string)

Contains a multiple definition of credentials used to perform authentication.

This parameter is required if UAC authentication is used.

Example 1.7. Set credential parameter

...
modparam("uac","credential","username:domain:password")
...

3.8. auth_realm_avp (string)

The definition of an AVP that might contain the realm to be used to perform authentication.

If you define it, you also need to define auth_username_avp (Section 3.9, “auth_username_avp (string)”) and auth_username_avp (Section 3.10, “auth_password_avp (string)”).

Example 1.8. Set auth_realm_avp parameter

...
modparam("uac","auth_realm_avp","$avp(i:10)")
...

3.9. auth_username_avp (string)

The definition of an AVP that might contain the username to be used to perform authentication.

If you define it, you also need to define auth_realm_avp (Section 3.8, “auth_realm_avp (string)”) and auth_username_avp (Section 3.10, “auth_password_avp (string)”).

Example 1.9. Set auth_username_avp parameter

...
modparam("uac","auth_username_avp","$avp(i:11)")
...

3.10. auth_password_avp (string)

The definition of an AVP that might contain the password to be used to perform authentication.

If you define it, you also need to define auth_password_avp (Section 3.10, “auth_password_avp (string)”) and auth_username_avp (Section 3.10, “auth_password_avp (string)”).

Example 1.10. Set auth_password_avp parameter

...
modparam("uac","auth_password_avp","$avp(i:12)")
...

3.11. reg_db_url (string)

DB URL to fetch user profiles for registration.

Example 1.11. Set reg_db_url parameter

...
modparam("uac", "reg_db_url",
    "mysql://openser:openserrw@localhost/openser")
...

3.12. reg_timer_interval (string)

Timer interval (in seconds) at which registrations are managed, e.g. renewed as needed.

The default value is 90 seconds.

Example 1.12. Set reg_timer_inteval parameter

...
modparam("uac", "reg_timer_interval", 60)
...

4. reg_contact_addr (string)

Address to be used to build contact address. Must be at least host part, can have port and parameters. Must not include 'sip:'.

Example 1.13. Set reg_contact_addr parameter

...
modparam("uac", "reg_contact_addr", "192.168.1.2:5080")
...

5. Functions

5.1.  uac_replace_from(display,uri)

Replace in FROM header the display name and the URI part.

display and URI parameters can include pseudo-variables.

This function can be used from REQUEST_ROUTE and from BRANCH_ROUTE.

Example 1.14. uac_replace_from usage

...
# replace both display and uri
uac_replace_from("$avp(s:display)","$avp(s:uri)");
# replace only display and do not touch uri
uac_replace_from("batman","");
# remove display and replace uri
uac_replace_from("","sip:robin@gotham.org");
# remove display and do not touch uri
uac_replace_from("","");
...

5.2.  uac_replace_from(uri)

Replace in FROM header the URI part without altering the display name.

URI parameter can include pseudo-variables.

This function can be used from REQUEST_ROUTE and from BRANCH_ROUTE.

Example 1.15. uac_replace_from usage

...
uac_replace_from("sip:batman@gotham.org");
...

5.3.  uac_restore_from()

This function will check if the FROM URI was modified and will use the information stored in header parameter to restore the original FROM URI value.

This function can be used from REQUEST_ROUTE.

Example 1.16. uac_restore_from usage

...
uac_restore_from();
...

5.4.  uac_replace_to(display,uri)

Replace in TO header the display name and the URI part.

display and URI parameters can include pseudo-variables.

This function can be used from REQUEST_ROUTE and from BRANCH_ROUTE.

Example 1.17. uac_replace_to usage

...
# replace both display and uri
uac_replace_to("$avp(s:display)","$avp(s:uri)");
# replace only display and do not touch uri
uac_replace_to("batman","");
# remove display and replace uri
uac_replace_to("","sip:robin@gotham.org");
# remove display and do not touch uri
uac_replace_to("","");
...

5.5.  uac_replace_to(uri)

Replace in TO header the URI part without altering the display name.

URI parameter can include pseudo-variables.

This function can be used from REQUEST_ROUTE and from BRANCH_ROUTE.

Example 1.18. uac_replace_to usage

...
uac_replace_to("sip:batman@gotham.org");
...

5.6.  uac_restore_to()

This function will check if the TO URI was modified and will use the information stored in header parameter to restore the original TO URI value.

This function can be used from REQUEST_ROUTE.

Example 1.19. uac_restore_to usage

...
uac_restore_to();
...

5.7.  uac_auth()

This function can be called only from failure route and will build the authentication response header and insert it into the request without sending anything.

This function can be used from FAILURE_ROUTE.

Example 1.20. uac_auth usage

...
uac_auth();
...

5.8.  uac_req_send()

This function sends a SIP message from the configuration file. The message is built out of $uac_req(...) pseudo-variable.

This function can be used from REQUEST_ROUTE, FAILURE_ROUTE, BRANCH_ROUTE, ONREPLY_ROUTE, LOCAL_ROUTE.

Example 1.21. uac_req_send usage

...
$uac_req(method)="OPTIONS";
$uac_req(ruri)="sip:kamailio.org";
$uac_req(furi)="sip:kamailio.org";
$uac_req(turi)="sip:kamailio.org";
uac_req_send();
...

5.9.  uac_reg_lookup(uuid, dst)

This function sets the PV dst to SIP URI that correspond to uuid in uac registations table. uuid and dst must be pseudo-variables.

This function can be used from ANY_ROUTE.

Example 1.22. uac_reg_lookup usage

...

if(uac_reg_lookup("$rU", "$ru"))
{
    lookup("location");
}
...

5.10.  uac_reg_request_to(user, mode)

This function can be used to send an authenticated request to a remote user in the uac registrations table. It sets the request-uri, dst-uri and auth_*_avp pv's to the values that correspond to the supplied user.

The mode indicates whether the user should match the local uuid (mode=0), or the username (mode=1).

The auth_*_avp module parameters must be set to valid pv's.

This function can be used from REQUEST_ROUTE, FAILURE_ROUTE, BRANCH_ROUTE.

Example 1.23. uac_reg_request_to usage

...

if(uac_reg_request_to("$fU", 0))
{
	xlog("L_NOTICE", "Found remote user [$rU] on [$rd] via [$du]");
	t_on_failure("REMOTE_AUTH");

	t_relay()
}
...
failure_route[REMOTE_AUTH] {
	if ($T_reply_code == 401 or $T_reply_code == 407) {
		xlog("L_NOTICE", "Remote asked for authentication");
		uac_auth()
	}
}
...

6. Exported pseudo-variables

  • $uac_req(key)

Exported pseudo-variables are documented at http://www.kamailio.org/dokuwiki/.

7. Remote Registration

The module can register contact addresses to remote REGISTRAR servers. You have to add records to uacreg table. The table stores following attributes:

  • l_uuid - local unique user id, e.g.,: 12345678

  • l_username - local user name, e.g.,: test

  • l_domain - local domain, e.g.,: mysipserver.com

  • r_username - remote username, e.g.,: test123

  • r_domain - remote domain, e.g.,: sipprovider.com

  • realm - remote relam, e.g.,: sipprovider.com

  • auth_username - authentication username, e.g.,: test123

  • auth_password - authentication password, e.g.,: xxxxxx

  • auth_proxy - SIP address of authentication proxy, e.g.,: sip:sipprovider.com

  • expires - expiration time for registration, in seconds, e.g.,: 360

The module takes care of sending REGISTER and refresh registrations before they expire.

When calls come in, you have to run uac_reg_lookup() that will detect if the call is coming from a remote SIP provider and can change the R-URI to local username@domain. Afterwards you can run location lookup.

Example 1.24. lookup remote registrations usage

...
    if(uac_reg_lookup("$rU", "$ru")) {
        xlog("request from a remote SIP provider [$ou => $ru]\n");
    }
    lookup("location");
...