This application claims the benefit of EPO Application No. 06425191.1, filed Mar. 22, 2006 and Italian Application No. BS2006A000065, filed Mar. 22, 2006, both of which are incorporated herein by reference in their entirety.
1. Technical Field
This invention relates to telecommunications processing systems. In particular, this invention relates to a flexible and independent messaging interface between telecommunications service provider processing systems.
2. Related Art
Rapid advances in data processing and telecommunications technology have lead to a vast array of communication services available to the consumer. Such telecommunication services include traditional telephone service, Internet service, cable television service, cellular phone service, paging service, combined voice and data delivery service, and many other services.
The advances in technology, though rapid, did occur over time. As a result, many telecommunications services providers began with telecommunications system architectures directly supporting a small subset of the services now available today. The early architectures were specific to individual services, such as wireline telephone services. Furthermore, the architectures commonly employed service specific billing systems, such as billing systems tailored for wireline telephone billing. While these service specific billing systems were well suited for implementing billing related functions, these systems may not be optimized for other tasks, such as managing billing data and the like.
Beyond billing systems, each architecture also included other dedicated supporting systems, such as customer care systems. The customer care systems were responsible for communicating and receiving messages to and from the billing systems, such as messages which established new customers. In other words, as they began to offer more products and services, telecommunications service providers were faced with the time consuming, expensive, and difficult task of installing, maintaining, and upgrading multiple independent systems in multiple independent architectures.
As these systems were integrated into a unified architecture, developers took advantage of the built-in functionality of pre-existing billing systems and developed tightly coupled systems. As a result, enhancing legacy architectures poses significant technical challenges. One technical challenge lies in extending functionality to process new products and services, because the tightly coupled nature of current integrations has left the architectures limited to performing only those functionalities offered by the legacy billing systems. Thus, previous architectures could only support limited function sets supported by the legacy systems and associated integration components. In other words, these systems could be integrated only to the degree that the underlying support system offered functions for performing given tasks. Another technical challenge is tracking message processing. In the past, message tracking was limited by the functionalities of the legacy systems. Typically, legacy billing systems do not provide any capability to enable the tracking of an entity's identifier exchanged between messages from, for example, a CRM system to the billing system. As a result, telecommunication service providers are left exposed to the risk of duplicated data due to the multiple processing of the same message. Moreover, these limitations make the analysis of any rejected messages, such as invalid messages, extremely complex. These limitations hamper the telecommunications industry, which is one that continually needs to improve and evolve its existing products and services, and which frequently introduces new products and services.
Accordingly, a need has long existed for an improved rating system for a telecommunications service provider.
A messaging interface implements several technical solutions to the technical problems associated with efficiently, flexibly, and reliably extending the functionality of a telecommunications service provider processing architecture in order to facilitate communications between telecommunication service provider processing systems. As a result, the messaging interface reduces the difficulty, cost, and time expenditures typically associated with integrating a new component into the architecture. The messaging interface also eliminates duplicative processing of events, as well as the duplicative storage of information and duplicative communications among the various telecommunication service provider processing systems which flow as a result of the additional processing.
One technical solution is layering the functionalities of the messaging interface to make the messaging interface highly reusable and extendible. Specifically, functionalities of the messaging interface that depend on the underlying support system may be logically separated from those functionalities that are independent of the underlying support system. As a result, only certain layers of the messaging interface may need to be adapted to integrate a new support system into the architecture. The remaining layers need not change.
Another technical solution lies in removing core message processing from the underlying support system and relocating the processing to the messaging interface. In the past, system architects were at the mercy of the processing performance and functionalities of the underlying support system. By moving message processing to the messaging interface, the system architect can define a common set of message or events that may be used across multiple different support systems. Again, this alleviates the dependency of the architect on the capabilities of the support system, and allows the architect to choose from a wider variety of underlying support systems. This also allows for more efficient processing of messages by freeing the underlying support system to only perform processing related to its underlying function, such as billing related processing for example, while allowing message processing, routing, and tracking to be performed outside of the underlying support system.
Another technical solution is provided in maintaining hierarchical relationships between support systems. In particular, the hierarchies of data elements in one system may be maintained as data is transferred through the architecture, such as hierarchical relationships between products, services and the like. This ensures the integrity of product offerings and the like, for example, such that child products or services may not be inadvertently processed without an underlying parent product. As a result, duplicative and/or erroneous processing of events is eliminated.
Yet another technical solution is provided by maintaining a correlation between support system specific product identifiers. For example, a table may be used to store identifiers of products, services and the like. Identifiers used in specific support systems may be associated such that the table provides a mapping from the identifier used in one system to a corresponding identifier used in a second system. This mapping allows the interface to track processing of orders and verify that account modifications are intended for valid products that already exist in each system, eliminating duplicative and/or erroneous processing by the systems.
In one aspect, a messaging interface for communication between telecommunications service provider processing systems is provided. The messaging interface may include a product instance table that includes multiple records which establish interrelationships between a first product instance identifier associated with a first telecommunications service provider processing system and a second product instance identifier associated with a second telecommunications service provider processing system.
The messaging interface may also include a memory. The memory may include message parameters which report an event. The event may be part of a common data model used across multiple telecommunication service provider systems. For example, the events may include a ‘Create Customer’ business event, a ‘Modify Customer General Data’ event, a Modify Customer Fiscal Address Data event, a Create Billing Account Data event, a Modify Billing Account General Data event, a Modify Billing Account Billing Profile Data event, a Modify Billing Account Bill-to Person Data event, a Modify Billing Account Bill-to Address Data event, a Modify Billing Account Payment Data event, or an Service Order event.
The messaging interface may also include an interface program operable to implement the event in the second telecommunications service provider processing system. The interface program may include instructions which determine the first product instance identifier using at least one of the message parameters, perform an action on the second telecommunications service provider processing system associated with the second product instance identifier, and update the product instance table using the first product instance identifier and the second product instance identifier. Finally, a processor may be coupled to the memory and the product instance table which executes the interface program.
Other systems, methods, features and advantages of the invention will be, or will become, apparent to one with skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description, be within the scope of the invention, and be protected by the following claims.
The invention can be better understood with reference to the following drawings and description. The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention. Moreover, in the figures, like referenced numerals designate corresponding parts or elements throughout the different views.
The elements illustrated in the Figures interoperate as explained in more detail below. Before setting forth the detailed explanation, however, it is noted that all of the discussion below, regardless of the particular implementation being described, is exemplary in nature, rather than limiting. For example, although selected aspects, features, or components of the implementations are depicted as being stored in memories, all or part of systems and methods consistent with the messaging interface may be stored on, distributed across, or read from other machine-readable media, for example, secondary storage devices such as hard disks, floppy disks, and CD-ROMs; a signal received from a network; or other forms of ROM or RAM either currently known or later developed.
Furthermore, although specific components of the communications architecture will be described, methods, systems, and articles of manufacture consistent with the messaging interface may include additional or different components. For example, a processor may be implemented as a microprocessor, microcontroller, application specific integrated circuit (ASIC), discrete logic, or a combination of other type of circuits or logic. Similarly, memories may be DRAM, SRAM, Flash or any other type of memory. Flags, data, databases, tables, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be distributed, or may be logically and physically organized in many different ways. Programs may be parts of a single program, separate programs, or distributed across several memories and processors. Systems may be implemented in hardware, software, or a combination of hardware and software in one processing system or distributed across multiple processing systems.
The customer care management system 102 includes a processor 114, a memory 116, and a customer database 118. The customer care management system 102 also includes a communication interface 120. A customer care management program 122 in the memory 116 prepares messages 124.
In one implementation, the processor 114 in the customer care management system 102 executes Siebel™ 7.8 CME and Siebel™ Server under the Windows™ operating system, the UNIX operating system, the SUN Solaris™ operating system, or any other operating system. Additionally, an Oracle™ or Microsoft™ SQL server platform may implement the customer database 118. However, additional or different customer care management programs may be implemented in the customer care management system 102.
The customer care management system 102 communicates the messages 124 through the communication interface 120 to the messaging interface 104. A message may define an event, such as a request for the creation of a customer account in the billing system. Alternatively, multiple messages 124 may be used to define a single event, or a single message 124 may define multiple events. Exemplary messages or events are described in more detail below. The messaging interface 104 may also include a processor 126 and a memory 128.
As shown in
The messaging interface 104 may include layers that separate certain functionalities of the interface 104. As illustrated, the interface 104 may include an integration layer 130, an event layer 132, an logic layer 134, and an API layer 136. The integration layer 130 may convert a message 124 to a representation that conforms to a standard or common data model that is enforced across two or more of the systems 102 and 106 of the architecture 100.
The event layer 132 may include functions for transforming the standard or common data model representation into data types for use in a specific system of the architecture 100. The logic layer 134 may include logic for managing calls to system specific functions available through an API layer 136 offered by a specific system of the architecture 100. The logic layer 134 may invoke these functions to implement a message 124 in the underlying support system 106 of the architecture 100. Finally, the messaging interface 104 may be coupled with a product instance table 137 for maintaining relationships between identifiers used to track products, services, and the like, in the various support systems of the architecture 100. Herein, the phrase “coupled with” is defined to mean directly connected to or indirectly connected through one or more intermediate components. Such intermediate components may include both hardware and software based components. The layers and their respective functionalities, as well as the product instance table 137, are described in more detail below.
The support systems 106 include the billing system 108.
Communication between the customer care management system 102, the messaging interface 104, and the support systems 106 may be accomplished in many ways. In some implementations, the communication interfaces 120, 136, 146, 150, and 154 may be network sockets defined by IP addresses, port numbers, and communication protocols. The messages may travel between the systems 102, 104, and 106 according to a wide range of protocols, including Tibco™ Rendezvous Messaging protocol, IBM MQseries™ protocol, Java Message Service protocol, or HTTP. In other implementations, the systems 102, 104, and 106 communicate via interprocess communication, messaging, or signaling.
The architecture 100 may incorporate message passing and application integration technologies such as TIBCO Business Work™ messaging, BizTalk™ messaging, BEA WLI™ and Vitria™ telecommunications solutions. Adapters may be provided between the customer care management system 102 and the message routing system 104, as well as between the messaging interface 104 and the support systems 106. The adapters may support transformation of the messages and/or message content from a format defined by one schema (e.g., a schema for messages to adhere to in the customer care management system 102) to another format defined by another schema (e.g., a schema for messages to adhere to in the messaging interface 104 and/or support systems 106).
In one implementation, the messages 124 may contain data described by extensible Markup Language (XML) tags and the adapters perform transformation according to extensible Stylesheet Language for Transformations (XSLT) stylesheets. The transformations may transform data between schemas for any of XML, Web Service Definition Language (WSDL), extensible Scheme Diagram (XSD), as examples. The messages may move between systems using any kind of transportation or data access protocol, including HTTP, Simple Object Access Protocol (SOAP), or other protocols in place at the customer care management system 102, messaging interface 104, and/or support systems 106. As described above, the messages 124 may represent the occurrence of or a request for an event to be processed by the support systems 106, such as the billing system 108.
As shown in
In one implementation, the Customer related events 210 include a CreateCustomer business event 212, a ModifyCustomerGeneralData business event 214, and a ModifyCustomerFiscalAddress business event 216. The CreateCustomer event 212 may occur when an order for a new customer is submitted. When the first order for a new customer is submitted, a CreateCustomer message 212 may be sent including the information used to create the account hierarchy in the billing system 108. The CreateCustomer event 212 may be mapped to a specific entity, such as any data field in the billing system database 144, so as to support the same customer and billing account hierarchy in the customer care system 102 and the billing system 108. In the implementation supported by the data model described below with regard to
The ModifyCustomerGeneralData event 214 may be used to update any of the customer general data attributes. Customer general data may refer to any customer account data. For example, customer general data may include data about the address of the customer and other customer specific information like name, personal ID or customer type. In one implementation, the customer type may include an individual or residential type, or business type. Optionally, specific business events may modify data associated with a customer. For example, the ModifyCustomerFiscalAddress event 216 may update the fiscal address of a customer. Exemplary XML messages defining a ModifyCustomerGeneralData event 214 and a ModifyCustomerFiscalAddress event 216 are shown in Tables 2 and 3, respectively.
The Billing Account related events 220 may include events for handling data related to billing accounts. In one implementation, the Billing Account related events 220 may include a CreateAccount event 221, a ModifyAccountGeneralData event 222, a ModifyAccountBillingProfile event 223, a ModifyAccountBillToPerson event 224, a ModifyAccountBillToAddress event 225, and a ModifyAccountPaymentData event 226. The CreateAccount event 221 may occur when an order for a new account is submitted. The CreateAccount event 221 may include information for recreating the account hierarchy in the billing system 108. The information may include a billing account code, a customer code, bill account code, a bill start date, a billing account object, a billing profile object, a payment data object, an address object, a contact object, and the like. The billing account objection may include a reason for a bill status change field, a bill status code field, a currency code field, a language field, an organizational code field, a tax type field, an account type field, and the like. The billing profile object may include a bill frequency field, a bill type field, a media type field, a payment method field, and the like. The payment data object may include a bank account number field, bank account type field, a bank branch field, a bank name field, a payer first name field, a payer last name field, a payer personal ID field, a credit card expiration date field, a credit card number field, a credit card type field, and the like. Finally, the address object may include a street type field, an address number field, a city field, a ZIP code field, a state field, a country field, a contact field, a contact first name field, a contact last name field, a contact title field, a contact phone field, a contact email field, an greetings field, and the like. The greetings field may be used to address the contact on the bill, and may include, for example, the concatenation of the Contact title, first name, and last name fields. Other information may also be used. An exemplary XML message defining a CreateAccount event 221 is shown in Table 4.
A ModifyAccountGeneralData event 222 may occur when general information about a billing account needs to be updated. For example, general data for a billing account may include a reason for the status change, a status code, a currency code, a language identifier, an organizational code, a tax type, and an account type. Other data items may also be included. An exemplary XML message defining a ModifyAccountGeneralData event 222 is shown in Table 5.
The ModifyAccountBillingProfile event 223 may occur when information about the invoice for a billing account changes. Information related to a billing invoice may include the bill period, bill format, media type, payment method, and the like. The ModifyAccountBillToPerson event 224 may occur when information about a registered person of the billing account changes. This event 224 may include information such as first name, last name, phone number, and the like. The ModifyAccountBillToAddress event 225 may occur when information about the shipment address of a billing account changes. Information related to the shipment address may include a street name, address number, city, state, zip code, and the like. The ModifyAccountPaymentData event 226 may occur when information about the bank account and/or credit card data used to make payments on the billing account change. Information related to a bank account and/or credit card may include a bank account number, bank account type, bank branch, bank name, payer first name, payer last name, payer personal ID, credit card expiration date, credit card number, credit card type, and the like. Exemplary XML messages defining a ModifyAccountBillingProfile event 223, a ModifyAccountBillToPerson event 224, a ModifyAccountBillToAddress event 225, and a ModifyAccountPaymentData event 226 are shown in Tables 6, 7, 8, and 9, respectively.
Service order related events 230 may be used for handling the processing of orders for products and services. For example, service order events 230 may be indicative of a transaction originating in a CRM system. As a consequence of the transaction, the service order event 230 may be generated and passed to the billing system. In one implementation, an AssetComponent event 232 may be used to indicate a CRM transaction, and may include information related to products and/or services and the account that should be updated. For example, an AssetComponent event 232 may occur when a service order needs processing, or when information about discounts and provisioning need updating. An AssetComponent event 232 may include a root instance ID, a parent instance ID, a product instance ID, an action code, a product catalogue ID, a service ID, a tariff ID, a start date for the product or service, a modify date for the product or service, an end date for the product or service, a list of attributes for the product or service, and the like. The list of attributes may include a plurality of attribute objects that define an attribute action code, attribute name, attribute value, and the like. An exemplary XML message defining an AssetComponent event 232 is shown in table 10. An exemplary attribute object defined in XML is shown in Table 11.
The action code may define the set of actions associated with a product or service that may be performed by the billing system 108. For example, the billing system may be able to add a product or service, delete a product or service, suspend a product or service, resume a product or service, or update a product or service. These actions may have corresponding actions codes such as “add,” “delete,” “suspend,” “resume,” and “update,” respectively. Other actions and corresponding codes may also be used. Specific implementations for performing these various actions are described in more detail below with reference to
As noted above, telecommunication service providers offer interrelated products and services. As described in more detail below, these products and services may be represented hierarchically as a single entity. Accordingly, AssetComponent events 232 may be serviced in various manners. For example, a bundle processing integration model may be implemented in which the entire hierarchical product structure is included in the event 200. For example, a customer may order a cell phone as a parent product, as well as a voicemail service for use on the phone. Under a bundle processing methodology, a single AssetComponent event 232 may be used to represent the ordering of the phone and voicemail. Alternatively, a per-partes processing integration model may be implemented in which each base or child product or service is processed individually. Referring to the example above, two AssetComponent events 232 may be used under a per-partes processing system, one to activate the phone and a second for activating the voicemail. Other processing methods may also be used. The processing of AssetComponent events 232 are discussed in further detail below in reference to
The customer entities 310 represent customer data, and may include an organizational entity 312. For example, a customer entity 310 may represent the legal entity representing the customer data, such as the entity contractually related to the telecommunication service provider and that may be responsible for any dunning action resulting from a failure to promptly pay for products and/or services. The organizational entity 312 may have a one-to-many relationship with customer entities 314. As shown in
The order and subscription entities 330 represent orders and subscription data. In the implementation shown in
The logical data model 300 may also include product and service catalogue entities 350. The product and service catalogue entities 352 may define a catalogue of products and services offered by the telecommunications services provider, and may include product and service entities that define archetypical products and services offered by the telecommunications services provider, attribute entities 354 that define attributes of the products and services, and price list entities 356 that define pricing structures for the product and service.
In order to ensure consistency among the various systems of the telecommunications network 100, it may be important to maintain the hierarchical relationships of the logical data model across systems. For example, it may important to avoid processing child products and services if the parent product with which they are associated does not exist. Similarly, maintaining the hierarchical relationship between products and services may also avoid duplicative billing and inaccurately processing bundled packages. Alternatively, or additionally, it may be advantageous to maintain the hierarchical relationship between the customer entities 314 and billing account entities 320 for similar reasons. For example, discounted products and/or services may be offered for preferred customers 314 that maintain multiple billing accounts. By maintaining the hierarchical relationship between customers 314 and billing accounts 320, the interface 146 may ensure that business events may be processed correctly.
Similarly, relationships among products may also be maintained. For example, main product entities 416 may include one or more component services 422 and child products 428 in accordance with the data model 300. The interface 104 may map these entities to corresponding fields in the support system, such as fields 446, 452, and 458 as illustrated. Additionally, other data items may also be mapped from the common data model to support system equivalents. For example, parent product attributes 418 and event source information 420, component service attributes 424 and event source information 426, child product attributes 430, and discounts 432 and discount attributes 434 may be associated with specific fields of the support system database, such as fields 448, 450, 454, 456, 460, 462, and 464 respectively as illustrated.
As illustrated in
The event layer 132 may perform further processing of the shared object 521. For example, the event layer 132 may convert the shared objects 521 into normalized objects 523. The normalized objects 523 may represent an abstraction of the shared object 521 that maintains the relationships defined in the shared object 521 but is structured in terms of billing system 108 entities. In other words, the normalized object 523 may be representation of the shared object 521 that is compliant with the underlying billing system. The event layer 132 may also convert a normalized object 523 into primitive data types 534, such as integers and the like, for use with the billing system 108. The primitive data types 534 may not maintain the relationships of the logical model 300, and may be based on Application Programming Interfaces (APIs) developed for use with the billing system 108. For example, the API may expose specific entities associated with the billing system 108, such as fields in a billing system database 108, by including functions for accessing and manipulating these entities. In order to perform this processing, the event layer 132 may invoke various functionalities of a common shared object library 522, normalized object library 524, and functions from the billing system API, such as hashes conversion functions 526, to convert the normalized object to more primitive data types 534.
The logic layer 134 may manage the set of calls to the billing system 108 in order to implement the business events 300. For example, the logic layer 134 calls functions associated with an API of the billing system 108, which reside at the API layer 136, to process a message or event. For example, one or more API calls may implement a specific event, such as creating a new customer account in the billing system and populating that account with customer account data. Depending on the message or event to be processed, the interface 104 may call various functions. The logic layer 134 may utilize the primitive data types 534 in order to implement these function calls.
The example shown in
By segmenting the functionality of the interface 104 into layers, the interface 104 may be more readily reusable. For example, the functionalities of the interface layer 130 do not depend on the underlying support system 106. Accordingly, the same integration layer 130 may be used to support a multitude of underlying support systems 106. In order to configure the interface for a specific support system 106, a system architect may modify the event layer 132 to create normalized objects 523 for the new support system 106 and modify the logic layer to call those functions offered by the new support systems' API 136. As a result, message or event processing may be standardized within the interface 104, and the architecture 100 may readily take advantage of a wide variety of support systems without worrying about the event handling limitations of those underlying support systems 106.
Next, the integration layer of the messaging interface converts the message into a shared object (act 604) that represents a common data model 300 representation of the event 232. Once the shared object is formed, the interface 104 proceeds to convert the shared object to a normalized object. A two-step process may be used perform this conversion. First, the interface 104 may identity product configuration data associated with the product or service (act 606). Product configuration data may include data needed by the underlying billing system and that may be used during the conversion of a shared object 521 to a normalized object 523. Next, the interface 104 may extract product data from the shared object representation (act 608). This data may include actual product attributes supported by the data model 300 as well as derived attributes for use in the underlying support system 106.
As noted above,
Next, the product and/or service data may be aggregated and transformed into a normalized object using entities of the billing system 108 (act 618). As noted above, the normalized object represents a hierarchical view of the AssetComponent defined in terms of support system entities, such as entities used by the billing system 108. The normalized object may then be converted into more primitive data forms for use by the billing system, such as integers, strings, and the like (act 620).
Once the data is suitable for processing by the billing system 108, the interface may call a series of functions supported by the billing system 108 to process the request (act 622). As illustrated, the interface 146 may invoke functions, for example, by a remote procedure call or the like, to create, delete and/or update a parent product instance in the billing system (act 624), create, delete and/or update a base service instance in the billing system (act 626), create, delete and/or update a child product instance in the billing system (act 628), create, delete and/or update a child service instance in the billing system (act 630), populate any additional derived attribute data in the billing system (act 632), and to complete processing of a product or service instance in the billing system (act 634). Finally, the interface 146 may process and encode the result of the call (act 636) and send this reply back to the architectural component that initiated the event (act 638). This may include a valid or successful result, an error code, and the like.
The interface 104 may also insert child products into the billing system 108. Depending on the integration model employed, the acts of the interface 146 may vary. As illustrated, the interface 104 may insert the child product directly into the billing system database 548 (act 712) and product instance table 137 (act 714) when implementing bundle processing. However, when per-partes processing is employed, the interface 104 may determine if an entry exists for the child product. If there is no corresponding entry, a new instance is inserted into the billing system database 548 (act 716) and the product instance table 137 (act 718). If an entry does exist, however, only a new product instance entry may need to be inserted (act 718).
Alternatively, the action code may include a resume request. If a matching entry does not exist for a child product associated with a resume request, an error may be thrown (act 1008). If a match is present, a check may be performed to verify that the current status of the child product or service is ‘suspend,’ If not, no action may be necessary. If the child product or service is currently suspended, the product instance table 137 (act 1004) may be updated to reflect the change in status. Similarly, a suspend or cancel request may throw an error if no the child product or service does not already have a corresponding entry in the product instance table 137 (act 1008). If all services associated with the child product or service are suspended or canceled (depending on the type of request), the product instance table 137 may be updated (act 1004).
The messaging interface 104 employs several technical solutions to the technical problems of efficiently, flexibly, and reliably extending the functionality of a telecommunications service provider processing architecture in order to facilitate communications between telecommunication service provider processing systems. As a result, a system architect is not limited by the time consuming complexities typically associated with integrating a new component into the architecture.
One technical solution is the use of layering the functionalities of the interface 104 to make the interface 104 as reusable as possible. Functionalities that depend on the underlying support system 106 to be integrated may be separated from those dependent functionalities so that only a small portion of the interface 104 may need to be adapted for integrating a new support system 106.
Another technical solution lies in removing core message or event processing from the underlying support system 106 to the interface 104. In the past, system architects were at the mercy of the processing performance and functionalities of the underlying support system 106. By moving this aspect to the interface 104, the system architect can define a common set of message or events that may be used across multiple different support systems 106. Again, this alleviates the dependency of the architect on the capabilities of the support system 106, and allows the architect to choose from a wider variety of underlying support systems 106.
Another technical solution is provided in maintaining various hierarchical relationships between support systems 106. In particular, the hierarchies of data elements in one system may be maintained as data is transferred through the architecture 100, such as hierarchical relationships between products, services and the like. This ensures the integrity of product offerings and the like, for example, such that child products or services may not be inadvertently processed without an underlying parent product.
Yet another technical solution is provided by maintaining a correlation between support system specific product identifiers. For example, a table may be used to store identifiers of products, services and the like. Identifiers used in specific support systems 106 may be associated such that the table provides a mapping from the identifier used in one system to a corresponding identifier used in a second system. This mapping allows the interface 104 to track processing of orders and verify that account modifications are intended for valid products that already exist in each system.
While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that many more embodiments and implementations are possible within the scope of the invention. Accordingly, the invention is not to be restricted except in light of the attached claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
06425191 | Mar 2006 | EP | regional |
BS2006A0065 | Mar 2006 | IT | national |
Number | Name | Date | Kind |
---|---|---|---|
20040103103 | Kalthoff et al. | May 2004 | A1 |
20040117377 | Moser et al. | Jun 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20070226306 A1 | Sep 2007 | US |