The present invention relates to a method and apparatus for use in a communications network, for example a Universal Mobile Telecommunications System having an IP Multimedia Subsystem.
IP Multimedia services provide a dynamic combination of voice, video, messaging, data, etc. within the same session. By growing the number of basic applications and the media which it is possible to combine, the number of services offered to the end users will grow, and the inter-personal communication experience will be enriched. This will lead to a new generation of personalised, rich multimedia communication services, including so-called “combinational IP Multimedia” services.
The UMTS (Universal Mobile Telecommunications System) is a third generation wireless system designed to provide higher data rates and enhanced services to subscribers. UMTS is a successor to the Global System for Mobile Communications (GSM), with an important evolutionary step between GSM and UMTS being the General Packet Radio Service (GPRS). GPRS introduces packet switching into the GSM core network and allows direct access to packet data networks (PDNs). This enables high-data rate packets switch transmissions well beyond the 64 kbps limit of ISDN through the GSM call network, which is a necessity for UMTS data transmission rates of up to 2 Mbps. UMTS is standardised by the 3rd Generation Partnership Project (3GPP) which is a conglomeration of regional standards bodies such as the European Telecommunication Standards Institute (ETSI), the Association of Radio Industry Businesses (ARIB) and others. See 3GPP TS 23.002 for more details.
The UMTS architecture includes a subsystem known as the IP Multimedia Subsystem (IMS) for supporting traditional telephony as well as new IP multimedia services (3GPP TS 22.228, TS 23.228, TS 24.229, TS 29.228, TS 29.229, TS 29.328 and TS 29.329 Releases 5 to 7). IMS provides key features to enrich the end-user person-to-person communication experience through the use of standardised IMS Service Enablers, which facilitate new rich person-to-person (client-to-client) communication services as well as person-to-content (client-to-server) services over IP-based networks. The IMS is able to connect to both PSTN/ISDN (Public Switched Telephone Network/Integrated Services Digital Network) as well as the Internet.
The IMS makes use of the Session Initiation Protocol (SIP) to set up and control calls or sessions between user terminals (or user terminals and application servers). The Session Description Protocol (SDP), carried by SIP signalling, is used to describe and negotiate the media components of the session. Whilst SIP was created as a user-to-user protocol, IMS allows operators and service providers to control user access to services and to charge users accordingly. The 3GPP has chosen SIP for signalling between a User Equipment (UE) and the IMS as well as between the components within the IMS.
Specific details of the operation of the UMTS communications network and of the various components within such a network can be found from the Technical Specifications for UMTS that are available from http://www.3gpp.org. Further details of the use of SIP within UMTS can be found from the 3GPP Technical Specification TS 24.228 V5.8.0 (2004-03).
A user registers with the IMS using the specified SIP REGISTER method. This is a mechanism for attaching to the IMS and announcing to the IMS the address at which a SIP user identity can be reached. In 3GPP, when a SIP terminal performs a registration, the IMS authenticates the user, and allocates a S-CSCF to that user from the set of available S-CSCFs. Whilst the criterion for allocating S-CSCFs is not specified by 3GPP, these may include load sharing and service requirements. It is noted that the allocation of an S-CSCF is key to controlling (and charging for) user access to IMS-based services. Operators may provide a mechanism for preventing direct user-to-user SIP sessions which would otherwise bypass the S-CSCF.
During the registration process, it is the responsibility of the I-CSCF to select a S-CSCF if a S-CSCF is not already selected. The I-CSCF receives the required S-CSCF capabilities from the home network's Home Subscriber Server (HSS), and selects an appropriate S-CSCF based on the received capabilities. (It is noted that S-CSCF allocation is also carried out for a user by the I-CSCF in the case where the user is called by another party, and the user is not currently allocated an S-CSCF.) When a registered user subsequently sends a session request to the IMS, the P-CSCF is able to forward the request to the selected S-CSCF based on information received from the S-CSCF during the registration process.
Within the IMS service network, Application Servers (ASs) are provided for implementing IMS service functionality. Application Servers provide services to end-users in an IMS system, and may be connected either as end-points over the 3GPP defined Mr interface, or “linked in” by an S-CSCF over the 3GPP defined ISC interface. In the latter case, Initial Filter Criteria (IFC) are used by an S-CSCF to determine which Applications Servers should be “linked in” during a SIP Session establishment. Different IFCs may be applied to different call cases. The IFCs are received by the S-CSCF from an HSS during the IMS registration procedure as part of a user's User Profile. Certain Application Servers will perform actions dependent upon subscriber identities (either the called or calling subscriber, whichever is “owned” by the network controlling the Application Server). For example, in the case of call forwarding, the appropriate (terminating) application server will determine the new terminating party to which a call to a given subscriber will be forwarded. In the case that an IFC indicates that a SIP message received at the S-CSCF should be forwarded to a particular SIP AS, that AS is added into the message path. Once the SIP message is returned by the AS to the S-CSCF, it is forwarded on towards its final destination, or forwarded to another AS if this is indicated in the IFCs.
3GPP TS 32.260 defines the IMS charging architecture and principles and thereby defines when to send charging information and when not to send charging information. 3GPP TS 23.228 sets out the architecture and interfaces defining the framework for interaction between the network elements executing the service, the Application Servers (AS), and the S-CSCF as the core element responsible for the service triggering analysis and charging traffic function. Key elements of the system are illustrated schematically in
In the context of any service execution, at least one charging determination point must exist to either generate accounting records (for offline charging) or requesting quota/authorization (for online charging) for this particular service or session. Offline charging is a post-paid type of charging scheme whereby charging is performed after a service has been consumed by the user; for example the user might receive a monthly bill showing chargeable items from the previous month. Online charging is a pre-paid type of charging scheme, where network entities would consult with the charging system before allowing a user access to the requested service.
According to [TS 32.260] and [TS 32.299], different IMS nodes can act as Charging Triggering Functions (CTFs); in particular, either the S-CSCF or the ASs (or both) can act as CTF for most traffic events and all service invocations.
The present applicant has appreciated the following problem with the situation as it is currently specified.
There are currently no mechanisms allowing a S-CSCF to distinguish, per AS or executed service, what kind of capabilities the AS in question incorporates. In particular, when it comes to charging capabilities, it is impossible for the S-CSCF to know in advance if the AS to be invoked is capable of acting as CTF or not. Consequently, in order to avoid double charging information (from both the S-CSCF and the ASs) the S-CSCF must be configurable to possibly prevent charging when an AS is invoked.
The only AS information available to the S-CSCF is the SIP URI and possibly a feature tag (as a Communication Service Identifier), downloaded as part of the IFC service triggering data provisioned to each and every user.
The use of a configuration option in the S-CSCF implies an “all or nothing” decision, generic for all ASs, as the S-CSCF would otherwise have to be modified each time a new AS is introduced in the network. In other words, a possible disabling of charging functions in S-CSCF when an AS is invoked is not based on the capabilities of that AS but a global decision made by the operator whether to accept possible double charging information or not.
It is desirable to address the above issue as identified and explained by the present applicant.
According to a first aspect of the present invention there is provided a method for use by a Serving Call Session Control Function, S-CSCF, of an IP Multimedia Subsystem, IMS. The method comprises, for each of a plurality of services being administered to users by the S-CSCF, determining the charging capabilities of an Application Server, AS, of the IMS providing the service, and cooperating with the AS in the generation of charging information relating to the service.
The determined charging capabilities may be used to decide where the charging information is to be generated; for example a decision could be made to generate charging information at the S-CSCF only, or at the AS only, or at both with suitable cooperation. This allows charging information to be generated at the most appropriate location, selected in dependence upon the determined charging capabilities.
A method embodying the present invention advantageously allows the S-CSCF to cooperate with the AS to avoid an unnecessary duplication of charging information between the S-CSCF and the AS.
A method embodying the present invention advantageously allows the S-CSCF to cooperate with the AS to avoid an unnecessary loss of charging information between the S-CSCF and the AS.
Charging capabilities information may be exchanged with the AS, so that there may be a two-way flow of such information to form the basis of cooperation between the nodes to generate charging information.
A record identifying each AS may be maintained, and this record may incorporate the determined charging capabilities for each AS, this record being referred to in later use.
As an option, which AS is providing the service can be determined using an Initial Filter Criteria, IFC, received as part of a registration procedure.
An embodiment of the present invention allows flexibility as to when the charging capabilities are determined; in this respect the charging capabilities determining step can be performed as part of a registration procedure or as part of an invite procedure, for example. The registration and invite procedures may be Session Initiation Protocol, SIP, registration and invite procedures. Alternatively, the charging capabilities determining step could be performed at a first traffic interaction towards the AS.
There is also flexibility as to the method used to determine the charging capabilities of the AS. As an option, the charging capabilities of the AS can be determined using a Session Initiation Protocol, SIP, method.
For example, as an option the charging capabilities of the AS can be determined by use of an Extensible Markup Language, XML, body in a response, such as a 200 OK response, to a Session Initiation Protocol, SIP, OPTIONS method performed between the S-CSCF and the AS.
The charging capabilities of the AS can also be determined by use of a Session Initiation Protocol, SIP, Private header comprising the capabilities in a Session Initiation Protocol, SIP, OPTIONS method performed between the S-CSCF and the AS.
As a further option, the charging capabilities of the AS can be determined by use of a SIP Private header comprising the capabilities in a 200 OK response to a Session Initiation Protocol, SIP, REGISTER message received at the AS.
As a further option, the charging capabilities of the AS can be determined by use of a Lightweight Directory Access Protocol, LDAP, or Hypertext Transfer Protocol, HTTP, request to the AS
An embodiment of the present invention allows charging information to be generated in dependence upon the determined charging capabilities, which has not been previously proposed.
According to a second aspect of the present invention there is provided a method for use by an Application Server, AS, of an IP Multimedia Subsystem, IMS, the AS providing a service for at least one user. The method comprises providing the charging capabilities of the AS to a Serving Call Session Control Function, S-CSCF, of the IMS administering the service to the user. The AS then cooperates with the S-CSCF in the generation of charging information relating to the service.
According to a third aspect of the present invention there is provided a method for use by a first Session Initiation Protocol, SIP, enabled node of a network to determine capabilities information of a second SIP enabled node of the network. The method comprises use of an Extensible Markup Language, XML, body to carry the capabilities information in a response to a SIP OPTIONS method performed between the first and second nodes.
As an option, the response is a 200 OK response. This method is particularly but not exclusively advantageous when applied to an IP Multimedia Subsystem, IMS, in which case the first and second nodes would be nodes of an IMS.
According to a fourth aspect of the present invention there is provided an apparatus for use as or in a Serving Call Session Control Function, S-CSCF, of an IP Multimedia Subsystem, IMS. The apparatus comprises means for determining, for each of a plurality of services being administered to users by the S-CSCF, the charging capabilities of an Application Server, AS, of the IMS providing the service. The apparatus also comprises means for cooperating with the AS in the generation of charging information relating to the service.
According to a fifth aspect of the present invention there is provided an apparatus for use as or in an Application Server, AS, of an IP Multimedia Subsystem, IMS, the AS providing a service for at least one user. The apparatus comprises means for providing the charging capabilities of the AS to a Serving Call Session Control Function, S-CSCF, of the IMS administering the service to the user. The apparatus also comprises means for cooperating with the S-CSCF in the generation of charging information relating to the service.
According to a sixth aspect of the present invention there is provided an apparatus for use as or in a first Session Initiation Protocol, SIP, enabled node of a network. The apparatus comprises means for determining capabilities information of a second SIP enabled node of the network by use of an Extensible Markup Language, XML, body to carry the capabilities information in a response to a SIP OPTIONS method performed between the first and second nodes.
According to a seventh aspect of the present invention there is provided a program for controlling an apparatus to perform a method according to any of the first to third aspects of the present invention or which, when loaded into an apparatus, causes the apparatus to become an apparatus according to any of the fourth to sixth aspects of the present invention. The program may be carried on a carrier medium. The carrier medium may be a storage medium. The carrier medium may be a transmission medium.
According to an eighth aspect of the present invention there is provided an apparatus programmed by a program according to the seventh aspect of the present invention.
According to a ninth aspect of the present invention there is provided a storage medium containing a program according to the seventh aspect of the present invention.
Another aspect of the present invention provides a method and apparatus for use by a first Session Initiation Protocol, SIP, enabled node of a network to determine capabilities information of a second SIP enabled node of the network, the method comprising use of SIP Private header to carry the capabilities in a SIP OPTIONS method performed between the first and second nodes.
Another aspect of the present invention provides a method and apparatus for use by a first Session Initiation Protocol, SIP, enabled node of a network to determine capabilities information of a second SIP enabled node of the network, the method comprising use of a SIP Private header carrying the capabilities in a 200 OK response to a SIP REGISTER message received at the second node.
Another aspect of the present invention provides a method and apparatus for use by a first Session Initiation Protocol, SIP, enabled node of a network to determine capabilities information of a second SIP enabled node of the network, the method comprising use of a Lightweight Directory Access Protocol, LDAP, or Hypertext Transfer Protocol, HTTP, request to the second node.
A technical advantage of the invention is that the most optimal CTF can be chosen depending on the capabilities of the AS in question for a certain call/service, thereby allowing the usage of network resources to be optimized, and ensuring that duplicated charging information can be avoided, and also that charging information is not missed out completely either.
As explained above, there are currently no mechanisms allowing a S-CSCF to distinguish, per AS or executed service, what kind of capabilities the AS in question incorporates. So, in order to avoid double charging information, at present the S-CSCF must be configurable to prevent charging when an AS is invoked, on an “all or nothing” basis and controlled centrally by the operator.
To overcome this limitation, a charging capabilities exchange mechanism must be in place in the context of the S-CSCF and AS IMS entities.
On the other hand, there are existing mechanisms already specified in SIP [RFC 3261] to facilitate the exchange of capabilities between SIP entities, based on the use of the OPTIONS method, as well as the use of Allow, Accept, Accept-Language and Supported headers.
The Allow, Accept, Accept-Language, and Supported header fields convey some information about the capabilities of a user agent. However, these header fields convey only a small part of the information that is needed. They do not provide a general framework for expression of capabilities. Furthermore, they only specify capabilities indirectly; the header fields really indicate the capabilities of the UA as they apply to this request. SIP also has no ability to convey characteristics, that is, information that describes a UA.
The SIP OPTIONS method, further specified in [RFC 3840], allows a UA to query another UA or a proxy server as to its capabilities. This allows a client to discover information about the supported methods, content types, extensions, codecs, etc. without “ringing” the other party. For example, before a client inserts a Require header field into an INVITE listing an option that it is not certain the destination User Agent Server (UAS) supports, the client can query the destination UAS with an OPTIONS to see if this option is returned in a Supported header field. All UAs must support the OPTIONS method, even an AS in the context of IMS.
Thus, this is considered to provide a more general framework for an indication of capabilities and characteristics in SIP. Capability and characteristic information about a UA can be carried as parameters of the Contact header field. These parameters can be used within REGISTER requests and responses, OPTIONS responses, and requests and responses that create dialogs (such as INVITE).
The following is what the RFC considers to be a “capability” and a “characteristic”:
As defined in RFC 2703, a “capability” is an attribute of a sender or receiver (often the receiver) which indicates an ability to generate or process a particular type of message content. A capability is distinct from a characteristic in that a capability may or may not be utilized in any particular call, whereas a characteristic is a non-negotiable property of a UA. SIP itself will often negotiate whether or not capabilities are used in a call.
A “characteristic” is like a capability, but describes an aspect of a UA which is not negotiable. As an example, whether or not a UA is a mobile phone is a characteristic, not a capability. The semantics of this specification do not differentiate between capability and characteristic, but the distinction is useful for illustrative purposes.
At the SIP level, these mechanisms are widely known and standardized, requiring as well to follow the normal process when registering capabilities, through standard track RFCs and IANA registration [IANAreg]. Those mechanisms for features, media features, and features and option tags require not only the aforementioned registration and definition using standard track and informational RFCs, but also require consensus to be accepted by the IETF community.
In any case, the unique nature of IMS entities and the way they interrelate with each other requires specific mechanisms to exchange these charging capabilities, as will now be described.
According to an embodiment of the present invention, a mechanism is provided to allow the exchange of charging capabilities, between an AS, defined in the IMS network and therefore assigned to any IFC provisioned to that IMS network users, and the corresponding S-CSCF where the user in question is registered. The S-CSCF communicates with new ASs that it finds in IFCs and stores the AS capabilities found in the response.
For each call/service involving an AS, the S-CSCF chooses whether or not to generate charging information based on the capabilities of that AS. This makes it possible to optimize the charging information generated by the network; double charging information can be avoided in this way, as well as the risk of not generating charging information for a certain service/AS.
The number and type of ASs incorporated in the IMS network can vary during the course of time, and thereby also the IFC triggers, but the extra signalling introduced for the S-CSCF would be limited to only one transaction per new AS incorporated to the AS list kept in the S-CSCF, for those alternatives where this transaction is proposed.
A solution embodying the present invention makes use of the following differentiated procedures:
The actual mechanism used to exchange the charging capabilities between the AS and the S-CSCF is not fixed, and three different possible alternatives are described below, by way of example.
Having obtained the charging capabilities of each AS, the decision as to whether or not to apply charging in the S-CSCF when an AS is invoked can then be based on the actual charging capabilities of the AS in question.
Three alternatives for the capability exchange will now be explained in turn, by way of example.
When the S-CSCF has extracted the ASs from the IFC downloaded at registration time, the S-CSCF can build up the AS list. For each new AS incorporated to the list, the S-CSCF carries out a protocol interaction with the AS in question to request its capabilities.
Several protocol options are available, as for instance a Lightweight Directory Access Protocol (LDAP) or Hypertext Transfer Protocol (HTTP) query to the AS's URI.
SIP can also be used, which represents an advantage implementation-wise. If SIP is used, two basic alternatives are proposed:
One possible disadvantage of using the third-party registration mechanism is that the AS in question has to subscribe to the mechanism, which may not always be the case.
The OPTIONS method can be used in many ways to obtain SIP UA capabilities, as defined in [RFC 3261]. Perhaps the most straightforward approach, and at the same time the most future-proof, is through the exchange of a message body in the 200 OK response to the OPTIONS request where the capabilities of the AS are expressed for instance in an XML document. This would involve the inclusion of the “Application/XML” in the “Accept” header of the OPTIONS request sent by S-CSCF.
The use of an IMS XML body is already envisioned in 3GPP [24.229] where a very basic data scheme is standardized for different purposes, none of them covering the scope of this invention. Therefore, an extension of this IMS XML body mechanism would be necessary, if the charging capabilities support is to be standardized. Ideally, this IMS XML body should be extended in such a way that the data scheme included is qualified and advertised inside the body itself, by specifying a concrete “name space” defining the scope and data scheme, e.g. whether the data to follow is standardized in IMS itself, or belongs to an operator defined set of capabilities or any other entity (e.g. ETSI/TISPAN) etc.
An example flow of events in this alternative is reflected in
In step S1 the S-CSCF obtains an identification of each AS from the IFCs in the user profile as part of the registration procedure, the identification being in this embodiment the URIs associated with the respective ASs. For each new AS, the charging capabilities of the AS are determined by the S-CSCF in step S2 and a list of ASs and their respective capabilities is maintained and updated in step S3. In this example, the charging capabilities are determined in step S2 by sending a SIP OPTIONS message to the AS (step 10) and processing the 200 OK response received back from the AS (step 11). Thereafter, the S-CSCF cooperates with the ASs in the generation of charging information for the services that the ASs provide, the services being administered to the users by the S-CSCF, and this cooperation is represented as step S4.
An alternative to the one above is to build up the list of ASs at registration in the same or a similar way as in the first alternative, but the actual exchange of capabilities takes place at the first traffic interaction towards the new AS.
The exchange of capabilities would then take place when S-CSCF and the AS in question are first communicating using the SIP INVITE method.
In this case, the AS would return its capabilities in the first 200 OK to the S-CSCF, the 200 OK being used as a capability container. Again, two basic methods are proposed to carry AS capabilities:
However, the use of a SIP private header would have to be documented in an Informational RFC, mutually agreed between IETF and 3GPP.
Alternatively, in connection with the reception of the INVITE in the AS and its reply with a 200 OK, other protocol alternatives as a LDAP or HTTP POST query could be possible, but they are seen as being less optimal.
A drawback with this alternative in general is that the call flow defined by 3GPP states that the initial Credit-Control-Request is sent before the INVITE is passed on and at that time the S-CSCF does not yet know whether or not it will be the CTF. This means that an unnecessary credit control session may be started from the S-CSCF for the first call to a new AS. In practical terms, this is a relatively insignificant drawback, as the capabilities would be exchanged and stored only at first contact with one AS.
One possible flow of events is reflected in the illustrative message exchange diagram of
In an embodiment of the present invention, additional steps P1 to P3 are performed. Of these, step P1 can be considered to form part of the registration procedure, or can be considered to be separate from but at least associated with the registration procedure. Step P2 can be considered to form part of the invite procedure, or can be considered to be separate from but at least associated with the invite procedure.
In step P1, the S-CSCF obtains an identification of each AS from the IFCs in the user profile obtained as part of the registration procedure, the identification being in this embodiment the respective URIs associated with the ASs. A list of ASs and their respective capabilities is maintained, and in step P1 the S-CSCF updates this list with the AS URIs (their respective capabilities will be updated later).
When a 200 OK message is subsequently received by the S-CSCF from one of the ASs as part of an invite procedure, the charging capabilities of the AS are determined from the 200 OK by the S-CSCF in step P2, and the list of ASs and their respective capabilities is updated with this information. In this respect, the 200 OK message comprises charging capability information, for example using one of the methods suggested previously.
Thereafter, the S-CSCF cooperates with the ASs in the generation of charging information for the services that the ASs provide, the services being administered to the users by the S-CSCF, and this cooperation is represented as step P3.
Another alternative is to add an additional piece of information reflecting AS capabilities associated to the AS name downloaded in the Cx Pull Response from the HSS during a SIP registration procedure.
In essence, the information included would be the same as defined for a XML body or a SIP Private header, for example.
This solution, although apparently simple, requires a data model change to be reflected in the current structure of IFCs, see [TS23.228] and corresponding provisioning work.
Apart from the relative drawback behind every extension of the IFC's data model, an additional problem with this alternative could arise from the fact that any update in software capabilities in any AS would mean an additional provisioning cycle of IFCs for each and every user.
An example flow of events in this alternative is reflected in
It will be appreciated that operation of one or more of the above-described components can be controlled by a program operating on the device or apparatus. Such an operating program can be stored on a computer-readable medium, or could, for example, be embodied in a signal such as a downloadable data signal provided from an Internet website. The appended claims are to be interpreted as covering an operating program by itself, or as a record on a carrier, or as a signal, or in any other form.
It will also be appreciated by the person of skill in the art that various modifications may be made to the above-described embodiments without departing from the scope of the present invention as defined by the appended claims. In particular, it will be appreciated that, although described in relation to a Universal Mobile Telecommunications System having an IP Multimedia Subsystem, the present invention is also applicable to corresponding parts of other types of network.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP07/61832 | 11/2/2007 | WO | 00 | 5/3/2010 |