10 Configuring Notifications in ECE
You can configure Oracle Communications Elastic Charging Engine (ECE) to publish in-session notifications to subscribers and system notifications to external applications.
Topics in this document:
- 
                     
                     Enabling ECE to Publish Notifications to External Applications 
- 
                     
                     Replicating Notifications to Kafka Partitions Dedicated to External Applications 
- 
                     
                     Replicating Notifications to Kafka Topics Dedicated to External Applications 
- 
                     
                     Publishing Asynchronous Notifications to a Separate Kafka Topic 
- 
                     
                     Publishing Asynchronous Notifications to Multiple External Topics 
- 
                     
                     Modifying JMS Credentials for Publishing External Notifications 
About ECE Notifications
ECE supports these types of notifications:
- 
                        
                        In-session notifications for your subscribers: These notifications are sent to customers during online charging. For example, notifying customers about their reserved balance amounts. You can configure in-session notifications for individual subscribers by using subscriber preferences. See "Configuring Subscriber Preferences". 
- 
                        
                        Notifications for external applications: These notifications contain information that external applications need. For example: - 
                              
                              The network mediation system can use data from the external notification in conjunction with customer policy data to implement network policy control. ECE sends notifications for external applications to the ECE Notification queue. You must configure your external application to retrieve and process notifications from the ECE Notification queue. 
- 
                              
                              Oracle Communications Billing and Revenue Management (BRM) can use data in the external notification to run billing for a specific customer. ECE sends BRM notifications to the ECE Notification queue. You can configure BRM to retrieve notifications from the queue and send them to the BRM Server for processing. 
 
- 
                              
                              
All notifications are disabled by default. You can configure ECE to do the following:
- 
                        
                        Publish in-session notifications to your subscribers 
- 
                        
                        Publish notifications to external applications, such as BRM 
- 
                        
                        Publish specific notification types to a dedicated Kafka topic 
- 
                        
                        Specify the type of notifications that are supported 
- 
                        
                        Send notifications to everyone in a sharing group when one of its members triggers a notification 
- 
                        
                        Configure BRM Gateway to retrieve notifications from the ECE Notification queue 
Enabling ECE to Publish Notifications to External Applications
To enable ECE to publish notifications to external applications such as BRM, do the following:
- 
                        Open the ECE_home/config/charging-cache-config.xml file. 
- 
                        Under the ServiceContext module, set cache-store to oracle.communication.brm.charging.notification.internal.coherence.AsynchronousNotificationPublisher: <init-param> <param-name>cache-store</param-name> <param-value>oracle.communication.brm.charging.notification.internal.coherence.AsynchronousNotificationPublisher</param-value>
- 
                        Save the file. 
Enabling Specific Notification Types
You can enable ECE to generate notifications for specific event types, such as exceeding a credit limit.
You specify whether a specific notification type is enabled and whether it can be sent to an external application, a subscriber, or both by setting its attribute to one of the values in Table 10-1.
Table 10-1 Notification Attribute Values
| Attribute Value | Description | 
|---|---|
| NONE | This notification type is disabled. | 
| ASYNCHRONOUS | Send asynchronous notifications to external applications. | 
| PIGGYBACK | Send in-session notifications to subscribers through the usage response message. | 
| ASYNC_PIGGYBACK | Send both asynchronous notifications to external applications, and in-session notifications to subscribers through the usage response message. | 
To enable ECE to generate specific types of notifications:
- 
                        
                        Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                        
                        Expand the ECE Configuration node. 
- 
                        
                        Expand charging.notification. 
- 
                        
                        Expand Attributes. 
