4 Action Sets

This chapter describes the components and functions of an NPP Action Set.

Action Sets

NPP allows customized numbering plan processing behavior to be provisioned as an Action Set. Up to 1024 Actions Sets are supported by an EAGLE.

An Action Set consists of three types of Actions and an outgoing FNAI class:

  • Conditioning Actions (CAs; up to 12 per Action Set) determine how a digit string is manipulated prior to applying service-specific behavior Digit manipulation includes number conditioning to international format and extraction of digits to use in formatting the outgoing digit string.
  • Service Actions (SAs; up to 8 per Action Set) determine what service-specific behavior to apply to a digit string (such as corrective dialing and number portability checking).
  • Formatting Actions (FAs; up to 12 per Action Set) determine how the outgoing digit string is formatted after Service Action execution.
  • Outgoing FNAI Class (outgoing FNAI or OFNAI ; one per Action Set) setting communicates the NAI of the outgoing digit string to the calling service.

Figure 4-1 shows the relationship between Actions and Action Sets.

Figure 4-1 Action and Action Set Relationship

img/c_npp_action_and_action_set_relationship.jpg

Action Set Examples

Examples of simple NPP Action Sets can be where number portability processing is needed on the following types of calls and all other calls are not subject to the specified number portability processing:
  • Properly formatted NATL calls
  • Messages with unknown NAI, a National Escape Code of 1, and 10 digits
The Actions for the examples are shown in Table 4-1:

Table 4-1 Action Set Actions Scenarios

Filter Nature of Address Filter Prefix Filter Digit Length Conditioning Actions Service Actions Format Outgoing NAI
NATL * * Add Default Country Code Number portability RN+DN NATL
Unknown 1 11 Delete matched prefix, add Default Country Code Number portability RN+DN Incoming

Conditioning Actions

NPP defines a set of Conditioning Actions (CAs) that are available to all NPP services. Conditioning Actions determine how a digit string is manipulated before service-specific behavior is applied to the digit string. The behavior of CAs does not differ between services; however, each service defines which CAs it supports. NPP allows up to 12 CAs per Action Set; certain CAs can occur more than once in an Action Set.

Table 6-2 lists CAs and their purpose.

Conditioning Actions are executed in the order of the consecutive numbers of the provisioned Conditioning Action parameters, or in thesequence of the values in the CA parameter comma-separated list. Enough Conditioning Actions must be provisioned to process all of the digits in the incoming digit string from the beginning to the end of the string.

Conditioning Actions determine whether or not digit strings that represent subscriber numbers are in international format. International format is defined as "CC + AC + SN" or "CC + DN" or "ZN" (see Table 6-2 for definitions). If a digit string is not in international format, the Conditioning Actions are used to convert the digit string to international format, which is required for performing RTDB lookup.

Conditioning Actions extract digits from the incoming digit string and assign the digits as values that are later used to format the outgoing digit string.

For filters with FDL=* (wildcard), the associated Conditioning Action group must contain a ZNX, DNX, or SNX Conditioning Action. For filters with specific FDL (Filter Digit Length) values, the associated Conditioning Action group must process the entire number of digits (by either ignoring or processing them).

Conditioning Action Examples

The following examples illustrate simple to more complex Conditioning Action scenarios:

  • EXAMPLE 1: Standard national calls all receive the same handling where NAI=NATL, digits XXXXXXXXXX

    To condition this number to international format, the Country Code must be prefixed. The conditioning action (CA) for this is Country Code Default (CCDEF)

    If CCDEF = 55 (for example), and the digit string is 87654321, then the digit string will become 5587654321

    • Filter NAI = national (FNAI = NATL)
    • Filter Prefix = wildcard (FPFX = *)
    • Filter Digit Length = wildcard (FDL = *)
  • EXAMPLE 2: International calls with International Escape Code where NAI = international (INTL), digits 011 + XXXXXXXXXXXX

    It is common that international calls need only to "escape" any service processing. In these cases, no CAs are required.

    • FNAI = INTL
    • FPFX = 011
    • FDL = *
  • EXAMPLE 3: Collect calls with Operator Code, Area Code follows the Operator Code, NAI=Unknown, digits 'b' + AC + 9090 + XXXXXXXX

    If the digit string is b33909087654321, FPFX = b339090 is matched. To achieve standard international format, "b" and "9090" must be stripped, Area Code "33" must be placed next to Directory Number "87654321", and the Country Code must be prefixed. The Conditioning Actions for this scenario are shown in Table 4-2.

    • FNAI = UNKNOWN
    • FPFX = b (or FPFX = b339090 or FPFX = b349090, etc. -- there are many options for this configuration)
    • FDL = 15

