Embodiments of the present invention relate to managing user devices. More specifically, embodiments of the present invention are related to unlocking a locked user device using a computer generated unlock code provided by a user.
In today's world, electronic user devices are very common. For example, many people have cell phones and personal assistant devices (PDAs) that they carry around with them. Asa result of the ubiquitous use of electronic user devices, it is becoming increasingly more common for users to loss their devices or to be the victim of the devices being stolen. The person who obtains the device may access the device owner's personal information or use expensive services provided by the device that the owner is obligated to pay for. Thus, there is a need for a way to prevent lost or stolen devices from being accessed or used. Further, there is a need for an efficient way to prevent lost or stolen devices from being accessed or used.
The accompanying drawings, which are incorporated in and form a part of this specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention:
The drawings referred to in this description should not be understood as being drawn to scale except if specifically noted.
Reference will now be made in detail to various embodiments of the invention, examples of which are illustrated in the accompanying drawings. While the invention will be described in conjunction with these embodiments, it will be understood that they are not intended to limit the invention to these embodiments. On the contrary, the invention is intended to cover alternatives, modifications and equivalents, which may be included within the spirit and scope of the invention as defined by the appended claims. Furthermore, in the following description of various embodiments of the present invention, numerous specific details are set forth in order to provide a thorough understanding of the present invention. In other instances, well-known methods, procedures, components, and circuits have not been described in detail so as not to unnecessarily obscure aspects of the present invention.
In the event that a user losses their cell phone or PDA, the user can call customer care or interact with a web based service to have their device locked up. The user may provide information to verify that they are the owner of the user device. According to one embodiment, an unlock code is provided to the user as a part of locking the user device. The unlock code can be provided to the user by transmitting the unlock code to the user's email address, by displaying the unlock code on a web page, or can be provided to the user verbally, for example, over the phone.
If the user finds their device at a later point in time, the user can use the unlock code to unlock their user device without having to call customer care. For example, the user can enter the unlock code directly into their user device. Thus, various embodiments provide an efficient way to prevent lost or stolen devices from being accessed or used.
In the event that a user losses a device, they can have their device locked by interacting with a web based service or calling customer care on the phone. The web based service may be a customer care portal or may be a self care portal provided, for example, by the device's service provider to enable users to act on their own behalf.
According to one embodiment, an unlock code is provided to the user as a part of locking the user device. The unlock code can be used to unlock the device in the event that at a later time the user locates their user device.
According to one embodiment, the user provides information to customer care or a web based service to prove that they are the owner of the device before the device is locked and they are provided with an unlock code. For example, the user may provide, among other things, a certificate, a password, an account number, a phone number, an answer to a question that only the user may know, some personal information, or a combination thereof.
More specifically, the user may log into a self care portal or a customer care portal with a password. In another example, the user may call customer care. In a small company the customer care operators may know the person. If not, the user may provide information such as an employee identification number to the customer care operators.
There are several ways that a user device can be locked. The keyboard of the user device may be disabled so that a person cannot interact with the user device. In another example, various major functions of the user device may be disabled. According to one embodiment, the user device is put in a mode so that it will only accept an unlock code. More specifically, the user device may display a user interface where only the unlock code can be entered and all other functions are disabled.
According to one embodiment, the unlock code that is provided to the user as a part of locking the user device is generated by a computer. The computer generated unlock code is sufficiently complex that a person can not determine what the computer generated unlock is, for example, by trial and error or by guessing. For example, the computer generated unlock code may be a half dozen alphanumeric characters that are randomly generated by a computer.
According to one embodiment, an unlock code is generated by an unlock code generator that executes on a computer. The unlock code generator may reside on a management server, as will become more evident, or may reside with the entity that the user interacted with to lock their user device. For example, the unlock code generator may reside at a web based service the user interacted with to lock their device, such as a self care portal or a customer care portal.
The computer generated unlock code can be provided to the user verbally over the phone, for example, by customer care personal. The computer generated unlock code can be provided to the user by transmitting the unlock code to the user's email address. The user may have provided their email address as a part of registering their phone.
The user can make a record of the computer generated unlock code and in the event that the user finds their device, the user can use it to unlock their device. The unlock code that is provided by the user is referred to herein as a “user provided unlock code.”
According to one embodiment, an unlock code expires after a period of time. For example, an unlock code may be used to unlock a user device for a period of 3 days. After the expiration period has elapsed, the unlock code cannot be used to unlock the user device. Continuing the example, the unlock code will expire after the 3 day period has elapsed. If the user finds their device after 3 days have elapsed, the user can still get their device unlocked, for example, by interacting with customer care or a self care portal.
Although the above example referred to an expiration period of 3 days, the expiration period can be specified with any measure of time, such as hours, days, months or a combination thereof.
The apparatus 100, according to one embodiment, includes a computer-generated-unlock-code-receiver 120 (referred to herein as a “CGUC receiver”), a computer-generated-unlock-code-storer 130 (referred to herein as a “storer”), a user-provided-unlock-code-receiver 140 (referred to herein as a “UPUC receiver”), a stored-generated-unlock-code-to-user-provided-unlock-code-comparer 150 (referred to herein as a “comparer”), and an unlock-user-device-based-on-comparing-computer-generated-unlock-code-to-user-provided-unlock-code-enabler 160 (referred to herein as “unlock enabler”).
The CGUC receiver 120 is configured for receiving from an unlock code generator a computer generated first unlock code for unlocking a user device. The unlock code generator is not under the control of the user, according to one embodiment. The first unlock code is also referred to as a “computer generated unlock code.” The storer 130 is configured for storing the first unlock code at a device that the apparatus 100 resides on. According to one embodiment, the apparatus 100 resides on the user device. According to another embodiment, the apparatus 100 resides on a device that a management server also resides on. The UPUC receiver 140 is configured for receiving a second unlock code. The second unlock code, according to one embodiment, is provided by the user. The second unlock code is entered into a computer based device by the user. The second unlock code is also referred to herein as a “user provided unlock code.” The comparer 150 is configured for comparing the first unlock code to the second unlock code. The unlock enabler 160 is configured for causing the user device to be unlocked if the first unlock code is the same as the second unlock code.
As will become more evident, the apparatus 100 depicted in
The blocks that represent features in
The user device 210, 310 can be any type of electronic device that can be lost or stolen. For example, the user device 210, 310 may be a cell phone or a personal digital assistant (PDA), among other things. A client, such as Open Mobile Alliance Device Management (OMA DM) Client™ may be associated with the user device 210, 310.
The management server 220, 320 may be any type of hardware, software, or firmware that can be used for managing the locking or unlocking of a user device. The management server 220, 320, according to one embodiment, is an Open Mobile Alliance Device Management (OMA DM) Server™ version 1.2.
According to one embodiment, the stored computer generated unlock code is co-located with the apparatus 100. For example, if the apparatus 100 resides on the user device 210, the computer generated unlock code 212 is stored on the user device 210 as depicted in
User device 210 may also include processing circuitry 214, such as a CPU and registers, among other things, and memory 216. The stored computer generated unlock code 212 may be stored in the memory 216.
According to one embodiment, at least a part of the apparatus 100 is implemented as an object that is transmitted to a user device 210. For example, the apparatus 100 may be a part of a lock management object that is transmitted from a management server to the user device. The lock management object may include the computer generated lock code and a method for accessing the computer generated lock code. Various features associated with the apparatus 100, such as the storer 130, the UPUC receiver 140, the comparer 150, and the unlock enabler 160 can be implemented as methods associated with the lock management object. The CGUC receiver 120 can be implemented as a variable, for example, on the user device 210 that is defined as type lock management object. The variable can be initialized with a lock management object that the user device 210 receives, as will become more evident.
In another embodiment, at least a part of the apparatus 100 is implemented as an object that is co-located with the management server 320, as will be described in the context of flowchart 400 and
According to another embodiment, the apparatus 100 is not implemented as an object. For example, the apparatus 100 (
All of, or a portion of, the embodiments described by flowchart 400 can be implemented using computer-readable and computer-executable instructions which reside, for example, in computer-usable media of a computer system or like device. The computer-usable media can be any kind of memory that instructions can be stored on. Examples of the computer-usable media include but are not limited to a disk, a compact disk (CD), a digital video device (DVD), read only memory (ROM), flash, and so on. As described above, certain processes and steps of the present invention are realized, in one embodiment, as a series of instructions (e.g., software program) that reside within computer readable memory of a computer system and are executed by the processor of the computer system. When executed, the instructions cause the computer system to implement the functionality of the present invention as described below.
The flowchart 400 will be used to describe two embodiments. The first embodiment pertains to the apparatus 100 (
In the present embodiment, certain operations are taken to prepare for the description of flowchart 400. Assume, for the embodiments depicted in
As will become more evident in the descriptions of flowcharts 400, the lock management object can be used to lock the user device, to unlock the user device, or a combination thereof. An unlock code generator, that is associated for example with the management server 220, 320, can generate an unlock code that is provided to the user. The lock management object may also include the computer generated unlock code and an unlock method. The management server 220, 320 could open a session with a client on the user device 210, 310 using the lock management object and use a handle associated with the lock management object to cause a lock command to be executed.
The following describes the flowchart 400 in the context of the embodiment depicted in
The method begins at step 410
At 420, the first unlock code is received from a computer based unlock code generator. For example, the unlock code generator may be co-located with the management server 220. The unlock code, that was generated by the unlock code generator (also referred to herein as the “computer generated unlock code”), can be transmitted from the management server 220 to the user device 210. The CGUC receiver 120 can receive the computer generated unlock code that is transmitted to the user device 210. The computer generated unlock code may be received at the user device 210 as a part of a lock management object that is transmitted to the user device 210 from the management server 220.
The computer generated unlock code may be displayed to the user on a web based service that the user interacted with to lock their device 210, provided verbally by customer care over the phone when the user called customer care to have their device 210 locked, or emailed to the user as a result of using a web based service or calling customer care, for example. The user can make a record of the computer generated unlock code.
According to one embodiment, the storer 130, the UPUC receiver 140, the comparer 150, and the unlock enabler 160 associated with the apparatus 100 (
According to another embodiment, the apparatus 100 is not implemented as an object. For example, the apparatus 100 (
At 430, the first unlock code is stored. For example, the storer 130 located at the user device 210 can store the computer generated unlock code at the location 212 associated with the user device 210 as depicted in
The computer generated unlock code may be stored as a part of initializing a variable of type lock management object with the received lock management object.
At 440, a second unlock code, which is provided by a user, is received. The user can provide the unlock code that they made a record of as described under 420. The user provided unlock code is entered into a computer based device by the user. For example, the user device 210 may be in a mode that only allows an unlock code to be entered. The user could, for example, provide the unlock code by entering the unlock code into the user device 210. In another example, the user may enter the unlock code into a web based service, such as a self care portal executes on. The user device 210 and the device that executes the self care portal are examples of computer based devices that the user can enter the user provided unlock code into. Thus, the user can avoid the time consuming process of calling customer care to have their user device unlocked. The UPUC receiver 140 can receive the user provided unlock code.
At 450, the first unlock code is compared with the second unlock code. For example, the comparer 150 can compare the computer generated unlock code 212 with the user provided unlock code.
At 460, the user device is unlocked if the first unlock code is the same as the second unlock code. For example, the unlock enabler 160 can cause the user device 210 to be unlocked if the comparer 150 indicates that the computer generated unlock code is the same as the user provided unlock code.
The user device 210 may be unlocked, for example, by executing an unlock method, such as the unlock enabler 160, associated with the lock management object.
The user device 210, according to one embodiment, opens a session with the management server 220 and notifies the management server 220 that the user device 210 has been unlocked.
At 470, the method ends.
The following describes the flowchart 400 in the context of the embodiment depicted in
The method begins at step 410
At 420, the first unlock code is received from a computer based unlock code generator. For example, the unlock code generator may be co-located with the management server 320. The unlock code, that is generated by the unlock code generator (also referred to herein as the “computer generated unlock code”), can be received by the GCUC receiver 120, which is co-located with the management server 320.
The computer generated unlock code may be displayed to the user on a web based service that the user interacted with to lock their device, provided verbally by customer care over the phone when the user called customer care to have their device locked, or emailed to the user as a result of using a web based service or calling customer care, for example. The user can make a record of the computer generated unlock code.
The apparatus 100 may be implemented as an object that is co-located with the management server 320. For example, the GCUC receiver 120, the starer 130, the UPUC receiver 140, the comparer 150, and the unlock enabler 160 associated with the apparatus 100 (
According to another embodiment, the apparatus 100 is not implemented as an object. For example, the apparatus 100 (
At 430, the first unlock code is stored. For example, the storer 130 located at the management server 320 can store the computer generated unlock code at the location 322 associated with the management server 320 as depicted in
At 440, a second unlock code, which is provided by a user, is received. For example, assume that the user finds their user device 310. The user can provide the unlock code that they made a record of as described under 420. The user provided unlock code is entered into a computer based device by the user. For example, the user device 310 may be in a mode that only allows an unlock code to be entered. The user could, for example, provide the unlock code by entering the unlock code into the user device 310. In another example, the user may enter the unlock code into a web based service, such a self care portal. The user device 310 and the device that executes the self care portal are examples of computer based devices that the user can enter the user provided unlock code into. Thus, the user can avoid the time consuming process of calling customer care to have their user device unlocked. The UPUC receiver 140 can receive the user provided unlock code.
At 450, the first unlock code is compared with the second unlock code. For example, the comparer 150 can compare the computer generated unlock code 322 with the user provided unlock code.
At 460, the user device is unlocked if the first unlock code is the same as the second unlock code. For example, if the comparer 150 indicates that the computer generated unlock code 322 is the same as the user provided unlock code, the management server 320 can establish a session with a client associated with the user device 310 and cause the unlock enabler 160 to command the user device 310 to be unlocked. For example, the management server 320 could open a session with a client on the user device 210 using the lock management object that was transmitted to the user device 320 by using the handle associated with the lock management object to cause a lock command to be executed.
The management server 320 may authenticate the user device 310 as a part of unlocking the user device 310.
At 470, the method ends.
Various embodiments provide an efficient way of locking a lost or stolen user device, for example, by allowing a user to enter a computer generated unlock code (the “user provided unlock code”) into a computer based device, instead of requiring the user to spend a significant amount of time calling customer care over the phone. Examples of a computer based device that the user can enter the computer generated unlock code into are the user device or a device that executes a web based service, such as a self care portal.
Further, various embodiments provide a high level of security by using a computer generated unlock code that is sufficiently complex to prevent someone from determining the unlock code by trail and error or by guessing. For example, many electronic devices or web based services allow users to log in using passwords that were determined by the user. Frequently, these passwords are not very complex. For example, the passwords may only include 4 numbers which can be determined fairly quickly by trial and error. Or the passwords may be personal information such as birth dates or names of children which can easily be determined. In contrast, a computer generated unlock code would not include personal information that can be obtained or guessed. Further, a computer generated unlock code would be sufficiently complex to prevent someone from determining the unlock code by trail and error. Thus, a computer generated unlock code could not be guessed or determined by trial and error.
Various embodiments have been described in various combinations. However, any two or more embodiments may be combined. Further, any embodiment may be used separately from any other embodiment.
Embodiments of the present invention are thus described. While the present invention has been described in particular embodiments, it should be appreciated that the present invention should not be construed as limited by such embodiments, but rather construed according to the following claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2008/071762 | 7/31/2008 | WO | 00 | 1/21/2011 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2010/014097 | 2/4/2010 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5732212 | Perholtz et al. | Mar 1998 | A |
5987609 | Hasebe | Nov 1999 | A |
6286104 | Buhle et al. | Sep 2001 | B1 |
6662023 | Helle | Dec 2003 | B1 |
6941468 | Johnson | Sep 2005 | B2 |
6950202 | Kikugawa | Sep 2005 | B1 |
7881745 | Rao et al. | Feb 2011 | B1 |
8490169 | Hird | Jul 2013 | B2 |
20010004591 | Jeong | Jun 2001 | A1 |
20020180582 | Nielsen | Dec 2002 | A1 |
20030088633 | Chiu | May 2003 | A1 |
20030208683 | Johnson | Nov 2003 | A1 |
20040143746 | Ligeti et al. | Jul 2004 | A1 |
20050044404 | Bhansali | Feb 2005 | A1 |
20050044906 | Spielman | Mar 2005 | A1 |
20050197099 | Nehushtan | Sep 2005 | A1 |
20050221800 | Jackson | Oct 2005 | A1 |
20060079204 | Pon et al. | Apr 2006 | A1 |
20060165060 | Dua | Jul 2006 | A1 |
20060236325 | Rao et al. | Oct 2006 | A1 |
20060276172 | Rydgren et al. | Dec 2006 | A1 |
20070082705 | Jain et al. | Apr 2007 | A1 |
20070130255 | Wolovitz et al. | Jun 2007 | A1 |
20070156804 | Mo | Jul 2007 | A1 |
20070259633 | Rao | Nov 2007 | A1 |
20080040786 | Chang | Feb 2008 | A1 |
20080083016 | Itoh | Apr 2008 | A1 |
20080150677 | Arakawa | Jun 2008 | A1 |
20080220744 | Rydgren et al. | Sep 2008 | A1 |
20090149192 | Vargas | Jun 2009 | A1 |
Number | Date | Country |
---|---|---|
1717082 | Jan 2006 | CN |
101166091 | Apr 2008 | CN |
20050328435 | Nov 2005 | JP |
1020060002603 | Jan 2006 | KR |
1020070056496 | Jun 2007 | KR |
WO-2007027065 | Mar 2007 | WO |
Entry |
---|
BPI—Forgot your User ID or Password? Don't worry!—accessed May 5, 2015—published on or before Apr. 7, 2003 https://web.archive.org/web/20030407043849/http://www.bpiexpressonline.com/passwordreset.htm—all pages pertinent. |
International Search Report and Written Opinion—PCT/US2008/071762—ISA/EPO—Dec. 30, 2008, 6 pages. |
Number | Date | Country | |
---|---|---|---|
20110128119 A1 | Jun 2011 | US |