This application claims priority based on a Japanese patent application, No. 2010-149245 filed on Jun. 30, 2010, the entire contents of which are incorporated herein by reference.
The present invention relates to a technique for delivery of streaming data, particularly, to a technique that processes and provides streaming data in real time.
Recently, services handling streaming data, such as IP (Internet Protocol) telephony, teleconference systems, and motion video delivery have become widely used.
For the delivery of streaming data, a streaming processing technique is becoming put into use. In such technique, instead of providing data from a delivery source directly to a delivery destination, data is delivered in such a way that it is forwarded via processing servers deployed along a communication path and processed and edited in real time by the processing servers in the course of data transmission.
By utilizing the streaming processing technique, for example, in motion video delivery, motion video data located on a server can be provided, while its format is converted into a format available to a receiving terminal of a user. Thereby, it becomes no longer necessary to prepare various formats of motion video data by encoding one type of content into these formats of data on the server beforehand and the cost for such preparation can be reduced.
The streaming processing technique is used not only in streaming delivery of multimedia data such as motion video and audio data, as mentioned above, but also in Web service systems for finance, settlement, and the like that need to process a great deal of text data described in, for example, an XML (eXtensible Markup Language) format or the like.
To make use of the streaming processing technique, necessity is routing to forward streaming data via a suitable server or servers so that intended processing is performed. As a technique for such routing on a service layer, for example, a technique described in Shirata Sumiko, Morito Takashi, Honjo Masaru, Morikawa Daisuke, Minami Masateru, “A Dynamic Service Composition Mechanism Using SIP 3rd Party Call Control” The Institute of Electronics, Information and Communication Engineers (IEICE) General Conference (March, 2006) exists. In Shirata Sumiko, Morito Takashi, Honjo Masaru, Morikawa Daisuke, Minami Masateru, “A Dynamic Service Composition Mechanism Using SIP 3rd Party Call Control” The Institute of Electronics, Information and Communication Engineers (IEICE) General Conference (March, 2006), such a technique is disclosed in which, by using a standard protocol, an SIP (Session Initiation Protocol), information about media formats available to both parties is obtained by parsing SDP (Session Description Protocol) included in an SIP message, and routing processing for media format conversion needed is performed using SIP Third Party Call Control.
There is a recent trend of data delivery service to give an added value to the service that users enjoy by editing or tailoring information dynamically according to user context such as preference and charging status of each individual user, not only delivering static data to users.
However, information about such user context is not reflected in SDP for carrying session information. Therefore, in the technique disclosed in Shirata Sumiko, Morito Takashi, Honjo Masaru, Morikawa Daisuke, Minami Masateru, “A Dynamic Service Composition Mechanism Using SIP 3rd Party Call Control” The Institute of Electronics, Information and Communication Engineers (IEICE) General Conference (March, 2006), a session between a delivery server and a user terminal has to be established only after a stage of obtaining information about both a format of streaming data for delivery and a format processible by the user terminal receiving the delivery and a procedure until the session establishment involves a large number of steps. A larger number of steps will be involved in order to implement service routing to give an added value to the delivery service other than format conversion.
To solve a problem as discussed above, a streaming data delivery system is configured as follows. The streaming data delivery system includes a streaming data delivery device using an SIP, a server for provisional coupling using an SIP, a plurality of format conversion servers using an SIP which perform format conversion of streaming data, a user terminal using an SIP, a 3PCC (Third Party Call Control) device which implements SIP Third Party Call Control, and a service routing computer which transmits a command to establish a session between the streaming data delivery device and the user terminal.
The 3PCC device, which receives the command to establish the session, obtains information about a first format available to the user terminal from the user terminal and establishes a session between the user terminal and the server for provisional coupling. The 3PCC device also obtains information about a second format of streaming data that the streaming data delivery device delivers from the streaming data delivery device and establishes a session between the streaming data delivery device and the server for provisional coupling. Further, the 3PCC device selects a format conversion server that converts the second format of the streaming data into the first format from the plurality of format conversion servers, transfers the session between the streaming data delivery device and the server for provisional coupling into a session between the streaming data delivery device and the selected format conversion server, and transfers the session between the user terminal and the server for provisional coupling into a session between the user terminal and the selected format conversion server.
In the streaming data delivery system in another preferred aspect, the service routing computer includes a user attribute information database which stores user attribute information for each user who uses a user terminal, a delivery policy database which stores a correlation between an identifier of an item of streaming data and user attribute information as a delivery policy, and a processing server list which correlates and stores a processing task to be performed for streaming data according to a delivery policy and an identifier of a processing server that performs the processing task. The service routing computer refers to the delivery policy database based on user attribute information from the user attribute information database and identifies a processing server that is to perform a processing task to be performed for the streaming data, and transmits a command to establish a session between the streaming data delivery device and the processing server and a command to establish a session between the processing server and the selected format conversion server in order to route the streaming data via the identified processing server. The 3PCC device, in response to the command to establish a session between the streaming data delivery device and the processing server, transfers the session between the streaming data delivery device and the server for provisional coupling into a session between the streaming data delivery device and the identified processing server, instead of transferring the session between the streaming data delivery device and the server for provisional coupling into a session between the streaming data delivery device and the selected format conversion server. Also, the 3PCC device, in response to the command to establish a session between the identified processing server and the selected format conversion server, establishes the session between the identified processing server and the selected format conversion server.
According to the teaching herein, it is possible to curtail the procedure until a session is established between the delivery server and the user terminal.
These and other benefits are described throughout the present specification. A further understanding of the nature and advantages of the invention may be realized by reference to the remaining portions of the specification and the attached drawings.
A streaming data delivery system of an embodiment includes a streaming data delivery device using SIP, a server for provisional coupling using SIP, a plurality of format conversion servers using an SIP which perform format conversion of streaming data, a user terminal using SIP, a 3PCC device which implements SIP 3rd Party Call Control, and a service routing computer which transmits a command to establish a session between the streaming data delivery device and the user terminal.
The 3PCC device having received the command to establish the session obtains information about a format available to the user terminal from the user terminal and establishes a session between the user terminal and the server for provisional coupling. The 3PCC device also obtains information about a format of streaming data to be delivered by the streaming data delivery device from the streaming data delivery device and establishes a session between the streaming data delivery device and the server for provisional coupling. Further, the 3PCC device selects a format conversion server that converts the streaming data format into the format available to the user terminal from the plurality of format conversion servers. Further, the 3PCC device transfers the session between the streaming data delivery device and the server for provisional coupling as a session between the streaming data delivery device and the selected format conversion server and transfers the session between the user terminal and the server for provisional coupling as a session between the user terminal and the selected format conversion server.
In order to provide a user with services other than format conversion in streaming data delivery, the service routing computer has a user attribute information database which stores user attribute information for each user who uses a user terminal, a delivery policy database which stores a correlation between an identifier of an item of streaming data and user attribute information as a delivery policy, and a processing server list which correlates and stores a processing task to be performed for streaming data according to a delivery policy and an identifier of a processing server that performs the processing task. The service routing computer refers to the delivery policy database based on user attribute information from the user attribute information database and identifies a processing server that is to perform a processing task to be performed for streaming data. In order to route the streaming data via the identified processing server, the service routing computer transmits a command to establish a session between the streaming data delivery device and the processing server and a command to establish a session between the processing server and the selected format conversion server. The 3PCC device, in response to the command to establish a session between the streaming data delivery device and the processing server, transfers the session between the streaming data delivery device and the server for provisional coupling as a session between the streaming data delivery device and the identified processing server, instead of transferring the session between the streaming data delivery device and the server for provisional coupling as a session between the streaming data delivery device and the selected format conversion server. Also, the 3PCC device, in response to the command to establish a session between the identified processing server and the selected format conversion server, establishes the session between the identified processing server and the selected format conversion server.
The 3PCC device 1060 is further coupled to a service routing computer 1000. The service routing computer 1000 is further coupled to a portal server 1110. Descriptions about each of these system components will be provided later.
The portal server 1110 is further coupled to a user Web terminal 1021 via the Internet 1091. Descriptions about each of these system components will be provided later.
The following will describe each of the system components shown in
The service routing computer 1000 is provided with databases for storing a list of registered users and their charging information (user information 1011), user preference information (user setting 1012), a list of streaming data for delivery (delivery data list 1013), policy information set for each streaming data item for delivery by a system administrator (delivery policy 1014), a list of processing servers (processing server list 1015), a list of servers responsible for format conversion of streaming data (format conversion server list 1016), and information about the locations of streaming processing servers (processing server locations 1017). Descriptions about data structures for each of these databases will be provided later.
The service routing computer 1000 determines a route (a series of servers) via which streaming data for delivery is to be forwarded, using the following information: a format of streaming data for delivery and a format available to a user's SIP terminal 1020 received from the 3PCC device 1060; and information from the databases for user information 1011, user setting 1012, delivery data list 1013, delivery policy information 1014, processing server list 1015, format conversion server list 1016, and processing server locations 1017. Details about processing for determining a route will be described later.
Both the user SIP terminal 1020 and the user Web terminal 1021 are terminals that are used by a user who uses the streaming data delivery service. The user SIP terminal 1020 is capable of establishing a session with a server that delivers or relays (forwards) streaming data using SIP and receiving the streaming data. The user Web terminal 1021 is coupled to the portal server 1110 via the Internet 1091 and transmits a request for streaming data delivery to the portal server 1110, using HTTP (HyperText Transfer Protocol).
The streaming data delivery device 1030 holds streaming data of contents which can be delivered to users in a contents database 1031, receives a request message for content delivery using SIP, and delivers content corresponding to that specified in the request message. The content corresponding to that specified in the request message is distinguished by, for example, an SIP URI (Uniform Resource Identifier) specific to each content item (streaming data).
The format conversion server 1041, posted message adding server 1042, and advertisement processing server 1043 are all service servers (processing servers) that perform streaming processing for services suitable for users. These servers receive streaming data, perform predefined processing on the received streaming data, and transmit the processed streaming data. In the foregoing general description, the format conversion server 1041 is seen like it differs from the processing servers. However, it may be regarded as a service server that performs streaming processing for services suitable for users or treated like a processing server, as it is selectively incorporated in a path of streaming data from the streaming data delivery device 1030 up to an SIP terminal 1020.
In the case of the format conversion server 1041, the predefined processing on the received streaming data means converting a format of streaming data for delivery into a data format available to a user's SIP terminal 1020.
In the case of the posted message adding server 1042, the predefined processing on the received streaming data means tailoring the streaming data to fit in with policy information set for each streaming data item for delivery by the service administrator and user preference information. For example, this processing is to add a message such as a comment posted by a user who uses the service and, possibly, related recommended information to the streaming data, so that such message will be superimposed on the displayed content corresponding to the streaming data.
In the case of the advertisement processing server 1043, the predefined processing on the received streaming data means adding an advertisement message to the streaming data to fit in with policy information set for each streaming data item for delivery by the service administrator and user charging information, so that the advertisement message will be superimposed on the displayed content.
The foregoing predefined processing tasks are exemplary and processing tasks that can be implemented in the present system are not limited to the foregoing tasks. For instance, such streaming processing may be included that adds a time stamp and a user ID (Identity) as digital watermark information to the streaming data in order to protect the content provided. The number of types of processing is not limited to the foregoing three types, either. Any processing may be included that provides a service suitable for users, selectively using the following: a format of streaming data for delivery; a format available to a user's SIP terminal 1020; policy information set for each streaming data item for delivery by the service administrator; user preference information; and user charging information.
Each of the service servers of the format conversion server 1041, posted message adding server 1042, and advertisement processing server 1043 may serve as an SIP UAC (User Agent Client) that can establish a session with another SIP UAS (User Agent Server) device according to a message sequence of SIP 3rd Party Call Control. Each of these service servers may also serve as an SIP UAS that can establish another SIP UAC device according to the message sequence of SIP 3rd Party Call Control. A service server serving as an SIP UAC establishes a session with another SIP UAS device and receives streaming data via the established session. In the meantime, a service server serving as an SIP UAS establishes a session with another SIP UAC device and transmits streaming data processed by any of the foregoing predefined processing tasks via the established session.
The 3PCC device 1060 is an SIP server and performs call control of an SIP UA coupled to the NGN 1090. The 3PCC device 1060 has a Web interface for communication with the service routing computer 1000. As the Web interface, Parlay X using SOAP (Simple Object Access Protocol) is already formulated as a standard interface. In the present embodiment, the system operation, which will be described later, is implemented by using Third Party Call WebService stipulated in Parlay X.
The server for provisional coupling 1070 serves as an SIP UAS when it communicates with a user SIP terminal 1020 and serves as an SIP UAC when it communicates with the streaming data delivery device 1030. The server for provisional coupling 1070, when having received a session establishment request (INVITE message) including SDP (Session Description Protocol) offer from another SIP UA, always returns a 200OK message that carries SDP answer indicating that it can establish a session. The SDP answer indicating that it can establish a session is to include the attributes in the media description fields included in the received SDP offer, as they are, without deleting them at all. Usage of the server for provisional coupling 1070 will be described later in an example of the system operation.
The portal server 1110 is a server that opens Web pages acting as a portal for the streaming data delivery service via the Internet 1091. The portal server 1110 authenticates a user who transmits a request for streaming data delivery via the Internet 1091 and transmits the service routing computer 1000 the user ID, the user charging information, the identifier of streaming data requested for delivery by the user, and SIP URI for the user to receive streaming data.
If the user is an anonymous guest user, “guest” is used as the user ID. User charging information may include given values assigned to each individual user, for example, as follows: “0” for an anonymous guest user; “1” for a user who has a user ID that is issued free of charge; and “2” for a user who has a user ID that is issued to have access to a charged service.
The system components such as the service routing computer 1000 and portal server 1110 shown in
The service routing computer 1000, user SIP terminal 1020, user Web terminal 1021, streaming data delivery device 1030, format conversion server 1041, posted message adding server 1042, advertisement processing server 1043, 3PCC device 1060, and portal server 1110 are embodied by loading programs that implement their functions into their memory 2002 and executing the programs by their CPU 2001. These programs may be stored beforehand in their external storage device 2003 or loaded from another device into their external storage device 2003 via the reading device 2007 or communication device 2004 and an available medium. Therefore, the 3PCC device 1060, streaming data delivery device 1030, and the servers such as the format conversion server 1041, posted message adding server 1042, and advertisement processing server 1043 do not need to be physically different entities. They may logically be configured on at least one computer 2000.
The available medium refers to, for example, a storage medium 2009 which is removably set in the reading device 2007 or a network to which the communication device 2004 can couple or carrier waves or digital signals which are propagated over the network. The programs may be stored once into the external storage device 2003 and, subsequently, loaded from there into the memory 2002 and executed by the CPU 2001, or may be loaded directly into the memory 2002 and executed by the CPU 2001 without being stored into the external storage device 2003.
In the following, exemplary data structures of information stored in the databases provided in the service routing computer 100 will be described in order, using
Although what to be added is only one, namely, the user posted message 3013 in the user setting 1012 database presented in
The user charging information 3032 has the same meaning as signified by the values of the user charging information 3002 in the user information 1011 database. That is, “0” represents an anonymous guest user, “1” represents a user having a charge-free ID registered, and “2” represents a user who is charged. The service routing computer 1000 refers to the delivery policy 1014 database and determines a route optimal for, e.g., “limiting the quality and adding an advisement, when delivering data “data0001” to an anonymous guest user”. Thereby, the service provider can provide the streaming data delivery service depending on policy setting.
An example of a general operation of the streaming data delivery service system is described. The service provider delivers streaming data via the NGN 1090, using the streaming data delivery device 1030. The service provider opens a portal site for accepting a request for streaming data delivery on the Internet 1091 through the user of the portal server 1110.
In addition, as a policy for streaming data delivery, the service provider is assumed to have set a delivery policy that “is neither to limit the quality, nor to add an advertisement, when delivering delivery data ID “data0001” to a charged user”. Concretely, a record in the third row of the delivery policy 1014 database of
Meanwhile, a charged user (user ID “usr0001”) registered as user for receiving the streaming data delivery service is assumed to register his or her preference information that “the user wants to have a user posted message added to streaming data when receiving delivery data “data0001” into the user setting 1012 database maintained on the service routing computer 1000 managed by the service provider. Concretely, a record in the first row of the user setting 1012 database of
The user “usr0001” accesses the portal server 1110 using the user Web terminal 1021, logs into the streaming data delivery service using his or her ID “usr0001”, and transmits the identifier of a streaming data item that the user wants to receive and the SIP URI of the user SIP terminal 1020 to receive streaming data. The format of streaming data available to the user SIP terminal 1020 is “h.263” and the format of streaming data with the delivery data ID “data0001” located in the contents database 1031 on the streaming data delivery device 1030 is “mpeg4”.
The user “usr0001” receives streaming data processed according to the policy (
The operation of the streaming data delivery service system, as above, is explained in accordance with a series of sequences illustrated in
Sequence Number 4001 (Authentication):
The user accesses the portal server 1110 from the user Web terminal 1021, transmits the user ID “usr0001”, and has user authenticated. The user authentication may, for example, comply with HTTP digest authentication or the like which is normally used in Web.
Sequence Number 4002 (Request):
Using an HTTP request method, the user Web terminal 1021 transmits to the portal server 1110 the following: the authenticated user ID “usr0001”; “data0001” as the identifier (delivery data ID) of streaming data that the user wants to receive; and SIP URI “sip:usr@usr-example.ne.jp” of the SIP terminal 1020 to receive streaming data.
Sequence Number 4003 (Request):
Using the HTTP request method, the portal server 1110 transmits to the service routing computer 1000 the received user ID “usr0001”, delivery data ID “data0001”, and SIP URI “sip:usr@usr-example.ne.jp” of the user SIP terminal 1020.
Sequence Number 4004 (Location Resolution):
The service routing computer 1000 refers to the delivery data list 1013 database and a row having “data0001” in the column of delivery data ID 3021 and obtains the location “sip:data1@server1example.com” of the delivery data. The service routing computer 1000 refers to the processing server locations 1017 database and a row having “temp” as a value in the column of processing server identifier 3061 and obtains the location “sip.tmp@tmpexample.com” of the server for provisional coupling 1070.
Sequence Number 4005 (3PCC (Coupling) Command):
Steps from sequence number 4005 (3PCC (coupling) command) to sequence number 4010 (notification of SDP information) are a process for establishing a session between the user SIP terminal 1020 and the server for provisional coupling 1070, thus allowing the service routing computer 1000 to obtain a format available to the user SIP terminal 1020.
The service routing computer 1000 transmits to the 3PCC device 1060 a session establishment command (makeCallSession request) to establish a session between the user SIP terminal 1020 and the server for provisional coupling 1070. Arguments specified in the makeCallSession request are the SIP URI “sip:usr@usr-example.ne.jp” of the user SIP terminal 1020 and the SIP URI “sip.tmp@tmpexample.com” of the server for provisional coupling 1070.
Sequence Number 4006 (Invite, 200OK):
A process from sequence number 4006 (INVITE, 200OK) to sequence number 4008 (session establishment) is compliant with a typical 3PCC message sequence which is described in, inter alia, RFC3725 (“Best Current Practices for Third Party Call Control in the Session Initiation Protocol”, http://www.rfc-editor.org/rfc/rcf3725.txt).
The 3PCC device 1060 transmits an INVITE message having no SDP to the user SIP terminal 1020. According to the operation of an SDP offer/answer model, the user SIP terminal 1020 returns a 200OK message storing SDP in its body part to the 3PCC device 1060 (SDP offer). In a media description filed of the SDP, information is described to indicate that the h.263 format is available. Thereby, the 3PCC device 1060 obtains the format available to the user SIP terminal 1020.
Sequence Number 4007 (Invite, 200OK, ACK):
The 3PCC device 1060 transmits to the server for provisional coupling 1070 an INVITE message including the SDP received from the user SIP terminal 1020 as an SDP offer in its body part. The server for provisional coupling 1070 returns a 200OK message to the 3PCC device 1060. In the body part of the 200OK message, SDP indicating that the server can establish coupling is stored (SDP answer). The server for provisional coupling 1070 transmits an ACK message to the 3PCC device 1060.
Sequence Number 4008 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the user SIP terminal 1020. In the body part of the ACK message, the SDP answer received from the server for provisional coupling 1070 is stored.
By way of the foregoing sequence of sequence number 4006 (INVITE, 200OK) and sequence number 4007 (INVITE, 200OK, ACK), coupling is established between the server for provisional coupling 1070 and the user SIP terminal 1020.
Sequence Number 4009 (Response to 3PCC (Coupling) Command):
The 3PCC device 1060 transmits to the service routing computer 1000 a response (the session number of the session established at sequence number 4008 (session establishment)) to the makeCallSession request at sequence number 4005 (3PCC (coupling) command).
Sequence Number 4010 (Notification of SDP Information):
Using SOAP/HTTP messaging, the 3PCC device 1060 transmits the SDP obtained at sequence number 4006 (INVITE, 200OK) to the service routing computer 1000.
By way of the foregoing process from sequence number 4005 (3PCC (coupling) command) to 4010 (notification of SDP information), the service routing computer 1000 obtains the format available to the user SIP terminal 1020.
However, if the NGN 1090 is a network that conforms to a specification that does not permit transmission of an INVITE message having no SDP, it is impossible to perform the foregoing process from sequence number 4005 (3PCC (coupling) command) to 4010 (notification of SDP information) and, therefore, the format available to the SIP terminal 1020 cannot be obtained. In this case, the service routing computer 1000 may obtain the format available to the SIP terminal 1020, for example, in such a manner in which the format available to the SIP terminal 1020 is included in the request message at sequence number 4002 (request) or in which the user registers beforehand the format available to the SIP terminal 1020 in the user setting 1012 database and the service routing computer 1000 refers to the user setting 1012 database also at sequence number 4004 (location resolution).
Sequence Number 4011 (3PCC (Coupling) Command):
Steps from sequence number 4011 (3PCC (coupling) command) to 4016 (notification of SDP information) are a process for establishing a session between the streaming data delivery device 1030 and the server for provisional coupling 1070, thus allowing the service routing computer 1000 to obtain the format of streaming data that the streaming data delivery device 1030 delivers.
The service routing computer 1000 transmits to the 3PCC device 1060 a session establishment command (makeCallSession request, if the Parlay X interface is used) to establish a session between the streaming data delivery device 1030 and the server for provisional coupling 1070. Arguments specified in the session establishment request are the location “sip:data0001@server1example.ne.jp” of data that the streaming data delivery device 1030 delivers and the SIP URI “sip.tmp@tmpexample.com” of the server for provisional coupling 1070.
Sequence Number 4012 (Invite, 200OK):
A process from sequence number 4012 (INVITE, 200OK) to sequence number 4014 (session establishment) is compliant with a typical 3PCC message sequence which is described in, inter alia, RFC3725.
The 3PCC device 1060 transmits an INVITE message having no SDP to the streaming data delivery device 1030. According to the operation of the SDP offer/answer model, the streaming data delivery device 1030 returns a 200OK message storing SDP in its body part to the 3PCC device 1060 (SDP offer). In a media description filed of the SDP, information is described to indicate that mpeg4, the format of data “data1” is available. Thereby, the 3PCC device 1060 obtains the format of the delivery data “data1”.
Sequence Number 4013 (INVITE, 200OK, ACK):
The 3PCC device 1060 transmits to the server for provisional coupling 1070 an INVITE message including the SDP received from the streaming data delivery device 1030 at sequence number 4012 (INVITE, 200OK) as an SDP offer in its body part. The server for provisional coupling 1070 returns a 200OK message to the 3PCC device 1060. In the body part of the 200OK message, SDP indicating that the server can establish coupling is stored (SDP answer). The server for provisional coupling 1070 transmits an ACK message to the 3PCC device 1060.
Sequence Number 4014 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the streaming data delivery device 1030. In the body part of the ACK message, the SDP answer received from the server for provisional coupling 1070 at sequence number 4013 (INVITE, 200OK, ACK) is stored.
By way of the sequence of sequence number 4012 (INVITE, 200OK) and sequence number 4013 (INVITE, 200OK, ACK), coupling is established between the server for provisional coupling 1070 and the streaming data delivery device 1030.
Sequence Number 4015 (Response to 3PCC (Connection) Command):
The 3PCC device 1060 transmits to the service routing computer 1000 a response (the session number of the session established at sequence number 4014 (session establishment)) to the coupling command at sequence number 4011 (3PCC (coupling) command).
Sequence Number 4016 (Notification of SDP Information):
Using SOAP/HTTP messaging, the 3PCC device 1060 transmits the SDP obtained at sequence number 4012 (INVITE, 200OK) to the service routing computer 1000.
By way of the foregoing process from sequence number 4011 (3PCC (coupling) command) to 4016 (notification of SDP information), the service routing computer 1000 obtains the format of streaming data that the streaming data delivery device 1030 delivers.
However, if the NGN 1090 is a network that conforms to a specification that does not permit transmission of an INVITE message having no SDP, it is impossible to perform the foregoing process from sequence number 4011 (3PCC (coupling) command) to 4016 (notification of SDP information) and, therefore, the format of streaming data that the streaming data delivery device 1030 delivers cannot be obtained. In this case, the service routing computer 1000 may obtain the format of streaming data for delivery, for example, in such a manner in which the format of each item of streaming data is registered beforehand in the delivery data list 1013 database and the service routing computer 1000 refers to the delivery data list 1013 database also at sequence number 4004 (location resolution).
Sequence Number 4017 (Route Determination Processing):
The service routing computer determines a service route which becomes necessary for processing streaming data and providing that data to the user, according to the policy of the service provider, the preference set by the user, the format available to the user SIP terminal, and the format of streaming data to be delivered to the user. Details about this processing will be described later.
As the result of this processing, the sessions are established between:
Moreover, the following are obtained:
Steps from sequence number 4018 (3PCC (transfer) command) to sequence number 4039 (response to request) are a process for performing service routing along the determined service route (establishing sessions between each server in a series of servers via which the streaming data to be delivered to the user SIP terminal 1020 is forwarded.
Sequence Number 4018 (3PCC (Transfer) Command):
Steps from sequence number 4018 (3PCC (transfer) command) to sequence number 4022 (response to 3PCC (transfer) command) are a process for transferring the already established session between the streaming data delivery device 1030 and the server for provisional coupling 1070 and establishing a session between the streaming data delivery device 1030 and the advertisement processing server 1043.
A transfer command (REFER message) is used for processing which will be described later. However, if the NGN 1090 is a network that conforms to a specification that does not permit transmission of a REFER message, it is impossible to perform the process, which will be described later, from sequence number 4018 (3PCC (transfer) command) to sequence number 4022 (response to 3PCC (transfer) command). In this case, for example, in the processing at sequence number 4018, instead of a 3PCC (transfer) command, a session establishment command (PCC (coupling) command) may be transmitted to establish a session between the server for provisional coupling 1070 and the advertisement processing server 1043, so that the session between them is established. By linking and using two sessions, namely, the session from the streaming data delivery device 1030 to the server for provisional coupling 1070 and the session from the server for provisional coupling 1070 to the advertisement processing server 1043, the same result can be obtained as establishing a session between the streaming data delivery device 1030 and the advertisement processing server 1043 by the transfer command, which will be described later.
At sequence number 4018 (3PCC (transfer) command), the service routing computer 1000 transmits to the 3PCC device 1060 a transfer command (e.g., a transferCallParticipant request, if the Parlay X interface is used) that is directed toward the streaming data delivery device 1030. Arguments specified in the transfer command are the session number obtained at sequence number 4015 (response to 3PCC (coupling) command), the location “sip:data1@server1example.ne.jp” of data to be delivered by the streaming data delivery device 1030, and the SIP URI “sip:adv0001@advexample.com” of the advertisement processing server 1043 which is the destination of the transfer (in the case where the above transferCallParticipant request of Parlay X is used, the SIP URI of the advertisement processing server 1043 which is the destination of the transfer is stored in a string form in a field for an argument of destinationCallSesssionIdentifier and the 3PCC device 1060 having received the request parses it properly (that is, treats it as the SIP URI of the destination of the transfer); thereby, the processing which will be described later is implemented).
Sequence Number 4019 (REFER, 200OK):
The 3PCC device 1060 transmits to the streaming data delivery device 1030 a transfer command (REFER message) for transfer to the advertisement processing server 1043. In the REFER message, both SIP URIs received at sequence number 4018 (3PCC (transfer) command) are replicated. The streaming data delivery device 1030 transmits a 200OK message as a response to the received REFER message to the 3PCC device 1060.
Sequence Number 4020 (INVITE, 200OK):
The 3PCC device 1060 transmits an INVITE message to establish a session with the streaming data delivery device 1030 to the advertisement processing server 1043. The advertisement processing server 1043 returns a 200OK message as a response to the received INVITE message to the 3PCC device 1060.
Sequence Number 4021 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the advertisement processing server 1043.
By way of the foregoing sequence of sequence number 4019 (REFER, 200OK) and sequence number 4020 (INVITE, 200OK), the destination of coupling of the streaming data delivery device 1030 is changed (the session is transferred) to the advertisement processing server 1043.
Sequence Number 4022 (Response to 3PCC (Transfer) Command):
The 3PCC device 1060 returns to the service routing computer 1000 a response to the transfer command received at sequence number 4018 (3PCC (transfer) command) (in the case where transferCallParticipant of Parlay X is used, a response is void and, hence, no response message is needed).
Sequence Number 4023 (3PCC (Coupling) Command):
Steps from sequence number 4023 (3PCC (coupling) command) to sequence number 4027 (response to 3PCC (coupling) command) are a process for establishing coupling between the advertisement processing server 1043 and the posted message adding server 1042.
The service routing computer 1000 transmits to the 3PCC device 1060 a session establishment command to establish a session between the advertisement processing server 1043 and the posted message adding server 1042. Arguments specified in the session establishment command are the SIP URI “sip:adv0001@advexample.ne.jp” of the advertisement processing server 1043 and the SIP URI “sip:msg0001@msgexample.com” of the posted message adding server 1042.
Sequence Number 4024 (INVITE, 200OK):
A process from sequence number 4024 (INVITE, 200OK) to sequence number 4026 (session establishment) is compliant with a typical 3PCC message sequence which is described in, inter alia, RFC3725.
The 3PCC device 1060 transmits an INVITE message to the advertisement processing server 1043. The advertisement processing server 1043 returns a 200OK message to the 3PCC device 1060.
Sequence Number 4025 (INVITE, 200OK, ACK):
The 3PCC device 1060 transmits an INVITE message to the posted message adding server 1042. The posted message adding server 1042 returns a 200OK message to the 3PCC device 1060. The server for provisional coupling 1070 transmits an ACK message to the 3PCC device 1060.
Sequence Number 4026 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the advertisement processing server 1043.
By way of the foregoing sequence of sequence number 4024 (INVITE, 200OK) and sequence number 4025 (INVITE, 200OK, ACK), coupling is established between the posted message adding server 1042 and the advertisement processing server 1043.
Sequence Number 4027 (Response to 3PCC (Coupling) Command):
The 3PCC device 1060 transmits to the service routing computer 1000 a response (the session number of the session established at sequence number 4026 (session establishment)) to the coupling command received at sequence number 4022 (3PCC (coupling) command).
Sequence Number 4028 (3PCC (Coupling) Command):
Steps from sequence number 4028 (3PCC (coupling) command) to sequence number 4032 (response to 3PCC (coupling) command) are a process for establishing coupling between the posted message adding server 1042 and the format conversion server 1041.
The service routing computer 1000 transmits to the 3PCC device 1060 a session establishment command to establish a session between the posted message adding server 1042 and the format conversion server 1041. Arguments specified in the session establishment command are the SIP URI “sip:msg0001@msgexample.com” of the posted message adding server 1042 and the SIP URI “sip:fmt0001@fmtl.example.com” of the format conversion server 1041.
Sequence Number 4029 (INVITE, 200OK):
A process from sequence number 4029 (INVITE, 200OK) to sequence number 4031 (session establishment) is compliant with a typical 3PCC message sequence which is described in, inter alia, RFC3725.
The 3PCC device 1060 transmits an INVITE message to the posted message adding server 1042.
Then, the posted message adding server 1042 returns a 200OK message to the 3PCC device 1060.
Sequence Number 4030 (INVITE, 200OK, ACK):
The 3PCC device 1060 transmits an INVITE message to the format conversion server 1041. Then, the format conversion server 1041 returns a 200OK message to the 3PCC device 1060. Then, the format conversion server 1041 transmits an ACK message to the 3PCC device 1060.
Sequence Number 4031 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the posted message adding server 1042.
By way of the foregoing sequence of sequence number 4029 (INVITE, 200OK) and sequence number 4030 (INVITE, 200OK, ACK), coupling is established between the format conversion server 1041 and the posted message adding server 1042.
Sequence Number 4032 (Response to 3PCC (Coupling) Command):
The 3PCC device 1060 transmits to the service routing computer 1000 a response (the session number of the session established at sequence number 4031 (session establishment)) to the coupling command received at sequence number 4028 (3PCC (coupling) command).
Sequence Number 4033 (3PCC (Transfer) Command):
Steps from sequence number 4033 (3PCC (transfer) command) to sequence number 4037 (response to 3PCC (transfer) command) are a process for transferring the user SIP terminal 1020 that established the session with the server for provisional coupling 1070 to the format conversion server 1041.
As is the case for the process from sequence number 4018 (3PCC (transfer) command) to sequence number 4022 (response to 3PCC (transfer) command), a transfer command (REFER message) is used for processing which will be described later. However, if the NGN 1090 is a network that conforms to a specification that does not permit transmission of a REFER message, it is impossible to perform the process, which will be described later, from sequence number 4033 (3PCC (transfer) command) to sequence number 4037 (response to 3PCC (transfer) command).
As is the case for the process from sequence number 4018 (3PCC (transfer) command) to sequence number 4022 (response to 3PCC (transfer) command), again, for example, in the processing at sequence number 4033, instead of a 3PCC (transfer) command, a session establishment command (PCC (coupling) command) may be transmitted to establish a session between the server for provisional coupling 1070 and the format conversion server 1041, so that the session between them is established. By linking and using two sessions, namely, the session from the format conversion server 1041 to the server for provisional coupling 1070 and the session from the server for provisional coupling 1070 to the user SIP terminal 1020, the same result can be obtained as establishing a session between the format conversion server 1041 and the user SIP terminal 1020 by the transfer command, which will be described later.
At sequence number 4033 (3PCC (transfer) command), the service routing computer 1000 transmits to the 3PCC device 1060 a transfer command (e.g., a transferCallParticipant request, if the Parlay X interface is used) that is directed toward the user SIP terminal 1020. Arguments specified in the transfer command are the session number obtained at sequence number 4009 (response to 3PCC (coupling) command), the SIP URI “sip:usr@usr-example.ne.jp” of the user SIP terminal 1020, and the SIP URI “sip:fmt0001@fmtexample.com” of the format conversion server 1041 which is the destination of the transfer.
Sequence Number 4034 (REFER, 200OK):
The 3PCC device 1060 transmits to the user SIP terminal 1020 a transfer command (REFER message) for transfer to the format conversion server 1041. In the REFER message, both SIP URIs received at sequence number 4033 (3PCC (transfer) command) are replicated. The user SIP terminal 1020 transmits a 200OK message as a response to the received REFER message to the 3PCC device 1060.
Sequence Number 4035 (INVITE, 200OK):
The 3PCC device 1060 transmits to the format conversion server 1041 an INVITE message to establish a session with the user SIP terminal 1020. The format conversion server 1041 returns a 200OK message as a response to the received INVITE message to the 3PCC device 1060.
Sequence Number 4036 (Session Establishment):
The 3PCC device 1060 transmits an ACK message to the format conversion server 1041.
By way of the foregoing sequence of sequence number 4034(REFER, 200OK) and sequence number 4035 (INVITE, 200OK), the destination of coupling of the user SIP terminal 1020 is changed (the session is transferred) to the format conversion server 1041.
Sequence Number 4037 (Response to 3PCC (Transfer) Command):
The 3PCC device 1060 returns to the service routing computer 1000 a response to the transfer command received at sequence number 4033 (3PCC (transfer) command) (in the case where transferCallParticipant of Parlay X is used, a response is void and, hence, no response message is needed).
By way of the foregoing process from sequence number 4018 (3PCC (transfer) command) to sequence number 4037 (response to 3PCC (transfer) command), service routing for the service route obtained by sequence number 4017 (route determination processing) is completed.
Sequence Number 4038 (Response to Request):
The service routing computer 1000 transmits to the portal server 1110 a message indicating that routing has been completed normally as a response to the request received at sequence number 4003 (request).
Sequence Number 4039 (Response to Request):
The portal server 1110 transmits to the user Web terminal 1021 a message indicating that it accepted the service request normally as a response to the request received at sequence number 4002 (request).
Sequence Number 4040 (Streaming Data):
A process from sequence number 4040 (streaming data) to sequence number 4046 (streaming data) is the process for delivering streaming data via the sessions established before this point of time.
At sequence number 4040 (streaming data), the streaming data delivery device 1030 transmits streaming data 0001 to the advertisement processing server 1043 via the session established at sequence number 4021 (session establishment).
In the sequence of the present embodiment, sequence number 4040 (streaming data) starts after the completion of sequence number 4039 (response to request). In practice, however, transmission of streaming data need not wait for the completion of sequence number 4039 (response to request) and may be initiated at any timing after the session is established at sequence number 4021 (session establishment). In that case, the advertisement processing server 1043 caches data received at sequence number 4040 (streaming data) until the completion of sequence number 4026 (session establishment).
Sequence Number 4041 (Advertisement Processing):
The advertisement processing server 1043 adds advertisement information to streaming data received at sequence number 4040 (streaming data).
Sequence Number 4042 (Streaming Data):
The advertisement processing server 1043 transmits streaming data processed at sequence number 4041 (advertisement processing) to the posted message adding server 1042 via the session established at sequence number 4026 (session establishment).
Sequence Number 4043 (Posted Message Adding Processing):
The posted message adding server 1042 adds information posted by a user of the service to streaming data received at sequence number 4042 (streaming data).
Sequence Number 4044 (Streaming Data):
The posted message adding server 1042 transmits streaming data processed at sequence number 4043 (posted message adding processing) to the format conversion server 1041 via the session established at sequence number 4031 (session establishment).
Sequence Number 4045 (Format Conversion Processing):
The format conversion server 1041 converts the format of streaming data received at sequence number 4044 (streaming data) from mpeg4 to h.263.
Sequence Number 4046 (Streaming Data):
The format conversion server 1041 transmits streaming data processed at sequence number 4045 (format conversion processing) to the user SIP terminal 1020 via the session established at sequence number 4036 (session establishment).
Step 5001 (Resolving User Information):
The service routing computer 1000 refers to the user information 1011 database, using user ID 5101 included in the request message received at sequence number 4003 (request), and obtains user charging information 3002.
In the illustrative example of the present embodiment, the service routing computer 1000 can obtain charging information “1” for user ID “usr0001”; that is, meaning that the user is a “charge-free ID registrant user”.
Step 5002 (Resolving Delivery Data Constraints):
The service routing computer 1000 refers to the delivery policy 1014 database, using delivery data ID 5102 included in the request message received at sequence number 4003 (request) and the user charging information obtained at step 5001 (resolving user information), and obtains information as to whether or not to limit quality and to present advertisement. Using the thus obtained information and the delivery data ID 5102, the service routing computer 1000 refers to the processing server list 1015 database and obtains the identifier of a processing server via which the streaming data is to be forwarded by service routing.
In the illustrative example of the present embodiment, since the delivery data ID 5102 is “data0001” and the user charging information is “1”, the service routing computer 1000 obtains a delivery policy not to limit quality and to present advertisement. Further, referring to the processing server list 1015 database, the service routing computer 1000 obtains “adv0001” as the identifier of a processing server via which the streaming data is to be forwarded.
Step 5003 (Resolving User Setting):
The service routing computer 1000 refers to the user setting 1012 database, using the user ID 1501 and delivery data ID 5102 included in the request message received at sequence number 4003 (request), and obtains information as to whether or not to add a user posted message. Using the thus obtained information and the delivery data ID 5102, the service routing computer 1000 refers to the processing server list 1015 database and obtains the identifier of a processing server via which the streaming data is to be forwarded by service routing.
In the illustrative example of the present embodiment, since the user ID 5101 is “usr0001” and the delivery data ID 5102 is “data0001”, the service routing computer 1000 can obtain user preference information that the user wants to have a user posted message added to the streaming data to be delivered. Further, referring to the processing server list 1015 database, the service routing computer 1000 obtains “msg0001” as the identifier of a processing server via which the streaming data is to be forwarded.
Step 5004 (Resolving Media Format):
The service routing computer 1000 refers to the format conversion server list 1016 database, using the format 1503 available to the user SIP terminal 1020 obtained at sequence number 4010 (notification of SDP information) and the format 1503 of streaming data for delivery obtained at sequence number 4016 (notification of SDP information), and obtains the identifier of a format conversion server 1041 to convert the format of the streaming data for delivery into the format available to the user SIP terminal 1020.
In the illustrative example of the present embodiment, since the format of the streaming data for delivery (with the delivery data ID 1502 of “data0001”) is “mpeg4” and the format available to the user SIP terminal 1020 is “h.263”, the service routing computer 1000 obtains “fmt0001” as the identifier of the format conversion server 1041.
Step 5005 (Creating Route Information):
The service routing computer 1000 determines information (a route) for service routing by using the processing results from step 5001 (resolving user information) to step 5004 (resolving media format), the delivery data list 1013 database, and the processing server locations 1017 database.
In the present embodiment, the system components or servers along the determined route are to be coupled one another statically in the following order: streaming data delivery device 1030; advertisement processing server 1043; posted message adding server 1042; quality limiting server, format conversion server 1041, user SIP terminal 1020 (among them, one system component (or server) couples to the next one in this order, but skipping a server of a type via which steaming data does not need to be forwarded).
Thus, in the illustrative example of the present embodiment, first, “the streaming data delivery device 1030 couples to the advertisement processing server 1043 “adv0001”” and, in turn, “the advertisement processing server 1043“adv0001” couples to the posted message adding server 1042“msg0001””, “the posted message adding server 1042“msg0001” couples to the format conversion server 1041“fmt0001””, and “the format conversion server 1041“fmt0001” couples to the user SIP terminal 1020”. And, reference to the locations yields results that “the advertisement processing server 1043 is “sip:adv0001@advexample.com”, the posted message adding server 1042 is “sip:msg0001@msgexample.com”, and the format conversion server 1041 is “sip:fmt0001@fmtexample.com”.
In the foregoing process, it is not necessarily the case that the order of the couplings along the route is determined statically. For example, dependence relations between processing servers, that is, “processing that is performed by one processing server (identifier) need to be performed before processing that is performed by another processing server (identifier)” may separately be retained as a matrix in a database. It is also possible to use a manner of determining the order of the couplings so as to satisfy such dependence relations.
According to the present embodiment described in the previous paragraphs, it is possible to curtail the procedure until a session is established between the delivery server and the user terminal.
Determining a service route and routing for processing according to data delivery policy, user preference, and available-format can be implemented. It becomes possible to give an added value to data to be delivered to users.
It also becomes possible to add business advertisement to data efficiently according to the contents of the data to be provided to users; this is beneficial for the service provider.
Further, for example, a streaming data processing server that adds user ID and a time stamp when the service is provided, as digital watermark data, to streaming data, may join a service route; this can produce an effect of content protection.
A standard protocol, an SIP is used as is for building the streaming data delivery system service in the present embodiment. Thus, it is not necessary to modify existing SIP servers and SIP clients. This is also advantageous, as it is possible to reduce the cost for developing the interfaces for service routing.
The embodiment described hereinbefore is only exemplary and is not intended to limit the present invention to the foregoing embodiment.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereto without departing from the spirit and scope of the invention(s) as set forth in the claims.
Number | Date | Country | Kind |
---|---|---|---|
2010-149245 | Jun 2010 | JP | national |