Table 4-2 Conditioning Actions for Collect Calls with Operator Code

Conditioning Action... Consisting of Formatting Actions... Resulting Digit String
    [incoming digit string = b33909087654321]
IGN1 [no Formatting Action, just ignore first digit] 33909087654321
AC2 AC =33 909087654321
PFXA4 AC=33, PFXA=9090 87654321
SNX AC=33, PFXA=9090, SN=87654321  
CCDEF AC=33, PFXA=9090, SN=87654321, CC=55  

Conditioning Action Execution

Conditioning Actions process the incoming digit string from the beginning to the end of the string, and extract digits from the string to be used in Service Action execution and Formatting Action execution. All digits must be ignored, assigned as Formatting Action values, or replaced by a Formatting Action value with a provisioned default value.

Conditioning Action execution identifies the digit strings that correspond to the subscriber number in international format, and populates the appropriate Formatting Action values to encode the outgoing digit string. A digit string in international format is passed to each Service Action that is executed for the service.

Service Actions

Service Actions (SAs) determine the EAGLE behavior to apply to a digit string. NPP allows up to 8 SAs to be associated with a single Action Set. Service Actions are provisioned and executed in order of an assigned precedence (see Service Action Precedence).

Service Action behavior is determined by the EAGLE feature or function (service) that invokes NPP. The service must provide a Service Action Handler for each Service Action that it supports. Such behavior includes Number Portability Release and Relay, RTDB lookup, and simple number substitution, and use of Additional Subscriber Data (ASD)and Generic Routing Number (GRN).

Table 6-3 describes valid Service Actions, the precedence for each Service Action, and EAGLE features and functions that use each Service Action.

Service Action Examples

The following examples illustrate Service Action scenarios:

  • Example 1: Standard national calls all receive the same handling; NAI=NATL XXXXXXXXXX

    If number portability service is needed here, then the IDP Relay Service Action can be just CDPNNP.

  • Example 2: International calls with International Escape Code; NAI=INTL 011+XXXXXXXXXXXX

    This call just wants to "escape" any service processing. There is no Service Action in this rule.

  • Example 3: Collect Calls with Operator Code, Area Code in-between; NAI=Unknown ‘b’+AC+9090+XXXXXXXX

    For this filter, the desired actions are number portability and forward the message to the Service Creation System (SCS). The Service Actions for TIF are NPRELAY and FWDSCS.

  • Example 4: Fraudulent Calls

    The FRAUDCHK Service Action uses the conditioned digit string for the RTDB lookup to determine whether the message Calling Party belongs to the network and to determine whether the call is fraudulent.

  • Example 5: Prepaid calls

    The PPRELAY Service Action uses the conditioned digit string for RTDB lookup to determine whether the Calling Party or Called Party is a prepaid subscriber, and for prepaid calls sets the message to be routed to a Prepaid Server.

Service Action Execution

Each service can support one or more Service Actions that can be assigned to the Action Sets in the Service Rule Set for the service.

Each Service Actions performs service-specific behavior for a conditioned digit string that it receives from a Conditioning Action that is executed for the service. The behavior is determined by feature-specific provisioned data and feature-specific logic. NPP verifies that the service status is ON for the calling service before executing Service Actions for the service.

When multiple Service Actions can be associated with an NPP Action Set for a service, the service must define the precedence value for each Service Action that it supports. The precedence determines the order in which multiple Service Actions will be executed for the service. Service Action precedence is represented by a number between 0 and 100. Higher precedence Service Actions are always executed before lower precedence Service Actions; execution of a lower precedence Service Action ahead of higher precedence Service Action is prevented. Service Actions can be defined with equal precedence. NPP executes Service Actions of equal precedence in the order of the consecutive numbers of the provisioned SAx parameters, or in the sequenced list of comma-separated SA parameter values.

NPP processes messages for MO SMS features when the smsmr service selector is provisioned. NPP verifies that the required MO SMS feature is enabled and on before executing a Service Action that is provisioned for an MO SMS service. The Service Actions are executed in precedence sequence first for Calling Party numbers (IS41 Original Originating Address digits or GSM MSISDN digits), then for Called Party numbers (IS41 Destination Address or Original Destination Address, or GSM TP-DA digits).

