The invention relates to extending universal plug and play (UPnP) framework by means of UPnP message translation beyond a local area network (LAN). More specifically, the invention relates to translating a message between UPnP and session initiation protocol (SIP). The invention enables UPnP services and control points to become highly mobile.
UPnP technology establishes protocols that allow networked UPnP devices to interact with each other. Examples of devices that may be configured to implement UPnP protocols include computers, servers, printers, telephones, digital cameras, video recorders, Internet personal appliances, or personal digital assistants.
Typically, one UPnP device acts as a control point and another UPnP device exposes a service to that control point. A control point is an entity on the Local Area Network (LAN) that invokes an action on the service. For example, a control point may request a service to transmit data to the control point. Due to the nature of UPnP service discovery and eventing mechanisms, UPnP technology is limited in that it is only applied to UPnP devices that are connected to well-controlled LAN environment, where multicasting is supported.
While UPnP is limited to the LAN, Session Initiation Protocol (SIP) possesses no such limitations. SIP is a signaling protocol that will likely provide Internet Protocol (IP) multimedia services for the next generation of mobile devices. SIP provides application layer mobility. SIP also carries extensible markup language (XML), performs eventing, and includes security features that are presently lacking under UPnP. For example, SIP establishes, modifies, and terminates multimedia sessions, such as Internet telephony calls commonly referred to as voice of IP (VOIP). Through its features, SIP is an ideal protocol for device and service discovery and control frameworks, where application and user mobility are important.
While SIP is increasingly viewed as the communication protocol to be used when merging the cellular and Internet worlds, there is present no architecture for extending UPnP with mobility by using SIP. It is therefore desirable to have a system networking architecture that overcomes this limitation.
The present invention will become more fully understood from the detailed description and the accompanying drawings, wherein:
The following description of the preferred embodiments is merely exemplary in nature and is in no way intended to limit the invention, its application, or uses. For purposes of clarity, the same reference numbers are used in the drawings to identify similar elements.
The present invention describes a plug and play (UPnP) mobility framework that extends UPnP beyond a local area network (LAN). This UPnP mobility framework is generally achieved through message translation between session initiation protocol (SIP) and UPnP.
One embodiment of the invention is briefly summarized below followed by a more detailed description of all of the various embodiments. One embodiment involves a method for extending UPnP messaging beyond a LAN. A proxy resides on the mobile device. The proxy includes at least one proxying agent such as a control proxying agent, a registration proxying agent, and/or an eventing proxying agent. At least one SIP message is translated into a UPnP message. For example, a SIP control message is translated by the control proxying agent into a UPnP control message.
Another example relates to a SIP registration message that is translated by the registration and service discovery proxying agent into a UPnP registration message, a UPnP service and discovery message, or a UPnP advertisement message.
Yet another example involves a SIP-based event-notification-driven service discovery message that is translated by the event proxying agent into a UPnP service discovery and registration message. The UPnP message is then sent over the LAN to the UPnP device. The UPnP device then responds to the UPnP message.
The first system 100 shown in
The mobile device 110 includes a proxy 105. The proxy 105 translates messages between two application and network layer protocols. For example, when translating from UPnP to SIP frameworks and protocols, generally a portion of the UPnP layer protocols are substituted with SIP, or vice versa. To accomplish this task, the proxy 105 includes a SIP stack 219, a plurality of proxy agents 159, and a UPnP stack 215.
The SIP stack 219 is a group of layered protocols, such as that which is shown in
The plurality of proxy agents 159 include a UPnP registration and service discovery proxy agent 116, a UPnP eventing proxy agent 117, and/or a UPnP control proxy agent 118. The UPnP registration and service discovery proxy agent 116 translates UPnP service discovery (e.g., advertise, search, response) messages into SIP service registration and eventing messages, enabling service discovery and registration between UPnP and SIP frameworks. The UPnP eventing proxy agent 117 translates eventing messages between SIP and UPnP frameworks and protocols, enabling UPnP state viable eventing and event moderation. The UPnP control proxy agent 118 translates device/service control messages between SIP and UPnP frameworks and protocols, enabling UPnP device control mobility.
The mobile device 110 also includes a UPnP stack 215. The UPnP stack 215 includes a group of layered protocols (e.g., SSDP, GENA) as is also shown in
Messages between the mobile device 110 and the UPnP devices 106-108, are transmitted through the gateway 121. The gateway 121 interconnects the LAN 112 and the WAN networks.
The LAN-side SIP-UPnP proxy 205 optionally resides in the gateway 121 or immediately thereafter. The LAN-side SIP-UPnP proxy 205 translates messages between SIP and UPnP frameworks in an inverse and complimentary fashion to mobile SIP-UPnP proxy 105. For example, the LAN proxy 205 receives the SIP message from the mobile device 110. The LAN-side proxy 205 then translates this SIP message to a UPnP message through a UPnP registration and service discovery proxy agent 116, a UPnP eventing proxy agent 117, or a UPnP control proxy agent 118. The UPnP message is then transmitted from the LAN-side proxy 205 to a UPnP device 106-108 over the LAN. While system 100 has been described relative to a message that is sent from the mobile device 110 to one of the UPnP devices 106-108, skilled artisans understand that the message flow may be reversed.
The mobile device 110 or the UPnP devices 106-108 may serve as control points to a UPnP service. As previously described, a UPnP control point (CP) invokes an action on a UPnP service. A control point may discover devices, retrieve device and service descriptions, invoke actions on services, query for state variables, receive events from services, and other like tasks. Each of these processes is briefly described.
Discovering UPnP devices involves a search on a network to find at least one device that meets the search criteria, originated by the CP. The universal resource locator (URL) of a UPnP device that matches the search criteria is then, sent to the control point in response. The control point then uses this URL to retrieve the device or the service description documents. The device description document contains device information such as the name of the manufacturer, the model of the device, the serial number, a list of services provided by the device, and a list of embedded devices. In comparison, a service description document contains detailed information about the service, the actions or commands that it provides, relevant parameters, and a return values. Once a control point has discovered and retrieved the device and/or service description documents, the control point may control the device, subscribe to events sourced by the device's services, or retrieve the device's presentation page. The presentation page is the interface used to control the device, to change operational parameters, to view the device or service information, or for any other device specific functionality implemented by the manufacturer.
A query for a state variable is responded to by a service to provide access to its state variables. A state variable has a name type, optional default value, and optional constraint values. The state variables may trigger UPnP events when its value changes. An event allows a control point to monitor state changes in a device. The device's service notifies all registered control points of any changes in its state variables.
UPnP message payloads, like control message 228, an eventing message 229, a discovery message 230, and a presentation message 231 are proxied through the registration proxy agent 116, eventing proxy agent 117, or control proxy agent 118 into a SIP message. The SIP message may include newly defined content-type 233, a newly defined SIP method 235, or a SIP extension header 237. For example, the newly defined SIP extension header indicates the type of UPnP request and the destination of such request. The so constructed SIP message is then transmitted through the transport layer of the SIP stack 219 for the mobile device 110 over the SIP network 220.
Referring now to
A comparison of the UPnP architecture protocol stack 520 to the SIP architecture protocol stack 550
The SIP layered architecture 550 includes a SIP 552, a UDP 530, a TCP 532 and a IP 534. SIP 552 carries and provides mobility to the UPnP elements of the UPnP message or an encapsulated UPnP message.
Generally, translating a UPnP message to a SIP message requires either a number of UPnP elements to be translated into the SIP header extensions or the UPnP message elements to be encapsulated into a SIP message body.
A UPnP control uses the simple object access protocol (SOAP). SOAP is a protocol that brings together XML and HTTP to provide web-based messaging and a remote procedure call mechanism. XML is used to express the contents of the message.
By parsing the elements of the structured UPnP XML message, a proxy 105 constructs the SIP message. The fields of the structured XML correspond to the new headers defined in SIP. In another embodiment, the entire portion of the XML on the left hand side of
In this embodiment, the control proxy agent 118 translates data from a control UPnP message to a SIP message carrying control information by mapping the UPnP elements to the SIP message in the fashion described above. The other types of UPnP messages are proxied into different types of SIP messages through one of the proxy agents 116-118.
Turning now to the actual mapping of the UPnP data to the SIP data, as shown in this example, UPnP elements are mapped to the SIP header extensions, which allows another SIP proxy agent to review the SIP header above to properly handle the message. The SOAP XML elements directly translates to the SIP extension headers as shown by the arrows in
The mobile device UPnP registration proxying agent 620 translates the SIP register message to a UPnP advertise message denoted as 2. This message is then sent to the UPnP control point 630. Mobile device database 621 is updated within 620 as a result of SIP:Register request.
The UPnP control point 630 can also send a search message, denoted as 3, to the registration proxying agent 620. The search message is a query for a registered UPnP service that may be invoked on a mobile device. The mobile device UPnP registration proxying agent 620 then accesses the mobile device database (DB) 621 for current service registrations and sends a UPnP response, denoted as 4, to the UPnP control point 630. This response indicates whether a UPnP service is available on the mobile device 110. The SIP UA 610 may also send another SIP registration message, denoted as 5, that cancels the registration of the mobile device 110 UPnP service.
Once this event occurs, the SIP UA 1010 sends a SIP:Notify message, denoted as 4, to the UPnP eventing proxying agent 1020. The SIP notify message, denoted as 4, indicates the status of the event generated by the UPnP device 110. The UPnP eventing proxying agent 1020 translates this message and then sends a UPnP:Event message Notify, denoted as 5, to the UPnP control point 1030. The UPnP eventing Subscription:Renew message, denoted as 6, can also be sent from UPnP control point 1030 to the eventing proxying agent 1020 in order to update UPnP event subscriptions. The UPnP control point 1030 sends an UPnP:Eventing:Unsubscribe message, denoted as 7, to eventing proxying agent 1020 to terminate even subscriptions. As a result, eventing proxying agent 1020 sends a SIP:Subscribe message with “Expires” header set to zero [null], denoted as 8, that cancels the event subscription.
As a result, a SIP OK message, denoted as 4, is then sent from the registration proxying agent 1120 to SIP UA 1110. Once the event occurs, the SIP UA 1110 sends a SIP notify message, denoted as 5, to the registration proxying agent 1120. Registration proxying agent 1120 then translates SIP event into UPnP event and sends a UPnP:Event Notify, denoted as 6, to the UPnP device/service. The SIP UA1110 may send the SIP:Subscribe message (expires=0), denoted as 7, to the registration proxying agent 1120 to unsubscribe from event notification. In response, the UPnP registration proxying agent 1120 then sends a UPnP eventing unsubscribe message, denoted as 8, to the UPnP device/service 1130.
It will be appreciated that more or fewer processes may be incorporated into the methods described herein without departing from the scope of the invention and that no particular order is implied by the arrangement of blocks shown and described herein. Skilled artisans will appreciate that the methods may be embodied in machine-executable instructions (e.g., software). The instructions can be used to cause a general-purpose or special-purpose processor that is programmed with the instructions to perform the operations described. Alternatively, the operations may be performed by specific hardware components that contain hard-wired logic for performing the operations, or by any combination of programmed computer components and custom hardware components.
The methods may be provided as a computer program product that may include a machine-readable medium having stored thereon instructions which may be used to program a computer (or other mobile devices) to perform the methods. For the purposes of this specification, the terms “machine-readable medium” includes any medium that is capable of storing or encoding a sequence of instructions for execution by the machine and that cause the machine to perform any one of the methodologies of the present invention. The term “machine-readable medium” includes, but is not be limited to, solid-state memories, optical and magnetic disks, and carrier wave signals.
The present invention may be implemented through various architectures such as a peer-to-peer network, a client/server network, or a master/slave network. Skilled artisans appreciate that any one of these networks may be involved at any instant in implementing techniques of the present invention with respect to
In the preceding detailed description, the invention is described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.