- 
                        
                        Specify which type of notifications can be sent to your customers, external applications, or both by setting the attributes in Table 10-2 to NONE, ASYNCHRONOUS, PIGGYBACK, or ASYNC_PIGGYBACK. Note: An asterisk (*) appears next to the default attribute value. Table 10-2 Notification Types Attribute Name Description Supported Values creditCeilingBreachNotificationMode Sends notifications when a customer's balance has breached a credit ceiling. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK creditFloorBreachNotificationMode Sends notifications when a customer's balance has breached a credit floor. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK thresholdBreachNotificationMode Sends notifications when a customer's balance has breached a credit threshold. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK topUpNotificationMode Sends notifications when a customer's balance is topped up. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK rarNotificationMode Sends notifications when an ongoing session requires a reauthorization request. NONE* ASYNCHRONOUS externalTopUpNotificationMode Sends notifications when a customer's balance is topped up through an external application. NONE* ASYNCHRONOUS billingNotificationMode Sends notifications when a subscriber starts a charging session near the time billing is set to run in BRM. This ensures that billing generates new recurring grants and charges on time. NONE* ASYNCHRONOUS adviceOfChargeNotificationMode Sends notifications to support the Advice of Charge (AoC) supplementary service. Notifications are sent at the beginning and end of a session. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK replenishPoidIdNotificationMode Sends notifications when ECE needs to obtain POID IDs from BRM. NONE ASYNCHRONOUS* lifeCycleTransitionNotificationMode Sends notifications when a customer's life-cycle state has changed. NONE* ASYNCHRONOUS firstUsageValidityInitNotificationMode Sends notifications to synchronize the validity of first usage balance elements from ECE to external applications. NONE* ASYNCHRONOUS offeringUsageValidityInitNotificationMode Sends notifications to synchronize the validity of offer usage balance elements from ECE to external applications. NONE ASYNCHRONOUS* spendingLimitNotificationMode Sends notifications when a threshold for a policy-driven charging rule has been reached. NONE* ASYNCHRONOUS aggregatedSpendingLimitNotificationMode Sends aggregated notifications when a threshold for a policy-driven charging rule has been reached. NONE* ASYNCHRONOUS subscriberPreferenceUpdateNotificationMode Sends notifications when a subscriber's notifications are updated. NONE* ASYNCHRONOUS rerateJobCreateNotificationMode Sends notifications when a rerate job is created. NONE ASYNCHRONOUS* customEventNotificationMode Sends notifications when a custom event occurs. NONE* ASYNCHRONOUS enrichBalanceQueryResponseMode Enriches the ECE balance query response with the subscriber's preferences. NONE* PIGGYBACK loanGrantNotificationMode Sends notifications when a customer is granted a loan. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK automaticTopUpTriggerNotificationMode Sends notifications when a customer's balance requires an automatic top up. NONE* ASYNCHRONOUS PIGGYBACK ASYNC_PIGGYBACK customBrmOpCodeEventNotificationMode Sends notifications when a custom event requires a call to a BRM opcode. NONE* ASYNCHRONOUS 
Replicating Notifications to Kafka Partitions Dedicated to External Applications
Note:
This functionality applies to ECE systems using the partition-based Kafka architecture only. (That is, the kafkaCustomPartitionAssignorEnabled ECE MBean attribute is set to false).
You can configure ECE to replicate one or more asynchronous notification types and publish them to multiple partitions in the ECE notification topics. This allows you to send the same notification to numerous external applications, with each application consuming notifications from a dedicated partition. For example, ECE could replicate a threshold-breach notification and then:
- 
                        
                        Publish the original notification to Partition 1, which is connected to BRM 
- 
                        
                        Publish the replicated notification to Partition 2, which is connected to Oracle Communications Convergent Charging Controller 
You configure an ECE on-premises installation to replicate one or more asynchronous notification types and publish them to multiple partitions by setting the eventListForInternalExternalPublish attribute in your charging-settings.xml file and then restarting your ECE system. For an ECE cloud native deployment, you set the eventListForInternalExternalPublish attribute in your override-values.yaml file for oc-cn-ece-helm-chart and then run the helm upgrade command.
To configure ECE to publish a notification to multiple partitions in the ECE notification topic without restarting ECE:
- 
                        
                        Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                        
                        Expand the ECE Configuration node. 
- 
                        
                        Expand charging.notification. 
- 
                        
                        Expand Attributes. 
- 
                        
                        In the eventListForInternalExternalPublish attribute, enter the list of notification types to replicate and publish to multiple partitions. Separate multiple notification types with a comma. The default is OFFERING_VALIDITY_INITIALIZATION_EVENT and EXTERNAL_TOP_UP_NOTIFICATION_EVENT. Table 10-3 lists the valid notification types. Table 10-3 Notification Types Notification Type Description SPENDING_LIMIT_NOTIFICATION_EVENT Generated when a threshold for a policy-driven charging rule has been reached. SUBSCRIBER_PROFILE_UPDATE_EVENT Generated when a subscriber preference has been created, modified, and deleted. CREDIT_FLOOR_BREACH_EVENT Generated when a customer's balance has breached a credit floor. CREDIT_CEILING_BREACH_EVENT Generated when a customer's balance has breached a credit ceiling. ADVICE_OF_CHARGE_EVENT Generated when an Advice of Charge (AoC) event occurs. Notifications are sent at the beginning and end of a session. THRESHOLD_BREACH_EVENT Generated when a customer's balance has breached a credit threshold. AGGREGATED_SPENDING_LIMIT_NOTIFICATION_EVENT Aggregated notifications are generated when a threshold for a policy-driven charging rule has been reached. RAR_NOTIFICATION_EVENT Generated when an ongoing session requires a reauthorization request. CUSTOM_EVENT_TYPE Generated when a custom event occurs. BILLING_NOTIFICATION_EVENT Generated when a subscriber starts a charging session near the time billing is set to run in BRM. This ensures that billing generates new recurring grants and charges on time. REPLENISH_POID_ID_EVENT Generated when ECE needs to obtain POID IDs from BRM. EXTERNAL_TOP_UP_NOTIFICATION_EVENT Generated when a customer's balance is topped up through an external application. LIFECYCLE_TRANSISTION_EVENT Generated when a service's life cycle transitions to a new state. FIRST_USAGE_VALIDITY_INIT_EVENT Generated to synchronize validity of first usage balance elements from ECE to external applications. RERATE_CREATE_JOB_EVENT Generated when a rerate job is created. OFFERING_VALIDITY_INITIALIZATION_EVENT Generated to synchronize the validity of offer usage balance elements from ECE to external applications. AUTOMATIC_TOP_UP_TRIGGER_NOTIFICATION_EVENT Generated when a customer's balance requires an automatic top-up. 
