1. Field
Example aspects described herein relate generally to mobile wallets in mobile communication devices for use in mobile commerce, and more particularly to systems, methods, and computer program products for managing access control for mobile communication devices that utilize secure elements.
2. Related Art
Mobile communication devices (also referred to herein as mobile devices) are becoming more and more versatile, and are being used in an increasing number of ways to make various everyday tasks simpler and/or more efficient. One area in which mobile devices are being used is mobile commerce. For example, mobile devices are being made to include mobile wallets, which may be used to conduct financial transactions (e.g., payments) and/or non-financial transactions (e.g., venue admissions), without the need for physical cash, checks, credit cards, tickets, and/or the like. In order to safeguard sensitive information (e.g., payment account information) that mobile wallets utilize in conducting such transactions, some mobile devices are made to include, and/or are communicatively coupled to, a secure element that stores such sensitive information.
Controlling access to the secure element is necessary for both security and business reasons. To this end, conventional access control specifications (e.g., Global Platform Access Control (GPAC), for example as described in Global Platform Device Technology—Secure Element Access Control, Version 1.0, Document Reference GPE_SPE_013, May 2012, 86 pages); Gemalto Access Control (GAC); and Public-Key Cryptography Standard No. 15 (PKCS15), each of which is hereby incorporated by reference herein in its entirety, typically require access control rules (also referred to herein as simply “access rules”) to be stored on the secure element.
In general, each access rule in a set of access rules stored on the secure element indicates whether a particular application stored on the mobile device is permitted to access a particular applet stored on the secure element. Any given one of the access rules may correspond to one or more of the applications stored on the mobile device and one or more of the applets stored on the secure element.
Some access control specifications permit the access rules stored in the secure element to be updated (e.g., added, modified, or deleted), for example, by way of a wireless communication protocol, such as an over-the-air (OTA) communication protocol. The secure element also stores a refresh tag (e.g., a flag, a date, a time, and/or another type of temporal indicator) that includes a value that indicates when any of the access rules stored on the secure element was most recently updated. Each time any of the access rules stored on the secure element is updated in the secure element, the value of the refresh tag in the secure element is updated as well.
In some cases, an enforcer module (also referred to herein as “enforcer”) residing on the mobile device retrieves from the secure element, and stores, the set of access rules. According to some access control specifications, the enforcer is required to periodically poll the refresh tag to determine whether any of the access rules stored in the secure element has been updated since the last time the enforcer retrieved the access rules from the secure element. In addition to periodic polling, the enforcer polls the refresh tag of the secure element each time access control is to be enforced (e.g., upon receiving a request for access to information and/or performance of an action that is protected by the rules, such as a request to open a secure communication channel using an application or applet stored on the secure element). If, upon polling the refresh tag, the enforcer determines that one or more pertinent access control rules has been updated since the most recent polling, then the enforcer retrieves from the secure element an updated set of access rules (or a subset of the updated set of access rules), and updates a local set of rules stored on the mobile communication device so as to be consistent with the rules stored in the secure element. One example of such a polling scheme may be found in GlobalPlatform Device Technology—Secure Element Access Control, Version 1.0, Document Reference GPE_SPE_013, Section 5—Remote Interface Based on RAM, May 2012, 86 pages), the entire contents of which are hereby incorporated by reference herein.
In one example, in order to enable the enforcer to determine whether any of the access rules stored in the secure element has been updated since the last time the enforcer retrieved the access rules from the secure element, each time the enforcer retrieves from the secure element, and stores, the access rules, the enforcer also retrieves from the secure element, and stores, the refresh tag that includes a value that indicates when the set of access rules stored on the secure element was most recently updated. In this way, the enforcer may determine whether any of the access rules stored in the secure element has been updated since the last time the enforcer retrieved the access rules from the secure element, by comparing the value of the refresh tag stored in the secure element to the value of the refresh tag stored by the enforcer.
If the value of the refresh tag stored in the secure element matches the value of the refresh tag stored by the enforcer, then that would indicate that the access rules stored by the enforcer are up-to-date; that is, that none of the access rules stored in the secure element has been updated since the last time the enforcer retrieved the access rules from the secure element. If, on the other hand, the value of the refresh tag stored in the secure element does not match the value of the refresh tag stored by the enforcer, then that would indicate that the access rules stored by the enforcer are not up-to-date; that is, that one or more of the access rules stored in the secure element has been updated since the last time the enforcer retrieved the access rules from the secure element. In this case, the enforcer would retrieve from the secure element, and store, the updated set of access rules and the updated value of the refresh tag.
One drawback, however, to polling schemes such as the scheme described above, is that they can result in an inefficient utilization of computing resources, such as the utilization of processor power, processor time, memory, communication channels, and the like. For instance, when no updates have been made to the access rules, polling the refresh tag periodically would needlessly render a processor of the mobile communication device busy.
Likewise, when no updates have been made to the access rules, polling the refresh tag upon receiving a request for information and/or an action protected by the rules would needlessly render the processor busy, and would also negatively impact the user's experience by delaying the granting of the request until after the polling has been completed.
Moreover, even when an update has been made to the access rules, polling the refresh tag upon receiving a request for information and/or an action protected by the rules would negatively impact the user's experience by delaying the granting of the request until after both the polling of the refresh tag and the updating of the local access rules have been completed.
Given the foregoing, it would be beneficial to enable access rules to be updated and enforced in an efficient manner that improves both the user's experience and the utilization of computing resources.
The example embodiments herein provide systems, methods, and computer program products for managing access control.
In accordance with one example aspect herein, a first set of access control rules is stored in a memory of mobile communication device. The mobile communication device receives from a trusted server over a communication network a notification message indicating that an access control rule has been updated in a secure element. In response to receiving the notification message, the mobile communication device retrieves from the secure element a second set of access control rules including at least the access control rule that has been updated. The first set of access control rules is updated based on the second set of access control rules retrieved from the secure element. An applet stored on the secure element is accessed via an application running on the mobile communication device, in accordance with the updated first set of access control rules.
In another example embodiment, the notification message is pushed to the mobile communication device each time the trusted server transmits an update message to the secure element to cause at least one access control rule of the second set of access control rules to be updated.
In one example herein, the trusted server pushes the notification message to the mobile communication device by way of a notification server.
In accordance with some example aspects herein, a plurality of applets stored on the secure element are accessed, in succession, without performing a polling process of a refresh tag of the secure element in between each accessing.
In another example herein, the mobile communication device includes the secure element.
A request to access the applet is communicated, in one example, and the retrieving of the second set of access control rules from the secure element is performed before the communicating of the request to access the applet.
The access control rule that has been updated indicates whether the application has permission to access the applet stored on the secure element, in accordance with another example herein.
The features and advantages of the example embodiments presented herein will become more apparent from the detailed description set forth below when taken in conjunction with the following drawings.
I. Overview
The terms “payment product” and “card” may be used interchangeably herein to refer to a product, such as, for example, a credit card, a general purpose reloadable (GPR) card, and/or the like, that may be used to conduct financial transactions.
The term “service provider data” as used herein generally refers to data relating to one or more service providers, service provider systems, and/or services provided by one or more service providers. In some example embodiments herein, service provider data refers to any data associated with a service provider that is stored in a wallet database and/or in a wallet client database.
The terms “access control rule” and “access rule” may be used interchangeably herein to refer to a rule that governs access to information stored on a secure element. For example, an access rule may indicate which applications installed on a mobile communication device are permitted to access which applications, applets, and/or other information stored on a secure element coupled to or installed in the mobile communication device. One example set of access rules that may be stored on a secure element and/or by an enforcer, and/or by another component of a mobile device is provided below in Table 1.
Each of the example access rules shown in Table 1 indicate whether a particular mobile device application (e.g., as identified by a corresponding hash value) is allowed or disallowed to access a particular applet (e.g., as identified by an application identifier (AID)) stored on the secure element.
Another example set of access rules that may be stored on a secure element and/or by an enforcer, and/or by another component of a mobile device is provided below in Table 2.
The example access rules shown in Table 2 indicate conditions (e.g., whether an application is signed with a particular certificate) based upon which access to one or more (or all) applets stored on the secure element is allowed or disallowed.
Presented herein are novel and inventive systems, methods, and computer program products for managing access control. In accordance with some aspects described herein, systems, methods, and computer program products are provided that enable access rules to be updated and enforced in an efficient manner that improves both the user's experience and the utilization of computing resources (e.g., the utilization of processor power, processor time, memory, communication channels, and the like).
Unlike existing approaches to managing access control, which employ an inefficient polling scheme whereby, for example, a refresh tag associated with access rules is periodically polled, irrespective of whether any updates have been made to the access rules, in accordance with the example aspects described herein, a triggers scheme is provided such that updates to access rules need only be retrieved upon the access rules having been updated.
Also, the example aspects described herein, unlike existing approaches, avoid the need to poll the refresh tag upon receiving a request for information and/or an action protected by the access rules. The user's experience is thus improved since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed.
II. System
The mobile device 101 may be a cellular phone, a tablet computer, or another type of electronic device with connectivity to one or more mobile networks. As will be described in further detail below in connection with
The mobile device 101 is communicatively coupled to the TSM 103 by way of the network 102. The network 102 may be a mobile phone cellular network, a radio network, a WI-FI network, and/or another type of network. In some example embodiments, the network 102 is operated by a corresponding mobile network operator (MNO) (not shown in
The TSM 103 is a module, implemented in hardware and/or software, that functions as an intermediary between entities (e.g., service provider systems 105, mobile wallets 106, secure elements 107, etc.) in a mobile commerce environment. In one example embodiment herein, the TSM 103 represents a central TSM managed by a mobile wallet provider (e.g., a provider of the mobile wallet 106). The TSM 103, for example, manages communications between entities, such as the SP systems 105 and the mobile device 101 (e.g., the mobile wallet 106, the secure element 107, and/or any other component of the mobile device 101), and also provides interfaces for communication with other computer systems. The TSM 103 communicates with the mobile device 101 via the network 102 using security protocols such as, for example, a GlobalPlatform secure channel protocol, secure sockets layer (SSL), transport layer security (TLS), and/or another security protocol.
The TSM 103 also provisions applets, such as contactless applets associated with the service provider systems 105, to the mobile device 101 for use by the mobile wallet 106, for example. The TSM 103 remotely distributes and remotely manages (e.g., by updating access rules for the applets) the contactless applets by communicating with the secure element 107.
As will be described in further detail below in connection with
The notification server 108 may be communicatively coupled to the mobile device 101 by way of the network 102, which, as described above, may be a mobile phone cellular network, a radio network, a WI-FI network, and/or another type of network. In some example embodiments, the notification server 108 is communicatively coupled to the mobile device 101 by way of an additional network (e.g., a mobile phone cellular network, a radio network, a WI-FI network, and/or another type of network; not shown in
In one example embodiment, the TSM 103 manages communications between the mobile wallet 106 and one of the SP systems 105 in order to request and obtain data for use in a mobile financial or non-financial transaction. For example, the TSM 103 provides access rules to the secure element 107 by way of the network 102, the access rules indicating which applications (e.g., the mobile wallet 106) installed on the mobile device 101 have permission to access which information (e.g., applets) stored on the secure element 107. The TSM 103 may provide the access rules upon an initial installation of a corresponding application on the mobile device 101, and/or may provide updates to the access rules after the corresponding application has been installed on the mobile device 101. The updates to the access rules may be initiated by the TSM 103, by the SP systems 105, by the mobile device 101, and/or by any other entity (e.g., an entity not shown in
The TSM 103 is communicatively coupled to the SP systems 105 by way of the network 104. The network 104 may be a virtual private network (VPN), a network using Hypertext Transfer Protocol (HTTP) standards, the Internet, and/or another type of network.
The SP systems 105, in some example embodiments, are systems owned, operated, maintained, and/or provided by service providers to enable customers or consumers to utilize one or more services of the service provider.
Having described the example system 100 for managing access control, reference will now be made to
The mobile device 101 also includes a processor 201, a memory 202, an enforcer 203, and locally stored (e.g., stored locally in one or more memories of the mobile device 101) access rules 204. It should be understood that, although not shown in
In general, the processor 201 executes instructions that may be stored in the memory 202, the mobile wallet 106, the enforcer 203, the secure element 107, and/or in any other component of the mobile device 101, to enable the mobile device 101 to perform certain functions. The memory 202 may also store data that is generated and/or used by the processor 201 in executing such instructions.
The mobile wallet 106 is an interactive application stored in a non-transitory memory of the mobile device 101. In one example embodiment, the mobile wallet 106 includes instructions that, when executed by the processor 201, enable the mobile communication device 101 to (1) access information or utilize one or more services provided by the service provider systems 105, (2) communicate with the service provider systems 105, and/or (3) interact with contactless services and/or control the operation of contactless hardware of the mobile device 101, for example, to conduct contactless transactions and/or process commerce information such as offer and/or loyalty information.
The mobile wallet 106 also includes instructions which, when executed by the processor 201, cause the mobile device 101 to act as an instrument for processing transactions such as financial transactions, in one example. The mobile wallet 106 provides an interface for receiving inputs and displaying outputs. The mobile wallet 106 communicates with the secure element 107 and applets 206 (described below) stored on the secure element 107, using commands transmitted via application programming interfaces (APIs) (not shown in
In one example, the mobile wallet 106 stores data (e.g., an account number corresponding to an account provided by the service provider for use via the mobile wallet, and/or any other type of data associated with the mobile wallet and/or with a service provider) that the mobile wallet 106 utilizes to perform certain functions. For instance, the mobile wallet 106 may store applet data regarding one or more applet(s) (e.g., the applets 206 described below) that the mobile wallet 106 uses to access and/or interact with the applets 206.
The secure element 107 is a platform onto which service account information and corresponding applications may be added, stored, personalized, and managed. The secure element 107 includes hardware and software, and implements interfaces and protocols that enable the secure storage of data, such as credentials, service account information, and applications (also referred to herein as “applets”) that may be used for conducting financial and/or non-financial transactions. In one example, the applets may correspond to a service (e.g., payment, commerce, ticketing) offered by a service provider (e.g., a service provider associated with one of the SP systems 105).
The secure element 107 may be implemented in different form factors, such as, for example, a Universal Integrated Circuit Card (UICC), an embedded secure element, and/or a separate chip or secure device (e.g., a near-field communication (NFC) enabler) that can be inserted into a slot on the mobile device 101. In one example embodiment, the mobile wallet 106 communicates with the secure element 107 using ISO 7816 commands, in order to conduct contactless transactions. The secure element 107 also stores security-critical applets, such as those involving payment and account credentials, which require secure hardware storage and a secure execution environment.
The secure element 107 includes secure element access rules 205 and one or more applets 206-1, 206-2, 206-n (collectively “206”). In one example embodiment, the one or more applets 206-1, 206-2, 206-n are associated with respective ones of the SP systems 105-1, 105-2 . . . 105-n described above in connection with
The applets 206 may include instructions that, when executed by the processor 201, enable a user of the mobile device 101 to communicate with, and/or utilize one or more services provided by, the corresponding service provider. For example, an applet 206 provided by a payment product issuer, may enable the user to check a balance of the user's account, view transaction history and/or other notifications regarding the user's account, and/or the like.
The enforcer 203 is a module, implemented in hardware and/or software, that enforces access rules that govern which applications installed on the mobile device 101 are permitted to access which information (e.g., applets 206) stored on the secure element 107. In some example embodiments herein, the enforcer 203 utilizes the memory 202 of the mobile device 101 and/or utilizes a separate memory included in the enforcer 203 (not shown in
III. Procedure
Having described an example system 100 for managing access control, reference will now be made to
At step 301, the enforcer 203 locally (e.g., in a memory local to the mobile device 101) stores an initial version of the access rules 204, which, in one example, are received (not shown in
At step 302, the TSM 103 communicates an update to one or more access rules 205 stored on the secure element 107. The update may be triggered by a service provider system 105, the TSM 103 itself, by an administrator computer (not shown in the Figures) coupled to the TSM 103, and/or by another system. The update may include, for example, new credentials, a new payment account number, and/or the like to be used in connection with any of the applets 206.
Upon receiving the update from the TSM 103 at block 302, the updated access rules 205 are stored in the secure element 107.
Once the access rules are successfully updated, the TSM 103 communicates, at step 303, a notification message to the enforcer 203, indicating that at least one of the access rules has been updated.
In one example embodiment, the enforcer 203 is configured such that the receipt of the notification message communicated at step 303 triggers the enforcer 203 to retrieve, at step 304, the updated access rules 205 from the secure element 107. By virtue of this trigger, the enforcer 203 may avoid the need to poll the refresh tag of the secure element 107 (whether periodically and/or upon receiving a request to access information on the secure element 107) to determine whether the access rules are up-to-date. That is, in accordance with this example embodiment, no polling of the refresh tag is required unless and until a notification message is received by the enforcer 203 indicating that the access rules have been updated. In this way, processing resources may be more efficiently utilized and network traffic may be decreased, since unnecessary polling messages may be discontinued.
At step 305, the enforcer 203 updates the locally stored access rules 204 based on the updated access rules 205 retrieved from the secure element 107 at step 304.
At step 306, the enforcer 203 receives a request for access to an applet 206 stored on the secure element 107. The request for access to the applet 206 may, in one example, be triggered by a request from a user to access a payment product associated with the applet 206 (e.g., an applet 206 associated with one of the SP systems 105) and provided via the mobile wallet 106.
At step 307, the enforcer 203 retrieves, from the locally stored access rules 204, one or more access rules that are associated with the applet 206 to which access was requested at step 306.
At step 308, the enforcer 203 grants or denies access to the applet 206 (stored in the secure element 107) that was requested at step 306, in accordance with the one or more corresponding access rules retrieved at step 307 from the locally stored access rules 204. Since no polling of the refresh tag is required upon receiving at step 306 the request for access, the user experience may be improved, since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed.
At step 309, the enforcer 203 receives a subsequent request for access to an applet 206 stored on the secure element 107. The applet 206 to which access is requested at step 309 may be the same as or different from the applet 206 to which access was requested at step 306.
At step 310, the enforcer 203 retrieves, from the locally stored access rules 204, one or more access rules that are associated with the applet 206 to which access was requested at step 309.
At step 311, the enforcer 203 grants or denies access to the applet 206 (stored in the secure element 107) that was requested at step 309, in accordance with the one or more corresponding access rules retrieved at step 308 from the locally stored access rules. Again, since no polling of the refresh tag is required upon receiving at step 309 the request for access, the user experience may be improved, since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed. Additionally, since no polling of the refresh tag need be performed in between successively received requests for access to applets, processing resources may be more efficiently utilized.
Having described a first example procedure 300 for managing access control, reference will now be made to
As will be apparent from the description below, one difference between the example procedure 300 described above and the example procedure 400 described below is that the procedure 400 employs an optional notification server 108. In one example embodiment, the notification server 108 provides the TSM 103 with communication protocol flexibility. For instance, the TSM 103 may push notifications to the mobile device 101 by using WI-FI, 3G, 4G LTE, the Short Message Service (SMS) protocol, or any other suitable communication protocol. In one example, the TSM 103 may utilize the notification server 108 to push notifications to the mobile device 101 by using a communication protocol that is different from the communication protocol(s) available by way of the network 102.
At step 401, the enforcer 203 locally stores an initial version of the access rules 204, which, in one example, are received (not shown in
At step 402, the TSM 103 communicates an update to one or more access rules 205 stored on the secure element 107. The update may be triggered by a service provider system 105, the TSM 103 itself, by an administrator computer (not shown in the Figures) coupled to the TSM 103, and/or by another system. The update may include, for example, new credentials, a new payment account number, and/or the like to be used in connection with any of the applets 206.
Upon receiving the update from the TSM 103 at block 402, the updated access rules 205 are stored in the secure element 107.
At step 403, upon successfully updating the access rules 205 stored in the secure element 107, the TSM 103 communicates to the notification server 108 a request that the notification server 108 push a notification message to the enforcer 203 to indicate that the access rules 205 have been successfully updated.
Upon receiving at step 403 the request from the TSM 103, the notification server 108 communicates, at step 404, a notification message to the enforcer 203, indicating that at least one of the access rules has been updated.
In one example embodiment, the enforcer 203 is configured such that the receipt of the notification message communicated at step 404 triggers the enforcer 203 to retrieve, at step 405, the updated access rules 205 from the secure element 107. By virtue of this trigger, the enforcer 203 may avoid the need to poll the refresh tag of the secure element 107 (whether periodically and/or upon receiving a request to access information on the secure element 107) to determine whether the access rules are up-to-date. That is, in accordance with this example embodiment, no polling of the refresh tag is required unless and until a notification message is received by the enforcer 203 indicating that the access rules have been updated. In this way, processing resources may be more efficiently utilized and network traffic may be decreased, since unnecessary polling messages may be discontinued.
At step 406, the enforcer 203 updates the locally stored access rules 204 based on the updated access rules 205 retrieved from the secure element 107 at step 304.
At step 407, the enforcer 203 receives a request for access to an applet 206 stored on the secure element 107. The request for access to the applet 206 may, in one example, be triggered by a request from a user to access a payment product associated with the applet 206 (e.g., an applet 206 associated with one of the SP systems 105) and provided via the mobile wallet 106.
At step 408, the enforcer 203 retrieves, from the locally stored access rules 204, one or more access rules that are associated with the applet 206 to which access was requested at step 407.
At step 409, the enforcer 203 grants or denies access to the applet 206 (stored in the secure element 107) that was requested at step 407, in accordance with the one or more corresponding access rules retrieved at step 408 from the locally stored access rules 204. Since no polling of the refresh tag is required upon receiving at step 407 the request for access, the user experience may be improved, since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed.
At step 410, the enforcer 203 receives a subsequent request for access to an applet 206 stored on the secure element 107. The applet 206 to which access is requested at step 410 may be the same as or different from the applet 206 to which access was requested at step 407.
At step 411, the enforcer 203 retrieves, from the locally stored access rules 204, one or more access rules that are associated with the applet 206 to which access was requested at step 410.
At step 412, the enforcer 203 grants or denies access to the applet 206 (stored in the secure element 107) that was requested at step 410, in accordance with the one or more corresponding access rules retrieved at step 411 from the locally stored access rules. Again, since no polling of the refresh tag is required upon receiving at step 410 the request for access, the user experience may be improved, since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed. Additionally, since no polling of the refresh tag need be performed in between successively received requests for access to applets, processing resources may be more efficiently utilized.
IV. Example Computer-Readable Medium Implementations
The example embodiments described above, such as, for example, the systems and procedures depicted in or discussed in connection with
The computer 500 may include without limitation a processor device 510, a main memory 525, and an interconnect bus 505. The processor device 510 may include without limitation a single microprocessor, or may include a plurality of microprocessors for configuring the computer 500 as a multi-processor system. The main memory 525 stores, among other things, instructions and/or data for execution by the processor device 510. The main memory 525 may include banks of dynamic random access memory (DRAM), as well as cache memory.
The computer 500 may further include a mass storage device 530, peripheral device(s) 540, portable storage medium device(s) 550, input control device(s) 580, a graphics subsystem 560, and/or an output display 570. For explanatory purposes, all components in the computer 500 are shown in
The portable storage medium device 550 operates in conjunction with a nonvolatile portable storage medium, such as, for example, a compact disc read only memory (CD-ROM), to input and output data and code to and from the computer 500. In some embodiments, the software for storing an internal identifier in metadata may be stored on a portable storage medium, and may be inputted into the computer 500 via the portable storage medium device 550. The peripheral device(s) 540 may include any type of computer support device, such as, for example, an input/output (I/O) interface configured to add additional functionality to the computer 500. For example, the peripheral device(s) 540 may include a network interface card for interfacing the computer 500 with a network 520.
The input control device(s) 580 provide a portion of the user interface for a user of the computer 500. The input control device(s) 580 may include a keypad and/or a cursor control device. The keypad may be configured for inputting alphanumeric characters and/or other key information. The cursor control device may include, for example, a mouse, a trackball, a stylus, and/or cursor direction keys. In order to display textual and graphical information, the computer 500 may include the graphics subsystem 560 and the output display 570. The output display 570 may include a cathode ray tube (CRT) display and/or a liquid crystal display (LCD). The graphics subsystem 560 receives textual and graphical information, and processes the information for output to the output display 570.
Each component of the computer 500 may represent a broad category of a computer component of a general and/or special purpose computer. Components of the computer 500 are not limited to the specific implementations provided here.
Portions of the example embodiments of the invention may be conveniently implemented by using a conventional general-purpose computer, a specialized digital computer and/or a microprocessor programmed according to the teachings of the present disclosure, as is apparent to those skilled in the computer art. Appropriate software coding may readily be prepared by skilled programmers based on the teachings of the present disclosure.
Some embodiments may also be implemented by the preparation of application-specific integrated circuits, field programmable gate arrays, or by interconnecting an appropriate network of conventional component circuits.
Some embodiments include a computer program product. The computer program product may be a storage medium or media having instructions stored thereon or therein which can be used to control, or cause, a computer to perform any of the procedures of the example embodiments of the invention. The storage medium may include without limitation a floppy disk, a mini disk, an optical disc, a Blu-Ray Disc, a DVD, a CD-ROM, a micro-drive, a magneto-optical disk, a ROM, a RAM, an EPROM, an EEPROM, a DRAM, a VRAM, a flash memory, a flash card, a magnetic card, an optical card, nanosystems, a molecular memory integrated circuit, a RAID, remote data storage/archive/warehousing, and/or any other type of device suitable for storing instructions and/or data.
Stored on any one of the computer readable medium or media, some implementations include software for controlling both the hardware of the general and/or special computer or microprocessor, and for enabling the computer or microprocessor to interact with a human user or other mechanism utilizing the results of the example embodiments of the invention. Such software may include without limitation device drivers, operating systems, and user applications. Ultimately, such computer readable media further includes software for performing example aspects of the invention, as described above.
Included in the programming and/or software of the general and/or special purpose computer or microprocessor are software modules for implementing the procedures described above.
As can be appreciated in view of the foregoing description, the example aspects herein provide a system, method, and computer-readable medium for managing access control that enable access rules to be updated and enforced in an efficient manner that improves both the user's experience and the utilization of computing resources (e.g., the utilization of processor power, processor time, memory, communication channels, and the like).
Unlike existing approaches to managing access control, which employ an inefficient polling scheme whereby, for example, a refresh tag associated with access rules is periodically polled, irrespective of whether any updates have been made to the access rules, in accordance with the example aspects described herein, updates to access rules are retrieved only upon the rules having been updated.
Also, the example aspects described herein, unlike existing approaches, avoid the need to poll the refresh tag upon receiving a request for information and/or an action protected by the access rules. The user's experience is thus improved since the granting of the request need not be delayed until after both the polling of the refresh tag and the updating of the local access rules have been completed.
While various example embodiments of the invention have been described above, it should be understood that they have been presented by way of example, and not limitation. It is apparent to persons skilled in the relevant art(s) that various changes in form and detail can be made therein. Thus, the invention should not be limited by any of the above described example embodiments, but should be defined only in accordance with the following claims and their equivalents.
In addition, it should be understood that the figures are presented for example purposes only. The architecture of the example embodiments presented herein is sufficiently flexible and configurable, such that it may be utilized and navigated in ways other than that shown in the accompanying figures.
Further, the purpose of the Abstract is to enable the U.S. Patent and Trademark Office and the public generally, and especially the scientists, engineers and practitioners in the art who are not familiar with patent or legal terms or phraseology, to determine quickly from a cursory inspection the nature and essence of the technical disclosure of the application. The Abstract is not intended to be limiting as to the scope of the example embodiments presented herein in any way. It is also to be understood that the procedures recited in the claims need not be performed in the order presented.
The present application claims priority to U.S. Provisional Application No. 61/805,410, filed on Mar. 26, 2013, the entire contents of which are hereby incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5590038 | Pitroda | Dec 1996 | A |
5640002 | Ruppert et al. | Jun 1997 | A |
5748740 | Curry et al. | May 1998 | A |
5805702 | Curry et al. | Sep 1998 | A |
5884271 | Pitroda | Mar 1999 | A |
5901303 | Chew | May 1999 | A |
5940510 | Curry et al. | Aug 1999 | A |
5949880 | Curry et al. | Sep 1999 | A |
6073840 | Marion | Jun 2000 | A |
6105013 | Curry et al. | Aug 2000 | A |
6116505 | Withrow | Sep 2000 | A |
6131811 | Gangi | Oct 2000 | A |
6237095 | Curry et al. | May 2001 | B1 |
6422464 | Terranova | Jul 2002 | B1 |
6587835 | Treyz et al. | Jul 2003 | B1 |
6601759 | Fife et al. | Aug 2003 | B2 |
6671358 | Sossaman et al. | Dec 2003 | B1 |
6732081 | Nicholson | May 2004 | B2 |
6769607 | Pitroda et al. | Aug 2004 | B1 |
6813609 | Wilson | Nov 2004 | B2 |
6837436 | Swartz et al. | Jan 2005 | B2 |
6925439 | Pitroda | Aug 2005 | B1 |
7083094 | Cooper | Aug 2006 | B2 |
7110792 | Rosenberg | Sep 2006 | B2 |
7127236 | Khan et al. | Oct 2006 | B2 |
7155405 | Petrovich | Dec 2006 | B2 |
7194422 | Killick | Mar 2007 | B1 |
7216109 | Donner | May 2007 | B1 |
7249112 | Berardi et al. | Jul 2007 | B2 |
7286818 | Rosenberg | Oct 2007 | B2 |
7298271 | Sprogis | Nov 2007 | B2 |
7308426 | Pitroda | Dec 2007 | B1 |
7330714 | Rosenberg | Feb 2008 | B2 |
7349885 | Gangi | Mar 2008 | B2 |
7469151 | Khan et al. | Dec 2008 | B2 |
7469381 | Ording | Dec 2008 | B2 |
7483858 | Foran et al. | Jan 2009 | B2 |
7494055 | Fernandes et al. | Feb 2009 | B2 |
7529563 | Pitroda | May 2009 | B1 |
7571139 | Giordano et al. | Aug 2009 | B1 |
7581678 | Narendra et al. | Sep 2009 | B2 |
7613628 | Ariff et al. | Nov 2009 | B2 |
7631810 | Liu et al. | Dec 2009 | B2 |
7693752 | Jaramillo | Apr 2010 | B2 |
7708198 | Gangi | May 2010 | B2 |
7712658 | Gangi | May 2010 | B2 |
7775430 | Lin | Aug 2010 | B2 |
7805615 | Narendra et al. | Sep 2010 | B2 |
7828214 | Narendra et al. | Nov 2010 | B2 |
7856377 | Cohagan et al. | Dec 2010 | B2 |
7864163 | Ording et al. | Jan 2011 | B2 |
7942337 | Jain | May 2011 | B2 |
7954715 | Narendra et al. | Jun 2011 | B2 |
7954716 | Narendra et al. | Jun 2011 | B2 |
7954717 | Narendra et al. | Jun 2011 | B2 |
7961101 | Narendra et al. | Jun 2011 | B2 |
7967215 | Kumar et al. | Jun 2011 | B2 |
7991158 | Narendra et al. | Aug 2011 | B2 |
8072331 | Narendra et al. | Dec 2011 | B2 |
8083145 | Narendra et al. | Dec 2011 | B2 |
8091786 | Narendra et al. | Jan 2012 | B2 |
8131645 | Lin et al. | Mar 2012 | B2 |
8140418 | Casey et al. | Mar 2012 | B1 |
8196131 | von Behren et al. | Jun 2012 | B1 |
8297520 | Wakerly | Oct 2012 | B1 |
8396808 | Greenspan | Mar 2013 | B2 |
8429046 | Pitroda | Apr 2013 | B2 |
8555067 | Schell et al. | Oct 2013 | B2 |
8646059 | von Behren et al. | Feb 2014 | B1 |
9027102 | Katzer | May 2015 | B2 |
9226143 | Kulkarni | Dec 2015 | B2 |
20020049631 | Williams | Apr 2002 | A1 |
20020082921 | Rankin | Jun 2002 | A1 |
20020174025 | Hind et al. | Nov 2002 | A1 |
20020179703 | Allen | Dec 2002 | A1 |
20030009382 | D'Arbeloff et al. | Jan 2003 | A1 |
20030083042 | Abuhamdeh | May 2003 | A1 |
20030115126 | Pitroda | Jun 2003 | A1 |
20030132298 | Swartz et al. | Jul 2003 | A1 |
20030200489 | Hars | Oct 2003 | A1 |
20040073519 | Fast | Apr 2004 | A1 |
20040186768 | Wakim et al. | Sep 2004 | A1 |
20050004866 | Bonalle et al. | Jan 2005 | A1 |
20050171898 | Bishop et al. | Aug 2005 | A1 |
20050222961 | Staib et al. | Oct 2005 | A1 |
20050234769 | Jain et al. | Oct 2005 | A1 |
20050247777 | Pitroda | Nov 2005 | A1 |
20060287004 | Fuqua | Dec 2006 | A1 |
20070014407 | Narendra et al. | Jan 2007 | A1 |
20070014408 | Narendra et al. | Jan 2007 | A1 |
20070198432 | Pitroda et al. | Aug 2007 | A1 |
20070207777 | Owen et al. | Sep 2007 | A1 |
20080306849 | Johnson, Jr. et al. | Dec 2008 | A1 |
20090108064 | Fernandes et al. | Apr 2009 | A1 |
20090164322 | Khan et al. | Jun 2009 | A1 |
20090221266 | Ohta et al. | Sep 2009 | A1 |
20090265471 | Li et al. | Oct 2009 | A1 |
20100190437 | Buhot | Jul 2010 | A1 |
20100207742 | Buhot et al. | Aug 2010 | A1 |
20100241494 | Kumar et al. | Sep 2010 | A1 |
20110073663 | Narendra et al. | Mar 2011 | A1 |
20110171996 | Narendra et al. | Jul 2011 | A1 |
20110223972 | Narendra et al. | Sep 2011 | A1 |
20110231238 | Khan et al. | Sep 2011 | A1 |
20110244796 | Khan et al. | Oct 2011 | A1 |
20110269438 | Narendra et al. | Nov 2011 | A1 |
20110271044 | Narendra et al. | Nov 2011 | A1 |
20110272468 | Narendra et al. | Nov 2011 | A1 |
20110272469 | Narendra et al. | Nov 2011 | A1 |
20110302310 | Diachina et al. | Dec 2011 | A1 |
20120036563 | Glasgow et al. | Feb 2012 | A1 |
20120064828 | Khan et al. | Mar 2012 | A1 |
20120109764 | Martin et al. | May 2012 | A1 |
20120238206 | Singh | Sep 2012 | A1 |
20120246119 | Haudenschild et al. | Sep 2012 | A1 |
20120266220 | Brudnicki et al. | Oct 2012 | A1 |
20120323664 | Klems | Dec 2012 | A1 |
20130060959 | Taveau | Mar 2013 | A1 |
20130086669 | Sondhi et al. | Apr 2013 | A1 |
20130102246 | Gagne | Apr 2013 | A1 |
20130174266 | Smrz | Jul 2013 | A1 |
20130268437 | Desai | Oct 2013 | A1 |
20130332343 | Desai | Dec 2013 | A1 |
20130339232 | Desai | Dec 2013 | A1 |
20140020068 | Desai et al. | Jan 2014 | A1 |
20140031024 | Xie et al. | Jan 2014 | A1 |
20140058937 | Watson | Feb 2014 | A1 |
20140089113 | Desai | Mar 2014 | A1 |
20140129430 | Desai | May 2014 | A1 |
20140129437 | Desai | May 2014 | A1 |
20140129438 | Desai | May 2014 | A1 |
20140130035 | Desai | May 2014 | A1 |
20140143826 | Sharp et al. | May 2014 | A1 |
20140189880 | Funk | Jul 2014 | A1 |
20140228001 | Kulkarni | Aug 2014 | A1 |
20140256251 | Caceres | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
2 381 614 | Mar 2001 | CA |
1 222 503 | Jul 2002 | EP |
0 766 852 | Aug 2004 | EP |
1 412 890 | Nov 2004 | EP |
1 477 943 | Nov 2004 | EP |
10-2011-0125698 | Nov 2011 | KR |
WO 0118629 | Mar 2001 | WO |
WO 03012717 | Feb 2003 | WO |
2014160715 | Oct 2014 | WO |
Entry |
---|
Fiorin, Leandro; Palermo, Gianluca; Lukovic, Slobodan; Catalano, Valerio; Silvano, Cristina; “Secure Memory Accesses on Networks-on-Chip”, IEEE Transactions on Computers, vol. 57, Issue 9, Jun. 10, 2008, pp. 1216-1229. |
Eun, Hasoo; Lee, Hoonjung; Oh, Heekuck; “Conditional Privacy Preserving Security Protocol for NFC Applications”, IEEE Transactions on Consumer Electronics, vol. 59, Issue 1, Feb. 2013, pp. 153-160. |
Benyo, B.; Sodor, B.; Kovacs, L.; Homlok, J.; Fordos, G.; “Security issues of service installation on a multi application NFC environment”, IEEE 14th International Conference on Intelligent Engineering Systems, May 5-7, 2010, pp. 145-149. |
Int'l Search Report and Written Opinion issued in connection with Int'l Appl'n No. PCT/US2014/031737 on Jul. 10, 2014 (7 pages). |
GlobalPlatform Inc., “GlobalPlatform Device Technology—Secure Element Access Control”, Version 1.0, Document Reference: GPE—SPE—013, May 2012 (86 pages). |
Wittmann-Regis, “International Preliminary Report on Patentability issued in International Application No. PCT/US2014/031737”, mailed on Oct. 8, 2015, 10 pages. |
Number | Date | Country | |
---|---|---|---|
20140298484 A1 | Oct 2014 | US |
Number | Date | Country | |
---|---|---|---|
61805410 | Mar 2013 | US |