Apparatuses, methods, and computer program products for proactive offline authentication
A method, apparatus, and computer program product for proactive offline authentication are provided. An example method includes determining a current offline condition of a computing device at a first time and determining a prior online condition of the computing device at a second time that is earlier than the first time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time. The method further includes obtaining, at the first time, first authentication credentials associated with the first user and determining a discrepancy between the first and the second authentication credentials. In response to the determined discrepancy, the method includes generating an authentication token based upon the second authentication credentials for authenticating a first user device of the first user with the computing device.
Latest Wells Fargo Bank, N.A. Patents:
Example embodiments of the present disclosure relate generally to authentication and, more particularly, to the use of a dynamic digital identity to provide proactive offline authentication techniques.
BACKGROUNDUsers often interact with a variety of businesses, merchants, financial institutions, and other entities, explicitly or implicitly, as part of their day-to-day lives. In doing so, an assortment of user data is generated that is tied to or representative of the underlying user. Furthermore, user's rely upon the security of the systems used for these interactions in order to keep their data safe. For example, systems may leverage authentication/authorization protocols or credentials in order to ensure that the user with which the system interacts is verified and has access to the features offered by the system. Often, network connectivity is required to perform various verification, authorization, and/or authentication operations.
BRIEF SUMMARYAs described above, authentication may be used in a variety of applications and industries to verify a session or otherwise validate interactions between users or devices. Traditional methods for authentication often rely upon a user to provide a password or other relatively static verifiable element that is used to confirm the identity of the user and generate a secure session with a requested entity (e.g., generate a session identifier that may be based upon the user's password or otherwise). These traditional techniques, however, have become increasingly susceptible to attack as the availability of computing power has increased, enabling exhaustive searching (e.g., Rainbow Tables or equivalent techniques). In this way, a user's session, password, etc. may be compromised simply by virtue of the new technical problems emergent in response to the growing computing resources available today, because perpetrators have a greater ability to breach a user's password or otherwise determine the method by which a session identifier is generated. Furthermore, conventional systems and methods for authenticating a user rely upon stagnant user credentials (e.g., a user inputted password or the like) that may be similarly susceptible to attack and/or require constant vigilance on the part of the user. For example, a user may be traditionally required to not only remember a unique password for use with each entity with which the user interacts but may also be required to diligently protect, update, and/or periodically change these passwords. Additionally, authentication, authorization, and/or verification techniques often require network connectivity in order to authenticate a user or session. For example, traditional systems often require network access in order to transmit user data to and receive user data from a remote server or other verified entity that serves to confirm the validity of user authentication credentials. Said differently, without network access, many conventional systems are incapable of properly authenticating a user, especially in instances in which user authentication credentials have changed.
To solve these issues and others, example implementations of embodiments of the present disclosure may leverage a digital identity construct database that provides a dynamic and evolving mechanism for authentication. In operation, an identity server described hereafter may determine an offline condition of a computing device (e.g., intermittent or absent network connectivity) at a first time but determine an online condition of the computing device (e.g., active network connectivity) at a second time that is earlier in time than the first time (e.g., the computing device is currently offline but at one point in the past was online). The embodiments described herein may determine that authentication credentials obtained for the first user by the computing device are from this second time (e.g., a prior or out-of-date version of the digital identity construct of the first user) and may, therefore, determine a discrepancy between these authentication credentials and credentials generated at the first time (e.g., based upon a current version of the digital identity construct of the first user). Given this discrepancy and inability (e.g., due to lack of network access) of the computing device to receive updated user attributes from the digital identity construct at the first time (e.g., the time at which the user and user devices requests authentication), the embodiments of the present disclosure may generate an authentication token based upon the prior-in-time generated credentials for authenticating the first user at the current time (e.g., first time).
In this way, the inventors have identified that the advent of computing resources have created a new opportunity for solutions for authentication which were historically unavailable. In particular, the embodiments herein may operate to address several technical challenges including providing a mechanism for proactive offline authentication based upon evolving user attributes. Said differently, embodiments described herein may detect an offline condition of a local device (e.g., a computing device of the present disclosure) with which a user and associated user device are or will attempt to interact and authenticate this user in the absence of network connectivity (e.g., when updated authentication credentials are unavailable to the computing device). In particular, this authentication and subsequent authorization may occur proactively in that a remote server (e.g., an identity server of the present disclosure) proactively (e.g., prior to an interaction between the computing device and the user device) determines that the computing device is incapable of receiving updated or otherwise current authentication credentials (e.g., an offline condition). These new proactive offline authentication techniques may further modify user attribute selection based upon detect network connectivity. For example, in instances in which networking connectivity is absent, authentication credentials of the user may be modified to require only static attributes of the user (e.g., attributes that have not changed since connectivity between the computing device and the remote server existed).
Systems, apparatuses, methods, and computer program products are disclosed herein for proactive offline authentication. In one embodiment, with reference to the claimed computer-implemented method, a method for proactive offline authentication is provided. The computer-implemented method may include determining a current offline condition of a computing device at a first time and determining a prior online condition of the computing device at a second time that is earlier in time than the first time. The second time is a time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time. The one or more user attributes may include one static attribute that remains constant over time and/or one dynamic attribute that varies over time. The method may include obtaining, at the first time, first authentication credentials associated with the first user that are based upon a current iteration of the at least one static attribute used in generating the second authentication credentials and/or at least one current iteration of the at least one dynamic attribute of the second authentication credentials from the digital identity construct database. The method may further include determining a discrepancy between the first authentication credentials and the second authentication credentials and generating an authentication token based upon the second authentication credentials for authenticating a first user device associated with the first user with the computing device.
In some embodiments, prior to determining the current offline condition of the computing device at the first time, the method may include detecting a forthcoming request for authentication for the first user device.
In some further embodiments, detecting the forthcoming request further includes receiving a user input indicative of the forthcoming request.
In other further embodiments, detecting the forthcoming request further includes obtaining one or more user parameters associated with the first user and detecting the forthcoming request based upon the one or more user parameters.
In some embodiments, the method further includes transmitting the authentication token to the first user device.
In some embodiments, determining the current offline condition of the computing device further includes generating a transmission to the computing device comprising at least one user attribute from the digital identity construct database, attempting to transmit the transmission to the computing device, and determining the offline condition in an instance in which a transmission failure is determined.
In some embodiments, the computing device is associated with an access location, and the method further includes causing access to be provided to the access location for the first user device based upon the authentication token.
In some embodiments, methods, systems, devices, apparatuses, and computer program products are provided for attribute modification. With reference to an example method, the method may include determining a periodic offline condition of a computing device at a first time and determining an online condition of the computing device at a second time that is later in time than the first time. The method may include generating first authentication credentials based upon one or more static user attributes obtained from a digital identity construct database associated with a first user at the first time or the second time and authenticating a first user device associated with the first user based upon the first authentication credentials. Such a attribute modification method may be used alternatively or in addition to the proactive offline authentication methods described herein.
The above summary is provided merely for purposes of summarizing some example embodiments to provide a basic understanding of some aspects of the disclosure. Accordingly, it will be appreciated that the above-described embodiments are merely examples and should not be construed to narrow the scope or spirit of the disclosure in any way. It will be appreciated that the scope of the disclosure encompasses many potential embodiments in addition to those here summarized, some of which will be further described below.
Having described certain example embodiments of the present disclosure in general terms above, reference will now be made to the accompanying drawings. The components illustrated in the figures may or may not be present in certain embodiments described herein. Some embodiments may include fewer (or more) components than those shown in the figures.
Some embodiments of the present disclosure will now be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all embodiments of the disclosure are shown. Indeed, these embodiments may 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 satisfy applicable legal requirements. Like numbers refer to like elements throughout. As used herein, the description may refer to an identity server as an example “apparatus.” However, elements of the apparatus described herein may be equally applicable to the claimed method and computer program product. Thus, use of any such terms should not be taken to limit the spirit and scope of embodiments of the present disclosure.
DEFINITION OF TERMSAs used herein, the terms “data,” “content,” “information,” “electronic information,” “signal,” “command,” and similar terms may be used interchangeably to refer to data capable of being transmitted, received, and/or stored in accordance with embodiments of the present disclosure. Thus, use of any such terms should not be taken to limit the spirit or scope of embodiments of the present disclosure. Further, where a first computing device is described herein to receive data from a second computing device, it will be appreciated that the data may be received directly from the second computing device or may be received indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, hosts, and/or the like, sometimes referred to herein as a “network.” Similarly, where a first computing device is described herein as sending data to a second computing device, it will be appreciated that the data may be sent directly to the second computing device or may be sent indirectly via one or more intermediary computing devices, such as, for example, one or more servers, remote servers, cloud-based servers (e.g., cloud utilities), relays, routers, network access points, base stations, hosts, and/or the like.
As used herein, the term “comprising” means including but not limited to, and should be interpreted in the manner it is typically used in the patent context. Use of broader terms such as comprises, includes, and having should be understood to provide support for narrower terms such as consisting of, consisting essentially of, and comprised substantially of.
As used herein, the phrases “in one embodiment,” “according to one embodiment,” “in some embodiments,” and the like generally refer to the fact that the particular feature, structure, or characteristic following the phrase may be included in at least one embodiment of the present disclosure. Thus, the particular feature, structure, or characteristic may be included in more than one embodiment of the present disclosure such that these phrases do not necessarily refer to the same embodiment.
As used herein, the word “example” is used herein to mean “serving as an example, instance, or illustration.” Any implementation described herein as “example” is not necessarily to be construed as preferred or advantageous over other implementations.
As used herein, the term “identity server” refers to computer hardware that is configured (either physically or by the execution of software) to authenticate a user and associated user device(s) and, among various other functions, is configured to directly, or indirectly, transmit and receive data. An example identity server may include a smartphone, a tablet computer, a laptop computer, a local server, a wearable device (e.g., smart glasses, smart watch, or the like), remote server, and/or the like. In some embodiments, an identity server may include a “smart device” that is equipped with chip of other electronic device that is configured to communicate with a first user device and/or a computing device via Bluetooth, NFC, Wi-Fi, 3G, 4G, 5G, RFID protocols, and the like. By way of a particular example, an identity server may be a remote server that may house, store, or otherwise access a digital identity construct database as described herein and may further be configured to authenticate an interaction between a user device and/or a computing device as defined herein.
As used herein, the terms “first user device,” “first mobile device,” “first electronic device,” and the like refer to computer hardware that is configured (either physically or by the execution of software) to access one or more services made available by the identity server (e.g., apparatus of the present disclosure) and, among various other functions, is configured to directly, or indirectly, transmit and receive data. Example first user devices may include a smartphone, a tablet computer, a laptop computer, a wearable device (e.g., smart glasses, smart watch, or the like), and the like. In some embodiments, a first user device may include a “smart device” that is equipped with chip of other electronic device that is configured to communicate with the identity server and/or computing device via Bluetooth, NFC, Wi-Fi, 3G, 4G, 5G, RFID protocols, and the like. By way of a particular example, a first user device may be a mobile phone equipped with a Wi-Fi radio that is configured to communicate with a Wi-Fi access point that is in communication with the identity server 200 or other identity server via a network. As described hereafter, the first user device may be configured to communicate (e.g., transmit and receive data) with a digital identity construct database (e.g., housed by a remote server, the identity server, or otherwise) via a Wi-Fi access point that is in communication with the digital identity construct database so as to receive updated user authentication credentials (e.g., current user attributes for the first user). Similarly, the first user device may be configured to communicate (e.g., transmit and receive data) with a computing device via a Wi-Fi access point that is in communication with the computing device so as to, as described hereafter, provide access to the first user device to one or more features (e.g., physical access, network access, etc.) offered by the computing device.
The “first user device” may, in some embodiments define, include, access, or otherwise leverage one or more sensing devices or sensors. For example, the first user device may include one or more cameras, infrared (IR) sensors, scanning devices, imagers, accelerometers, gyroscopes, positional sensors, heartrate sensors, temperature sensors, pressure sensors, positional sensors, and/or the like configured to generate user data associated with or indicative of the first user. The one or more sensing devices or sensors may be configured to generate user data associated with user attributes (e.g., dynamic or static) as defined herein. The present disclosure contemplates that any example first user device may include any number of sensing devices without limitation. The first user device and associated first user may, in some embodiments, be associated with a first user profile storing one or more user parameters of the first user. By way of a non-limiting example, the first user profile may include data entries associated with or indicative of the location of the first user (e.g., location data), transactions of the first user (e.g., financial or transaction data), user preferences, user accounts, user correspondences, user social media data, and/or the like.
As used herein, the terms “computing device,” “access location device,” and the like refer to computer hardware that is configured (either physically or by the execution of software) to access one or more services made available by the identity server (e.g., apparatus or identity server of the present disclosure) and, among various other functions, is configured to directly, or indirectly, transmit and receive data. Example computing devices may include a smartphone, a tablet computer, a laptop computer, a wearable device (e.g., smart glasses, smart watch, or the like), a terminal, and the like. In some embodiments, a computing device may include a “smart device” that is equipped with chip of other electronic device that is configured to communicate with the identity server and/or first user device via Bluetooth, NFC, Wi-Fi, 3G, 4G, 5G, RFID protocols, and the like. By way of a particular example, a computing device may be a terminal equipped with a Wi-Fi radio that is configured to communicate with a Wi-Fi access point that is in communication with the identity server 200 or other device via a network. As described hereafter, the computing device may be configured to communicate (e.g., transmit and receive data) with a digital identity construct database (e.g., housed by a remote server or otherwise) via a Wi-Fi access point that is in communication with the digital identity construct so as to receive user authentication credentials (e.g., user attributes).
The computing device may, for example, be associated with an access location (e.g., configured to authenticate a user to provide access to the access location) and may access a digital identity construct database as described hereafter to retrieve user attributes used in generating user authentication credentials. The computing device may be configured to communicate with the digital identity construct database (e.g., housed by a remote server, the identity server, or otherwise) via a Wi-Fi access point that is in communication with the digital identity construct database. As described hereafter, the computing device may have intermittent or absent network connectivity such that the computing device is unable to receive updated user attributes from the digital identity construct database.
The “computing device” may, in some embodiments, define, include, access, or otherwise leverage one or more sensing devices or sensors. For example, the computing device may include one or more cameras, infrared (IR) sensors, scanning devices, imagers, accelerometers, gyroscopes, positional sensors, heartrate sensors, temperature sensors, pressure sensors, positional sensors, and/or the like configured to generate user data associated with or indicative of the first user. The one or more sensing devices or sensors may be configured to generate user data associated with user attributes (e.g., dynamic or static) as defined herein. The present disclosure contemplates that any example computing device may include any number of sensing devices without limitation.
As used herein, the terms “digital identity construct” and “digital identity construct database” refer to a data structure or repository for storing user attributes. The digital identity construct database may, for example, include a plurality of static attributes and dynamic attributes. As such, “static” attributes may refer to data entries associated with user attributes that may remain constant over time. By way of example, a static attribute may include dates, locations, addresses, and/or the like indicative of events (e.g., birthdays, first car purchase, most recent mailing addresses, or the like) that do not change. Alternatively, “dynamic” attributes may refer to data entries associated with user attributes that may vary over time. By way of example, a dynamic data attribute may include biometric features (e.g., age, weight, height, hair color, etc.), current location data, and/or the like that are capable of changing as, for example, a user ages, moves, etc. The present disclosure contemplates that the digital identity construct may include any number of user attributes associated with any number of respective users and may operate to, in some embodiments, store substantially all identifying data attributes, events, or the like associated with a particular user. Said differently, the present disclosure contemplates that the digital identity construct database may store any feature, data entry, element, data object, etc. associated with a user without limitation so as to form a substantially complete digital representation of the user's identity. For example, the digital identity construct and digital identity database may encompass, include, or otherwise access an identity system or identity databank, such as those described in U.S. patent application Ser. No. 16/268,288.
The digital identity construct database may be, for example, initially populated or otherwise supplied with user data as part of an initial set up procedure. For example, a first may supply information (e.g., static or dynamic) about the first user as part of an account set up procedure. Additionally or alternatively, the digital identity construct may be populated, updated, modified, or the like over time to provide an evolving repository of user attributes. For example, one or more static user attributes may be added to the digital identity construct database over time (e.g., new biometric data entries, new locations, new addresses, new financial transactions, etc.) and one or more dynamic user attributes may be updated or modified over time (e.g., current location, current job, new height, new weight, new hair color, etc.). In some instances, user attributes may be added or updated in the digital identity construct database in response to actions on the part of the user, such as input by the user in response to a request. In other embodiments, attributes may be added or updated in the digital identity construct automatically or otherwise without affirmative action on the part of the associated user. By way of example, a user may interact with an automated teller machine (ATM) and may input user attributes associated with the user (e.g., a request for an updated address, phone number, etc.). The ATM (e.g., computing device) may include, for example, one or more sensors (e.g., cameras, scanners, scales, microphones, or the like) configured to determine user attributes (e.g., hair color, weight, etc.) and may update the digital identity construct database accordingly. The present disclosure contemplates that any mechanism for supplying user attributes to the digital identity construct (e.g., social media scraping, location data monitoring, transaction history analysis, data processing, etc.) may be used without limitation.
The International Organization for Standardization (ISO) standard ISO/IEC 24760-1:2011—Security techniques—A framework for identity management—Part 1: Terminology and Concepts, defines identity as a set of attributes related to an entity. As such, the digital identity construct and digital identity construct database described herein may be configured such that digital identity is information (e.g., attributes) that may be used to represent an entity. Thus the digital identity construct that includes dynamic user attributes is a set of attributes that may change over time such that the most current version of user attributes be used for generating user authentication credentials for online authentication while the most recent user attributes (e.g., the most recent iteration of a dynamic user attribute) may be used to generate use authentication credentials for offline authentication.
As used herein, the term “computer-readable medium” refers to non-transitory storage hardware, non-transitory storage device or non-transitory computer system memory that may be accessed by a controller, a microcontroller, a computational system or a module of a computational system to encode thereon computer-executable instructions or software programs. A non-transitory “computer-readable medium” may be accessed by a computational system or a module of a computational system to retrieve and/or execute the computer-executable instructions or software programs encoded on the medium. Exemplary non-transitory computer-readable media may include, but are not limited to, one or more types of hardware memory, non-transitory tangible media (for example, one or more magnetic storage disks, one or more optical disks, one or more USB flash drives), computer system memory or random access memory (such as, DRAM, SRAM, EDO RAM), and the like.
Having set forth a series of definitions called-upon throughout this application, an example system architecture and example apparatus is described below for implementing example embodiments and features of the present disclosure.
Device Architecture and Example ApparatusWith reference to
The identity server 200 may include circuitry, networked processors, or the like configured to perform some or all of the apparatus-based (e.g., identity server-based) processes described herein, and may be any suitable network server and/or other type of processing device. In this regard, identity server 200 may be embodied by any of a variety of devices. For example, the identity server 200 may be configured to receive data (e.g., user attribute data, sensor data, sensing data, etc.) and may include any of a variety of fixed terminals, such as a server, desktop, or kiosk, or it may comprise any of a variety of mobile terminals, such as a portable digital assistant (PDA), mobile telephone, smartphone, laptop computer, tablet computer, or in some embodiments, a peripheral device that connects to one or more fixed or mobile terminals. Example embodiments contemplated herein may have various form factors and designs, but will nevertheless include at least the components illustrated in
The network 104 may include one or more wired and/or wireless communication networks including, for example, a wired or wireless local area network (LAN), personal area network (PAN), metropolitan area network (MAN), wide area network (WAN), or the like, as well as any hardware, software and/or firmware for implementing the one or more networks (e.g., network routers, switches, hubs, etc.). For example, the network 104 may include a cellular telephone, mobile broadband, long term evolution (LTE), GSM/EDGE, UMTS/HSPA, IEEE 802.11, IEEE 802.16, IEEE 802.20, Wi-Fi, dial-up, and/or WiMAX network. Furthermore, the network 104 may include a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to TCP/IP based networking protocols.
The first user device 102 may be associated with a first user and may be configured to generate and/or access user attribute data associated with the first user. Although a single user device associated with a corresponding user is shown, the example system 100 may include any number of user devices that may be associated with various users. The first user device 102 may be a cellular telephone (e.g., a smartphone and/or other type of mobile telephone), laptop, tablet, electronic reader, e-book device, media device, wearable, smart glasses, smartwatch, mobile device, any combination of the above, or any device by which the first user may access the identity server 200, the digital identity construct database 110, or the like. In some embodiments, the first user device 102 may be configured to request authentication (e.g., from the identity server 200). The first user device 102 may also allow a user to provide input (e.g., by way of a biometric scan, actionable notification, or the like) via sensing devices or sensors, which may be conveyed to the identity server 200 via the network 104 as attribute data. User data or attribute data may be, as described above, generated via one or more input devices, sensing devices, or sensors, including, without limitation, a touchscreen, microphone, camera, optical scanner, fingerprint reader, and/or motion sensor device (e.g., an accelerometer, gyroscope, etc.).
The computing device 106 may be associated with an access location and may be configured to provide access (e.g., physical access, system access, application access, network access, etc.) to the first user device 102. Although a single computing device 106 is shown, the example system 100 may include any number of computing devices. The computing device 106 may be a cellular telephone (e.g., a smartphone and/or other type of mobile telephone), laptop, tablet, electronic reader, e-book device, media device, wearable, smart glasses, smartwatch, mobile device, ATM, terminal, any combination of the above. In some embodiments, the computing device 106 may be configured to request authentication credentials and/or user attributes (e.g., from the identity server 200). The computing device 106 may also allow a user to provide input (e.g., by way of a biometric scan, actionable notification, or the like) via sensing devices or sensors, which may be conveyed to the identity server 200 via the network 104 as attribute data when network connectivity is present. User data or attribute data may be, as described above, generated via one or more input devices, sensing devices, or sensors, including, without limitation, a touchscreen, microphone, camera, optical scanner, fingerprint reader, and/or motion sensor device (e.g., an accelerometer, gyroscope, etc.). As described hereafter, network connectivity between the computing device 106 and the digital identity construct database 110 and the identity server 200 via the network 104 may vary in quality or duration (e.g., intermittent connectivity) and/or may be absent during an attempt to authenticate an interaction between a user and the computing device 106 by the identity server 200.
The digital identity construct database 110 may be stored by any suitable storage device configured to store some or all of the information described herein (e.g., a separate memory system separate from the identity server 200, such as one or more database systems, backend data servers, network databases, cloud storage devices, or the like provided by a computing device 106 or the first user device 102). The digital identity construct database 110 may comprise data received from the identity server 200 (e.g., via a memory 204 and/or processor(s) 202) or the first user device 102, and the corresponding storage device may thus store this data. To avoid unnecessarily overcomplicating the disclosure, the digital identity construct database 110 is shown and described as a separate database, despite the fact that they may each be hosted by any number of specific physical devices, together or separately.
As illustrated in
Of course, while the term “circuitry” should be understood broadly to include hardware, in some embodiments, the term “circuitry” may also include software for configuring the hardware. For example, although “circuitry” may include processing circuitry, storage media, network interfaces, input/output devices, and the like, other elements of the identity server 200 may provide or supplement the functionality of particular circuitry.
In some embodiments, the processor 202 (and/or co-processor or any other processing circuitry assisting or otherwise associated with the processor) may be in communication with the memory 204 via a bus for passing information among components of the identity server 200. The memory 204 may be non-transitory and may include, for example, one or more volatile and/or non-volatile memories. In other words, for example, the memory may be an electronic storage device (e.g., a non-transitory computer readable storage medium). The memory 204 may be configured to store information, data, content, applications, instructions, or the like, for enabling the identity server to carry out various functions in accordance with example embodiments of the present disclosure.
The processor 202 may be embodied in a number of different ways and may, for example, include one or more processing devices configured to perform independently. Additionally or alternatively, the processor may include one or more processors configured in tandem via a bus to enable independent execution of instructions, pipelining, and/or multithreading. The use of the term “processing circuitry” may be understood to include a single core processor, a multi-core processor, multiple processors internal to the identity server, and/or remote or “cloud” processors.
In an example embodiment, the processor 202 may be configured to execute instructions stored in the memory 204 or otherwise accessible to the processor 202. Alternatively or additionally, the processor 202 may be configured to execute hard-coded functionality. As such, whether configured by hardware or by a combination of hardware with software, the processor 202 may represent an entity (e.g., physically embodied in circuitry) capable of performing operations according to an embodiment of the present disclosure while configured accordingly. Alternatively, as another example, when the processor 202 is embodied as an executor of software instructions, the instructions may specifically configure the processor 202 to perform the algorithms and/or operations described herein when the instructions are executed.
The identity server 200 further includes input/output circuitry 206 that may, in turn, be in communication with processor 202 to provide output to a user and to receive input from a user, user device, or another source (e.g., so as receive user attribute data or sensor data). In this regard, the input/output circuitry 206 may comprise a display that may be manipulated by a mobile application. In some embodiments, the input/output circuitry 206 may also include additional functionality such as a keyboard, a mouse, a joystick, a touch screen, touch areas, soft keys, a microphone, a speaker, or other input/output mechanisms. The processor 202 may be configured to control one or more functions of a display through computer program instructions (e.g., software and/or firmware) stored on a memory accessible to the processor (e.g., memory 204, and/or the like), so as receive user attribute data and/or sensor data.
The communications circuitry 208 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to receive and/or transmit data from/to a network and/or any other device, circuitry, or module in communication with the identity server 200. In this regard, the communications circuitry 208 may include, for example, a network interface for enabling communications with a wired or wireless communication network. For example, the communications circuitry 208 may include one or more network interface cards, antennae, buses, switches, routers, modems, and supporting hardware and/or software, or any other device suitable for enabling communications via a network. Additionally or alternatively, the communication interface may include the circuitry for interacting with the antenna(s) to cause transmission of signals via the antenna(s) or to handle receipt of signals received via the antenna(s). These signals may be transmitted by the identity server 200 using any of a number of wireless personal area network (PAN) technologies, such as Bluetooth® v1.0 through v3.0, Bluetooth Low Energy (BLE), infrared wireless (e.g., IrDA), ultra-wideband (UWB), induction wireless transmission, or the like. In addition, it should be understood that these signals may be transmitted using Wi-Fi, Near Field Communications (NFC), Worldwide Interoperability for Microwave Access (WiMAX) or other proximity-based communications protocols.
Sensing circuitry 210 includes hardware components designed to either generate sensor data or to analyze sensor data, such as data generated by one or more sensing devices of the first user device 102 and/or the computing device 106. For example, sensing circuitry 210 may include hardware components configured to perform image processing. Sensing circuitry 210 may utilize processing circuitry, such as the processor 202, to perform its corresponding operations, and may utilize memory 204 to store collected information. It should also be appreciated that, in some embodiments, the sensing circuitry 210 may include a separate processor, specially configured field programmable gate array (FPGA), or application specific interface circuit (ASIC) to perform its corresponding functions.
In addition, computer program instructions and/or other type of code may be loaded onto a computer, processor or other programmable identity server's circuitry to produce a machine, such that the computer, processor other programmable circuitry that execute the code on the machine create the means for implementing the various functions, including those described in connection with the components of identity server 200.
As described above and as will be appreciated based on this disclosure, embodiments of the present disclosure may be configured as systems, methods, mobile devices, and the like. Accordingly, embodiments may comprise various means including entirely of hardware or any combination of software with hardware. Furthermore, embodiments may take the form of a computer program product comprising instructions stored on at least one non-transitory computer-readable storage medium (e.g., computer software stored on a hardware device). Any suitable computer-readable storage medium may be utilized including non-transitory hard disks, CD-ROMs, flash memory, optical storage devices, or magnetic storage devices.
Example Operations for Proactive Offline AuthenticationAs shown in operation 302, the apparatus (e.g., identity server 200) includes means, such as input/output circuitry 206, communications circuitry 208, or the like, for determining a current offline condition of a computing device at a first time. As described herein, the computing device 106 may be associated with an access location such that the computing device 106 operates to authenticate users and associated user devices to provide access to said access location. By way of a non-limiting example, the computing device 106 may be associated with a door, gate, or the like of a user's vacation home, rental property, or other location that may, for example, be subject to intermittent network connectivity, power supply, or the like. Although described hereafter with reference to a remote location, the present disclosure contemplates that the computing device 106 may be associated with any location, device, system, or the like without limitation.
As described further hereafter with reference to
In some example embodiments, as shown in operation 302, the apparatus (e.g., identity server 200) includes means, such as input/output circuitry 206, communications circuitry 208, or the like, for detecting a forthcoming request for authentication for the first user device 102. In some embodiments, the identity server may receive a user input indicative of the forthcoming request that may or may not further indicate an offline condition of the computing device 106. By way of example, the first user associated with the first user device 102 may input plans to travel to or otherwise interact with the computing device 106 at a time in the future. By way of a particular example, the first user may indicate that the first user plans to travel to a vacation property associated with the computing device 106 in the future. In such an embodiment, the identity server 200 may detect a forthcoming request for authentication between the first user device 102 and the computing device 106 (e.g., when the first user arrives at the vacation property). In some embodiments, the user input from the first user may also indicate an offline condition of the computing device 106 at the first time. By way of example, the first user may be aware that the computing device 106 is offline from a prior attempt to communicate with the computing device 106.
In some example embodiments, the detection of the forthcoming request for authentication at operation 302 may include obtaining one or more user parameters associated with the first user and detecting the forthcoming request based upon the one or more user parameters. As defined above, the first user device and associated first user may, in some embodiments, be associated with a first user profile storing one or more user parameters of the first user. The first user profile may include data entries associated with or indicative of the location of the first user (e.g., location data), transactions of the first user (e.g., financial or transaction data), user preferences, user accounts, user correspondences, user social media data, and/or the like. As operation 302, the identity server may obtain one or more user parameters and determine the forthcoming request for authentication based upon the user parameters. For example, the user profile may include data entries indicative of the current location of the first user device 102. In such an example, the identity server may determine that the first user device 102 is in close proximity to the computing device 106 (e.g., based upon one or more threshold comparisons or the like) and determine (e.g., predict or the like) a forthcoming request for authentication by the first user device due to this location data. By way of an additional example, the identity server 200 may be associated with a financial institution such that the identity server 200 may access financial transaction data of the first user. In such an example, the identity server 200 may analyze the financial transactions of the first user to determine an forthcoming request for authentication (e.g., a plane ticket to the location of the computing device 106, transactions with entities located in close proximity the computing device 106, transactions associated with access type (e.g., towels for a pool location) of the computing device 106, and/or the like). Although described herein with reference to transaction data and/or location data, the present disclosure contemplates that any type of user parameters or data may be analyzed in order to detect a forthcoming request for authentication at operation 302.
Turning back to operation 306, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for determining a prior online condition of the computing device at a second time that is earlier in time than the first time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time. As described above, the computing device 106 may, at a second time that is earlier in time than the first time (e.g., prior to the time at which network connectivity is absent), be communicably coupled with the digital identity construct database 110 and/or identity server 200 so as to receive user attributes and associated authentication credentials therefrom. Said differently, prior to the first time, the computing device 106 may at least once have access to the digital identity construct database 110 to retrieve user attributes so as to obtain user authentication credentials in light of the same. As such, at operation 306, the identity server 200 may obtain second authentication credentials that are based upon at least one previously acquired iteration of the at least one static attribute of the first authentication credentials and/or at least one previously acquired iteration of the at least one dynamic attribute of the first authentication credentials.
As described above, the digital identity construct database 110 may store any feature, data entry, element, data object, etc. associated with the first user without limitation so as to form a substantially complete digital representation of the user's identity. The second time may also refer to the time at which the user features and/or authentication credentials stored by the digital identity construct database 110 are accessible (e.g., due to network connectivity) by the computing device 106. Said differently, the computing device 106 may, via network 104, transmit data to and receive data from the digital identity construct database 110 so as to receive user attributes (e.g., at least one static and/or at least one dynamic attribute) from the digital identity construct database 110 at the second time.
The user attributes used in generating the second authentication credentials may, for example, be determined based upon the identity server 200. By way of example, the password for the first user to access the access location associated with the computing device 106 may be based upon the first user's first home address (e.g., a static attribute) and the user's current hair length (e.g., a dynamic attribute). At the second time (e.g., a time at which network connectivity exists for the computing device 106), in some embodiments, the computing device 106 may query the digital identity construct database 110 and retrieve the first user's home address and the user's current hair length (e.g., current as of the second time). The digital identity construct database 110 and/or identity server 200 may generate second authentication credentials based upon the at least one static attribute and/or the at least one dynamic attribute determined for the first user. Although described hereinafter with reference to a static user attribute of a user's first home address and a dynamic attribute of a user's current hair length, the present disclosure contemplates that any user attribute of any number or type may be used at operation 306 based upon the intended application of the identity server 200 and/or the sensing devices of the user device 102 or the computing device 106.
In instances in which the user attribute (e.g., static or dynamic) is associated with a location (e.g., global positioning system (GPS) coordinates or the like), a date (e.g., birthdate, date of first car purchase, etc.) or numerical biometric feature (e.g., weight, height, etc.) or the like, the generation of the portion of the second authentication credentials for this attribute may refer to the numerical value associated with the attribute. In other embodiments in which the user attribute is not associated with a numerical value (e.g., a user's hair color, type of car owned, city of current location, etc.), the digital identity construct database 110 and/or the identity server 200 may employ one or more hash functions, randomization functions, binarizing operations, or other techniques configured to convert non-numerical elements into associated numerical values. The digital identity construct database 110 and/or the identity server 200 may, for example, perform any mathematical transformation based on the numerical values of the determined attributes. For example, the mathematical operation, in some embodiments, may comprise a multiplication of the value associated with the determined static attribute with the value associated with the determined dynamic attribute.
The present disclosure contemplates that any number of mathematical operations and combinations of mathematical operations (e.g., multiplication, addition, subtraction, division, exponential functions, logarithmic functions, etc.) may be used to generate the second authentication credentials referenced at operation 306 such that the generated second authentication credentials are of near-infinite scope and degree. Furthermore, the present disclosure contemplates that the numerical values obtained from the static attribute and the dynamic attribute (e.g., or a plurality of the same) may, based upon the size of these numerical values, operate to increase the assurance associated with the second authentication credentials. For example, increasing the number of selected attributes and/or the values of these attributes (e.g., GPS coordinates or the like) operates to substantially increase the complexity of the generated second authentication credentials.
In some example embodiments, the user attributes used to generate the second authentication credentials may be randomly or pseudo-randomly selected for each interaction with the identity server 200, such as instances in which the identity server 200 accesses a plurality of static attributes and a plurality of dynamic attributes. The selection of user attributes (e.g., at least one static and/or at least one dynamic attribute) may include implementing a random or pseudo-random selection protocol that identifies at least one static attribute and at least one dynamic attribute. By way of example, in some embodiments, once a dynamic or static attribute is selected, a selection frequency for each user attribute may be monitored such that the likelihood that an unselected attribute is selected on subsequent determinations is increased until the unselected attributed is used. Although an example frequency calculation procedure is described herein, the present disclosure contemplates that any pseudo-random number generation algorithm (e.g., a middle-square method, mersenne twister, inversive congruential generator, lagged Fibonacci generator, linear feedback shift register or the like) may additionally or alternatively be used to pseudo-randomly determine the at least one static attribute and the at least one dynamic attribute without departing from the scope of the disclosure.
Thereafter, as shown in operation 308, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for obtaining, at the first time, first authentication credentials associated with the first user. The first authentication credentials may be based upon a current iteration of the at least one static attribute used in generating the second authentication credentials and/or at least one current iteration of the at least one dynamic attribute of the second authentication credentials from the digital identity construct database. At the first time and the second time, the first user device 102 may have access to the digital identity construct database 110 and/or the identity server 200 so as to receive current user attributes for the first user (e.g., attribute that reflect the current condition, location, etc. of the first user). As such, the first time may refer to the time at which a request for authentication is received such that the first time refers to a current or up-to-date version of the digital identity construct database 110 for the first user. Said differently, the first user device 102 may, via network 104, transmit data to and receive data from the digital identity construct database 110 such that the user attributes (e.g., at least one static and at least one dynamic attribute) received by the first user device 102 from the digital identity construct database 110 are similarly current or up-to-date.
The user attributes used in generating the first authentication credentials may, for example, be determined based upon the identity server 200 but may include those selected in generating the second authentication credentials. By way of example, the password for the first user to access the access location associated with the computing device 106 may be based upon the first user's first home address (e.g., a static attribute) and the user's current hair length (e.g., a dynamic attribute) as described above. At the first time (e.g., substantially current or real time associated with the request or any such time that the computing device 106 lacks network connectivity), in some embodiments, the first user device 102 may query the digital identity construct database 110 and retrieve the first user's home address and the user's current hair length. In other embodiments, the first user device 102 may, for example, request that the first user input one or more user attributes, such as a request that the user input his or her first home address. Additionally or alternatively, the first user device 102 may, via one or more sensing devices or sensors, capture images of the first user (e.g., via a camera of the first user device 102) and determine one or more user attributes of the first user (e.g., image processing to determine the first user's current hair length). The digital identity construct database 110 and/or the identity server 200 may generate first authentication credentials based upon the at least one static attribute and the at least one dynamic attribute determined for the first user. Although described hereinafter with reference to a static user attribute of a user's first home address and a dynamic attribute of a user's current hair length, the present disclosure contemplates that any user attribute of any number or type may be used at operation 308 based upon the intended application of the identity server 200, the sensing devices of the user device 102, and/or the user attributes used in generating the second authentication credentials as described above.
Similar to operation 306, in instances in which the user attribute (e.g., static or dynamic) is associated with a location (e.g., global positioning system (GPS) coordinates or the like), a date (e.g., birthdate, date of first car purchase, etc.) or numerical biometric feature (e.g., weight, height, etc.) or the like, the generation of the first authentication credentials for this attribute may refer to the numerical value associated with the attribute. In other embodiments in which the user attribute is not associated with a numerical value (e.g., a user's hair color, type of car owned, city of current location, etc.), the identity server 200 may employ one or more hash functions, randomization functions, binarizing operations, or other techniques configured to convert non-numerical elements into associated numerical values. In the generation of the first authentication credential, the identity server 200 may, for example, perform any mathematical transformation based on the numerical values of the previous iterations of the user attributes. For example, the mathematical operation, in some embodiments, may comprise a multiplication of the value associated with the current iteration of the static attribute with the value associated with the current iteration of the dynamic attribute.
Thereafter, as shown in operation 310, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for determining a discrepancy between the first authentication credentials and the second authentication credentials for the first user. As described above with reference to operation 302, the computing device 106 may lack network connectivity or be otherwise unable to access the digital identity construct database 110 (e.g., an offline condition of the computing device 106) such that the second authentication credentials are based upon user attributes of the first user from a second time (e.g., prior in time to the first time). As such, the identity server 200 may compare the second authentication credentials with the first authentication credentials and determine a discrepancy in an instance in which the first authentication credentials are not identical or substantially the same as the second authentication credentials. Said differently, the identity server 200 may determine that the user attributes from the second time used by the identity server 200 in generating the second authentication credentials (e.g., out-of-date user attributes) differ from the user attributes used in generating the first authentication credentials at the first time (e.g., current user attributes). By way of continued example, a dynamic attribute (e.g., the current length of the first user's hair) may have changed during the time period elapsed between the second time and the first time.
Thereafter, as shown in operation 312, the apparatus (e.g., identity server 200) includes means, such as processor 202, communications circuitry 208, or the like, for generating an authentication token based upon the second authentication credentials for authenticating a first user device 102 associated with the first user with the computing device 106. In response to determining the discrepancy at operation 310, the identity server 200 may determine that the second authentication credentials (e.g., the current credentials with respect to the user attributes accessible to the computing device 106) do not account for the change associated with a dynamic user attribute of the first user (i.e., the second authentication credentials are not up-to-date), and, therefore, will not properly authenticate the first user device 102 and the first user with the computing device 106. As such, the identity server 200 may generate an authentication token based upon the second authentication credentials (e.g., out-of-date attributes with respect to the first time but current to the computing device 106) so as to proactively provide an authentication mechanism for the first user device 102. The authentication token may include any access token, data object, storage device, or the like configured to allow for authentication of the first user with the computing device 106. Said differently, the identity server 200 may operate to monitor the offline condition (e.g., monitored connectivity) associated with a plurality of computing devices that may periodically receive user attributes from the digital identity construct database 110 and determine the status of the user attributes received by these respective computing devices. This status may refer to the version of the digital identity construct database 110 used by the respective computing devices in generating authentication credentials. In this way, the identity server 200 may dynamically generate authentication tokens for use by the user device 102 to access a plurality of computing devices without additional effort on the part of the user.
In some embodiments, the apparatus (e.g., identity server 200) includes means, such as processor 202, communications circuitry 208, or the like, for transmitting the authentication token to the first user device. By way of continued example, the identity server 200 may detect a forthcoming request for authentication as described above with reference to optional operation 302 that includes a planned trip to a remote location with poor network coverage associated with the computing device 106. The transmission of the authentication token to the first user device 102, for example, prior to traveling to the remote location may further operate to prevent the first user device 102 from experiencing the same network connectivity difficulties associated with the computing device 106.
In some embodiments, the apparatus (e.g., identity server 200) includes means, such as processor 202, communications circuitry 208, or the like, for providing access to the access location in response to authenticating the first user. As described above, the computing device 106 may be associated with an access location (e.g., door, gate, etc.) or otherwise be configured to authenticate a user and subsequently provide access to the location based upon this authentication. By way of continued example, the computing device 106 may be associated with a remote location that lacks consistent network connectivity (e.g., vacation property, rental property, or the like). In response to the operations of
Turning next to
As shown in operation 402, the apparatus (e.g., identity server 200) includes means, such as input/output circuitry 206, communications circuitry 208, processor 202, or the like, for generating a transmission to the computing device 106 comprising at least one user attribute from the digital identity construct database 110. As described above, the identity server 200 may receive a request for user attributes from the computing device 106 when network connectivity is present. Additionally or alternatively, the identity server 200 may periodically attempt to transmit current user attributes to the computing device 106. In order to attempt to authenticate users with the computing device 106, the identity server 200 may generate a transmission that includes at least one user attribute from the digital identity construct database 110 at the first time (e.g., current attributes). The transmission of, for example, updated credentials and user attributes, may include a transmission of one or more user attributes (e.g., all user attributes, only dynamic user attributes, etc.) from the digital identity construct database 110 at the first time (e.g., an attempt to transmit current user attributes from the digital identity construct 110 by the computing device 106).
Thereafter, as shown in operation 404, the apparatus (e.g., identity server 200) includes means, such as input/output circuitry 206, communications circuitry 208, processor 202, or the like, for attempting to transmit the transmission to the computing device 106. Given that the computing device 106 may only have intermittent network access, the identity server 200 may, at the first time, be unable to transmit the transmission of updated credentials or user attributes to the computing device 106. Thereafter, as shown in operation 406, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for determining the offline condition in an instance in which a transmission failure is determined. In instances in which the transmission generated at operation 402 is attempted to be provided by the identity server 200, the transmission failure may, for example, occur after the expiration of a determined amount of time. Additionally or alternatively, the transmission failure may occur, for example, in an instance in which the identity server 200 fails to receive a responsive communication from the computing device 106. In some instances, periodic or iterative transmissions may occur before an offline condition is determined (e.g., a minimum number of transmission failures during a time period).
Turning next to
As shown in operation 502, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for determining a periodic offline condition of a computing device at a first time. As described above, the identity server 200 may periodically transmit user attributes or updated credentials to the computing device 106. Additionally or alternatively, the computing device 106 may periodically request user attributes or updated credentials from the identity server 200 and/or the digital identity construct database 110. In instances in which transmission failure occurs as described with reference to
As shown in operation 504, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for determining an online condition of the computing device at a second time that is later in time than the first time. As described above, the computing device 106 may be subject to intermittent network connectivity such that at a second time that is later in time than the first time of operation 502, the computing device 106 is able to transmit to and receive data from the identity server 200. Once this connectivity is established, the operations of
Thereafter, as shown in operation 506, the apparatus (e.g., identity server 200) includes means, such as processor 202 or the like, for generating first authentication credentials based upon one or more static user attributes obtained from a digital identity construct database associated with a first user at the first or the second time and, as shown in operation 508, authenticating a first user device associated with the first user based upon the first authentication credentials. By way of continued example, the identity server 200 may determine that the lack of consistent network access by the computing device 106 prevents the computing device 106 from reliably leveraging dynamic user attributes for authentication. As such, at operations 506 and 508, the identity server may limit the use of static attributes by the computing device 106 for authentication of the first user and first user device 102. The first authentication credentials at operation 506 may be generated as described above with reference to
With reference to
The example digital identity construct database 600 may include a plurality of user attribute (e.g., entity attribute) entries 606, 608, 610 associated with a first attribute, a second attribute, . . . , and an Nth attribute. The first attribute entry 606 may include an associated timestamp indicative of the time at which the first attribute was received by the digital identity construct database 600. In some embodiments, this timestamp may instead refer to the time at which the first attribute entry 606 was generated. The first attribute entry 606 may further include an associated assurance or weight associated with the first attribute entry 606. As described above, the assurance may refer to a confidence associated with the first attribute entry 606. Similarly, the second first attribute entry 608 and the Nth attribute entry 610 may include an associated timestamp indicative of the time at which the second attribute and the Nth attribute, respectively, were received by the digital identity construct database 600. As above, in some embodiments, this timestamp may instead refer to the time at which the second attribute entry 608 and Nth attribute entry 610, respectively, were generated. The second attribute entry 608 and the Nth attribute entry may further include an associated assurance or weight associated with the second attribute entry 608 and the Nth attribute entry 610, respectively. As described above, the present disclosure contemplates that the example digital identity construct database 600 may include any number of user attributes without limitation. Furthermore, the timestamp value for various attribute entries may vary (e.g., a current version of the database 600 may have today's date but one application entry may have a timestamp that is a week/a month old). Each request for authentication may accept or reject attribute entries based upon, for example, the timestamp and/or assurance associated with each attribute entry.
As described above, various technical challenges are surmounted via technical solutions contemplated herein. For example, the embodiments described herein may operate to provide a mechanism for proactive offline authentication based upon evolving user attributes. Said differently, embodiments described herein may detect an offline condition of a local device (e.g., a computing device of the present disclosure) with which a user and associated user device will attempt to interact and authenticate this user in the absence of network connectivity (e.g., when updated authentication credentials are unavailable to the computing device). In particular, this authentication and subsequently authorization may occur proactively in that a remote server (e.g., an identity server of the present disclosure) proactively (e.g., prior to an interaction between the computing device and the user device) determines that the computing device is incapable or receiving updated or otherwise current authentication credentials (e.g., an offline condition). These new proactive offline authentication techniques may further modify user attribute selection based upon detect network connectivity. For example, in instances in which networking connectivity is absent, authentication credentials of the user may be modified to require only static attributes of the user (e.g., attributes that have not changed since connectivity by the computing device and the remote server existed).
The flowchart blocks support combinations of means for performing the specified functions and combinations of operations for performing the specified functions. It will be understood that one or more blocks of the flowcharts, and combinations of blocks in the flowcharts, can be implemented by special purpose hardware-based computer systems which perform the specified functions, or combinations of special purpose hardware with computer instructions.
CONCLUSIONMany modifications and other embodiments of the disclosure set forth herein will come to mind to one skilled in the art to which these embodiments pertain having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the embodiments are 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. Moreover, although the foregoing descriptions and the associated drawings describe example embodiments in the context of certain example combinations of elements and/or functions, it should be appreciated that different combinations of elements and/or functions may be provided by alternative embodiments without departing from the scope of the appended claims. In this regard, for example, different combinations of elements and/or functions than those explicitly described above are also contemplated as may be set forth in some 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.
Claims
1. A computer-implemented method for proactive offline authentication, the computer-implemented method comprising:
- detecting, by an identity server, a forthcoming request for authentication for the first user device;
- subsequent to detecting the forthcoming request, determining, by the identity server, a current offline condition of a computing device at a first time;
- determining, by the identity server, a prior online condition of the computing device that existed at a second time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time, wherein the second time is earlier in time than the first time, wherein the one or more user attributes comprise at least: one static attribute, wherein static attributes comprises attributes of the first user that remain constant over time; and/or one dynamic attribute, wherein dynamic attributes comprises attributes of the first user that vary over time;
- obtaining, by the identity server, at the first time, first authentication credentials associated with the first user, wherein the first authentication credentials are based upon a current iteration of the at least one static attribute used in generating the second authentication credentials and/or at least one current iteration of the at least one dynamic attribute of the second authentication credentials from the digital identity construct database;
- determining, by the identity server, a discrepancy between the first authentication credentials and the second authentication credentials; and
- generating, by the identity server, an authentication token based upon the second authentication credentials for authenticating a first user device associated with the first user with the computing device.
2. The computer-implemented method according to claim 1, wherein detecting the forthcoming request further comprises receiving, by the identity server, a user input indicative of the forthcoming request.
3. The computer-implemented method according to claim 1, wherein detecting the forthcoming request further comprises:
- obtaining, by the identity server, one or more user parameters associated with the first user; and
- detecting, by the identity server, the forthcoming request based upon the one or more user parameters.
4. The computer-implemented method according to claim 1, further comprising transmitting, by the identity server, the authentication token to the first user device.
5. The computer-implemented method according to claim 1, wherein determining the current offline condition of the computing device further comprises:
- generating, by the identity server, a transmission to the computing device comprising at least one user attribute from the digital identity construct database;
- attempting, by the identity server, to transmit the transmission to the computing device; and
- determining, by the identity server, the offline condition in an instance in which a transmission failure is determined.
6. The computer-implemented method according to claim 1, wherein the computing device is associated with an access location, the method further comprising causing access to be provided to the access location for the first user device based upon the authentication token.
7. The computer-implemented method according to claim 1 further comprising, determining, by the identity server, the current offline condition of the computing device based on a count of one or more transmission failures during a period of time.
8. An identity server for proactive offline authentication comprising at least one processor and at least one memory, the at least one memory having computer-code instructions stored thereon that, with when executed by the at least one processor, configure the identity server to:
- detect a forthcoming request for authentication for the first user device;
- subsequent to detecting the forthcoming request, determine a current offline condition of a computing device at a first time;
- determine a prior online condition of the computing device that existed at a second time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time, wherein the second time is earlier in time than the first time, wherein the one or more user attributes comprise at least: one static attribute, wherein static attributes comprises attributes of the first user that remain constant over time; and/or one dynamic attribute, wherein dynamic attributes comprises attributes of the first user that vary over time;
- obtain at the first time, first authentication credentials associated with the first user, wherein the first authentication credentials are based upon a current iteration of the at least one static attribute used in generating the second authentication credentials and/or at least one current iteration of the at least one dynamic attribute of the second authentication credentials from the digital identity construct database;
- determine a discrepancy between the first authentication credentials and the second authentication credentials; and
- generate an authentication token based upon the second authentication credentials for authenticating a first user device associated with the first user with the computing device.
9. The identity server according to claim 8, wherein the computer-code instructions, when executed by the at least one processor, configure the identity server to detect the forthcoming request by receiving a user input indicative of the forthcoming request.
10. The identity server according to claim 8, wherein the computer-code instructions, when executed by the at least one processor, configure the identity server to detect the forthcoming request by:
- obtaining one or more user parameters associated with the first user; and
- detecting the forthcoming request based upon the one or more user parameters.
11. The identity server according to claim 8, wherein the computer-code instructions, when executed by the at least one processor, configure the identity server transmit the authentication token to the first user device.
12. The identity server according to claim 8, wherein the computer-code instructions, when executed by the at least one processor, configure the identity server to determining the current offline condition of the computing device by:
- generating a transmission to the computing device comprising at least one user attribute from the digital identity construct database;
- attempting to transmit the transmission to the computing device; and
- determining the offline condition in an instance in which a transmission failure is determined.
13. The identity server according to claim 8, wherein the computing device is associated with an access location, and the computer-code instructions, when executed by the at least one processor, configure the identity server to cause access to be provided to the access location for the first user device based upon the authentication token.
14. The identity server according to claim 8, wherein the computer-code instructions, when executed by the at least one processor, configure the identity server to determine the current offline condition of the computing device based on a count of one or more transmission failures during a period of time.
15. A computer program product for proactive offline authentication comprising at least one non-transitory computer-readable storage medium having computer program code thereon that, when executed by at least one processor, configures an identity server to:
- detect a forthcoming request for authentication for the first user device;
- subsequent to detecting the forthcoming request, determine a current offline condition of a computing device at a first time;
- determine a prior online condition of the computing device that existed at a second time at which the computing device generated second authentication credentials based upon one or more user attributes obtained from a digital identity construct database associated with a first user at the second time, wherein the second time is earlier in time than the first time wherein the one or more user attributes comprise at least: one static attribute, wherein static attributes comprises attributes of the first user that remain constant over time; and/or one dynamic attribute, wherein dynamic attributes comprises attributes of the first user that vary over time;
- obtain at the first time, first authentication credentials associated with the first user, wherein the first authentication credentials are based upon a current iteration of the at least one static attribute used in generating the second authentication credentials and/or at least one current iteration of the at least one dynamic attribute of the second authentication credentials from the digital identity construct database;
- determine a discrepancy between the first authentication credentials and the second authentication credentials; and
- generate an authentication token based upon the second authentication credentials for authenticating a first user device associated with the first user with the computing.
16. The computer program product according to claim 15, wherein the computer program code, when executed by at least one processor, configures the identity server to detect the forthcoming request by receiving a user input indicative of the forthcoming request.
17. The computer program product according to claim 15 wherein the computer program code, when executed by at least one processor, configures the identity server to detect the forthcoming request by:
- obtaining, by the identity server, one or more user parameters associated with the first user; and
- detecting, by the identity server, the forthcoming request based upon the one or more user parameters.
18. The computer program product according to claim 15 wherein the computer program code, when executed by at least one processor, configures the identity server to determine the current offline condition of the computing device by:
- generating a transmission to the computing device comprising at least one user attribute from the digital identity construct database;
- attempting to transmit the transmission to the computing device; and
- determining the offline condition in an instance in which a transmission failure is determined.
19. The computer program product according to claim 15, wherein the computing device is associated with an access location, wherein the computer program code, when executed by at least one processor, further configures the identity server to cause access to be provided to the access location for the first user device based upon the authentication token.
20. The computer program product according to claim 15, wherein the computer program code, when executed by at least one processor, further configures the identity server to transmit the authentication token to the first user device.
7724924 | May 25, 2010 | Didier et al. |
8689294 | April 1, 2014 | Thakur |
9665832 | May 30, 2017 | Thieberger et al. |
10572641 | February 25, 2020 | Griffin et al. |
10681025 | June 9, 2020 | O'Regan et al. |
10958641 | March 23, 2021 | Burmester et al. |
11048794 | June 29, 2021 | Bordow |
20090164796 | June 25, 2009 | Peirce |
20100174914 | July 8, 2010 | Shafir |
20130227677 | August 29, 2013 | Pal |
20170111335 | April 20, 2017 | Hibbert |
20210021601 | January 21, 2021 | Valecha et al. |
20210036856 | February 4, 2021 | Wang |
Type: Grant
Filed: Aug 17, 2021
Date of Patent: Apr 2, 2024
Assignee: Wells Fargo Bank, N.A. (San Francisco, CA)
Inventors: Peter Bordow (Fountain Hills, AZ), Jeff J. Stapleton (O'Fallon, MO), Ramesh Yarlagadda (Charlotte, NC)
Primary Examiner: Jacob Lipman
Application Number: 17/404,674