Replicating Notifications to Kafka Topics Dedicated to External Applications
Note:
This functionality applies to ECE systems using the topic-based Kafka architecture only. (That is, the kafkaCustomPartitionAssignorEnabled ECE configuration MBean is set to true).
You can configure ECE to replicate one or more asynchronous notification types and publish them to multiple topics. This allows you to send the same notification to numerous external applications, with each application consuming notifications from a dedicated topic. For example, ECE could replicate a threshold-breach notification and then:
- 
                        
                        Publish the original notification to topic 1, which is connected to BRM 
- 
                        
                        Publish the replicated notification to topic 2, which is connected to Oracle Communications Convergent Charging Controller 
ECE creates each notification topic using this naming convention:
Notify.clusterName.consumerGroup[.notificationName][.networkClientId][.eceGatewayId]
where:
- 
                        
                        clusterName is the string that represents the site name from your charging-settings.xml file. The allowable values are BRM1, BRM2, ECE1, ECE2, and so on. 
- 
                        
                        consumerGroup is the name of the consumer group. The possible values are DiamNetwork, RadNetwork, ChfNetwork, Brm, Ext, Suspense, and Overage. 
- 
                        
                        notificationName is the notification event type. This is included for DiamNetwork, RadNetwork, ChfNetwork, Brm, and Ext consumer groups. 
- 
                        
                        networkClientId is used to differentiate the CHF Network (for the HTTP Gateway) from the Diameter Client (for the Diameter Gateway). This is included for DiamNetwork and ChfNetwork consumer groups. 
- 
                        
                        eceGatewayId is the value taken from the Diameter Gateway ID. This is included for DiamNetwork consumer groups. 
The following shows sample notification topic names:
Notify.Ece1.DiamNetwork.RarNotificationEvent.pcrf1.oracle.com.dgw-11 Notify.Ece1.ChfNetwork.SpendingLimitNotificationEvent.ChfNetwork001 Notify.Ece2.RadNetwork.UserDisconnectNotificationEvent Notify.Ece2.Brm.LifecycleTransitionNotification Notify.Ece1.Ext.CreditCeilingBreachNotification Notify.Ece1.Suspense Notify.Ece2.Overage
To configure ECE to replicate one or more asynchronous notification types and publish them to multiple topics, follow the configuration instructions in "Replicating Notifications to Kafka Partitions Dedicated to External Applications".
Publishing Asynchronous Notifications to a Separate Kafka Topic
Note:
This functionality applies to ECE systems using the partition-based Kafka architecture only. (That is, the kafkaCustomPartitionAssignorEnabled ECE configuration MBean is set to false).
By default, ECE publishes asynchronous notifications for external applications to the ECE notification topics.
However, you can configure ECE to publish one or more asynchronous notifications to multiple partitions in a separate Kafka topic (called the ECE External Notification topic). In this case, ECE routes notifications using the customer ID as a partition key, meaning each notification type has a dedicated partition for a given customer.
Having separate partitions allows you to manage notifications more effectively and replicate the external partitions across sites to increase resiliency.
You configure an ECE on-premises installation to publish asynchronous notifications to a separate Kafka topic using the following entries in your charging-settings.xml file and then restarting your ECE system. For an ECE cloud native deployment, you set these entries in your override-values.yaml file for oc-cn-ece-helm-chart and then run the helm upgrade command:
- 
                        
                        externalTopicEnabled: Set this to true. The default is false. 
- 
                        
                        externalTopicName: Set this to the name of the ECE External Notification topic. The default is EceExtNotifications. 
- 
                        
                        externalPartitions: Set this to the total number of Kafka partitions in the external topic. The default is 15. 
- 
                        
                        eventListForECEExternalTopic: Set this to one or more notification types listed in Table 10-3, separated by commas. 
To configure these entries without restarting ECE:
- 
                        
                        Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                        
                        Expand the ECE Configuration node. 
- 
                        
                        Expand charging.kafkaConfigurations.BRM. 
- 
                        
                        Expand Attributes. 
- 
                        
                        Enable the ECE External Notification topic and specify its configuration values: - 
                              
                              externalTopicEnabled: Set this to true. This specifies that the ECE External Notification topic is created and in use. 
- 
                              
                              externalTopicName: Set this to the name of the ECE External Notification topic. 