When the TIF Subscr CgPN Blacklist feature, the TIF Range CgPN Blacklist feature, or the TIF Selective Screening feature is on, two Service Action Data (SA Data) values can be associated with each provisioned TIF CgPN/CdPN Blacklist Service Action to provide configurable Release Cause values for the blacklist scenarios. The first value is used for ANSI ISUP and the second value is used for ITU ISUP.

NPP Formatting Action values can be populated during Service Action execution (see Provisioning Formatting Actions).

Upon execution completion, the Service Action indicates whether to continue executing another Service Action and whether to execute Formating Actions. The CDIAL Service Action can be provisioned to execute Formatting Actions even when a Service Action indicates that Formatting Action execution should not occur.

Service Action Precedence

Multiple service actions (SAs) can be associated with an NPP Action Set. To provide a systematic method for Service Action provisioning and execution, SA precedence value is assigned. Each service defines the order in which SAs are executed. SA execution order follows the defined SA precedence value.

SA precedence is represented by a number between 0 and 100. Higher precedence SAs are always executed before lower precedence SAs; provisioning of a lower precedence SA ahead of higher precedence SA is prevented. SAs can be defined with equal precedence. NPP executes SAs of equal precedence in the order of the consecutive numbers of the provisioned SAx parameters, or in the sequence of the values in the SA parameter comma-separated list.

Table 4-3 shows an example group of SAs and their precedence values.

Table 4-3 Service Action Precedence Example

Example Service Action Name Precedence Notes
EXSA1 100 Always executed first regardless of provisioning order
EXSA2 50 Always executed after EXSA1 and prior to EXSA4; EXSA2 and EXSA3 execution order is dependent on the order provisioned.
EXSA3 50 Always executed after EXSA1 and prior to EXSA4; EXSA2 and EXSA3 execution order is dependent on the order provisioned. in consecutively numbered :sa[x] parameters.
EXSA4 10 Always executed last

Given the SA precedence values defined in Table 4-3, the SA groups defined in Table 4-4 are allowed and the SA groups defined in Table 4-5 are prevented.

Table 4-4 Valid Service Action Group Examples

Service Action Group Validity Notes

:sa1=EXSA1

:sa=EXSA1

Valid Single Service Actions always execute in the correct order [100]

:sa1=EXSA2

:sa=EXSA2

Valid Single Service Actions always execute in the correct order [50]

:sa1=EXSA3

:sa=EXSA3

Valid Single Service Actions always execute in the correct order [50]

:sa1=EXSA4

:sa=EXSA4

Valid Single Service Actions always execute in the correct order [10]

:sa1=EXSA1:sa2=EXSA2

:sa=EXSA1,EXSA2

Valid Service Actions executed in order of precedence [100, 50]

:sa1=EXSA1:sa2=EXSA3

:sa=EXSA1,EXSA3

Valid Service Actions executed in order of precedence [100, 50]

:sa1=EXSA1:sa2=EXSA4

:sa=EXSA1,EXSA4

Valid Service Actions executed in order of precedence [100, 10]

:sa1=EXSA1:sa2=EXSA2:sa3=EXSA3

:sa=EXSA1,EXSA2,EXSA3

Valid Service Actions executed in order of precedence [100,50,50] – Service Actions of equal precedence execute in the order provisioned (EXSA2 then EXSA3).

:sa1=EXSA1:sa2=EXSA2:sa3=EXSA4

:sa=EXSA1,EXSA2,EXSA4

Valid Service Actions executed in order of precedence [100,50, 10]

:sa1=EXSA1:sa2=EXSA3:sa3=EXSA2

:sa=EXSA1,EXSA3,EXSA2

Valid Service Actions executed in order of precedence [100,50,50] – Service Actions of equal precedence execute in the order provisioned (EXSA3 then EXSA2).

:sa1=EXSA1:sa2=EXSA3:sa3=EXSA4

:sa=EXSA1,EXSA3,EXSA4

Valid Service Actions executed in order of precedence [100,50,10]

:sa1=EXSA1:sa2=EXSA2:sa3=EXSA3:sa4=EXSA4

:sa=EXSA1,EXSA2,EXSA3,EXSA4

Valid Service Actions executed in order of precedence [100,50,50,10] – Service Actions of equal precedence execute in the order provisioned (EXSA2 then EXSA3).

:sa1=EXSA1:sa2=EXSA3:sa3=EXSA2:sa4=EXSA4

:sa=EXSA1,EXSA3,EXSA2,EXSA4

Valid Service Actions executed in order of precedence [100,50,50,10] – Service Actions of equal precedence execute in the order provisioned (EXSA3 then EXSA2)

:sa1=EXSA2:sa2=EXSA3

