Local Policy Session Agent Matching for SIP
When you enable the local policy session agent matching option in your global SIP configuration, you change the way local policies match session agents. Normally, the Oracle® Enterprise Session Border Controller looks up and stores matched session agents configured as next hops so it does not need to perform the lookup while processing requests. In this type of matching, the Oracle® Enterprise Session Border Controller does take the realm set in the local policy attributes into consideration. When the Oracle® Enterprise Session Border Controller performs its regular matching method and you have enabled overlapping IP addresses for session agents, the Oracle® Enterprise Session Border Controller might match session agents to different realms than the ones you intended when creating your configuration.
Local policy session agent matching provides a way to match session agents differently, taking realms and nested realms into consideration during the matching process. This difference is key to deployments with multiple peering partners that use the overlapping IP address feature, and have multiple local policies routing to the same IP address in different realms where some target next hops require session constraints but others do not. In the cases where no session constraints are required, session agents are not needed. But session agents still match the local policy, applying their constraints, because they match the next hop IP address.
In addition to modifying this behavior, this feature also affects the use of realms and nested realms. It triggers the use not only of realms, but of all the realms nested however deeply—thereby improving matching efficiency.
You can set the local policy session agent matching option with values that define how the Oracle® Enterprise Session Border Controller performs session agent matching:
- any—The 
		  Oracle® Enterprise Session Border Controller looks up and stores matched session agents configured
		  as next hops so it does not need to perform the lookup while processing
		  requests, without regard to realms. 
		  
                     This behavior is the default when the SIP configuration does not have the local policy session agent matching option set. 
- realm—The 
		  Oracle® Enterprise Session Border Controllerselects session agents in the realm that the local
		  policy attribute indicates; this provides an exact match, rather than not
		  taking the realm into consideration during session agent selection. 
		  
                     For example, the session agent is a match if the session agent realm-id and the local policy attribute realm parameters are an exact match. 
- sub-realm—Session
		  agents in the same realm or the same realm lineage—where session agents and
		  realms are related to one another via realm parent-child relationships no
		  matter the depth of realm nesting configured 
		  
                     For example, the session agent is a match if the local policy attribute realm is a sub-realm of the realm specified in the session agent realm-id parameter. 
- interface—Session
		  agents in the same realm or same realm lineage via the realm set in the local
		  policy attribute, and whose realm uses the same signaling interface as the
		  realm set in the local policy attribute 
		  
                     For example, the session agent is a match if the session agent realm-id is a sub-realm of the local policy attribute realm, and both referenced realms use the same SIP signaling interface. 
- network—Session
		  agents whose realm is in the realm lineage for the same realm set in the local
		  policy attributes, and whose realm is associated with the same network
		  interface as the realm set in the local policy attributes 
		  
                     For example, the session agent is a match if the session agent realm-id is a sub-realm of the local policy attribute realm, and realm reference by both use the same network interface. 
If it cannot find a match, the Oracle® Enterprise Session Border Controller will use the IP address as the next hop. Further, requests matching local policy attributes will not be associated with session agents, and so their constraints will not be applied.
The Oracle® Enterprise Session Border Controller stores session agent information that it looks up when performing local policing session agent matching. To perform the lookup, it uses the session agent hostname as a key. When the hostname is an FQDN and there is a configured IP address in the ip-address parameter, the Oracle® Enterprise Session Border Controller uses the ip-address value as a secondary key. Given this implementation, the following are true when selecting session agents:
- If multiple session agents share the same IP address, the one with an IP address in the hostname parameter takes precedence.
- If all session agents with the same IP address have an FQDN as their hostname, the one whose name is alphabetically lower will take precedence, where alphabetically lower means earlier in the alphabet (closer to A than to Z).
- For non-global session agents (whose realms are configured but not wildcarded) with an IP address, the Oracle® Enterprise Session Border Controller uses a key that is a combination of the IP address and the realm in the form <address>:<realm>.
- For a session agent whose realm has a parent realm, the Oracle® Enterprise Session Border Controller uses a combination of the IP address, realm, and realm-path (or lineage for the realm) in the form <address>:<realm-path>. For example, the realm path for a realm core3 with a parent core2, which in turn has a parent core would be core:core2:core3.
When it looks up a session agent with a realm, the Oracle® Enterprise Session Border Controller first searches for an exact match for the IP address and realm combination. If this fails, it performs a second search if the desired realm has parents or children. The Oracle® Enterprise Session Border Controller locates an entry in its repository of session agent information that is greater than or equal to the IP address with the base realm, which is the ancestor of the desired realm without a parent. Having gathered this set of candidates, the Oracle® Enterprise Session Border Controller narrows down the search for a match by comparing sub-realms and determines there is a match if either:
- The desired realm path is a sub-string of the entry’s realm path, or
- The entry’s realm path is a substring of the desired realm path (i.e., the desired realm is a sub-realm of the entry’s realm)
Then the Oracle® Enterprise Session Border Controller orders the candidates by depth of the entry’s realm-path, or number of levels from the base realm relative to the depth of the desired realm. By searching the ordered set until the entry’s realm depth equals the desired realm’s depth, the Oracle® Enterprise Session Border Controller determines a parent candidate, all subsequent entries being sub-realms of the desired realm. The Oracle® Enterprise Session Border Controller only considers entries at the first level deeper than the desired realm. If at this point there is only one entry, the Oracle® Enterprise Session Border Controller deems it a match. Otherwise, it selects the parent candidate as the matching entry. In the event the search does not yield a matching realm, the Oracle® Enterprise Session Border Controller uses the global session agent for the IP address, if there is one.
The following diagram shows the realm tree, where the clouds are realms and squares are session agents, representing a group of session agents sharing the IP address 1.2.3.4. The Oracle® Enterprise Session Border Controller searches for the session agents lower in the tree along the session agent realm-path and the desired realm.

