The instant application is related to and co-pending with U.S. application Ser. No. 12/411,928, entitled, “System and Method for Managing Created Location Contexts in a Location Server,” filed Mar. 26, 2009, the entirety of which is incorporated herein by reference.
The location of a mobile, wireless or wired device is a useful and sometimes necessary part of many services. A Location Information Server (“LIS”) may be responsible for providing location information to such devices with an access network. The LIS may utilize knowledge of the access network and its physical topology to generate and serve location information to devices.
The LIS, in general terms, is a network node originally defined in the National Emergency Number Association (“NENA”) i2 network architecture addressing a solution for providing E-911 service for users of Voice over Internet Protocol (“VoIP”) telephony. In VoIP networks, the LIS is the node that determines the location of the VoIP terminal. Beyond the NENA architecture and VoIP, the LIS is a service provided by an access network provider to supply location information to users of the network by utilizing knowledge of network topology and employing a range of location determination techniques to locate devices attached to the network. The precise methods used to determine location are generally dependent on the type of access network and the information that can be obtained from the device. For example, in a wired network, such as Ethernet or DSL, a wiremap method is commonplace. In wiremap location determination, the location of a device may be determined by finding which cables are used to send packets to the device. This involves tracing data through aggregation points in the network (e.g., Ethernet switches, DSL access nodes) and finding the port for which packets are sent to the device. This information is combined with data available to the LIS (generally extracted from a database) to determine a final location of the device.
In wireless networks, a range of technologies may be applied for location determination, the most basic of which uses the location of the radio transmitter as an approximation. The Internet Engineering Task Force (“IETF”) and other standards forums have defined various architectures and protocols for acquiring location information from an LIS. In such networks, an LIS may be automatically discovered and location information retrieved using network specific protocols. Location information may be retrieved directly or the LIS may generate temporary uniform resource identifiers (“URI”) utilized to provide location indirectly (i.e., location URI). Geodetic, civic positions and location URIs for a mobile device may be determined as a function of location information from the LIS. A request for geodetic and/or civic locations may provide location information at the time the location request is made. A location URI may generally be passed to another party which can utilize it to retrieve the target device's location at a later time, typically from the same location server that provided the location URI. There is, however, a need in the art to overcome the limitations of the prior art and provide a novel system and method for managing created location contexts in a location server.
One embodiment of the present subject matter provides a method for creating a location URI for determining the location of a target device. The method may comprise receiving a location request for a target device and collecting location context information for the target device including starting information, validating information and policy information. The collected location context information may be encrypted in an LIS and then converted to a form compatible with URI syntax. A location URI may then be constructed as a function of the converted information.
Another embodiment of the present subject matter may provide a method for handling a location request for a target device using a location URI. The method may comprise receiving a location request for a target device from a requesting entity, the target device having a location context information represented by a location URI and including starting information, initial validating information and policy information. The form of the location URI may be verified by an LIS, the form including at least an encrypted context string. The encrypted context string may be extracted and decrypted by the LIS and it may be determined if the location request can continue as a function of the policy information. An estimated location of the target device may then be determined as a function of the starting information and additional validating information collected. This additional validating information may be correlated with the initial validating information, and the estimated location of the target device provided to the requesting entity.
A further embodiment of the present subject matter provides an LIS comprising circuitry for receiving a location request for a target device, circuitry for collecting location context information for the target device including starting information, validating information and policy information. The LIS may also include circuitry for encrypting the collected location context information, and circuitry for converting the encrypted location context information to a form compatible with URI syntax. The LIS may include circuitry for constructing a location URI as a function of the converted information.
One embodiment of the present subject matter provides an LIS comprising circuitry for receiving a location request for a target device, the target device having a location context information represented by a location URI and including starting information, initial validating information and policy information. The LIS may include circuitry for verifying the form of the location URI, the form including at least an encrypted context string, circuitry for extracting and decrypting the encrypted context string, and circuitry for determining if the location request can continue as a function of the policy information. Further, the LIS may include circuitry for determining an estimated location of the target device as a function of the starting information, circuitry for collecting additional validating information, and circuitry for correlating the additional validating information with the initial validating information. The LIS may also include circuitry for providing the estimated location of the target device to the requesting entity.
These embodiments and many other objects and advantages thereof will be readily apparent to one skilled in the art to which the invention pertains from a perusal of the claims, the appended drawings, and the following detailed description of the embodiments.
Various aspects of the present disclosure will be or become apparent to one with skill in the art by reference to the following detailed description when considered in connection with the accompanying exemplary non-limiting embodiments.
With reference to the figures where like elements have been given like numerical designations to facilitate an understanding of the present subject matter, the various embodiments of a system and method for managing created location contexts in a location server are herein described.
As generally discussed above, the Location Information Server (“LIS”) is a network server that provides devices with information about their location. The phrases and respective acronyms of Location Information Server (“LIS”) and Location Server (“LS”) are used interchangeably throughout this document and such should not limit the scope of the claims appended herewith. Devices that require location information are able to request their location from the LIS. In the architectures developed by the IETF, NENA and other standards forums, the LIS may be made available in an exemplary IP access network connecting one or more target devices to the Internet. In other modes of operation, the LIS may also provide location information to other requesters relating to a target device. To determine location information for a target device, an exemplary LIS may utilize a range of methods. The LIS may use knowledge of network topology, private interfaces to networking devices like routers, switches and base stations, and location determination algorithms. Exemplary algorithms may include known algorithms to determine the location of a mobile device as a function of satellite information, satellite assistance data, various downlink or uplink algorithms such as, but not limited to, time difference of arrival (“TDOA”), time of arrival (“TOA”), angle of arrival (“AOA”), round trip delay (“RTD”), signal strength, advanced forward link trilateration (“AFLT”), enhanced observed time difference (“EOTD”), observed time difference of arrival (“OTDOA”), uplink-TOA and uplink-TDOA, enhanced cell/sector and cell-ID, etc., and hybrid combinations thereof.
A location server according to an embodiment of the present subject matter may utilize a range of inputs to determine location information for the target device. For example, from a request made of the location server, the location server may determine one or more parameters, e.g., Internet Protocol (“IP”) and Media Access Control (“MAC”) addresses, that uniquely identify the target mobile device. This identification information may be used as an input to an exemplary measurement collection process that produces further information in the form of measurements or measurement results. Measurement information may also be data already known to the location server, additional parameters that identify the target mobile device in other ways, and/or parameters relating to the network attachment of the target mobile device. Non-limiting examples include the MAC address of the device, the identity of network nodes from which network traffic to and from the device transits (including any physical connections involved), the location of network intermediaries (e.g., wiring maps), radio timing, signal strength measurements and other terrestrial radio frequency information, and network configuration parameters, to name a few.
Protocols such as Flexible LIS-ALE Protocol (“FLAP”) are being developed in the Alliance for Telecommunications Industry Solutions (“ATIS”) forum to provide a formal definition of location-related measurements for different types of access networks. FLAP generally facilitates transfer of values of location measurement parameters from a network to the LIS to enable the latter to compute the location of an IP end-device. The LIS may interact with an Access Location Entity (“ALE”) residing in an access network to retrieve location measurements. Location information may be retrieved directly or the LIS may generate temporary uniform resource identifiers (“URI”) utilized to provide location indirectly (i.e., location URI). Geodetic, civic positions and location URIs for a mobile device may be determined as a function of location information from the LIS. A request for geodetic and/or civic locations may provide location information at the time the location request is made. A location URI may be passed to another party which can utilize it to retrieve the target device's location at a later time, typically from the same location server that provided the location URI.
There are many models in which an LIS may be utilized. For example,
With reference to
For a location URI to be utilized in providing a target device's location, a location context for the device should be established. In one embodiment, this location context may comprise starting details, validating details, and policy details. Starting details may be any information required to initiate a location determination for the target device, e.g., IP address, MAC address, etc. Validating details may be any information used to ensure the starting details still apply to the same target device. Validating details are generally needed because some of the starting details may become invalid, and over time, may refer to a different device. Some level of confidence may generally be required to ensure that the starting details continue to refer to the same target device. Exemplary validating details in an enterprise network may be, but are not limited to, the MAC address of the target device, assuming this information is available to the location server. Policy details may be any information indicating whether a location is allowed to be provided, including but not limited to, a location context expiry time (e.g., after this time, the location context cannot be used), etc.
Conventionally, location context information is shared among the processing units within a location server using a back channel, such as a shared database, or using inter-processing unit network communication. However, such prior art mechanisms may be too complex to implement, may be fragile, and/or may have difficult to manage failure modes such as race conditions. Furthermore, these deficiencies are magnified in geographically redundant configurations. Embodiments of the present subject matter, however, embed and utilize location context information directly in the location URI, thus avoiding the back channel issues prevalent in the conventional art.
At step 430, the information in the location context may then be encrypted. This encryption may be conducted utilizing a method and encryption key known to any one or all processing units in the location server. At step 440, the encrypted context may then be converted to a form compatible with the syntax of URIs, e.g., hexadecimal string, etc. In certain embodiments, it may be necessary to compress the location context before the encryption process to keep a resulting location URI at a reasonable length. At step 450, the location URI may be constructed and may include the host address of the location server, other URI details (e.g., addressing information within the host based on protocol, routing and network details, etc.), and the encrypted context string. The location URI may also include a uniform resource name (“URN”), a uniform resource location (“URL”), and combinations thereof. For example, a non-limiting constructed URI may take the form of:
At step 530, the location server may then extract and decrypt the encrypted context string. In one embodiment, the context string may be decrypted using shared knowledge among any number or combination of location server processing units that identify the necessary encryption algorithm and keys. At step 540, it may be determined whether the location request can continue as a function of the policy information. For example, if the expiry time in the reconstructed location context has passed, then an error may be returned to the location client and the process terminated. At step 550, given the reconstructed location context information, the location server may determine an estimated location of the target device as a function of the starting details. During this process, at step 560, additional validating details may also be collected. These additional validating details may be correlated or checked for consistency with the validating details in the target device's location context at step 570. In the instance where this check fails or is inconsistent, then an error may be returned to the location client instead of a location. In one embodiment, this consistency check may occur as information is collected, rather than after a location is determined; further, additional information beyond that needed to determine location may also be collected. At step 580, an estimated location of the target device may be returned or provided to the requesting entity. Of course, this requesting entity may be the target device or a location client system to enable the system to locate the device. Any number of the steps described above and shown in
It is thus an aspect of embodiments of the present subject matter to provide a system and method for creating and using location contexts embedded directly in a location URI suitable for use by a highly available location server for implicitly created location contexts.
As shown by the various configurations and embodiments illustrated in
While preferred embodiments of the present subject matter have been described, it is to be understood that the embodiments described are illustrative only and that the scope of the invention is to be defined solely by the appended claims when accorded a full range of equivalence, many variations and modifications naturally occurring to those of skill in the art from a perusal hereof.
Number | Name | Date | Kind |
---|---|---|---|
4728959 | Maloney | Mar 1988 | A |
5327144 | Stilp et al. | Jul 1994 | A |
5608410 | Stilp et al. | Mar 1997 | A |
5959580 | Maloney et al. | Sep 1999 | A |
6047192 | Maloney | Apr 2000 | A |
6091362 | Stilp | Jul 2000 | A |
6097336 | Stilp | Aug 2000 | A |
6097709 | Kuwabara | Aug 2000 | A |
6101178 | Beal | Aug 2000 | A |
6108555 | Maloney et al. | Aug 2000 | A |
6108558 | Vanderspool, II | Aug 2000 | A |
6115599 | Stilp | Sep 2000 | A |
6115605 | Siccardo et al. | Sep 2000 | A |
6115754 | Landgren | Sep 2000 | A |
6119013 | Maloney et al. | Sep 2000 | A |
6127975 | Maloney | Oct 2000 | A |
6172644 | Stilp | Jan 2001 | B1 |
6184829 | Stilp | Feb 2001 | B1 |
6266013 | Stilp et al. | Jul 2001 | B1 |
6269246 | Rao et al. | Jul 2001 | B1 |
6281834 | Stilp | Aug 2001 | B1 |
6285321 | Stilp et al. | Sep 2001 | B1 |
6288675 | Maloney | Sep 2001 | B1 |
6288676 | Maloney | Sep 2001 | B1 |
6317081 | Stilp | Nov 2001 | B1 |
6317604 | Kovach, Jr. et al. | Nov 2001 | B1 |
6334059 | Stilp et al. | Dec 2001 | B1 |
6351235 | Stilp | Feb 2002 | B1 |
6366241 | Pack | Apr 2002 | B2 |
6388618 | Stilp et al. | May 2002 | B1 |
6393294 | Perez-Breva et al. | May 2002 | B1 |
6400320 | Stilp et al. | Jun 2002 | B1 |
6449486 | Rao | Sep 2002 | B1 |
6463290 | Stilp et al. | Oct 2002 | B1 |
6483460 | Stilp et al. | Nov 2002 | B2 |
6492944 | Stilp | Dec 2002 | B1 |
6519465 | Stilp et al. | Feb 2003 | B2 |
6546256 | Maloney et al. | Apr 2003 | B1 |
6563460 | Stilp et al. | May 2003 | B2 |
6591112 | Siccardo et al. | Jul 2003 | B1 |
6603428 | Stilp | Aug 2003 | B2 |
6646604 | Anderson | Nov 2003 | B2 |
6661379 | Stilp et al. | Dec 2003 | B2 |
6765531 | Anderson | Jul 2004 | B2 |
6771625 | Beal | Aug 2004 | B1 |
6782264 | Anderson | Aug 2004 | B2 |
6782265 | Perez-Breva et al. | Aug 2004 | B2 |
6873290 | Anderson et al. | Mar 2005 | B2 |
6876859 | Anderson et al. | Apr 2005 | B2 |
6944465 | Spain et al. | Sep 2005 | B2 |
6996392 | Anderson | Feb 2006 | B2 |
7023383 | Stilp et al. | Apr 2006 | B2 |
7116987 | Spain, Jr. et al. | Oct 2006 | B2 |
7167713 | Anderson | Jan 2007 | B2 |
7167714 | Dressler et al. | Jan 2007 | B2 |
7233799 | Spain, Jr. | Jun 2007 | B2 |
7250907 | Krumm et al. | Jul 2007 | B2 |
7257414 | Spain, Jr. et al. | Aug 2007 | B2 |
7271765 | Stilp et al. | Sep 2007 | B2 |
7340259 | Maloney | Mar 2008 | B2 |
7383051 | Spain, Jr. et al. | Jun 2008 | B2 |
7400876 | Freilich | Jul 2008 | B2 |
7427952 | Bull et al. | Sep 2008 | B2 |
7433652 | Durgin | Oct 2008 | B2 |
7433695 | Gordon et al. | Oct 2008 | B2 |
7440762 | Maloney et al. | Oct 2008 | B2 |
7441032 | Costa Requena | Oct 2008 | B2 |
7460505 | Spain | Dec 2008 | B2 |
7475140 | Requena | Jan 2009 | B2 |
7593738 | Anderson | Sep 2009 | B2 |
7725111 | Dressler et al. | May 2010 | B2 |
7734298 | Bhattacharya et al. | Jun 2010 | B2 |
7753278 | Spain, Jr. et al. | Jul 2010 | B2 |
7796966 | Bhattacharya et al. | Sep 2010 | B2 |
7848762 | Gordon et al. | Dec 2010 | B2 |
7870196 | Costa Requena | Jan 2011 | B2 |
7899467 | Feuerstein et al. | Mar 2011 | B2 |
8013785 | Bhattacharya et al. | Sep 2011 | B2 |
8068802 | Bhattacharya et al. | Nov 2011 | B2 |
8068855 | Dressler et al. | Nov 2011 | B2 |
8106817 | Bhattacharya et al. | Jan 2012 | B2 |
8106818 | Bhattacharya et al. | Jan 2012 | B2 |
8149697 | Parkkinen et al. | Apr 2012 | B2 |
8155394 | Allegra et al. | Apr 2012 | B2 |
8205074 | Hoshino et al. | Jun 2012 | B2 |
20020004399 | McDonnell et al. | Jan 2002 | A1 |
20020172223 | Stilp et al. | Nov 2002 | A1 |
20030064734 | Stilp et al. | Apr 2003 | A1 |
20040203539 | Benes et al. | Oct 2004 | A1 |
20050135335 | Hession et al. | Jun 2005 | A1 |
20060003775 | Bull et al. | Jan 2006 | A1 |
20060030333 | Ward et al. | Feb 2006 | A1 |
20060165060 | Dua | Jul 2006 | A1 |
20070111746 | Anderson et al. | May 2007 | A1 |
20070127448 | Buntin et al. | Jun 2007 | A1 |
20070136603 | Kuecuekyan | Jun 2007 | A1 |
20070155401 | Ward et al. | Jul 2007 | A1 |
20070155489 | Beckley et al. | Jul 2007 | A1 |
20080132244 | Anderson et al. | Jun 2008 | A1 |
20080132247 | Anderson et al. | Jun 2008 | A1 |
20080137524 | Anderson et al. | Jun 2008 | A1 |
20080158059 | Bull et al. | Jul 2008 | A1 |
20080160952 | Bull et al. | Jul 2008 | A1 |
20080160953 | Mia et al. | Jul 2008 | A1 |
20080161015 | Maloney et al. | Jul 2008 | A1 |
20080228654 | Edge | Sep 2008 | A1 |
20080248811 | Maloney et al. | Oct 2008 | A1 |
20080261611 | Mia et al. | Oct 2008 | A1 |
20080261612 | Mia et al. | Oct 2008 | A1 |
20080261613 | Anderson et al. | Oct 2008 | A1 |
20080261614 | Mia et al. | Oct 2008 | A1 |
20090005061 | Ward et al. | Jan 2009 | A1 |
20100248740 | Justusson et al. | Sep 2010 | A1 |
20120149325 | Titus et al. | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
2006088472 | Aug 2006 | WO |
2009142963 | Nov 2009 | WO |
Entry |
---|
J Winterbottom; “Held Protocol Context Management Extensions”; Internet Engineering Task Force; Standard Working Draft, Internet Society; Geneva Switzerland; No. 3; Sep. 29, 2008; pp. 2-24. |
M Barnes et al.; “HTTP Enabled Location Delivery (HELD)”; Internet Engineering Task Force; Standard Working Draft; Geneva Switzerland; vol. geopriv, No. 13; Feb. 25, 2009; entire document. |
Rick Roberts, “Project: IEEE P802.15 Working Group for Wireless Personal Area Networks (WPANS),” Harris Corporation, Melbourne Florida, Oct. 4, 2004, pp. 1-11. |
Stephanie Bell, A Beginners Guide to Uncertainty of Measurement, The National Physics Laboratory of the United Kingdom of Great Britain and Northern Ireland, Teddington, Middlesex, UK, 2001, pp. 1-41. |
Number | Date | Country | |
---|---|---|---|
20100246567 A1 | Sep 2010 | US |