:sa=EXSA2,EXSA3
Valid Service Actions executed in order of precedence [50,50] – Service Actions of equal precedence execute in the order provisioned (EXSA2 then EXSA3)

:sa1=EXSA2:sa2=EXSA3:sa3=EXSA4

:sa=EXSA2,EXSA3,EXSA4

Valid Service Actions executed in order of precedence [50,50, 10] – Service Actions of equal precedence execute in the order provisioned (EXSA2 then EXSA3)

:sa1=EXSA2:sa2=EXSA4

:sa=EXSA2,EXSA4

Valid Service Actions executed in order of precedence [50,10]

:sa1=EXSA3:sa2=EXSA2

:sa=EXSA3,EXSA2

Valid Service Actions executed in order of precedence [50,50] – Service Actions of equal precedence execute in the order provisioned (EXSA3 then EXSA2).

:sa1=EXSA3:sa2=EXSA2:sa3=EXSA4

:sa=EXSA3,EXSA2,EXSA4

Valid Service Actions executed in order of precedence [50,50,10] – Service Actions of equal precedence execute in the order provisioned (EXSA3 then EXSA2)

:sa1=EXSA3:sa2=EXSA4

:sa=EXSA3,EXSA4

Valid Execution follows Service Action precedence in decreasing order [50, 10]

Table 4-5 Invalid Service Action Group Examples

Service Action Group Validity Notes

:sa1=EXSA4:sa2=EXSA1

:sa1=EXSA4,EXSA1

Invalid Violated Service Action precedence (10 < 100)

:sa1=EXSA4:sa2=EXSA2

:sa=EXSA4,EXSA2

Invalid Violated Service Action precedence (10 < 50)

:sa1=EXSA4:sa2=EXSA3

:sa=EXSA4,EXSA3

Invalid Violated Service Action precedence (10 < 50)

:sa1=EXSA2:sa2=EXSA1

:sa=EXSA2,EXSA1

Invalid Violated Service Action precedence (50 < 100)

:sa1=EXSA3:sa2=EXSA1

:sa=EXSA3,EXSA1

Invalid Violated Service Action precedence (50 < 100)

:sa1=EXSA1:sa2=EXSA4:sa3=EXSA2

:sa=EXSA1,EXSA4,EXSA2

Invalid Violated Service Action precedence (10 < 50)

:sa1=EXSA1:sa2=EXSA4:sa3=EXSA3

:sa=EXSA1,EXSA4,EXSA3

Invalid Violated Service Action precedence (10 < 50)

Formatting Actions

Formatting Actions (FAs) are applied after Service Action execution and determine how the outgoing digit string is formatted. The digits associated with each provisioned Formatting Action are made available during Conditioning Action execution and Service Action execution. The outgoing digit string is constructed by inserting digits associated with each FA into the string. If values are empty (no digit value assigned), they are skipped.

The behavior of a Formatting Action does not differ between services; however, each service defines the Formatting Actions that it supports. NPP allows up to 12 Formatting Actions to be associated with one Action Set. Formatting Actions are executed in the order of the consecutive numbers of the provisioned Formatting Action parameters, or in the sequenced list of comma-separated FA parameter values.

Valid Formatting Actions are listed in Table 6-4.

To provision Formatting Action parameters, Conditioning Actions for at least one of the following international formats must be provisioned:
  • CC + AC + SN
  • CC + DN
  • ZN

Service Actions might also have to be provisioned, depending on the particular Formatting Action.

Formatting Action List Type for Response Messages (FATYPE)

In addition to the Formatting Actions used to format the outgoing digits of the relayed message, Formatting Action List Types are used to format outgoing digits in the response messages generated by the services using NPP. These Formatting Action List Types are provisioned with the Formatting Actions to provide various combinations of digit formatting for different conditions. The service using NPP defines the service-specific usage of the Formatting Actions List Types. Valid values for Formatting Action List Types are shown in Table 6-5.

Formatting Action Execution

Conditioning Actions and Service Actions populate Formating Action digit string values that are used to construct the outgoing digit string during Formatting Action execution.

Formatting Action execution occurs after Service Action execution is complete for a digit string. The Service Action can indicate whether Formatting Action execution will or will not occur for the string.

NPP begins with an empty outgoing digit string, and inserts digits into the string in the order in which the Formatting Action values are provisioned in a sequenced list of comma-separated parameter values consecutively number parameter values. If a provisioned Formatting Action is not populated, the outgoing digit string is not modified for that Formatting Action.