For the diagram above, the following shows how the hostname would look for this group of session agents.
| Key | Session Agent (hostname[realm]) | 
|---|---|
| 1.2.3.4 (This session agent owns the primary key for the IP address because its hostname is the IP address.) | 1.2.3.4[CORE2] | 
| 1.2.3.4:CORE (IP+realm key entry) | SA[CORE] | 
| 1.2.3.4:CORE (IP+realm key entry) | 1.2.3.4[CORE2] | 
| 1.2.3.4:CORE212 (IP+realm key entry) | SA212[CORE212] | 
| 1.2.3.4:CORE2121 (IP+realm key entry) | SA2121[CORE2121] | 
| 1.2.3.4:CORE231 (IP+realm key entry) | SA231[CORE231] | 
| 1.2.3.4:CORE232 (IP+realm key entry) | SA232[CORE232] | 
| 1.2.3.4:CORE: (IP+realm-path key entry) | SA[CORE] | 
| 1.2.3.4:CORE:CORE2: (IP+realm-path key entry) | 1.2.3.4[CORE2] | 
| 1.2.3.4:CORE2:CORE21:CORE212 (IP+realm-path key entry) | SA212[CORE212] | 
| 1.2.3.4:CORE2:CORE21:CORE212:CORE2121 (IP+realm-path key entry) | SA2121[CORE2121] | 
| 1.2.3.4:CORE2:CORE23:CORE231 (IP+realm-path key entry) | SA231[CORE231] | 
| 1.2.3.4:CORE2:CORE23:CORE232 (IP+realm-path key entry) | SA232[CORE232] | 
For each realm in the table above, the search results for each realm would look like this:
| IP Address | Realm | Session Agent (hostname[realm]) | 
|---|---|---|
| 1.2.3.4 | CORE | SA[CORE] | 
| 1.2.3.4 | CORE2 | 1.2.3.4[CORE2] | 
| 1.2.3.4 | CORE21 | SA212[CORE212[ | 
| 1.2.3.4 | CORE211 | 1.2.3.4[CORE2] | 
| 1.2.3.4 | CORE212 | SA212[CORE212] | 
| 1.2.3.4 | CORE2121 | SA2121[CORE2121] | 
| 1.2.3.4 | CORE22 | 1.2.3.4[CORE2] | 
| 1.2.3.4 | CORE23 | 1.2.3.4[CORE2] | 
| 1.2.3.4 | CORE231 | SA231[CORE231] | 
| 1.2.3.4 | CORE232 | SA232[CORE232] | 
Local Policy Session Agent Matching Configuration
When you enable local policy session agent matching, remember that you can choose from five different ways to use the feature: all, realm, sub-realm, interface, and network.
This example shows you how to use the realm selection.
To enable local policy session agent matching using the realm method:
- Unordered—Meaning that the endpoint can deliver data within regard for their stream sequence number
You set this preference in the network parameters configuration.
About Wildcarding
The Oracle® Enterprise Session Border Controller supports wildcarding the event type in the subscribe-event configuration. To wildcard the value, you enter an asterisk (*) for the event-type parameter instead of typing in the name of an actual event type.
When you wildcard this value, the Oracle® Enterprise Session Border Controller applies the subscription limitations you set across all event types. Or, if you have entered multiple subscribe-event configurations, the Oracle® Enterprise Session Border Controller applies the wildcard limits across the event types for which you have not set limits.
Consider the following example of a configured enforcement profile with a wildcarded subscribe-event configuration:
enforcement-profile
        name                              rulefour
        allowed-methods
        sdp-address-check                 disabled
        subscribe-event
                 event-type                      *
                 max-subscriptions               1
        subscribe-event
                 event-type                      xyz
                 max-subscriptions               0
        last-modified-by                  admin@console
        last-modified-date                2008-11-11 12:49:27In this example, the enforcement profile allows all subscriptions that are event type xyz for a user. But it allows only one maximum for every other subscription event type.