- 
                              
                              externalPartitions: Set this to the total number of Kafka partitions in the ECE External Notification topic. 
 
- 
                              
                              
- 
                        
                        Under the ECE Configuration node, expand charging.notification. 
- 
                        
                        Expand Attributes. 
- 
                        
                        In the eventListForECEExternalTopic attribute, enter the list of notification types to publish to the ECE External Notification topic. Separate multiple notification types with a comma. See Table 10-3 for the list of valid notification types. 
- 
                        
                        Perform a rolling upgrade of the ecs server. 
Publishing Asynchronous Notifications to Multiple External Topics
Note:
This functionality applies to ECE systems using the topic-based Kafka architecture only. (That is, the kafkaCustomPartitionAssignorEnabled ECE configuration MBean is set to true).
You can configure ECE to publish one or more asynchronous notifications for external applications to multiple external topics, with one topic per notification type. This means each notification type has a dedicated partition for a target external application.
ECE creates the notification topics using this naming convention:
Notify.clusterName.consumerGroup[.notificationName]
where:
- 
                        
                        clusterName is the string that represents the site name from your charging-settings.xml file. The allowable values are BRM1, BRM2, ECE1, ECE2, and so on. 
- 
                        
                        consumerGroup is the name of the consumer group. The possible values are Ext. 
- 
                        
                        notificationName is the notification event type. This is included for the Ext consumer group. 
The following shows sample notification topic names:
Notify.Ece1.Ext.CreditCeilingBreachNotification
To configure ECE to publish one or more asynchronous notifications for external applications to multiple external topics, follow the configuration instructions in "Publishing Asynchronous Notifications to a Separate Kafka Topic".
Enabling In-Session Group Notifications in ECE
You can configure ECE to send notifications to everyone in a sharing group when one of its members triggers a notification. For example, when a member breaches a credit limit or credit threshold, a notification is sent to all members in the sharing group.
When group notifications are disabled, ECE sends notifications only to the member that triggered the notification.
To enable group notifications:
- 
                        
                        Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                        
                        Expand the ECE Configuration node. 
- 
                        
                        Expand charging.server. 
- 
                        
                        Expand Attributes. 
- 
                        
                        Set the groupNotificationEnabled attribute to True. 
- (For firstUsageValidityInitNotificationMode notification types only) Set replicateFirstUsageValidityInitEvent to true.
- 
                        
                        Configure the NotificationEnabledAgreements subscriber preference: - 
                              
                              Add a string for NotificationEnabledAgreements in the BRM_home/sys/msgs/active_mediation/active_mediation.en_US file. For example: STR ID = string_id; Version = 1; STRING = "NotificationEnabledAgreements"; ENDwhere string_id is a unique numerical ID for the string. See "Creating New Strings and Customizing Existing Strings" in BRM Developer's Guide for information about adding strings. 
- 
                              
                              Add NotificationEnabledAgreements to the BRM_home/sys/data/config/config_subscriber_preferences_map.xml file. For example: <SUBSCRIBER_PREFERENCES elem="preference_id"> <NAME>NotificationEnabledAgreements</NAME> <SUBSCRIBER_PREFERENCE_ID>preference_id</SUBSCRIBER_PREFERENCE_ID> <STRING_ID>string_id</STRING_ID> <STR_VERSION>1</STR_VERSION> <DEFAULT></DEFAULT> <TYPE>1</TYPE> </SUBSCRIBER_PREFERENCES> where: - 
                                    
                                    preference_id is a unique numerical ID for the preference. 
- 
                                    
                                    string_id is the same value you used for ID in the active_mediation.en_US file. 
 Note: Leave the <DEFAULT> element blank to ensure that only subscribers who opt in will receive notifications. 
- 
                                    
                                    
 
