The present invention relates generally to a network gateway device and, more particularly, to a network gateway device having an XML interface for communicating with external devices, such as billing and content servers, via XML commands and responses.
In order to connect the computer of a user/subscriber to one or more networks or other online services, a variety of gateway devices have been developed. For example, one advantageous gateway device is described by U.S. patent application Ser. No. 08/816,174 and U.S. Provisional Patent Application No. 60/111,497, the contents of both of which are incorporated herein by reference. The gateway device can serve as a gateway to the Internet, an enterprise network, or other networks and/or on-line services. In addition to serving as a gateway, the gateway device can automatically adapt to the protocols and other parameters utilized by the host computer, in order that the host computer may communicate with the network in a manner that is transparent both to the user/subscriber and the network. Once the gateway device has appropriately adapted to the packets coming from the user's computer, the computer can appropriately communicate via the network, such as the network at a hotel, at home, at an airport, or any other location, in order to access other networks, such as the enterprise network, or other online services, such as the internet. In this fashion, the gateway device is capable of providing more efficient network access and network maintenance to the user/subscriber and the network operator.
Gateway devices must therefore communicate with a variety of external devices. For example, gateway devices typically communicate with billing and content servers which present customizable billing options and content pages for every subscriber of the gateway device. With respect to content, billing and content servers can present different log-on screens and pricing to a subscriber based upon one or more attributes associated with the subscriber. For example, a billing and content server can present different log-on screens and pricing based upon the location from which the subscriber accesses the network. In this regard, a subscriber in a suite may be presented with a different log-on screen and pricing options than a subscriber in a regular room or a conference room. Additionally, billing and content servers can present subscribers with customized web content based upon one or more attributes associated with the subscriber. By way of example, a billing and content server can customize the web content based upon the location from which the subscriber accesses the network. In this respect, different fire escape route maps can be presented to the subscriber based upon the room location from which the subscriber accesses the network. Additionally, guests in suites may have access to different web content than subscribers residing in a standard room.
With respect to billing, billing and content servers typically interface with a credit card authorization server in order to obtain credit card information and authorization regarding the various subscribers. Depending upon the billing arrangement of a particular subscriber, the billing and content server can communicate directly with the credit card authorization service in order to appropriately charge the subscriber's credit card account for the various services that the subscriber accesses via the gateway device. Alternatively, the billing and content server can communicate via the gateway device with a network management system, such as the property management system of a hotel, in order to appropriately charge the subscriber's account for the various services that the subscriber accesses via the gateway device.
Billing and content servers can also perform other functions, such as distributing email based upon mailing lists configured according to subscriber-specific information. Billing and content servers can also maintain and update membership records, such as frequent users clubs or frequent visitors clubs.
As briefly mentioned above, gateway devices may also communicate with a network management system, such as the property management system maintained by a hotel or the like. The functions performed by a network management system typically vary based upon the installation and application. For example, typical hotel property management systems automate operations such as room reservations, room assignments, guest check-in and check-out, and other front desk activities. Furthermore, typical hotel property management systems can maintain a log of telephone calls and telephone charges for each guest room, and can be in communication with the Internet to facilitate on-line reservations. As described in a provisional application entitled Systems And Methods For Enabling Network Gateway Devices To Communicate With Management Systems To Facilitate Subscriber Management bearing application No. 60/160,973 filed Oct. 22, 1999 and in a utility patent application entitled Systems and Methods for Integrating A Network Gateway Device with Management Systems filed concurrently herewith, gateway devices oftentimes communicate with network management systems, such as in instances in which the subscriber's access to various networks or on-line services is to be charged to their account that is administered by the network management system. The contents of these applications are also incorporated herein by reference.
Upon requesting access to a particular computer system or on-line service, the gateway device typically determines if the subscriber is entitled to access the computer system, the level of access and/or the type of services to which the subscriber is entitled according to an Authentication, Authorization, and Accounting (AAA) procedure that is described by U.S. patent application Ser. No. 09/458,602 entitled Systems and Methods for Authorizing, Authenticating and Accounting Users Having Transparent Computer Access to a Network Using a Gateway Device filed Dec. 8, 1999 and a patent application entitled Systems and Methods for Providing Dynamic Network Authorization, Authentication and Accounting filed concurrently herewith, the contents of each of which are incorporated herein by reference. An AAA server, which is a database of subscriber records, may be remote to the gateway device or the AAA database may be incorporated into the physical embodiment housing the gateway device. As such, in instances in which the AAA server is remote to the gateway device, the gateway device must also frequently communicate with the AAA server.
In addition to the external devices described above with which the gateway device frequently communicates, gateway devices may also communicate with a wide variety of other external devices depending upon the application. Unfortunately, communications with any of these external devices may be limited due to the particular format in which the external devices are designed to transmit and receive information. Since the external devices are typically designed by a number of different vendors, each of which may prefer a different format for communications, this problem is compounded by the lack of uniformity in the format with which the external devices communicate. In this regard, one external device may be designed to communicate according to one format, while another external device may be required to communicate according to another format. Since the subscriber gateway may be required to communicate with a variety of different external devices, the gateway device would seemingly have to communicate with each external device according to the particular format that is acceptable to the external device. This requirement can quickly prove cumbersome to the design, implementation and efficient operation of a gateway device since it will be forced to communicate according to a number of different formats. While this requirement is a current concern for the efficient utilization of gateway devices that must communicate with multiple external devices, this concern is expected to grow as the variety of applications in which gateway devices are employed increases and the number of different types of external devices with which the gateway device must communicate also grows.
According to the present invention, a gateway device and associated method are therefore provided that facilitate communications with external devices by utilizing a uniform communications format. As such, the gateway device is not required to communicate with each external device according to a unique format defined by the respective external device. Accordingly, the gateway device and associated method of the present invention improve communications between the subscriber computer, gateway device and various external devices, such as billing and content servers, property management systems, external AAA servers and the like.
According to one aspect of the present invention, a gateway device is provided that includes a subscriber interface for adapting to a subscriber computer that is connected to the gateway device. The subscriber interface facilitates communications between the subscriber computer and at least one network or on-line service without requiring the subscriber computer to be reconfigured and, in particular, without requiring the subscriber computer to support XML commands and responses. According to the present invention, the gateway device also includes an XML interface for communicating with an external device via a series of XML commands and responses. The XML commands and responses can relate to a variety of matters, including various subscriber management matters.
Typically, the XML interface includes a parser front end, a parser section and a building section for appropriately handling XML commands that are received by the gateway device and for sending appropriate responses. The parser front end determines the type of operation requested by the external device. The parser section is responsive to the parser front and organizes elements parsed from either an XML command or an XML response. Once parsed, the XML command is executed. Typically, the parser section passes at least some of the elements to a requested application. Prior to passing the elements to a requested application, however, the parser section typically nests the elements to be passed within an application programming interface (API) wrapper. The building section prepares responses to requests received by the gateway device. Typically, the building section assembles results returned by requested application into an XML response. The gateway device of the present invention can also include an internal web server for communicating with both the XML interface and the internet to thereby facilitate XML-based communications between the gateway device and external devices connected to the internet. As such, the gateway device supports communications involving the subscriber computer and the external devices without ever requiring the subscriber computer to support XML commands and responses.
The present invention also provides a method for communicating between the gateway device and external device via the internet. According to this aspect of the present invention, an XML command is initially received at the gateway device from the external device, such as the billing and content server. The XML command is then parsed, and the parsed XML command is executed, such as by being passed to a respective application program, such as the AAA server for performing the requested function, such as a subscriber management function. Prior to passing the parsed XML command to the respective application program, however, the elements to be passed to the requested application are preferably nested within an API wrapper. Upon completion of the requested function, the application program issues a response that is received by the gateway device and that is then included within an XML response transmitted from the gateway device to the external device.
As such, the gateway device and associated method of the present invention facilitate communications between the subscriber computer, the gateway device and a variety of external devices, such as external billing and content servers, property management systems and external AAA servers. In this regard, the gateway device can communicate with each of these various external devices in a uniform manner via a series of XML commands and responses, thereby dramatically reducing, if not eliminating, the instances in which the gateway device would have to communicate with an external device according to the unique format established by the external device. As a result, the design, implementation and operation of the gateway device should be considerably simplified. However, the gateway device and associated method of the present invention permit the subscriber computer to enjoy the benefits of the common XML command and response format without ever having to be reconfigured to support XML.
The present invention now will be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like numbers refer to like elements throughout.
Referring now to
As illustrated in
The computer system 10 further includes one or more routers 18 and/or servers (not shown in
As described above, gateway devices 14 must typically communicate with a variety of external devices. For example, gateway devices typically communicate with billing and content servers 26 as depicted in
The gateway device 12 may also communicate with a management system 28, such as the property management system of a hotel or the like. In this regard,
While the functions performed by network management systems 28 vary based upon the installation and the application, typical hotel property management systems automate operations such as room reservations, room assignments, guest check-in and check-out and other front desk activities as described above. In addition, typical hotel property management systems can maintain a log of telephone calls and telephone charges for application to the bill for each guest room. Accordingly, the gateway device 12 of the present invention can communicate with a property management system in order to place charges for the various services that a subscriber accessed via the gateway device upon the appropriate bill that is maintained by the property management system.
Moreover, while the AAA functionality is typically physically embodied within the gateway device 12, the gateway device can be configured to communicate with external AAA servers in order to authenticate a subscriber, to obtain authorization for the services requested by the subscriber and to appropriately account for their usage. In addition, gateway devices may communicate with a wide variety of other external devices, particularly as gateway devices are deployed in new applications or installations.
In order to avoid the overhead associated with communicating with each of these external devices according to the unique format in which the external device is designed to communicate, the gateway device 12 of the present invention communicates with the external devices with a series of commands and responses formatted according to the extensible markup language (XML). As known to those skilled in the art, XML is defined as an application profile of the standard generalized markup language (SGML) that is defined by ISO 8879. While SGML has been the standard, vendor-independent technique to maintain repositories of structured documentation for more than a decade, SGML is not well suited to serving documents over the world wide web. While XML is designed to enable the use of SGML on the world wide web, XML is not a single, predefined markup language. Instead, XML allows the system designer to design their own markup language. In this regard, a predefined markup language, such as hypertext markup language (HTML), defines one manner in which to describe information in one specific class of documents. In contrast, XML allows the system designer to define its own customized markup languages for different classes of documents. As such, XML specifies neither semantics nor a tag set. However, XML provides a facility to define tags and the structural relationships between them. See XML specification 1.0 for further details regarding XML.
XML has conventionally been utilized to facilitate communications between servers, such as for billing purposes, and not to facilitate communications with a user, either directly with a user's computer 14 or through an intermediary such as a gateway device 12. As such, computers are not generally configured to communicate in or to support XML. In order to provide a user with the advantages of XML including the ability to communicate in a common language with a wide variety of network devices without requiring that each computer be reconfigured to support XML, the gateway device 12 of the present invention serves as a proxy for the user's computer and utilizes XML to communicate with a variety of external devices, including the billing and content server 26 and the property management system 28. In addition, in instances in which the AAA functionality resides in an external AAA server, the gateway device can also communicate with the external AAA server via XML. In particular, the gateway device is designed to communicate with the network devices according to a set of XML commands and XML responses, thereby affording the user's computer the advantages offered by XML without requiring the user's computer to be reconfigured to support XML. Since the XML format is not specific to any particular external device, the gateway device can advantageously communicate with a variety of external devices via a common format, i.e., XML, and need not format messages differently based upon the format with which the external device is otherwise designed to communicate.
For example, a user can submit a request to purchase a product from an online provider. According to the present invention and as described in the following examples, the gateway device 12 can then communicate in a common XML format with various network devices, including billing and content servers, to authenticate and authorize the user, to order the product and to account for the user's payment for the product, without ever requiring the user's computer 14 to support XML.
As depicted in
In order to handle XML commands that are received from an external device, the gateway device 12 includes an XML interface, also known as an XML parser 32, that is typically comprised of software, that is compliant with the world wide web consortium (W3C) standards to validate the XML command strings and the attributes and data derived from an XML query string. As depicted in
The XML interface 32 of the gateway device 12 also includes a parser section 36, typically comprised of software, to handle elements as they are parsed from the XML stream. In this regard, parsed elements are organized into separate parameters that are passed to the requested application, such as the AAA server, via an appropriate application program interface (API). As shown in
The gateway device 12 therefore also includes a building section 44 that is also comprised of software and that prepares responses to requests received by the gateway device. In this regard, the building section of the XML interface 32 assembles the results returned by the requested application into a new XML string that will be part of the HTTP response stream returned to the external device via a component such as the aforementioned goahead server. With respect to a HTTP response stream sent back to a billing and content server 26 via the world wide web, the HTTP response stream is typically nested inside a TCP/IP packet in order to be appropriately transmitted and received by the billing and content server. See, for example,
A response that is returned by the gateway device 12 can be one of two types. First, a standard “OK” response can be returned that typically includes the data, if any, requested by the external device. Alternatively, an error response can be returned that typically consists of a numeric error code and a textual description of the error. In either instance, the XML interface 32 generally creates a standard header consisting of the status, such as “OK” or “ERROR”, the ID of the gateway device and the gateway device's IP address. This response is then placed onto the world wide web by the internal web server 30 of the gateway device for delivery to the external device.
While the XML interface 32 of the gateway device 12 of the present invention will be primarily described hereinafter in conjunction with XML commands received by the gateway device from an external device, followed by XML responses sent by the gateway device to the external device, the gateway device of the present invention can be constructed so as to initiate XML-based communications by issuing XML commands to various external devices and awaiting appropriate responses. In addition, while the gateway device including an XML interface will primarily be described in conjunction with communications involving an external billing and content server 26 that requests information from the AAA server, the gateway device can establish XML-based communications with other external devices, such as a property management system 28 or, in instances in which the AAA server is external to the gateway device, with the AAA server itself. In any of these instances, the gateway device is able to communicate with the external device or server according to a common protocol, i.e., XML, without having to communicate with each external device in the format unique to the respective external device. As such, the only requirement of the external device is that the external device has an XML interface and be adapted to support the same XML command protocol as the gateway device.
While various XML command protocols can be established depending upon the external device and the nature of the communication between the external device and the gateway device 12, one command protocol established between an external billing and content server 26 and a gateway device is hereinafter provided by way of example and not by way of limitation. In this example, the billing and content server sends XML commands to the gateway device which, in turn, responds to the billing and content server. In one example, the XML commands transmitted by the billing and content server to the gateway device are sent using an HTTP form POST in which the information is placed in packets sent after the HTTP header. In this example, the command text will generally follow the following format:
<USG COMMAND=“(command)” [(attr)=“(attr_data)”]>
<(tag_n) [tag_n_attr=“(tag_n_attr_data)”]>(data_n)</(tag_n)>
</USG>
where:
(command) is a gateway device command;
(attr) is an optional attribute associated with a command;
(attr_data) is the data associated with the optional attribute tag;
(tag_n) is a data name tag used for specifying command parameter names;
(tag_n_attr) is an optional attribute name tag;
(tag_n_attr_data) is optional attribute data, and
(data_n) is the data associated with a data name tag.
In addition, the typical XML response from the gateway device 12 to a billing and content server 28 following receipt of an XML command from the billing and content server is typically formatted as follows:
In this regard, while the series of XML tag/data pairs referenced in the above exemplary XML response format will depend upon the particular command as described below, one series of XML tag/data pairs typically follow the following format:
<USG RESULT=“(RESULTCODE)” ID=“(UI)” IP=“(USG_IP_ADDR)”>
[<ERROR_NUM (error number)</ERROR_NUM>]
[<ERROR_DESC>(error description)</ERROR_DESC>]
<(tag_n) [tag_n_attr=“tag_n_attr_data”]>(data_n)</(tag_n)>
</USG>
where:
(RESULTCODE) is either “OK” or “ERROR”;
(UI) is the gateway device ID;
(USC_IP_ADDR) is the IP address of the gateway device;
(tag_n) is a data name tag;
(tag_n_attr) is an optional attribute name tag;
(tag_n_attr_data) is optional attribute data; and
(data_n) is the data associated with a data name tag.
As indicated, all XML responses returned following an XML command will contain error information. In this regard, the attribute RESULT will be assigned either “OK” or “ERROR”. If an error did occur, two additional tag/data pairs will be added as part of the response form, namely, error_num and error_desc. The error number data will contain an integer number representing the error that occurred, while the error description data will be a readable textual description of the error.
While a variety of commands and responses can be established based upon the foregoing XML command and response formats, examples of several particular commands that could be issued by a billing and content server 26 to the gateway device 12, requesting either room administration or user administration, are provided below. The resulting responses provided by the gateway device are also provided. However, the following commands and responses are for purposes of illustration only and should not be construed as limitations of the type of XML commands and responses that can be formulated.
Regarding room administration, the billing and content server 28 can issue an XML command to set the access mode of a specified room that includes the following command, command attribute, command attribute data, and tag/data pair:
In response, the gateway device 12 would typically issue a standard XML response indicating that the command was received and implemented appropriately or that an error occurred.
Also with respect to room administration, a billing and content server 26 can issue a command querying the gateway device 12 regarding the access mode of a specified room. In this regard, the query room status command could include the following command, command attribute, and command attribute data:
In response, the gateway device 12 could return a standard response, including the following tags and data in which the room access mode is selected from one of “room_open”, “room_charge” or the “room_block”:
With respect to user administration, the billing and content server 26 can issue a command to add or update a user that has been authorized for access and should now be added to the MAC or some other type of authorization table, that is, a memory table maintained by the gateway device 12. In this regard, one example of an XML command to add/update a user typically includes the following command, command attribute, command attribute data, and tag/data pair:
In response, the gateway device 12 would typically issue a standard XML response indicating that the command was received and processed appropriately or that an error occurred.
The billing and content server 26 can also issue an XML command to delete a user who is identified by a Subscriber Identifier, such as aMAC address, a user name or an IP address. In this regard, one example of a delete user command typically includes the following command, tag and data:
In response, the gateway device 12 would typically issue a standard XML response indicating that the command was received and processed appropriately or that an error occurred.
The billing and content server 26 can also query the gateway device 12 for the current user data by issuing an XML command that, in one, example, includes the following command, tag and data:
In response, the gateway device 12 typically uses a standard XML response with the following tags/data pairs:
The billing and content server 26 can also issue a command to check a user's identity, as specified by a MAC address, as one example, against the authorization tables maintained by the gateway device 12 or the associated AAA server. If the user is found either in the MAC or room authorization table of this example, VALID_USER is returned along with the user authorization method, such as RADIUS, property management system (PMS) (in instances in which the fee is to be billed to the user's account), credit card or room (in instances in which the room is opened up for free internet access). If the user was not found in the MAC or room authorization tables, INVALID_USER will be returned. In any event, the XML command issued by the billing and content server typically includes the following command, command attribute and command attribute data:
In response, the gateway device 12 typically issues a standard XML response indicating that the command was received and processed appropriately or that an error occurred, and that includes the following tag and data pairs:
The billing and content server 26 can also issue an XML command requesting user authorization and payment. If the authorization method that the user has selected is RADIUS, then the gateway device 12 will establish communication with the RADIUS server, authenticate the user, charge the user's account, and return the result of the authorization to the billing and content server. If the authorization method chosen by the user is PMS, the gateway device will establish communication with the PMS 28, authenticate the user, have an access fee added to the user's room bill, and return the result of the authorization to the billing and content server. In either event, the XML command issued by the billing and content server to request user authorization payment includes the following command, command attribute, command attribute data and tag and data pairs:
In response, the gateway device 12 issues a standard XML response indicating that the command was received and processed appropriately or that an error occurred, and that includes the following tag and data:
The billing and content server 26 can also issue an XML command in instances in which a user makes an e-commerce or special service purchase that is to be charged, such as to the user's bill via the property management system 28. In this regard, the billing and content server issues an XML command that includes the following command, command attribute, command attribute data and tag and data pairs.
In response, the gateway device will issue a standard XML response indicating that the command was received and processed appropriately or that an error occurred.
Finally, the billing and content server 26 can issue an XML command in order to update cache memory by changing the status of an entry in the memory authorization table, as identified by the MAC address by way of example, from “pending” to “authorized”. In this regard, the XML command can include the following command, command attribute, command attribute date and tag and data pair:
In response, the gateway device will issue a standard XML response indicating that the command was received and processed appropriately or that an error occurred.
While the foregoing XML commands and XML responses that would flow between a billing and content server 26 and a gateway device 12 have been provided by way of example in order to illustrate one particular application of the XML interface 32 or XML parser of a gateway device, the gateway device that includes an XML interface according to the present invention can be employed to communicate with the billing and content server according to a wide variety of other commands and responses depending upon the application. In addition, a gateway device that includes an XML interface can also be employed to communicate with a wide variety of other external devices, including a property management system 28, an external AAA server, or other external devices. In addition, the gateway device can be configured to issue the XML commands and to receive XML responses if necessary for the particular application. In any event, a gateway device that includes an XML interface facilitates communication between the gateway device and various external devices in a uniform manner, thereby avoiding having to communicate with each of the external devices according to a unique format established by the vendor of the external device. As a result, the design, implementation operation of the gateway device is greatly simplified and the user is able to reap the advantages provided by XML without having to reconfigure their computer 14 to support XML.
Many modifications and other embodiments of the invention will come to mind to one skilled in the art to which this invention pertains having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the invention is not to be limited to the specific embodiments disclosed and that modifications and other embodiments are intended to be included within the scope of the appended claims. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
Enabling Network Gateway Devices to Communicate with Management Systems to Facilitate Subscriber Management
A system and method for enabling a management system to communicate with a network gateway device to automatically bill a computer operator for access to a computer network, such as a local network. The system includes a computer, and a network gateway device in communication with the computer for connecting the computer to a computer network, wherein the network gateway device maintains data representative of the computer operator's access to the computer network and wherein the network gateway device reconfigures the data. The system also includes a management system connected to said network gateway device for automatically billing the computer operator based upon usage of the computer network, wherein the management system is configured to communicate according to at least one predetermined protocol. The network gateway device reconfigures the data to meet one of the predetermined protocols supported by the management system, and the management system receives the data reconfigured by the network gateway device and utilizes the data reconfigured by the network gateway device for automatic billing purposes. The method for enabling a management system to communicate with a network gateway device to automatically bill a customer for network access includes allowing a computer operator to access a computer network via a network gateway device, collecting data corresponding to a customer's local network access in the network gateway device, storing the data in the network gateway device, reconfiguring the data to a predetermined data format received from a management system, and transmitting the reconfigured data to the management system.
In order for a computer to function properly, the computer must be appropriately configured. Among other things, this configuration process establishes the protocol and other parameters by which the computer transmits and receives data. In one common example, a plurality of computers is networked to create a local area network (LAN). In the LAN, each computer must be appropriately configured in order to exchange data over the network. Since most networks are customized to meet a unique set of requirements, computers that are part of different networks are generally configured in different manners in order to appropriately communicate with their respective networks
While desktop computers generally remain a part of the same network for a substantial period of time, laptops or other portable computers are specifically designed to be transportable. As such, portable computers are connected to different networks at different times depending upon the location of the computer. In a common example in which the portable computer serves as an employee's desktop computer, the portable computer is configured to communicate with their employer's network, i.e., the enterprise network. When the employee travels, however, the portable computer may be connected to different networks that communicate in different manners. In this regard, the employee may connect the portable computer to the network maintained by an airport or by a hotel in order to access the enterprise network, the internet or some other on-line service. Since these other networks are configured somewhat differently, however, the portable computer must also be reconfigured in order to properly communicate with these other networks. Typically, this configuration is performed by the user each time that the portable computer is connected to a different network. As will be apparent, this repeated reconfiguration of the portable computer is not only quite time consuming, but is also prone to errors.
As described by U.S. patent application Ser. No. 08/816,174 and U.S. Prov. Pat. App. No. 60/111,497, a universal subscriber gateway has been developed by Nomadix, Inc. of Santa Monica, Calif. The contents of both of these applications are incorporated herein by reference. The gateway device serves as a gateway to a number of networks or other online services. For example, the gateway device can serve as a gateway to the internet, the enterprise network, or other on-line services. In addition to serving as a gateway, the gateway device automatically configures a computer to communicate with the new network in a manner that is transparent to the user. In this regard, the gateway device will download the necessary protocols and other parameters to the computer without any intervention by the operator and without loading any additional software on the computer.
Because high speed access to enterprise networks, the internet and on-line services is a desirable commodity, like long distance telephone service, costs associated with the service are typically passed on to the remote user/subscriber. Therefore, in many instances the remote user/subscriber is concerned with being able to acquire network access and service in the most cost efficient and convenient manner. In this regard, subscriber remote service concerns parallel those concerns of customers utilizing internet service providers for conventional telephone line dial-up internet access. In both cases, computer operators typically want inexpensive, flexible and customer friendly service options. Correspondingly, the gateway device administrator desires the capability to be able to offer the user/subscriber numerous and different service and billing rate options, like those available in conventional dial-up internet access. For example, the remote user in a hotel environment may desire a subscription for only a day, or for the duration of their stay at the hotel. The user/subscriber may be charged on an hourly rate, a daily rate, a weekly rate, or at any other interval. Such flexible plans offer cost savings to consumers and are an attractive incentive to lure customers into buying access time to the enterprise network, online services or the internet.
Unlike conventional dial-up internet access, however, gateway devices permit remote users to access various computer networks and on-line services without having a prior service contract or an ongoing relationship with the service provider. Therefore, unlike conventional dial up access plans, which can bill subscribers on a set monthly schedule, gateway devices make recouping remote access charges more challenging. This is especially true for nomadic users, who may utilize a remote connection to a network only once before relocating. Once the traveler has moved onward, the network provider may have difficulty in collecting any unpaid service charges. Furthermore, billing of nomadic users is another hurdle to fast and easy access to the enterprise network, on-line services and the internet. The benefits of remote plug and play access therefore may be overshadowed by time consuming payment methods. For example, where a computer operator is required to complete an onerous billing procedure to pre-purchase local network time or to pay for the network use after each session, the computer operator may decide not to use the network.
Thus, any convenience provided by the computer network is superseded by the inconvenient billing method. Gateway device administrators also desire convenient methods in which to bill users/subscribers. Because the gateway device enables subscribers immediate plug and play connections to computer networks, such as hotel or airport networks, the computer network provider and/or service provider of the high speed network would like to quickly and immediately bill the users/subscribers. This billing should be able to easily track a user/subscriber's usage of the network so as to recoup costs for the network hardware and network connection. Furthermore, such billing should be automated such that system administrators do not need to individually bill each remote user.
Therefore, it is desirable for customers, network providers and service providers to implement automatic billing through the computer network so that users may be billed automatically. Such automatic billing of remote and nomadic users would benefit customers by facilitating fast and easy access, and also would benefit network providers who could appropriately charge customers for obtaining remote access.
The present invention relates generally to a network gateway device and, more particularly, to network gateway devices communicating with management systems, such as hotel property management systems, to facilitate subscriber management. The connection of the users to the system can be transparent for billing purposes, although the computer network may also provide services to the users through the management system.
According to one embodiment of the invention, there is provided a system for enabling a management system to communicate with a network gateway device on order to automatically bill a computer operator for access to a computer network such as a local network. The system includes a computer, and a network gateway device in communication with the computer for connecting the computer to a computer network and for maintaining data representative of the computer operator's access to the computer network. The system also includes a management system connected to the network gateway device that is designed to automatically bill the computer operator based upon their access to the computer network. The management system is also designed to communicate with a third party device according to at least one predetermined protocol. According to the present invention, the gateway device is therefore designed to supply billing data using one of the predetermined protocols supported by the management system. As such, the management system receives the billing data supplied by the network gateway device and utilizes the data for automatic billing purposes.
Furthermore, in the system for enabling a management system to communicate with a network gateway device to automatically bill a computer operator for access to a computer network, the management system can be located within the computer network. Additionally, the system can include a translator in communication with the gateway device and management system for receiving the data supplied by the network gateway device. The translator can further reconfigured the supplied billing data received from the network gateway device, and can transmit the further reconfigured data to the management system. The data representative of the computer operator's access to the computer network can include data representative of the computer operator's location, access time, date which access was obtained, billing rate, and other pertinent information.
According to another embodiment of the invention, a method for enabling a management system to communicate with a network gateway device in order to automatically bill a customer for access to a computer network, such as a local network, is provided. The method comprises allowing a network administrator to access a computer network via a network gateway device, and collecting data corresponding to a customer's local network access in the network gateway device. Furthermore, the method of the present invention comprises storing the data in the network gateway device, reconfiguring the data to one of the predetermined data formats which may be received by a management system, and transmitting the reconfigured data to the management system.
The ability to bill customers for service automatically and track customers without system intervention allows the local network service provisioning to be done economically and efficiently. This invention provides an incentive for hotels, airports, and other computer networks to provide network connections to users because the computer network has a captive customer base. Furthermore, automatic billing can enable usage-based billing for network access and services, which is desirable to customers. Finally, automatic billing can reduce the risk of network use by an unauthorized user.
Referring now to
Most commonly, the gateway device 12 is located near the computers 14 at a relatively low position in the overall network (i.e., the gateway will be located within the hotel, multi-unit residence, airport, etc.). However, the gateway device 12 can be located at a higher position in the system by being located closer to the various networks 20 or other online services 22, if so desired. Although the gateway device 12 can be physically embodied in many different fashions, the gateway device 12 typically includes a controller and a memory device in which software is stored that defines the operational characteristics of the gateway device 12. Alternatively, the gateway device 12 can be embedded within another network device, such as an access controller 16 or a router 18. Moreover, the software that defines the functioning of the gateway device 12 can be stored on a PCMCIA card that can be inserted into a computer of the plurality of computers 14 in order to automatically reconfigure the computer to communicate with a different computer system, such as the networks 20 and online services 22.
The computer system 10 typically includes an access controller 16 positioned between the computers 14 and the gateway device 12 for multiplexing the signals received from the plurality of computers onto a link to the gateway device 12. Depending upon the medium by which the computers 14 are connected to the access controller, the access controller 16 can be configured in different manners. For example, the access controller can be a digital subscriber line access module (DSLAM) for signals transmitted via regular telephone lines, a cable head end for signals transmitted via coaxial cables, a wireless access point (WAP) for signals transmitted via a wireless network, a CMPS, a switch or the like. As also shown in
The gateway device 12 is specifically designed to allow computers to log onto the computer network in a manner that is transparent to the subscriber In the typical computer network that employs dynamic host configuration protocol (DHCP) service, the DHCP server 24 will initially assign an IP address to a computer that is logging onto the computer network. Upon opening their web browser or otherwise attempting to access an on-line service, the gateway device 12 will direct the subscriber to enter their ID and password. The gateway device 12 then determines if the subscriber is entitled to access the computer system, the level of access and/or the type of services to which the subscriber is entitled according to an authentication, authorization and accounting procedure that is described by U.S. patent application Ser. No. 08/816,174 and U.S. Provisional Application No. 60/111,497. Assuming that the subscriber has been authenticated and has authorization, the gateway device 12 typically presents new subscribers with a home page or control panel that identifies, among other things, the online services or other computer networks that are accessible via the gateway device 12. In addition, the home page presented by the gateway device 12 can provide information regarding the current parameters or settings that will govern the access provided to the particular subscriber. As such, the operator can readily alter the parameters or other settings in order to tailor the service according to their particular application. Typically, changes in the parameters or other settings that will potentially utilize additional resources of the computer system will come at a cost, such that the gateway device 12 will charge the subscriber a higher rate for their service. For example, a subscriber may elect to increase the transfer rate at which signals are transmitted across the computer network and pay a correspondingly higher price for the expedited service.
The home page also permits the subscriber to select the computer network 20 or other online service 22 that the subscriber wishes to access. For example, the subscriber can access the enterprise network on which the computer is typically resident. Alternatively, the subscriber can access the internet or other on-line services. Once the subscriber elects to access a computer network or other online service, the gateway device 12 establishes the appropriate links via one or more routers 18 to the desired computer network or online service.
Thereafter, the subscriber can communicate freely with the desired computer network 20 or other online service 22. In order to support this communication, the gateway device 14 generally performs a packet translation function that is transparent to the subscriber. In this regard, for outbound traffic from the computer 12 to the computer network or other on-line service, the gateway device 12 changes the content of the packet, such as the source address, checksum, and application specific parameters, such that all outgoing packets will be directed back to the gateway device 12 rather than to the computer. In contrast, the inbound traffic from the computer network or other online service that arrives at the gateway device 12, which is really intended for the computer, is passed through the translation function so the packets eventually delivered to the computer appear to have been sent directly to the computer. As such, the computer will be completely unaware of the translation being performed by the gateway device. Additional information regarding the translation function is provided by U.S. patent application Ser. No. 08/816,714. By utilizing the gateway device 12 to communicate with the computer network or other online service, however, the subscriber will never have had to configure their computer 12 since the gateway device automatically adopts the computer in a manner that is transparent to the subscriber.
As shown in
The gateway device 50 is in direct communication with the management system 56. Management systems may include any well known computer based systems implemented in hotels, airports, arenas or other venues to manage operations. In the embodiment of
In the embodiment of
As will be appreciated by those of skill in the art, the information passed from the gateway device 12 can be, in most respects, identical to information received by the property management system 56 from a private branch telephone system (PBX), which are commonly utilized in hotels. PBX systems allow room to room, local and long distance telephone calls to be made by guests, and are typically connected to hotel property management systems to facilitate billing of hotel guests based upon the room in which the call is made. Charges for such use can then be paid by the guest upon checkout, automatically billed to the guest's credit card or automatically billed to the guest with room charges.
As can be appreciated with reference to
Through the property management systems, a user/subscriber's account may be billed directly to that user's hotel bill. For example, where the management system receives data representing a computer operator's access to the local system, the management system can automatically bill the operator through the use of a credit card authorization system in communication with the property management system. In this manner, the customer's payment can be fast, easy, automated and transparent to the user.
Traditional hotel property management systems are configured to communicate with various third party systems, such as point of sale systems, PBX systems, pay per view systems, and credit card authorization servers, as noted above. Hotel property management systems are generally configured to receive such communications because these third party systems are typically used in the vast majority of hotels. To receive data from each of these third party systems, management systems typically include software for communicating with the third party systems based upon the data protocol and data structure implemented by the management system. The software allows data from third party systems to be received and reconfigured, if necessary, so that the data is in a format appropriate to be utilized by the management system 56. However, because typical management systems that are currently deployed are not designed to receive data from a gateway device 12, the gateway device 12 is preferably designed to interface with the management system 56 without requiring additional programming of the management system software.
The gateway device 12 of the present invention formats data such that the data has the same data protocol and data structure as that of a third party service, such as a PBX, that the management system 56 is already designed to receive. The management system 56 is adapted to communicate using different protocols, through technology known as COM objects. Thus, the gateway device 12 can masquerade as a PBX or another third party system. The gateway device 12 receives a data record corresponding to an individual user/subscriber's use of the computer system, including the user/subscriber's location (room number), access time, and additional information, as discussed above. The gateway device 12 stores this information and modifies the data record to fit the proper format required by the property management system vendor. Although the format of the data is changed, no data is changed in the modification. The reconfigured data is then transmitted to the management system 56. This data can be in a call accounting record (CAR) and low level protocol (LLC) format, data formats typical of third party systems such as PBXs. Such formats are well known to those of skill in the art of property management system design.
Because management systems can differ, each system utilizing different user interfaces, variables, and operating systems, the gateway device should communicate data to the property management system 56 using data formats acceptable to a large number of management systems. In this manner, the gateway device 12 may be compatible with a majority of property management systems. For example, the gateway device 12 may be preconfigured to operate with the most popular management systems and formats, such as Micros Fidelio (manufactured by MICROS Systems, Inc., Beltsville, Md.), HOBIC, AutoClerk (manufactured by AutoClerk, Inc., Lafayette, Calif.), and other well known systems and formats.
However, there are many different management system standards, none of which are universal and implemented in all property management systems. As a result, although the gateway device 12 can configure data to conform to a large number of differing management systems, the gateway device 12 may not be able to conform to some systems. As a result, a translator 53 may be optionally used to manipulate the data output by the gateway device 12 in such a manner as to allow the data to be utilized by the property management system 56. In one embodiment, the translator may comprise a Lodging Link II device (LL) (manufactured by Protocol Technologies, Inc., Scottsdale, Ariz.) to convert incoming data from the gateway device 12 to data acceptable to the property management system device, such as UHALL protocol. Additionally, the translator may also be connected to one or more devices or systems in communication with the property management system, such as the pay per view system or credit card authorization system, to format data output by any system or component having data protocols which differ from those of the management system 56.
Because data may be transferred to the management system in a CAR format, data typically within such format must be altered to accurately reflect the computer network service being provided to the user/subscriber. For example, in PBX systems, CAR format usually includes the phone number to which a telephone call is being made. However, when a user/subscriber is obtaining access to the hotel network via the gateway device 12, no telephone number is dialed or called. Therefore, when possible, data within the CAR format (i.e., telephone record), such as telephone numbers, may be replaced with a descriptive record that indicates some other data that the property management systems wish to track or record. On the other hand, where the CAR records cannot be replaced, a bogus field, such as a bogus telephone number, may be included so that the property management system receives the entire record it is programmed to receive. Thereafter, the bogus number is not utilized by the management system 56. Additional problems may also exist, for example, where the management system 56 is not devised to support the non-numeric ASCII characters typically transmitted by the gateway device 12. In this situation, the gateway device can be configured to replace the ASCII characters with numeral designations.
Once the data transmitted by the gateway device is received by the property management system 56, the property management system can display the data using a management system interface. Preferably, the data may be displayed in an easily readable and printable form to allow a user/subscriber to view a summary of access information. Additionally, the data should be accessible to the user/subscriber's accounting record. In this manner, charges due to network access may be automatically placed on a customer's pre-existing bill, such as a hotel bill. Where access is obtained at another location, such as at an airport, the airport system manager (i.e., equivalent to the hotel property management system in the above example) may automatically bill the customer, can automatically charge the customer's credit card, or can add the charges to an account which the customer maintains. In this regard, while the property management system 56 has primarily been described in conjunction with a hotel computer network, the property management system can be utilized in a variety of other applications in which a user/subscriber obtains access to a computer network or other on-line service via a gateway device.
the present application claims priority from the U.S. provisional patent application bearing application No. 60/161,181 filed Oct. 22, 1999 by Joel E. Short, et al., the contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4677588 | Benjamin | Jun 1987 | A |
4811011 | Sollinger | Mar 1989 | A |
5065393 | Sibbitt | Nov 1991 | A |
5124984 | Engel | Jun 1992 | A |
5142622 | Owens | Aug 1992 | A |
5166931 | Riddle | Nov 1992 | A |
5185860 | Wu | Feb 1993 | A |
5218605 | Low et al. | Jun 1993 | A |
5258906 | Kroll | Nov 1993 | A |
5293488 | Riley | Mar 1994 | A |
5329619 | Page | Jul 1994 | A |
5369705 | Bird | Nov 1994 | A |
5406555 | Yoshida | Apr 1995 | A |
5420862 | Perlman | May 1995 | A |
5481542 | Logston | Jan 1996 | A |
5490252 | Macera | Feb 1996 | A |
5526489 | Nilakantan | Jun 1996 | A |
5533026 | Ahmadi | Jul 1996 | A |
5548646 | Aziz | Aug 1996 | A |
5550984 | Gelb | Aug 1996 | A |
5553223 | Greenlee et al. | Sep 1996 | A |
5574779 | Ely | Nov 1996 | A |
5583864 | Lightfoot | Dec 1996 | A |
5592537 | Moen | Jan 1997 | A |
5598536 | Slaughter | Jan 1997 | A |
5604896 | Duxbury | Feb 1997 | A |
5606668 | Shwed | Feb 1997 | A |
5613090 | Willems | Mar 1997 | A |
5615339 | Ban | Mar 1997 | A |
5617540 | Civanlar et al. | Apr 1997 | A |
5623600 | Ji et al. | Apr 1997 | A |
5633999 | Clowes | May 1997 | A |
5636371 | Yu | Jun 1997 | A |
5644719 | Aridas | Jul 1997 | A |
5649001 | Thomas | Jul 1997 | A |
5652908 | Douglas | Jul 1997 | A |
5657452 | Kralowetz | Aug 1997 | A |
5659684 | Giovannoni | Aug 1997 | A |
5664102 | Faynberg | Sep 1997 | A |
5678041 | Baker | Oct 1997 | A |
5696899 | Kalwitz | Dec 1997 | A |
5699520 | Hodgson | Dec 1997 | A |
5708654 | Arndt | Jan 1998 | A |
5717737 | Doviak | Feb 1998 | A |
5724510 | Arndt | Mar 1998 | A |
5745699 | Lunn et al. | Apr 1998 | A |
5751961 | Smyk | May 1998 | A |
5757784 | Liebowitz | May 1998 | A |
5757924 | Friedman et al. | May 1998 | A |
5758083 | Singh et al. | May 1998 | A |
5758186 | Hamilton | May 1998 | A |
5764890 | Glasser | Jun 1998 | A |
5774668 | Choquier | Jun 1998 | A |
5774869 | Toader | Jun 1998 | A |
5790548 | Sistanizadeh | Aug 1998 | A |
5793762 | Penners et al. | Aug 1998 | A |
5794221 | Egendorf | Aug 1998 | A |
5796952 | Davis et al. | Aug 1998 | A |
5802047 | Kinoshita | Sep 1998 | A |
5802285 | Hirviniemi | Sep 1998 | A |
5802310 | Rajaraman | Sep 1998 | A |
5805803 | Birrell | Sep 1998 | A |
5806043 | Toader | Sep 1998 | A |
5812786 | Seazholtz | Sep 1998 | A |
5812819 | Rodwin | Sep 1998 | A |
5815664 | Asano | Sep 1998 | A |
5818845 | Moura et al. | Oct 1998 | A |
5832229 | Tomoda | Nov 1998 | A |
5835061 | Stewart | Nov 1998 | A |
5835720 | Nelson et al. | Nov 1998 | A |
5835724 | Smith | Nov 1998 | A |
5835725 | Chiang | Nov 1998 | A |
5835727 | Wong | Nov 1998 | A |
5844973 | Venkatraman | Dec 1998 | A |
5848233 | Radia | Dec 1998 | A |
5856974 | Gervais | Jan 1999 | A |
5862325 | Reed et al. | Jan 1999 | A |
5862328 | Colyer | Jan 1999 | A |
5864683 | Boebert | Jan 1999 | A |
5881234 | Schwob | Mar 1999 | A |
5884035 | Butman | Mar 1999 | A |
5889958 | Willens | Mar 1999 | A |
5894321 | Downs | Apr 1999 | A |
5894479 | Mohammed | Apr 1999 | A |
5901287 | Bull et al. | May 1999 | A |
5903732 | Reed | May 1999 | A |
5909441 | Alexander, Jr. et al. | Jun 1999 | A |
5915093 | Berlin | Jun 1999 | A |
5916302 | Dunn | Jun 1999 | A |
5918018 | Gooderum | Jun 1999 | A |
5922049 | Radia | Jul 1999 | A |
5923853 | Danneels | Jul 1999 | A |
5930255 | Tsukamoto et al. | Jul 1999 | A |
5931917 | Nguyen | Aug 1999 | A |
5940394 | Killian | Aug 1999 | A |
5941947 | Brown | Aug 1999 | A |
5941988 | Bhagwat | Aug 1999 | A |
5946687 | Gehani | Aug 1999 | A |
5949875 | Walker | Sep 1999 | A |
5951694 | Choquier | Sep 1999 | A |
5958015 | Dascalu | Sep 1999 | A |
5958018 | Eng | Sep 1999 | A |
5968126 | Ekstrom | Oct 1999 | A |
5969678 | Stewart | Oct 1999 | A |
5970490 | Morgenstern | Oct 1999 | A |
5982773 | Nishimura | Nov 1999 | A |
5987523 | Hind | Nov 1999 | A |
5987611 | Freund | Nov 1999 | A |
5999536 | Kawafuji | Dec 1999 | A |
5999912 | Wodraz | Dec 1999 | A |
6006258 | Kalajan | Dec 1999 | A |
6011782 | DeSimone | Jan 2000 | A |
6012083 | Savitzky | Jan 2000 | A |
6018771 | Hayden | Jan 2000 | A |
6028848 | Bhatia | Feb 2000 | A |
6035281 | Crosskey e | Mar 2000 | A |
6038233 | Hamamoto | Mar 2000 | A |
6044062 | Brownrigg | Mar 2000 | A |
6055236 | Nessett | Apr 2000 | A |
6055243 | Vincent | Apr 2000 | A |
6058418 | Kobata | May 2000 | A |
6061349 | Coile | May 2000 | A |
6061650 | Malkin | May 2000 | A |
6061668 | Sharrow | May 2000 | A |
6061739 | Reed | May 2000 | A |
6064674 | Doidge et al. | May 2000 | A |
6070191 | Narendran et al. | May 2000 | A |
6070243 | See | May 2000 | A |
6073160 | Grantham | Jun 2000 | A |
6073175 | Tavs | Jun 2000 | A |
6088451 | He | Jul 2000 | A |
6088725 | Kondo et al. | Jul 2000 | A |
6091732 | Alexander | Jul 2000 | A |
6092196 | Reiche | Jul 2000 | A |
6094659 | Bhatia | Jul 2000 | A |
6101543 | Alden | Aug 2000 | A |
6108330 | Bhatia | Aug 2000 | A |
6112239 | Kenner et al. | Aug 2000 | A |
6115376 | Sherer et al. | Sep 2000 | A |
6115545 | Mellquist | Sep 2000 | A |
6119161 | Lita et al. | Sep 2000 | A |
6122268 | Okanoue | Sep 2000 | A |
6128298 | Wootton | Oct 2000 | A |
6128601 | Van Horne et al. | Oct 2000 | A |
6130892 | Short et al. | Oct 2000 | A |
6137791 | Frid | Oct 2000 | A |
6137869 | Voit | Oct 2000 | A |
6138142 | Linsk | Oct 2000 | A |
6138144 | DeSimone | Oct 2000 | A |
6138162 | Pistriotto et al. | Oct 2000 | A |
6141010 | Hoyle | Oct 2000 | A |
6141653 | Conklin | Oct 2000 | A |
6141686 | Jackowski et al. | Oct 2000 | A |
6141690 | Weiman | Oct 2000 | A |
6144991 | England | Nov 2000 | A |
6147976 | Shand | Nov 2000 | A |
6148336 | Thomas et al. | Nov 2000 | A |
6154172 | Piccionelli | Nov 2000 | A |
6154764 | Nitta | Nov 2000 | A |
6154775 | Coss | Nov 2000 | A |
6154839 | Arrow | Nov 2000 | A |
6157377 | Shah-Nazaroff | Dec 2000 | A |
6157647 | Husak | Dec 2000 | A |
6157925 | Jenkins et al. | Dec 2000 | A |
6157953 | Chang | Dec 2000 | A |
6158008 | Maria | Dec 2000 | A |
6160874 | Dickerman | Dec 2000 | A |
6166730 | Goode | Dec 2000 | A |
6167513 | Inoue | Dec 2000 | A |
6173322 | Hu | Jan 2001 | B1 |
6175869 | Ahuia et al. | Jan 2001 | B1 |
6182154 | Campagnoni | Jan 2001 | B1 |
6189030 | Kirsch et al. | Feb 2001 | B1 |
6194992 | Short et al. | Feb 2001 | B1 |
6199100 | Filepp | Mar 2001 | B1 |
6201962 | Sturniolo | Mar 2001 | B1 |
6202169 | Razzaghe-Ashrafi | Mar 2001 | B1 |
6205148 | Takahashi | Mar 2001 | B1 |
6205481 | Heddaya | Mar 2001 | B1 |
6219786 | Cunningham | Apr 2001 | B1 |
6219790 | Lloyd | Apr 2001 | B1 |
6223205 | Harchol-Balter et al. | Apr 2001 | B1 |
6223286 | Hashimoto | Apr 2001 | B1 |
6226675 | Meltzer et al. | May 2001 | B1 |
6233618 | Shannon | May 2001 | B1 |
6233686 | Zenchelsky | May 2001 | B1 |
6237026 | Prasad | May 2001 | B1 |
6237037 | Larsson | May 2001 | B1 |
6240091 | Ginzboorg | May 2001 | B1 |
6240402 | Lynch-Aird | May 2001 | B1 |
6240513 | Friedman | May 2001 | B1 |
6240533 | Slemmer | May 2001 | B1 |
6243379 | Veerina et al. | Jun 2001 | B1 |
6247054 | Malkin | Jun 2001 | B1 |
6249820 | Dobbins | Jun 2001 | B1 |
6256307 | Salmonson | Jul 2001 | B1 |
6259405 | Stewart | Jul 2001 | B1 |
6266335 | Bhaskaran | Jul 2001 | B1 |
6282180 | Paneth | Aug 2001 | B1 |
6288739 | Hales | Sep 2001 | B1 |
6292478 | Farris | Sep 2001 | B1 |
6295291 | Larkins | Sep 2001 | B1 |
6298383 | Gutman | Oct 2001 | B1 |
6304857 | Heindel | Oct 2001 | B1 |
6308212 | Besaw | Oct 2001 | B1 |
6311275 | Jin | Oct 2001 | B1 |
6321336 | Applegate | Nov 2001 | B1 |
6326918 | Stewart | Dec 2001 | B1 |
6327242 | Amicangioli et al. | Dec 2001 | B1 |
6330586 | Yates | Dec 2001 | B1 |
6345291 | Murphy, Jr. et al. | Feb 2002 | B2 |
6345303 | Knauerhase et al. | Feb 2002 | B1 |
6359892 | Szlam | Mar 2002 | B1 |
6366893 | Hannula | Apr 2002 | B2 |
6377982 | Rai | Apr 2002 | B1 |
6381646 | Zhang | Apr 2002 | B2 |
6381650 | Peacock | Apr 2002 | B1 |
6385644 | Devine et al. | May 2002 | B1 |
6385653 | Sitaraman et al. | May 2002 | B1 |
6389462 | Cohen | May 2002 | B1 |
6393484 | Massarani | May 2002 | B1 |
6397255 | Nurenberg et al. | May 2002 | B1 |
6408336 | Schneider | Jun 2002 | B1 |
6412073 | Rangan | Jun 2002 | B1 |
6414635 | Stewart et al. | Jul 2002 | B1 |
6418324 | Doviak | Jul 2002 | B1 |
6424636 | Seazholtz | Jul 2002 | B1 |
6427170 | Sitaraman | Jul 2002 | B1 |
6434627 | Millet et al. | Aug 2002 | B1 |
6438125 | Brothers | Aug 2002 | B1 |
6438528 | Jensen | Aug 2002 | B1 |
6438578 | Schmid | Aug 2002 | B1 |
6452498 | Stewart | Sep 2002 | B2 |
6453353 | Win | Sep 2002 | B1 |
6453361 | Morris | Sep 2002 | B1 |
6463473 | Gubbi | Oct 2002 | B1 |
6463474 | Fuh | Oct 2002 | B1 |
6466076 | Yoshikawa | Oct 2002 | B2 |
6466976 | Alles | Oct 2002 | B1 |
6466981 | Levy | Oct 2002 | B1 |
6466986 | Sawyer et al. | Oct 2002 | B1 |
6470027 | Birrell | Oct 2002 | B1 |
6470386 | Combar | Oct 2002 | B1 |
6473411 | Kumaki | Oct 2002 | B1 |
6480486 | Kikinis | Nov 2002 | B2 |
6487538 | Gupta | Nov 2002 | B1 |
6487605 | Leung | Nov 2002 | B1 |
6496704 | Yuan | Dec 2002 | B2 |
6515968 | Combar et al. | Feb 2003 | B1 |
6515989 | Ronneke | Feb 2003 | B1 |
6516416 | Gregg et al. | Feb 2003 | B2 |
6519636 | Engel | Feb 2003 | B2 |
6519643 | Foulkes | Feb 2003 | B1 |
6523028 | DiDomizio | Feb 2003 | B1 |
6535493 | Lee et al. | Mar 2003 | B1 |
6535511 | Rao | Mar 2003 | B1 |
6539395 | Gjerdingen et al. | Mar 2003 | B1 |
6546392 | Bahlmann | Apr 2003 | B1 |
6546425 | Hanson et al. | Apr 2003 | B1 |
6549220 | Hsu | Apr 2003 | B1 |
6553178 | Abecassis | Apr 2003 | B2 |
6557038 | Becker | Apr 2003 | B1 |
6571221 | Stewart | May 2003 | B1 |
6574664 | Liu | Jun 2003 | B1 |
6577642 | Fijolek | Jun 2003 | B1 |
6578078 | Smith et al. | Jun 2003 | B1 |
6580717 | Higuchi | Jun 2003 | B1 |
6584505 | Howard | Jun 2003 | B1 |
6587880 | Saigo | Jul 2003 | B1 |
6591306 | Redlich | Jul 2003 | B1 |
6597693 | Leung | Jul 2003 | B1 |
6601065 | Nelson et al. | Jul 2003 | B1 |
6609154 | Fuh | Aug 2003 | B1 |
6615212 | Dutta et al. | Sep 2003 | B1 |
6622128 | Bedell et al. | Sep 2003 | B1 |
6625645 | Van Horne | Sep 2003 | B1 |
6626957 | Lippert et al. | Sep 2003 | B1 |
6633899 | Coward | Oct 2003 | B1 |
6636504 | Albers | Oct 2003 | B1 |
6636894 | Short et al. | Oct 2003 | B1 |
6643701 | Aziz et al. | Nov 2003 | B1 |
6658625 | Allen | Dec 2003 | B1 |
6665718 | Chuah | Dec 2003 | B1 |
6667968 | Tran | Dec 2003 | B1 |
6671379 | Nemirovski | Dec 2003 | B2 |
6671739 | Reed | Dec 2003 | B1 |
6687732 | Bector | Feb 2004 | B1 |
6697018 | Stewart | Feb 2004 | B2 |
6697103 | Fernandez et al. | Feb 2004 | B1 |
6701350 | Mitchell | Mar 2004 | B1 |
6701361 | Meier | Mar 2004 | B1 |
6711146 | Yegoshin | Mar 2004 | B2 |
6714987 | Amin | Mar 2004 | B1 |
6717943 | Schwering | Apr 2004 | B1 |
6728884 | Lim | Apr 2004 | B1 |
6731612 | Koss | May 2004 | B1 |
6732176 | Stewart | May 2004 | B1 |
6735633 | Welch et al. | May 2004 | B1 |
6735691 | Capps | May 2004 | B1 |
6738382 | West | May 2004 | B1 |
6751677 | Ilnicki | Jun 2004 | B1 |
6757740 | Parekh et al. | Jun 2004 | B1 |
6759960 | Stewart | Jul 2004 | B2 |
6760416 | Banks | Jul 2004 | B1 |
6760444 | Leung | Jul 2004 | B1 |
6771609 | Gudat et al. | Aug 2004 | B1 |
6771661 | Chawla | Aug 2004 | B1 |
6775267 | Kung | Aug 2004 | B1 |
6779035 | Gbadegesin | Aug 2004 | B1 |
6785704 | McCanne | Aug 2004 | B1 |
6789110 | Short | Sep 2004 | B1 |
6795852 | Kleinrock et al. | Sep 2004 | B1 |
6810426 | Mysore et al. | Oct 2004 | B2 |
6822954 | McConnell et al. | Nov 2004 | B2 |
6822955 | Brothers | Nov 2004 | B1 |
6823059 | Kalmanek | Nov 2004 | B2 |
6826694 | Dutta et al. | Nov 2004 | B1 |
6834341 | Bahl | Dec 2004 | B1 |
6839757 | Romano | Jan 2005 | B1 |
6850532 | Thubert | Feb 2005 | B2 |
6856800 | Henry et al. | Feb 2005 | B1 |
6857009 | Ferreria et al. | Feb 2005 | B1 |
6859212 | Kumar et al. | Feb 2005 | B2 |
6868399 | Short et al. | Mar 2005 | B1 |
6876668 | Chawla | Apr 2005 | B1 |
6892226 | Tso | May 2005 | B1 |
6901433 | San Andres | May 2005 | B2 |
6907449 | Srinivasan | Jun 2005 | B2 |
6915345 | Tummala | Jul 2005 | B1 |
6922672 | Hailpern | Jul 2005 | B1 |
6934754 | West et al. | Aug 2005 | B2 |
6937597 | Rosenberg et al. | Aug 2005 | B1 |
6944661 | Moore et al. | Sep 2005 | B2 |
6947398 | Ahmed | Sep 2005 | B1 |
6950433 | Okamoto | Sep 2005 | B1 |
6950628 | Meier et al. | Sep 2005 | B1 |
6961762 | Yeap | Nov 2005 | B1 |
6970927 | Stewart | Nov 2005 | B1 |
6983327 | Koperda | Jan 2006 | B2 |
6985479 | Leung et al. | Jan 2006 | B2 |
6996073 | West | Feb 2006 | B2 |
7003578 | Kanada et al. | Feb 2006 | B2 |
7007080 | Wilson | Feb 2006 | B2 |
7009556 | Stewart | Mar 2006 | B2 |
7016960 | Howard | Mar 2006 | B2 |
7017046 | Doyle et al. | Mar 2006 | B2 |
7020082 | Bhagavath et al. | Mar 2006 | B2 |
7020681 | Ayyagari et al. | Mar 2006 | B1 |
7032243 | Leerssen et al. | Apr 2006 | B2 |
7035248 | Wengrovitz | Apr 2006 | B2 |
7043532 | Humpleman et al. | May 2006 | B1 |
7043563 | Vange et al. | May 2006 | B2 |
7047415 | Doyle et al. | May 2006 | B2 |
7051087 | Bahl et al. | May 2006 | B1 |
7058594 | Stewart | Jun 2006 | B2 |
7072056 | Greaves et al. | Jul 2006 | B1 |
7080077 | Ramamurthy | Jul 2006 | B2 |
7086077 | Giammaressi | Aug 2006 | B2 |
7088727 | Short et al. | Aug 2006 | B1 |
7093020 | McCarty et al. | Aug 2006 | B1 |
7117526 | Short | Oct 2006 | B1 |
7120678 | Greuel | Oct 2006 | B2 |
7120701 | Warrier et al. | Oct 2006 | B2 |
7124437 | Byrne | Oct 2006 | B2 |
7126915 | Lu | Oct 2006 | B1 |
7139268 | Bhagwat | Nov 2006 | B1 |
7145898 | Elliott | Dec 2006 | B1 |
7151758 | Kumaki | Dec 2006 | B2 |
7159035 | Garcia-Luna-Aceves | Jan 2007 | B2 |
7185360 | Anton et al. | Feb 2007 | B1 |
7188085 | Pelletier | Mar 2007 | B2 |
7194554 | Short | Mar 2007 | B1 |
7197556 | Short et al. | Mar 2007 | B1 |
7200578 | Paltenghe et al. | Apr 2007 | B2 |
7210035 | Doyle et al. | Apr 2007 | B2 |
7216043 | Ransom et al. | May 2007 | B2 |
7216152 | Short et al. | May 2007 | B2 |
7225249 | Barry | May 2007 | B1 |
7240106 | Cochran et al. | Jul 2007 | B2 |
7269653 | Mentze et al. | Sep 2007 | B2 |
7272639 | Levergood et al. | Sep 2007 | B1 |
7283542 | Mitchell | Oct 2007 | B2 |
7287071 | MacLean | Oct 2007 | B2 |
7289763 | Denninson et al. | Oct 2007 | B2 |
7293077 | Teo | Nov 2007 | B1 |
7313631 | Sesmun et al. | Dec 2007 | B1 |
7319673 | Briscoe | Jan 2008 | B1 |
7324972 | Oliver | Jan 2008 | B1 |
7325063 | Dillon | Jan 2008 | B2 |
7333500 | Roshko | Feb 2008 | B2 |
7333942 | Cowles | Feb 2008 | B1 |
7336960 | Zavalkovsky et al. | Feb 2008 | B2 |
7349982 | Hannum et al. | Mar 2008 | B2 |
7356841 | Wilson et al. | Apr 2008 | B2 |
7376113 | Taylor et al. | May 2008 | B2 |
7401120 | Walbeck | Jul 2008 | B2 |
7428413 | Fink | Sep 2008 | B2 |
7437474 | Iyer et al. | Oct 2008 | B2 |
7457397 | Saylor et al. | Nov 2008 | B1 |
7472191 | Stewart | Dec 2008 | B2 |
7474617 | Molen et al. | Jan 2009 | B2 |
7483871 | Herz | Jan 2009 | B2 |
7493084 | Meier et al. | Feb 2009 | B2 |
7493402 | McCarty et al. | Feb 2009 | B2 |
7512136 | Korotin | Mar 2009 | B2 |
7526538 | Wilson | Apr 2009 | B2 |
7536714 | Yuan | May 2009 | B2 |
7539291 | D'Angelo et al. | May 2009 | B2 |
7552090 | Barber | Jun 2009 | B1 |
7554995 | Short | Jun 2009 | B2 |
7555542 | Ayers et al. | Jun 2009 | B1 |
7580376 | West | Aug 2009 | B2 |
7602782 | Doviak | Oct 2009 | B2 |
7685311 | Friedman et al. | Mar 2010 | B2 |
7685525 | Kumar et al. | Mar 2010 | B2 |
7689716 | Short et al. | Mar 2010 | B2 |
7698377 | Parekh et al. | Apr 2010 | B2 |
7698432 | Short et al. | Apr 2010 | B2 |
7734541 | Kumar et al. | Jun 2010 | B2 |
7739383 | Short et al. | Jun 2010 | B1 |
7743404 | Deutschmann et al. | Jun 2010 | B1 |
7752334 | Paunikar et al. | Jul 2010 | B2 |
7774612 | Deutschmann et al. | Aug 2010 | B1 |
7813741 | Hendrey et al. | Oct 2010 | B2 |
7818454 | Kim et al. | Oct 2010 | B2 |
7822871 | Stolorz et al. | Oct 2010 | B2 |
7822873 | Paunikar | Oct 2010 | B1 |
7844729 | Friedman et al. | Nov 2010 | B1 |
7953857 | Short et al. | May 2011 | B2 |
8051206 | Paunikar et al. | Nov 2011 | B2 |
20010003823 | Mighdoll et al. | Jun 2001 | A1 |
20010012282 | Yegoshin | Aug 2001 | A1 |
20010041571 | Yuan | Nov 2001 | A1 |
20010044818 | Liang | Nov 2001 | A1 |
20010054020 | Barth et al. | Dec 2001 | A1 |
20020006788 | Knutsson et al. | Jan 2002 | A1 |
20020016736 | Cannon et al. | Feb 2002 | A1 |
20020021689 | Robbins | Feb 2002 | A1 |
20020095651 | Kumar et al. | Jul 2002 | A1 |
20020133412 | Oliver et al. | Sep 2002 | A1 |
20020178070 | Leveridge | Nov 2002 | A1 |
20030067911 | Kikinis | Apr 2003 | A1 |
20030069991 | Brescia | Apr 2003 | A1 |
20030083889 | Macklin | May 2003 | A1 |
20030204756 | Ransom et al. | Oct 2003 | A1 |
20040015572 | Kang | Jan 2004 | A1 |
20040030797 | Akinlar et al. | Feb 2004 | A1 |
20040039798 | Hotz et al. | Feb 2004 | A1 |
20040076144 | Ishidoshiro | Apr 2004 | A1 |
20040203752 | Wojaczynski et al. | Oct 2004 | A1 |
20050021943 | Ikudome | Jan 2005 | A1 |
20050102205 | Yamamoto | May 2005 | A1 |
20050143065 | Pathan et al. | Jun 2005 | A1 |
20050148342 | Sylvain | Jul 2005 | A1 |
20050240620 | Danner et al. | Oct 2005 | A1 |
20050260973 | van de Groenendaal | Nov 2005 | A1 |
20060026170 | Kreitler et al. | Feb 2006 | A1 |
20060080446 | Bahl | Apr 2006 | A1 |
20060089122 | Zavalkovsky et al. | Apr 2006 | A1 |
20060135155 | Chung et al. | Jun 2006 | A1 |
20060174019 | Ikudome | Aug 2006 | A1 |
20070011268 | Banga et al. | Jan 2007 | A1 |
20070162598 | Gorodyansky | Jul 2007 | A1 |
20070201702 | Hendricks | Aug 2007 | A1 |
20070266125 | Lu | Nov 2007 | A1 |
20070271598 | Chen et al. | Nov 2007 | A1 |
20070294417 | Ikudome | Dec 2007 | A1 |
20080148383 | Pitchaikani et al. | Jun 2008 | A1 |
20080271109 | Singh et al. | Oct 2008 | A1 |
20090024745 | Short et al. | Jan 2009 | A1 |
20100115113 | Short et al. | May 2010 | A1 |
20100332615 | Short et al. | Dec 2010 | A1 |
20110030037 | Olshansky et al. | Feb 2011 | A1 |
20110131339 | Brown et al. | Jun 2011 | A1 |
Number | Date | Country |
---|---|---|
2003255101 | Mar 2004 | AU |
2 330 857 | Nov 1999 | CA |
2330857 | Nov 1999 | CA |
2 296 937 | Jul 2000 | CA |
2296937 | Jul 2000 | CA |
0573739 | Dec 1993 | EP |
0742657 | Nov 1996 | EP |
0767595 | Apr 1997 | EP |
0873037 | Oct 1998 | EP |
0901301 | Mar 1999 | EP |
0912026 | Apr 1999 | EP |
0946027 | Sep 1999 | EP |
1 076 975 | Nov 1999 | EP |
1 111 872 | Jun 2001 | EP |
1 026 853 | Dec 2007 | EP |
2 283 645 | May 1995 | GB |
2311439 | Sep 1997 | GB |
2 326 306 | Dec 1998 | GB |
H06-209319 | Jul 1994 | JP |
06-348625 | Dec 1994 | JP |
7030575 | Jan 1995 | JP |
H07-202931 | Apr 1995 | JP |
8-265372 | Oct 1996 | JP |
H08-265372 | Nov 1996 | JP |
9046352 | Feb 1997 | JP |
10-105516 | Apr 1998 | JP |
10-107839 | Apr 1998 | JP |
11-055726 | Feb 1999 | JP |
11055326 | Feb 1999 | JP |
11-282804 | Oct 1999 | JP |
2002-514802 | Nov 1999 | JP |
2000059416 | Feb 2000 | JP |
2000-354127 | Dec 2000 | JP |
2002-111870 | Apr 2002 | JP |
WO 9605549 | Feb 1996 | WO |
WO 9702687 | Jan 1997 | WO |
WO 9709672 | Mar 1997 | WO |
WO 9722936 | Jun 1997 | WO |
WO 9727546 | Jul 1997 | WO |
WO 9741586 | Nov 1997 | WO |
WO 9748210 | Dec 1997 | WO |
WO 9915995 | Apr 1999 | WO |
WO 9928819 | Jun 1999 | WO |
WO 9938303 | Jul 1999 | WO |
WO 9939481 | Aug 1999 | WO |
WO 9946890 | Sep 1999 | WO |
WO 9957837 | Nov 1999 | WO |
WO 0027092 | May 2000 | WO |
WO 0058804 | Oct 2000 | WO |
WO 0079406 | Dec 2000 | WO |
WO 0103011 | Jan 2001 | WO |
WO 0103011 | Jan 2001 | WO |
WO 0163835 | Aug 2001 | WO |
WO 2004017658 | Feb 2004 | WO |
WO 2004100499 | Nov 2004 | WO |
Number | Date | Country | |
---|---|---|---|
60161181 | Oct 1999 | US |