After successful digit string processing and Formatting Action execution, NPP sends an outgoing NAI value (see Outgoing FNAI Class with the outgoing digit string to the calling service.

Formatting Actions Examples

The effects of Formatting Actions on digit strings are shown in Table 4-6, Table 4-7, Table 4-8, and Table 4-9. The examples include assumptions for required Conditioning Actions and Service Actions.

Table 4-6 FA Example 1

Example 1: Standard national calls all receive the same handling
Assumptions:
  • NAI=NATL XXXXXXXXXX
  • To condition this number to international format, the Country Code must be prefixed, CA1CA=CCDEF
  • Example digit string is 87654321 before Conditioning Action
  • Example digit string after Conditioning Action (CA1)(CA) is 559192252645
  • Assume the example requires number portability service and the Service Action (SA) is just CdPNNP.
  • Assume the example requires just prefixing the Routing Number (RN) returned from the Realtime Database (RTDB) and the outgoing digit string should be sent in NATL format.
  • Assume the Routing Number (RN) that was returned from the RTDB is "7777".
  • The resulting outgoing format is RN DN.
Formatting Action set = {FA1=RN, FA2=DN}{FA=RN, DN}
Formatting Action ==> Resulting Outgoing Digit String
Begin ==>  
RN ==> 7777
DN ==> 7777559192252645

Table 4-7 FA Example 2

Example 2: International calls with International Escape Code
Assumptions:
  • NAI=INTL 011+XXXXXXXXXXXX
  • Assume the original number is 449192252645.
  • Assume this call just needs to "escape" any service processing; only minimum Conditioning Actions (CAs) are required (ZNX).
  • Because this call needs to "escape" any service processing, there are no Service Actions (SA) required.
  • Because this call just needs to "escape" any service processing, the outgoing format is the original number (ORIG).
Formatting Action set = {FA1=ORIG}{FA=ORIG}
Formatting Action ==> Resulting Outgoing Digit String
Begin ==>  
ORIG ==> 011449192252645

Table 4-8 FA Example 3

Example 3: Collect calls with Operator Code, Area Code in-between
Assumptions:
  • NAI=Unknown 'b' + AC + 9090 + XXXXXXXX
  • Assume the digit string is b33909087654321
  • If the desired outgoing format is to replace the 'b' with a 'd', and to insert the number portability RN after the '9090'.
    • '9090' put in PFX4
    • The NPRelay Service Action updated the RN token.
    • Assume DLM1 is provisioned as 'd'.
    • Assume the RN is "5555".
  • In this case, the desired outgoing format is
    • DLMA
    • AC
    • PFX4
    • RN
    • SN
Formatting Action set = {FA1=DLMA, FA2=AC, FA3=PFX3, FA4=RN, FA5=SN}{FA=DLMA, AC, PFX4, RN, SN}
Formatting Action ==> Resulting Outgoing Digit String
Begin ==>  
DLMA ==> d
AC ==> d33
PFX4 ==> d339090
RN ==> d3390905555
SN ==> d339090555587654321

Figure 4-2 shows the Formatting Action Execution for FA Example 4.

Table 4-9 FA Example 4

Generic Example
Assumptions:
  • Variables (Formatting Actions): PFXA = c, PFXB = b, DN = 669192252645, RN = 1234567890
Formatting Action set = {FA1=PFXA, FA2=RN, FA3=PFXB, FA4=DN}{FA=PFXA, RN, PFXB, DN}
Action ==> Resulting Outgoing Digit String
Begin ==>  
PFXA ==> c
RN ==> c1234567890
PFXB ==> c1234567890b
DN ==> c1234567890b669192252645

Figure 4-2 Formatting Action Execution Example


img/c_formatting_execution_example_npp.png

img/c_formatting_execution_example_npp.png

Outgoing FNAI Class

The calling service sends an incoming NAI value to NPP with the incoming digit string to be processed. NPP maps NAI numerical values to provisioned Filter NAI (FNAI) mnemonic values (NATL, INTL, NAI1, NAI2, NAI3, UNKN). The FNAI values are used in filtering incoming digit strings and NAI values for a service, to determine if NPP will process the string for the calling service.

After successful digit string processing and Formatting Action execution, NPP returns an outgoing NAI value with the outgoing digit string to the calling service.

Each Action Set for a service must indicate by the provisioned outgoing FNAI (OFNAI) mnemonic value that either:
  • The OFNAI mnemonic value will be mapped to a corresponding numerical value to be sent as the outgoing NAI value.
  • The incoming numerical NAI value will be returned to the calling service.