- 
                              
                              
When group notifications are enabled, you set subscriber preferences at the profile level to enable notifications for the individual subscribers who want to receive them. See "Configuring Group Notifications" for more information.
Including Rollover Balances in Notifications
Rollover data is included in the balance data synchronized from BRM to ECE using the PIN_FLD_ROLLOVER_DATA field. You can customize notifications sent by ECE to include this data using the ECE SDK. To do so, extend ECE at the post-charging extension point to call the getRolloverData() method.
Enriching Notifications Using ECE Extensions
Using the ECE SDK, you can customize the information included in notifications sent by ECE. Enriching the notification payload can help you provide subscribers with relevant data like their initial granted balance, current balance, session ID, and notification type.
To enrich notifications, extend ECE at the post-charging extension point and use the SamplePostChargingExtension program. See "Post-Charging Extension - Enriching Notifications" for more information.
About Configuring BRM Gateway to Process ECE Notifications
ECE publishes notifications intended for external applications to the ECE notification queue. If the notifications are targeted for BRM, BRM Gateway retrieves the notifications from the queue and calls the appropriate BRM opcode. Table 10-4 lists the BRM opcode called for each ECE notification type.
Table 10-4 ECE Notification to BRM Opcode Mapping
| ECE Notification Type | BRM Opcode Called | Description | 
|---|---|---|
| AUTOMATIC_TOP_UP_TRIGGER_NOTIFICATION_EVENT | PCM_OP_PYMT_TOPUP | Generated for top ups made directly via ECE. | 
| BILLING_NOTIFICATION_EVENT | PCM_OP_BILL_MAKE_BILL | Generated when an event occurs after a customer's accounting cycle has terminated. Billing is triggered. Relevant charges and changes in state are synchronized to ECE through the EM Gateway when the opcode completes. | 
| CUSTOM_BRM_OP_CODE_EVENT_NOTIFICATION_EVENT | The opcode called is based on the opcode XML tag. | Permits custom opcodes to be called through the BRM Gateway. | 
| EXTERNAL_TOP_UP_NOTIFICATION_EVENT | PCM_OP_BILL_DEBIT | Synchronizes external top ups, received directly in ECE, for persistence within BRM. | 
| FIRST_USAGE_VALIDITY_INITIALIZATION_EVENT | PCM_OP_BAL_CHANGE_VALIDITY | Initializes BRM-side balance validities based on first-usage alignment configuration. | 
| LIFECYCLE_TRANSITION_NOTIFICATION_EVENT | PCM_OP_CUST_UPDATE_SERVICES | Life cycle transitions are invoked (for things like pre-active to active SIMs), which trigger service status changes on BRM. These changes may indirectly trigger other configured activity. | 
| LOAN_GRANT_EVENT | PCM_OP_LOAN_NOTIFY_THRESHOLD | For triggering loan assessment in BRM (usually a low-balance automatic loan that may permit a session to continue rather than exhaust a customer's credit). | 
| OFFER_VALIDITY_INITIALIZATION_EVENT | PCM_OP_SUBSCRIPTION_SET_VALIDITY | Initializes BRM-side subscription validity based on first-usage alignment configuration. | 
| REPLENISH_POID_ID_NOTIFICATION_EVENT | PCM_OP_GET_POID_IDS | POIDs (used for /item assignment in ECE) are preemptively replenished via this opcode call when about 20% of the initial POID cache is remaining. | 
| RERATE_CREATE_JOB_EVENT | PCM_OP_RERATE_INSERT_RERATE_REQUEST | Triggers rerating requests in BRM. | 
| SUBSCRIPTION_CYCLE_FORWARD_EVENT | PCM_OP_SUBSCRIPTION_CYCLE_FORWARD | Permits triggering of cycle-forward events in BRM whenever a balance (that is considered recurring) is expiring as part of an ongoing ECE session. | 
Configuring BRM Gateway to Process ECE Notifications
Note:
The following steps apply to ECE systems using the partition-based Kafka architecture only. (That is, when the kafkaCustomPartitionAssignorEnabled attribute is set to false.)
To configure BRM Gateway to process ECE notifications, you must connect BRM Gateway to both BRM and the ECE notification topics or queues:
- 
                           
                           When you install ECE: - 
                                 
                                 Add details for connecting the BRM Gateway to the BRM Connection Manager (CM). 
- 
                                 
                                 If you are using Oracle WebLogic Server for notification handling, specify to create WebLogic queues and enter the details for your ECE Notification queue and Suspense queue. 
- 
                                 
                                 If you are using Apache Kafka for notification handling, specify to create Kafka topics and enter the details for your ECE notification topics and Suspense topic. Note: Systems that support 5G networks must use Apache Kafka for notification handling. 
 For more information, see "Installing an ECE Integrated System" in Elastic Charging Engine Installation Guide. 
- 
                                 
                                 
- 
                           
                           During the ECE postinstallation process, do this: - If you are using Oracle WebLogic for notification handling, run the post_Install.pl script to create your ECE Notification queue, Suspense queue, and Acknowledgment queue. See "Creating WebLogic JMS Queues for BRM" in Elastic Charging Engine Installation Guide.
- 
                                 
                                 If you are using Apache Kafka for notification handling, run the kafka_post_install.sh script to create your ECE notification topics and Suspense topic. Then, run the post_Install.pl script and choose to create only the Acknowledgment queue. See "Creating Kafka Topics for ECE" and "Creating WebLogic JMS Queues for BRM" in Elastic Charging Engine Installation Guide. 
 
- 
                           
                           Configure your BRM Gateway instances: - 
                                 
                                 If you want to configure a single BRM Gateway instance, see "Configuring the BRM Gateway". 
- If you want to configure multiple BRM Gateway instances, see "Configuring Multiple BRM Gateway for Multi-Schema Deployments".
 
- 
                                 
                                 
- 
                           
                           Configure the BRM Gateway queues or topics: - 
                                 
                                 If you are using WebLogic queues, see "Configuring WebLogic Queues for BRM Gateway". 
- 
                                 
                                 If you are using Kafka topics, see "Connecting BRM Gateway to Kafka Topics and BRM". 
- 
                                 
                                 If you are using queues from an external application, see "Considerations for Using a Non-WebLogic Server JMS Provider". 
 
- 
                                 
                                 
Configuring the BRM Gateway
You must configure a BRM Gateway instance for each schema in your BRM database. To configure a single BRM Gateway instance:
- 
                           
                           Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                           
                           Expand the ECE Configuration node. 
- 
                           
                           Expand charging.brmGatewayConfiguration. 
- 
                           
                           Expand Attributes. 
- 
                           
                           Use the following attributes to configure BRM Gateway: - 
                                 
                                 name: The name of this BRM Gateway instance. 
- 
                                 
                                 schemaNumber: The number of the database schema BRM Gateway connects to in the BRM database. 
- 
                                 
                                 emptyQueueThreadSleepInterval: Specifies the interval, in milliseconds, in which the gateway thread pings the ECE Notification queue to check if a connection is available when the queue is empty. 
- 
                                 
                                 jmsReceiveSleepInterval: Specifies the interval, in milliseconds, where the BRM Gateway will wait and continue if there are no messages from the Kafka or WebLogic queue. 
- 
                                 
                                 brmResponseTimeOutInterval: Specifies the interval, in milliseconds, where BRM opcode service will wait for all responses from CM. 
- 
                                 
                                 gatewaySleepInterval: Specifies the number of milliseconds between connection retry attempts for the Notification queue. 
- 
                                 
                                 jmsBatchSize: Specifies the maximum number of failed update requests BRM Gateway can retrieve from the Suspense queue in a batch. 
- 
                                 
                                 jmsReceiveTimeout: Specifies the timeout in milliseconds for Kafka/JMS to receive messages from the queue. 
- 
                                 
                                 brmWorkerThreads: Specifies the number of gateway threads, which, as part of the charging settings configuration, is 10 but should not be less than 1. 
- 
                                 
                                 brmSchedulerThreadInitialDelay: Specifies the initial delay in milliseconds before the BRM opcode service task is executed. 
- 
                                 
                                 brmSchedulerThreadDelayPeriod: Specify the interval, in milliseconds, at which the BRM opcode service starts executing continuously within the given period. 
- 
                                 
                                 brmSuspenseQueuePeriod: Specifies the maximum amount of time, in milliseconds, BRM Gateway has to retrieve a batch from the Suspense queue. 
- 
                                 
                                 connectionRetryCount: Specifies the number of times BRM Gateway can retry a connection to the BRM CM after it fails. 
- 
                                 
                                 connectionRetryInterval: The amount of time, in milliseconds, between reconnection attempts to the CM. 
 
- 
                                 
                                 
Configuring Multiple BRM Gateway for Multi-Schema Deployments
You must configure a BRM Gateway instance for each schema in your BRM database, i.e., you cannot have a single BRM Gateway in multi-schema. For example, in a system with three schemas, you must have BRM Gateway 1 connected to Schema 1, BRM Gateway 2 connected to Schema 2, and BRM Gateway 3 connected to Schema 3.
In on-premises systems, you can optionally define more than one BRM Gateway instance for each schema. In this case, ECE automatically makes one of the BRM Gateways active while the other instances are inactive. One of the inactive instances comes online only if the active instance goes down. For example, assume BRM Gateway 1 and 2 are connected to Schema 1. When BRM Gateway 1 is active, it remains active and continues processing ECE notifications until the instance goes down. Then, BRM Gateway 2 becomes active and starts processing notifications.
To configure multiple BRM Gateway instances:
- 
                           
                           Open the ECE_home/config/management/charging-settings.xml file. 
- 
                           
                           Delete the existing charging.brmGatewayConfiguration section: <brmGatewayConfiguration config-class="oracle.communication.brm.charging.appconfiguration.beans.connection.BRMGatewayConfiguration" name="brmGatewayConfiguration" emptyQueueThreadSleepInterval="50" jmsReceiveSleepInterval="100" brmResponseTimeOutInterval="600000" gatewaySleepInterval="2000" jmsBatchSize="10" jmsReceiveTimeout="2000" brmWorkerThreads="10" brmSchedulerThreadInitialDelay="10" brmSchedulerThreadDelayPeriod="3" brmSuspenseQueuePeriod="1800000" connectionRetryCount="10" connectionRetryInterval="10000"> </brmGatewayConfiguration>
- 
                           
                           Copy the following charging.brmGatewayConfigurations section into the file: <brmGatewayConfigurations config-class="oracle.communication.brm.charging.appconfiguration.beans.connection.BRMGatewayConfigurations"> <brmGatewayConfigurationList config-class="java.util.ArrayList"> <brmGatewayConfiguration config-class="oracle.communication.brm.charging.appconfiguration.beans.connection.BRMGatewayConfiguration" name="brmGatewayN" clusterName="@CLUSTER_NAME@" emptyQueueThreadSleepInterval="50" jmsReceiveSleepInterval="100" brmResponseTimeOutInterval="600000" gatewaySleepInterval="2000" jmsBatchSize="10" jmsReceiveTimeout="2000" brmWorkerThreads="10" brmSchedulerThreadInitialDelay="10" brmSchedulerThreadDelayPeriod="3" brmSuspenseQueuePeriod="1800000" connectionRetryCount="10" connectionRetryInterval="10000" schemaNumber="N"/> </brmGatewayConfigurationList>
- 
                           
                           Under brmGatewayConfigurationList, add this section for each additional BRM Gateway instance that you want to create: <brmGatewayConfiguration config-class="oracle.communication.brm.charging.appconfiguration.beans.connection.BRMGatewayConfiguration" name="brmGateway" clusterName="@CLUSTER_NAME@" emptyQueueThreadSleepInterval="50" jmsReceiveSleepInterval="100" brmResponseTimeOutInterval="600000" gatewaySleepInterval="2000" jmsBatchSize="10" jmsReceiveTimeout="2000" brmWorkerThreads="10" brmSchedulerThreadInitialDelay="10" brmSchedulerThreadDelayPeriod="3" brmSuspenseQueuePeriod="1800000" connectionRetryCount="10" connectionRetryInterval="10000" schemaNumber="1"/> </brmGatewayConfigurationList>
- 
                           
                           Edit these properties for each BRM Gateway instance: - 
                                 
                                 name: Set this to the name of your BRM Gateway instance in this format: brmGatewayN. For example, name the first instance brmGateway1, the second instance brmGateway2, and so on. 
- 
                                 
                                 schemaNumber: Set this to the schema number that the BRM Gateway instance connects to in the BRM database. Enter 1 to connect to the first schema, 2 to enter the second schema, and so on. 
 
- 
                                 
                                 
- 
                           
                           Save and close the charging-settings.xml file. 
- 
                           
                           Stop BRM Gateway: stop brmGateway
- 
                           
                           Open the ECE_home/config/eceTopology.conf file. 
- 
                           
                           Add a row to the file for each BRM Gateway instance. For example, to configure three BRM Gateway instances, add three rows in which the node name value is brmGateway1, brmGateway2, and brmGateway3, and the role value for all three rows is brmGateway: #node-name |role |host name (no spaces!) |host ip |JMX port |start CohMgt |JVM Tuning File brmGateway1 |brmGateway |localhost | |9994 |false |defaultTuningProfile brmGateway2 |brmGateway |localhost | |9994 |false |defaultTuningProfile brmGateway3 |brmGateway |localhost | |9994 |false |defaultTuningProfile 
- 
                           
                           Save and close the eceTopology.conf file. 
- 
                           
                           From the ECE_home/bin directory, start Elastic Charging Controller (ECC): ./ecc
- 
                           
                           Start all BRM Gateway instances: start brmGateway
Connecting BRM Gateway to Kafka Topics and BRM
To connect BRM Gateway to the ECE Notification Kafka topic and BRM:
- 
                           
                           Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                           
                           Expand the ECE Configuration node. 
- 
                           
                           Expand charging.server. 
- 
                           
                           Expand Attributes. 
- 
                           
                           Set the kafkaEnabledForNotifications property to true. 
- 
                           
                           Expand charging.kafkaConfigurations. 
- 
                           
                           Expand Attributes. 
- 
                           
                           Specify the Kafka configuration values for the attributes in Table 10-5. Verify that the name, hostname, and topic names that you provide match the settings entered when installing ECE. Table 10-5 Settings for Connecting BRM Gateway to Kafka Topics Property Name Description name The name of your ECE cluster. hostname The host name and port number of the machine in which Apache Kafka is up and running. If it contains multiple Kafka brokers, create a comma-separated list. topicName The name of the Kafka topic in which BRM Gateway retrieves notifications from ECE. partitions The total number of Kafka partitions in your topics. The recommended number to create is calculated as follows: [(Max Diameter Gateways * Max Peers Per Gateway) + (1 for BRM Gateway) + Internal Notifications] kafkaBRMReconnectionInterval The amount of time, in milliseconds, BRM Gateway waits before attempting to reconnect to the Kafka topic. kafkaBRMReconnectionMax The maximum amount of time, in milliseconds, BRM Gateway waits before attempting to reconnect to a broker that has repeatedly failed to connect. The kafkaBRMReconnectionInterval will increase exponentially for each consecutive connection failure up to this maximum. 
- 
                           
                           Expand charging.connectionConfigurations.brmConnection. 
- 
                           
                           Expand Attributes. 
- 
                           
                           Specify the configuration values for connecting BRM Gateway to the BRM Connection Manager (CM): - 
                                 
                                 hostName: Enter the host name of the server in which the CM is running. For example: abc01.example.com. 
- 
                                 
                                 loginName: Enter the user name for logging in to BRM. The default is root.0.0.0.1. 
- 
                                 
                                 cmPort: Enter the port number for the BRM CM. 
 
- 
                                 
                                 
About BRM Gateway Error Handling
When BRM Gateway calls an opcode, it checks whether the opcode ran successfully. If it did not, the exception from the opcode is checked and, if the exception is one of the following, it retries the opcode call.
- 
                              
                              ERR_TIMEOUT 
- 
                              
                              ERR_DEADLOCK 
- 
                              
                              ERR_STREAM_EOF 
- 
                              
                              ERR_IM_CONNECT_FAILED 
- 
                              
                              ERR_EM_CONNECT_FAILED 
- 
                              
                              ERR_NAP_CONNECT_FAILED 
If the opcode continues to fail after all of the configured retry attempts, the notification is moved to the Suspense topic.
If the exception is due to a duplicate message (ERR_DUPLICATE), the opcode call is not retried and the message is not moved to the Suspense topic.
Configuring WebLogic Queues for BRM Gateway
To configure WebLogic queues for BRM Gateway:
- 
                           
                           Access the ECE configuration MBeans in a JMX editor, such as JConsole. See "Accessing ECE Configuration MBeans". 
- 
                           
                           Expand the ECE Configuration node. 
- 
                           
                           Expand charging.connectionConfigurations.brmConnection. 
- 
                           
                           Expand Attributes. 
- 
                           
                           Use the following attributes to specify connection values to the BRM Connection Manager (CM): - 
                                 
                                 loginName: Enter the user name for logging in to BRM. The default is root.0.0.0.1. 
- 
                                 
                                 hostName: Enter the IP address or the host name of the computer on which BRM is configured. 
- 
                                 
                                 cmPort: Enter the port number for the BRM CM. 
 
- 
                                 
                                 
Setting the Transaction Timeout for the connectionFactory
For the connectionFactory created within the WebLogic server for creating connections to the JMS topic, do the following:
Refer to the Oracle WebLogic Server documentation for information about setting up a JMS topic on WebLogic Server.
- 
                              
                              Log on to the WebLogic Server on which the JMS topic resides. 
- 
                              
                              Click Edit Tree, then Services, and then JMS Modules. The Summary of JMS Modules page appears. 
- 
                              
                              In the JMS Modules table, click the JMS topic used for ECE notifications. 
- 
                              
                              Click Connection Factories in the tree in the left pane. 
- 
                              
                              In the JMS Connection factories table, click NotificationFactory. 
- 
                              
                              Click the Transaction tab and set the Transaction Timeout field to 2147483647. 
- 
                              
                              Click Save. 
- 
                              
                              Click the shopping cart  at the top right, and then click Commit Changes to commit your
                    changes. at the top right, and then click Commit Changes to commit your
                    changes.
Considerations for Using a Non-WebLogic Server JMS Provider
If you choose to use a JMS provider other than WebLogic Server for publishing ECE notification events, you must do the following on the driver machine:
- 
                           Copy the other JMS provider's client JARs to the ECE_home/lib directory. 
- 
                           Rename the other JMS provider JAR file to wlthint3client.jar. 
- 
                           Update the ECE_home/config/JMSConfiguration.xml file to specify the InitialContextFactory and protocol information of the other JMS provider. 
Modifying JMS Credentials for Publishing External Notifications
When you install ECE, you can specify to publish notifications to a WebLogic JMS queue (named ECE Notification queue) as well as how to connect to the queue.
If you need to change the connection information after ECE is installed, you can edit the parameters in the JMSConfiguration.xml file.
To modify the JMS credentials in ECE, do the following:
- 
                        Open the ECE_home/config/JMSConfiguration.xml file. 
- 
                        Locate the <MessagesConfigurations> section. 
- 
                        Specify the values for the parameters in the NotificationQueue section: Note: Do not change the value of the JMSDestination name parameter. - 
                              For the HostName parameter, specify the host name of the WebLogic server on which the JMS topic resides. 
- 
                              For the Port parameter, specify the port number on which the WebLogic server resides. 
- 
                              For the UserName parameter, specify the user for logging in to the WebLogic server. This user must have write privileges on the JMS topic created. 
- 
                              For the Password parameter, specify the password for logging in to the WebLogic server. When you install ECE, the password you enter is encrypted and stored in the KeyStore. If you change the password, you must first run a utility to encrypt the new password before entering it here. 
- 
                              For the ConnectionFactory parameter, specify the connectionFactory created within the WebLogic server for creating connections to it. You must also configure settings in the WebLogic server for the connectionFactory. See "Setting the Transaction Timeout for the connectionFactory" for information. 
- 
                              For the QueueName parameter, specify the JMS topic. This is the JMS topic which holds the published external notification messages. 
- 
                              For the Protocol parameter, specify the wire protocol used. For the WebLogic server, set this to t3://. 
 
- 
                              
- 
                        Save and close the file.