Any and all applications for which a foreign or domestic priority claim is identified in the Application Data Sheet as filed with the present application are hereby incorporated by reference in their entirety under 37 CFR 1.57.
A large organization (e.g., a corporation, a governmental organization) can include large numbers of employees spread across large numbers of departments, with each employee associated with a user account that can access one or more networks maintained by the organization. In a sensitive environment in which a portion of the employees may have access to private, or otherwise sensitive, data, the organization can desire to audit the behavior of its employees with respect to the data. In general, the organization can maintain records and copies of electronic reports generated by employees, and determine access to the private, or sensitive, data based on an analysis of the electronic reports.
A described system can access logs generated by network accessible systems, and determine objects (e.g., documents, presentations, e-mails, and so on) that have been interacted with (e.g., exported, imported, viewed, printed, e-mailed) by users of one or more networks associated with the network accessible systems. The system can determine, from large quantities of logs, summary information regarding objects and users, including the most frequently interacted with objects, and users that most frequently interacted with objects. In this way, the system can provide insights into otherwise incomprehensible log data generated in the normal course of the network accessible systems execution.
Due to the complexity of user interactions with objects stored on networks, an organization that maintains the networks can have tremendous difficulty determining which users accessed particular objects, which objects were accessed by particular users, and recreating the workflow history of a particular user or object. This can be a severe problem when the organization, or an auditing organization, desires to determine whether objects have been accessed in a proper, or otherwise reasonable manner or whether users have been accessing objects in a proper, or otherwise reasonable manner, and to ensure that private, or otherwise sensitive, data is treated in a manner that comports with the organization's practices. As an example, a governmental entity can have access to objects (e.g., electronic records) describing private details of citizens. An auditing organization (e.g., a governmental reviewing, or auditing, group within the governmental entity) can have a need to ensure that the objects are being accessed for specific approved purposes. Lacking in methods to accomplish this, the public's faith in the governmental entity to maintain objects can be substantially reduced.
The system described below can correlate large quantities of logs, and visualize the log data to allow for a reviewing user (e.g., the governmental reviewing group) to quickly ascertain information related to objects or users. As will be described, the system can generate user interfaces that allow for previously impossible looks into log data spread across network accessible systems. As an example, a reviewing user can quickly cycle through generated user interfaces to recreate a workflow of a particular user (e.g., determine which objects were accessed by the particular user, determine search queries entered by the particular user to locate objects, and determine frequencies of the user's access of each object). In this way, the reviewing user can ensure that the particular user is following best or proper practices.
As another example, a reviewing user can quickly ascertain which objects are frequently being accessed (e.g., accessed above a threshold), and which objects are rarely being accessed (e.g., accessed below a threshold). The reviewing user can then take particular actions, such as relocating commonly accessed objects to faster storage, or spreading the commonly accessed objects across multiple network accessible systems for duplication purposes, or to make the objects physically closer to clusters of users that have a need to access them. Additionally, the reviewing user can determine that the less commonly accessed objects can be relocated to slower storage (e.g., cold storage), or removed from storage entirely. Furthermore, the reviewing user can determine that objects of a particular type (e.g., document, event, e-mail), or that describe a particular subject matter, are rarely accessed, and determine that future objects of the same type or subject matter should be automatically moved to slower storage. In this way, the described system can decrease processing time, access time to objects by users, and make better use of storage and network accessible systems.
It has been noted that design of computer user interfaces “that are useable and easily learned by humans is a non-trivial problem for software developers.” (Dillon, A. (2003) User Interface Design. MacMillan Encyclopedia of Cognitive Science, Vol. 4, London: MacMillan, 453-458.) The present disclosure describes various embodiments of interactive and dynamic user interfaces that are the result of significant development. This non-trivial development has resulted in the user interfaces described herein which may provide significant cognitive and ergonomic efficiencies and advantages over previous systems. The interactive and dynamic user interfaces include improved human-computer interactions that may provide reduced mental workloads, improved decision-making, reduced work stress, and/or the like, for a user. For example, user interaction with the interactive user interface via the inputs described herein may provide an optimized display of, and interaction with, graph data, image data, and/or other data, and may enable a user to more quickly and accurately access, navigate, assess, and digest the data than previous systems.
Further, the interactive and dynamic user interfaces described herein are enabled by innovations in efficient interactions between the user interfaces and underlying systems and components. For example, disclosed herein are improved methods of receiving user inputs (including methods of interacting with, and selecting, images, graphs, and other types of data), translation and delivery of those inputs to various system components, automatic and dynamic execution of complex processes in response to the input delivery, automatic interaction among various components and processes of the system, and automatic and dynamic updating of the user interfaces (to, for example, display the relevant data from various different applications and/or data sources). The interactions and presentation of data via the interactive user interfaces described herein may accordingly provide cognitive and ergonomic efficiencies and advantages over previous systems.
Various embodiments of the present disclosure provide improvements to various technologies and technological fields. For example, existing data aggregation and analysis technology is limited in various ways (e.g., limited in the types of applications or data sources the data may be drawn from, loss of data interactivity, etc.), and various embodiments of the disclosure provide significant improvements over such technology. Additionally, various embodiments of the present disclosure are inextricably tied to computer technology. In particular, various embodiments rely on detection of user inputs via graphical user interfaces, aggregation of data from different applications and data sources, and automatic processing, formatting, and display of the aggregated data via interactive graphical user interfaces. Such features and others (e.g., automatically determining an application or data source an inputted link is directed to, accessing the application or data source to retrieve and display the requested data, implementing interactivity of displayed data reflective of how the data would be displayed in its native application) are intimately tied to, and enabled by, computer technology, and would not exist except for computer technology. For example, the interactions with displayed data described below in reference to various embodiments cannot reasonably be performed by humans alone, without the computer technology upon which they are implemented. Further, the implementation of the various embodiments of the present disclosure via computer technology enables many of the advantages described herein, including more efficient interaction with, and presentation of, various types of electronic data.
Particular embodiments of the subject matter described in this specification can be implemented so as to realize one or more of the following advantages. A system can generate user interfaces describing user actions of users of one or more networks, with the user actions associated with objects accessible through the networks, or describing actions on objects accessible through one or more networks, with the actions associated with users of the networks. Since the user actions and object actions are stored across large quantities of log files generated by network accessible systems, without the user interfaces and methods described below, a reviewing user would be unable to obtain important information related to objects or users. In some situations, this information may be time-sensitive (e.g., a reviewing user may have a need to quickly ascertain information buried across large quantities of logs), and without the user interfaces described below, the reviewing user would be unable to obtain information in a timely fashion.
In general, one innovative aspect of the subject matter described in this specification can be embodied in methods that include the actions of obtaining, from the electronic data sources, one or more logs generated by a plurality of network-accessible systems describing one or more user actions of one or more users, the user actions associated with one or more objects accessible over one or more networks associated with the network-accessible systems; determining, from the logs, one or more of the user actions associated with each user, wherein the one or more user actions associated with each user are associated with one or more of the objects; determining, from the logs, one or more of the user actions associated with each object; generating an interactive user interface for presentation on one or more user devices, wherein the interactive user interface: presents summary information, the summary information comprising identification of one or more of the users that have performed one or more of the user actions on greater than a first threshold number of the objects and identification of one or more of the objects that have had greater than a second threshold number of the user actions performed on each object; and presents, in response to receiving information specifying one or more of the identified users and/or objects, information associated with the one or more specified users and/or objects, wherein for the specified users, the interactive user interface presents: identification of one or more of the objects upon which the specified users have performed one or more of the user actions, each identification available for selection, and a timeline describing the one or more user actions of the specified users; and wherein for the specified objects, the interactive user interface presents: identification of one or more of the users that have performed one or more of the user actions on the specified objects, each identification available for selection, and a timeline describing the one or more user actions associated with the specified objects.
Additional embodiments of the disclosure are described below in reference to the appended claims, which may serve as an additional summary of the disclosure.
In various embodiments, computer systems are disclosed that comprise one or more hardware computer processors in communication with one or more non-transitory computer readable storage devices, wherein the one or more hardware computer processors are configured to execute the one or more of computer executable instructions in order to cause the computer system to perform operations comprising one or more aspects of the above-described embodiments (including one or more aspects of the appended claims).
In various embodiments, computer-implemented methods are disclosed in which, under control of one or more hardware computing devices configured with one or more specific computer executable instructions, one or more aspects of the above-described embodiments (including one or more aspects of the appended claims) are implemented and/or performed.
In various embodiments, non-transitory computer-readable storage mediums storing software instructions are disclosed, wherein, in response to execution by a computing system having one or more hardware processors, the software instructions configure the computing system to perform operations comprising one or more aspects of the above-described embodiments (including one or more aspects of the appended claims).
Further, as described herein, various embodiments of the system may be configured and/or designed to generate user interface data useable for rendering the various interactive user interfaces described. The user interface data may be used by the system, and/or another computer system, device, and/or software program (for example, a browser program), to render the interactive user interfaces. The interactive user interfaces may be displayed on, for example, electronic displays (including, for example, touch-enabled displays).
The details of one or more embodiments of the subject matter of this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
This specification describes one or more systems that can obtain logs generated by network accessible systems, and can generate user interfaces (e.g., for presentation to a reviewing user) describing information included in one or more of the logs. The information can include, for example, information describing particular objects accessible using one or more networks, and information describing particular users that have accessed objects, performed searches, or performed other actions using one or more networks.
In this specification, an object is any data which can be accessed, viewed, exported, imported, modified, created, copied, moved, transmitted, downloaded, uploaded, printed, or otherwise acted upon and can be associated with a type, such as a document, an e-mail, information describing a person (e.g., a person object), information describing an event (e.g., an event object), information describing a company, organization, or other entity, and so on. An object can be associated with particular properties (e.g., an attribute of the object associated with a value), and each object type can be associated with particular properties that can be distinct from properties associated with other object types. As an example, a property associated with a document type object can be Title, and a value of the property can be a Title associated with the document. The objects can thus represent an object-centric data model, wherein data (e.g., in the form of files) can be stored in objects and made accessible to users over one or more networks. In this way, a user can search for, and subsequently receive, particular objects that relate to his/her search request.
For a further discussion of objects, and an object-centric data model, this specification hereby incorporates by reference in its entirety, and for all purposes, U.S. patent application Ser. No. 14/875,536, titled “SEARCHES OF HIGHLY STRUCTURED DATA.”
As described above, the systems (hereinafter ‘the system’, which is described further below as the system 100), obtain logs generated by network accessible systems. Upon access (e.g., exporting, viewing, printing, modifying, e-mailing, and so on) of an object by a user, the network accessible system, or other network accessible system or user device, storing, or providing access to, the object can generate a log entry identifying at least the user accessing the object and the object being accessed. Thus, access to any object stored or otherwise maintained to be accessible to users of the networks, can be recorded for posterity and use (e.g., by a reviewing user as will be described). Furthermore, logs can record user actions, such as specific actions the users took with respect to objects (e.g., a download, a viewing, a printing, a modification, an e-mailing, and so on), and with respect to actions associated with identifying, or locating, objects (e.g., search queries entered into a search system, and so on).
The system (e.g., the system 100 described below) can generate user interfaces describing information included in one or more logs, and identify all log entries associated with a particular user or a particular object. To generate the user interfaces, the system can determine (e.g., as requests for user interfaces are received) summary information associated with particular users and/or objects, or the system can periodically determine summary information and store (e.g., cache) the information for later use. The system can maintain (e.g., in one or more databases) information associated with each user (e.g., such user's actions associated with objects) and/or each object (e.g., interactions by users with such object), and can determine summary information for a given time period. This summary information can be presented in interactive user interfaces (e.g., as described in
As will be described summary information can include tallies related to objects accessed by certain users, and tallies related to users that access certain objects. For instance, summary information can include a total amount of unique accesses to objects (e.g., a number of accesses to objects not including repeat accesses by the same user), identifications of one or more users and numbers of accesses to objects each user made, identifications of one or more objects and numbers of unique accesses to each object, and so on.
As described above, a system (e.g., the system 100 described below) can generate user interfaces describing summary information associated with users and objects. In the example user interface 10, trend information 12 is included providing the reviewing user a quick glance at summary information of users of network accessible systems and objects accessed by the users. While user interface 10 indicates “Trends from the Past Week” 12, the time period of “Past Week” can be modified by the reviewing user to update the time period from which trend information 12 is to be determined. In some implementations, the reviewing user can select the “Trends from the Past Week” 12, and the user interface 10 can be updated to provide a refinement of the time period (e.g., a user interface element can be presented that includes one or more options for a new time period, and/or the user interface element can receive a time entered by the reviewing user). In some implementations, the reviewing user can interact with a date range 14 specifying a time period of interest to the reviewing user, and if the time period of interest is less than a week, the trend information 12 can be updated to include trend information from a shorter time period (e.g., a time period encompassing the specified time period in the date range 14). Similarly, if the time period of interest is greater than a week, in some implementations, the trend information 12 can be updated to include trend information from a greater time period (e.g., the time period can be a month, a quarter, and so on).
As illustrated, the trend information 12 includes information describing unique object accesses 16 (e.g., in the time period indicated in the trend information 12, which as illustrated in the example of
The trend information 12 further includes information describing object imports 18, indicating a number of objects that were imported (e.g., uploaded to one or more network accessible systems for storage as identified in logs) during the time period indicated in the trend information 12. Similarly, the trend information further includes information describing object exports 20, indicating a number of objects that were exported by users (e.g., e-mailed, printed, downloaded) during the time period indicated in the trend information 12.
The trend information 12 further includes unique logins 22 by users, and indicates a number of users that logged into the system and may have interacted with objects (e.g., accessed objects, imported objects, searched for objects, and so on). In some implementations, the unique logins 22 can represent a total number of logins by all users.
The example user interface 10 includes a graphical representation 24 of activity during the date range 14, which as described above can be selected by the reviewing user, or automatically selected (e.g., to correspond to a prior week, quarter, year, and so on). The example graphical representation 24 is a chart mapping activity to specific time periods included in the date range 14. Activity in this specification includes any activity associated with objects performed by users, which can include searching for objects, accessing objects, importing objects, exporting objects, and so on.
The user interface 30 includes an indication of a number of unique objects viewed 34 by respective users. That is, the number of unique objects viewed 34 for a particular user (e.g., “User1”) indicates a number of objects accessed by the particular user one or more times (e.g., in the example of
The user interface 30 includes an indication of a number of unique objects exported by respective users. For instance, user “User1” exported 0 objects.
In addition, the user interface 30 includes an indication of the most recent login 38 of the user (e.g., a most recent time that an employee used his/her user account). In some implementations, the most recent login 38 can be the most recent login irrespective of the selected date range 14 (e.g., as illustrated, user “User1” was logged into on 2015 Sep. 2, which is later than the date range 14 ending 7 Aug. 2015). In some other implementations, the latest login 38 can indicate a latest login 38 up until the end of the selected date range 14.
The user interface 30 further includes an indication of a number of logs that were generated (e.g., by network accessible systems as will be described below) based on user interactions with the network accessible systems. As an example, user “User1” was included in 25,649 logs. As described above, a log can include information describing not only interactions associated with objects, but other interactions associated with the user including logins, interactions with network accessible systems (e.g., user access of a network accessible system, user searches, and so on). Therefore, each inclusion in a log does not necessarily mean that user “User1” accessed an object, indeed the user could have searched for objects but not interacted with any, or merely connected to a network accessible system. As another example, user “User2” was included in 2,191 logs, but did not access any objects.
Utilizing user interface 30, the reviewing user can quickly ascertain which users are active. The reviewing user can select a particular user, and receive an updated user interface with information specific to the selected user (e.g., as described below in
The objects are each associated with a title (e.g., a parameter associated with each object can be a title of the object), and the user interface 50 identifies a respective title 52 for each object. The user interface 50 further includes an “Object ID” 54 associated with each object, which can be a value generated by a system to uniquely identify the object (e.g., in some implementations the ID can be a hash of the object, such as an MD5 hash). In the example, adjacent to the “Object ID” 54 is a type of the object, which as described above in a non-exhaustive list can be a document, an e-mail, an event object (e.g., an object including information that describes an event), a person object (e.g., an object including information that describes a person), and so on.
The user interface 50 indicates a number of user interactions 58 with each object, indicating which objects are frequently accessed by any user. A review user can organize the presented objects according to number of user interactions 58, thus gaining an insight into the large quantities of objects being stored. Each object in the user interface 50 can be selected by the reviewing user, and upon selection the user interface 50 can be updated to present information associated with the selected object (e.g., as described below in
Since an organization may store large quantities of objects being actively imported, exported, viewed, modified, and so on, the user interface 50 includes a filter control 60 enabling the reviewing user to limit the objects presented. For instance, the filter control 60 enables the reviewing user to limit objects to objects that have been loaded by users, viewed by users, saved by users, exported by users, and imported by users. Upon selection of a particular filter option, the user interface 50 can update to include objects that match the filter option. That is, the system (e.g., the system 100 described below) can identify objects that match the selected filter option, and include identifications of the objects in the user interface 50.
The object user log correlation system 100 includes an object determination engine 110 that can access user action logs (e.g., user action logs A-N 102A-102N) specifying user interactions with network accessible systems, and determine user interactions associated with particular objects maintained by the network accessible systems, and user interactions of particular users that are associated with objects. For instance, the object determination engine 110 can access a log 124 generated by a network accessible system 120 (e.g., in response to user interactions 122 by a user 104), identify a nature of the user interaction (e.g., an object the user accessed, a search query entered by the user to identify objects, and so on), and identify the specific user 104 involved. The object determination engine 110 can then maintain information describing the user interaction of the specific user 104, for later retrieval when generating user interfaces describing summary data of the specific user 104, or objects interacted with by the specific user 104. In some implementations, the object determination engine 110 can index each generated log and maintain information for later searching by a reviewing user using the user device 140 (e.g., the object determination engine 110 can utilize Elasticsearch, and so on to provide search functionality for the reviewing user).
Additionally, the object log determination engine 110 can generate user interfaces 132 describing summary information (e.g., as illustrated in
The system obtains logs generated by network accessible systems that indicate user interactions associated with objects (block 302). As described above, users in an organization (e.g., a governmental organization or corporation), can be required to access objects (e.g., documents, e-mails, and so on) that are relevant to particular workflows being implemented by the users. For instance, a user can access objects related to a particular company, and view the related objects to generate reports in the course of their work that describe the particular company. When accessing objects, or tracking user interactions associated with objects (e.g., entering search queries to locate objects), network accessible systems that facilitate access to, or store, objects can generate logs describing all received user interactions. As described above (e.g., with reference to
The system determines user interactions by each user identified in the obtained logs (block 304). To determine summary information of each user, the system identifies, in the logs, user interactions of each user that are associated with objects. The system stores each user interaction along with an associated timestamp, generating a record of user interactions of each user.
Similarly, the system determines user interactions associated with each object (block 306). To determine summary information for each object, the system identifies, in the logs, user interactions associated with each object. The system stores each user interaction along with an associated time-stamp, generating a record of user interactions with each object.
The system generates user interfaces for presentation describing information included in the logs (block 308). As illustrated in
As an example, the system receives user input specifying a user or object (block 310). As will be described below, the reviewing user can initially receive and view an interactive user interface describing summary data (e.g., as described in
In some implementations, the system can automatically select a user or object for the reviewing user to review. As a particular example, and as will be described further below, the reviewing user can receive triggered information transmitted to his/her user device from the system (e.g., the user device can execute an application or other software in communication with the system for quickly receiving updates). The triggered information can include information describing that a user has exported greater than a threshold number of objects (e.g., greater than an average), and/or at a particular time not known to be associated with the user's working hours (e.g., exported a greater than average number of objects at 2 in the morning), or that a user has attempted to access an object to which such user should not have access, or that a user has attempted to access a sensitive object. The reviewing user can receive this time-sensitive triggered information (e.g., as a short description with a reference, such as a hyperlink, to a user interface generated by the system). The reviewing user can then view information associated with a user.
The system determines information associated with the specified user or object (block 312). As described above, the system maintains information associated with users and objects, including, for each user, user interactions associated with objects, and for each object, user interactions with the object. The system accesses the maintained information (e.g., the system can search one or more databases) and obtains relevant information for the reviewing user's specification.
The system generates a user interface for presentation (block 314). The system generates user interface data for presentation to the reviewing user that includes information associated with his/her specified user or object.
The information determined above in blocks 302 and 314 can be maintained as searchable data by the system, allowing the system to receive requests for particular information from the reviewing user, and quickly generate user interfaces including the requested information.
User Interfaces
User interfaces described in
Each of the user interfaces described below includes user selectable options, which upon selection, can cause the system to obtain associated information (e.g., from databases 102 A-N), determine updated information, and modify, or generate, user interface data.
In this specification, when reference is made to the system generating user interface data, it should be understood to mean that the system can generate data sufficient to cause a receiving device (e.g., user device) to be able to present the user interface (e.g., render the data, retrieve images and other visual elements for presentation, and so on). Additionally, in some implementations the system can provide data (e.g., summary data of users or objects) and the receiving device (e.g., user device) can access information describing user interfaces and present the received data in one or more of the user interfaces (e.g., the user device can execute an application that can receive data and present the data).
Additionally, users can be organized according to departments, office, building, team, group, employee role, or other useful category and summary information (e.g., as described in
After the reviewing user selects the particular user, the user interface 400 can be updated to include user information 404 associated with the particular user, such as a user name of the particular user (e.g., a name of an employee associated with the particular user), an account name of the particular user (e.g., a login name of the particular user), and an account ID associated with the particular user (e.g., a unique identifier specific to the particular user). The reviewing user can examine the user information 404 to determine whether the particular user is the user he/she wishes to review.
As described above, with reference to trend information 12 in
For instance, user activity 406 includes an identification of unique object accesses 408 (e.g., a number of unique objects accessed by the particular user). The unique object accesses 408 further identifies a percentage of all unique object accesses that were performed by the particular user, providing a quick summary of the activity of the particular user with respect to other users during the prior time period (e.g., the prior week). Additionally, the unique object accesses 408 indicates a delta (e.g., a difference) from the prior time period (e.g., the week before the prior week). In this way, the reviewing user can note any upticks or other changes in object access.
User activity 406 further includes indications of numbers of objects that have been imported 410, and exported 412, by the particular user. These indications can provide the reviewing user with information relevant to how active the particular user is with bringing in new information, or exporting information. Similar to the above, the object imports 410 and exports 412 include indications of a delta from the prior time period to the present time period, and percentages of all object imports, and exports, performed by the particular user.
User activity 406 includes a number of unique logins 414 by the particular user, which in the illustrated example is 4 unique logins. In some implementations, the user interface 400 can include information describing an average (e.g., central measure of tendency) of unique logins of the particular user for the time period, and/or an average of unique logins of all users, or users of a same, or similar, employee role or other user category as the particular user. The number of unique logins 414 further indicates a delta from a prior time period, and a percentage of all the unique logins performed by the particular user.
The objects 502 interacted with by the selected user are indicated in a list 508, which can be organized (e.g., in ascending or descending order) according to one or more metrics (e.g., date of last interaction 504, number of interactions 506, and so on). In the case of organizing by date of last interaction, the list 508 can be a timeline of access to objects. Each indication of an object in the list 508 is available for selection, which is described further in
The list 508 of objects 502 includes titles (e.g., name of the object as stored on a network accessible system) associated with the objects (e.g., “Object1”, “Object2”, and so on), along with associated identification numbers.
In the example user interface 500, a type 510 of each object is presented adjacent (e.g., in the presented table) to the identification number. As described above, objects can be associated with types, some examples of which include documents, e-mails, person objects, organization objects (e.g., information describing an organization, such as information organized by key-value pairs that describe the organization), and so on. For example, for the object associated with title “Object1,” the type is a person object. The reviewing user can view this information, and determine that the selected user viewed information describing the person “Object1” (e.g., most recently on “2015 Sep. 28,” and a total of 21 times during the date range 512).
Using the user interface 500, the reviewing user can quickly ascertain objects interacted with by the selected user (e.g., organized by quantity of interaction). Since the reviewing user can modify the date range 512, the reviewing user can determine what focus the selected user had, and can determine whether the selected user was accessing objects according to best practices and within the scope of the selected user's work.
As described above, each object 502 included in the list 508 can be selected by the reviewing user. For instance, as illustrated in
The user interface 700 further includes detailed information 710 describing particular user interactions with the selected object 704 by the selected user 702, arranged as in a timeline. As illustrated, a list 714 (e.g., a timeline when organized by timestamp) of particular user interactions is presented, which can be filtered according to filter categories 712 that describe user interactions. For instance, the filter categories 712 include “object exported,” “object imported,” “object loaded,” “objected viewed,” and “object saved.” The reviewing user can interact with a filter category 712, and the user interface 700 can be updated to include only user interactions associated with the filter category (e.g., only user interactions in which the selected object was loaded are retained in the list 714), or the user interface 700 can be updated to remove user interactions associated with the filter category.
The list 714 includes timestamps of each user interaction, along with the associated user interaction category 716 and a method 718 invoked by the user interaction (e.g., a programming method such as a JAVA method associated with the user interaction).
The frequently searched terms 804 include particular search terms 806 entered by the selected user (e.g., “AddressSearchTerm1”) along with a frequency 808 of entry (e.g., a number of times the reviewing user entered the search term).
Each search term 806 is available for selection, and upon selection the user interface 800 can be updated to show specific times (e.g., time of day and date) that the search term was entered. In this way the reviewing user can determine whether search terms were entered outside of working hours or more frequently than usual or reasonable (e.g., which might indicate that the selected user account has been compromised, or that the selected user is accessing objects not in line with a work approved purposed).
Similar to the above discussion of a reviewing user selecting a user, the reviewing user can select an object and receive similar summary and detailed information regarding user interactions by any user with the selected object. In some implementations, the user interfaces generated and presented for a selected object are the same, or similar, to user interfaces generated and presented for a selected user. As such, in these implementations features described above in
After receiving a selection of an object 902, the user interface 900 can be updated to include object information 906 associated with the object (e.g., parameters associated with the object). For instance, the object information 906 includes a title associated with the selected object, a type of the object, and a unique object identifier.
The user interface 900 includes identifications of users that have interacted with the selected object 902. As illustrated, a list 908 identifies users arranged (e.g., in ascending or descending order) according to one or more metrics (e.g., a date of a most recent interaction 910, a number of interactions 912 with the selected object 902 by each user, and so on).
The list 908 identifies a user name for each user (e.g., an employee name associated with the user), along with an associated user identifier (e.g., a log-in name). Each user identified in the list 908 can be selected, which in some implementations will cause the user interface 900 to update to include user interface 400 describing the selected user.
Additionally, the example user interface 1000 includes filter categories 1006, which upon selection cause the user interface 1000 to be updated to remove user interactions associated with the filter category, or solely to include the selected filter category(s). For instance, in an example if the reviewing user selects the filter category 1006 (“Object Loaded”), all user interactions associated with the object being loaded can be removed. The graphical representation 1004 is then updated in the user interface 1000 to remove generated logs associated with the object being loaded.
As in
Utilizing the user interface 1100, a reviewing user can quickly ascertain all user interactions that occurred with the selected object. That is, if the reviewing user has a need to determine all users that viewed the object, the reviewing user can filter the user interactions to solely include “object viewed,” and take any additional action with the included information (e.g., select a particular user and view other objects interacted with by the selected user, and so on as described above).
User query 1204 includes user interface elements to enter or otherwise indicate information relevant to identifying user interactions of one or more users. For instance, a reviewing user can enter one or more user names 1208, and receive all user interactions of the entered users during the selected date range 1202. The reviewing user can enter a particular user interaction category 1210 (e.g., search queries or search term entered) and receive user interactions of the entered users 1208 that were of the entered user interaction category 1210.
The results of the search are provided in portion 1212, which describes the resultant user interactions and associated information. For instance, as illustrated the reviewing user has searched for user interactions of user “User1” and “User2” that were search queries. The portion 1212 therefore includes the resulting user interactions along with a timestamp of each user interaction (e.g., the user interactions can be organized as a timeline), a user name of the user, a type of user interaction (e.g., a user interaction category), and so on. The reviewing user can select a user and receive detailed information regarding the user interaction (e.g., particular search terms entered as described in
Similarly, the reviewing user can enter information in an object query 1206, including a title associated with objects, a unique identifier, and a type of objects. The reviewing user can combine the user query 1204 with the search query 1206 to ascertain whether one or more users interacted with one or more objects.
Additional Embodiments
Additional Storage Locations
As described above, the system can determine (e.g., through an analysis of the generated logs) which objects are being utilized at greater than a threshold and less than a threshold. The system can generate user interface data describing that particular objects would benefit by being stored, or maintained, at more than one network accessible system (e.g., server system) and at more than one geographic location.
For instance, the system can determine that greater than a threshold number of users (e.g., the threshold can be user selectable, the threshold can depend on a quantity of users) are utilizing an object. The system can then generate a user interface for presentation to a reviewing user indicating that the object be stored by a faster network accessible system (e.g., a system with faster storage, a system with faster processors, a system connected via a faster network connection). The system can also determine geographic locations from which users are accessing the object (e.g., from log data describing user actions associated with objects, coupled with user access logs indicating locations from which employees utilize their associated user logins). Upon determining that the users are accessing a same object from greater than a threshold distance away from each other, or from a network accessible system storing the object, the system can generate a user interface describing additional geographic locations for the object to be stored in (e.g., copies of the object can be stored by databases, storage systems, computer systems, and so on, located in the additional geographic locations). That is, the system can obtain locations of network accessible systems, and determine a closeness of the systems to users that have historically accessed the object. The system can then generate user interface data describing recommendations regarding the additional locations.
In some implementations, the generated user interfaces can include a control to effect the recommendations provided in the user interfaces. That is, the control can interact with agents (e.g., software executing on network accessible systems storing objects, or one or more systems that directs the network accessible systems) that can direct objects to be stored in additional geographic locations and/or stored by network accessible systems with faster memory, processing power, network connections.
In this way, the system can perform additional functions beyond reviewing user interactions with objects (e.g., as for an audit of user behavior). That is, the system can decrease a time in which users have to wait to access particular objects. The system therefore increases the efficiency at which objects can be presented to users. Similarly, the system can utilize a size of the objects (e.g., a file size) to determine the recommendations regarding additional storage locations. For instance, if an object is greater than a threshold size, the system can determine that storing the object in additional locations will decrease the download time for users. In contrast, of the object is less than a threshold size, the system can determine that the savings in download time are not greater than the increase in storage requirements and complexity regarding multiple storage locations.
Risky User Behavior
In some implementations the system can determine (e.g., without user interaction by a reviewing user) behavior of a user that is risky (e.g., indicative of the user being compromised, indicative of the user not following best practices, and so on). The system can then flag (e.g., identify) particular users for later review by a reviewing user. For instance, the system can flag particular users upon determining that the users are exporting greater than a threshold number of objects. The system can access information indicating averages of object exports by users, by particular users, or by users of a same, or similar, employee role or other user category.
Furthermore, the system can flag users that are accessing objects outside of normal working hours, or flag users that are being logged into from locations not normally associated with employees or operations of a business entity, governmental entity, or other organization. Similarly, the system can determine that users associated with an employee role or other user category are accessing objects not known to be associated with that employee role or user category.
In this way, the system can flag users for review, and increase the security of object access.
Additionally, the system can determine locations to which objects are exported. The system can access additional log data, including e-mail log data, network interaction data, and so on, and determine that after a user exported an object, the object was e-mailed to a particular e-mail address (e.g., e-mail addresses known to be unsafe or not approved). Similarly, the system can access log data generated by operating systems, or by an agent executing on user devices of users, and determine that the exported object was stored on a removable SD Card, and so on. In this way, the system can flag users that are providing objects to locations outside of the networks maintained by the business entity, or governmental entity.
Triggered Information
In some embodiments, alerts and/or notifications are automatically transmitted to the user device of the reviewing user. As described above, the system can generate notifications describing high volumes of object exports, and other anomalous user information (e.g., as described above with respect to Risky User Behavior). The alert and/or notifications can be transmitted at the time that the alert and/or notification are generated or at some determined time after generation of the alert and/or notification. When received by the user device, the alert and/or notification can cause the user device to display the alert and/or notification via the activation of an application on the device (e.g., a browser, a mobile application, etc.). For example, receipt of the alert and/or notification may automatically activate an application on the user device, such as a messaging application (e.g., SMS or MMS messaging application), a standalone application (e.g., a log reviewing application), or a browser, for example, and display information included in the alert and/or notification. If the user device is offline when the alert and/or notification is transmitted, the application may be automatically activated when the user device is online such that the alert and/or notification is displayed. As another example, receipt of the alert and/or notification may cause a browser to open and be redirected to a login page generated by the system so that the entity can log in to the system and view the alert and/or notification. Alternatively, the alert and/or notification may include a URL of a webpage (or other online information) associated with the alert and/or notification, such that when the user device (e.g., a mobile device) receives the alert, a browser (or other application) is automatically activated and the URL included in the alert and/or notification is accessed via the Internet.
Tracking Object Properties/Permissions
In some implementations, the system can monitor object properties and permissions (e.g., read, write, permissible users or groups of users that can access an object, and so on) associated with objects over periods of time. That is, the system can determine whether an escalation of permissions has occurred, and track when the escalation occurred and/or a user that escalated the permissions. As an example, the system can monitor each access of an object and upon an access, can record information describing the present set of properties and/or permissions. The system can determine changes to the properties and/or permissions, and present the information in one or more user interfaces (e.g., in a user interface describing a particular object, or in summary information). Additionally, the system can provide real-time triggered notifications as described above.
Each of the processes, methods, and algorithms described in the preceding sections may be embodied in, and fully or partially automated by, code modules executed by one or more computer systems or computer processors comprising computer hardware. The code modules (or “engines”) may be stored on any type of non-transitory computer-readable medium or computer storage device, such as hard drives, solid state memory, optical disc, and/or the like. The systems and modules may also be transmitted as generated data signals (for example, as part of a carrier wave or other analog or digital propagated signal) on a variety of computer-readable transmission mediums, including wireless-based and wired/cable-based mediums, and may take a variety of forms (for example, as part of a single or multiplexed analog signal, or as multiple discrete digital packets or frames). The processes and algorithms may be implemented partially or wholly in application-specific circuitry. The results of the disclosed processes and process steps may be stored, persistently or otherwise, in any type of non-transitory computer storage such as, for example, volatile or non-volatile storage.
In general, the terms “engine” and “module”, as used herein, refer to logic embodied in hardware or firmware, or to a collection of software instructions, possibly having entry and exit points, written in a programming language, such as, for example, Java, Lua, C or C++. A software module may be compiled and linked into an executable program, installed in a dynamic link library, or may be written in an interpreted programming language such as, for example, BASIC, Perl, or Python. It will be appreciated that software modules may be callable from other modules or from themselves, and/or may be invoked in response to detected events or interrupts. Software modules configured for execution on computing devices may be provided on a computer readable medium, such as a compact disc, digital video disc, flash drive, or any other tangible medium. Such software code may be stored, partially or fully, on a memory device of the executing computing device, such as the user log correlation system 100, for execution by the computing device. Software instructions may be embedded in firmware, such as an EPROM. It will be further appreciated that hardware modules may be comprised of connected logic units, such as gates and flip-flops, and/or may be comprised of programmable units, such as programmable gate arrays or processors. The modules described herein are preferably implemented as software modules, but may be represented in hardware or firmware. Generally, the modules described herein refer to logical modules that may be combined with other modules or divided into sub-modules despite their physical organization or storage. Electronic Data Sources can include databases, volatile/non-volatile memory, and any memory system or subsystem that maintains information.
The various features and processes described above may be used independently of one another, or may be combined in various ways. All possible combinations and subcombinations are intended to fall within the scope of this disclosure. In addition, certain method or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate. For example, described blocks or states may be performed in an order other than that specifically disclosed, or multiple blocks or states may be combined in a single block or state. The example blocks or states may be performed in serial, in parallel, or in some other manner. Blocks or states may be added to or removed from the disclosed example embodiments. The example systems and components described herein may be configured differently than described. For example, elements may be added to, removed from, or rearranged compared to the disclosed example embodiments.
Conditional language used herein, such as, among others, “can,” “could,” “might,” “may,” “for example,” and the like, unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments include, while other embodiments do not include, certain features, elements and/or steps. Thus, such conditional language is not generally intended to imply that features, elements and/or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without author input or prompting, whether these features, elements and/or steps are included or are to be performed in any particular embodiment. The terms “comprising,” “including,” “having,” and the like are synonymous and are used inclusively, in an open-ended fashion, and do not exclude additional elements, features, acts, operations, and so forth. Also, the term “or” is used in its inclusive sense (and not in its exclusive sense) so that when used, for example, to connect a list of elements, the term “or” means one, some, or all of the elements in the list. Conjunctive language such as the phrase “at least one of X, Y and Z,” unless specifically stated otherwise, is otherwise understood with the context as used in general to convey that an item, term, etc. may be either X, Y or Z. Thus, such conjunctive language is not generally intended to imply that certain embodiments require at least one of X, at least one of Y and at least one of Z to each be present.
The term “a” as used herein should be given an inclusive rather than exclusive interpretation. For example, unless specifically noted, the term “a” should not be understood to mean “exactly one” or “one and only one”; instead, the term “a” means “one or more” or “at least one,” whether used in the claims or elsewhere in the specification and regardless of uses of quantifiers such as “at least one,” “one or more,” or “a plurality” elsewhere in the claims or specification.
The term “comprising” as used herein should be given an inclusive rather than exclusive interpretation. For example, a general purpose computer comprising one or more processors should not be interpreted as excluding other computer components, and may possibly include such components as memory, input/output devices, and/or network interfaces, among others.
While certain example embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the disclosure. Thus, nothing in the foregoing description is intended to imply that any particular element, feature, characteristic, step, module, or block is necessary or indispensable. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions, and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions disclosed herein. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of certain of the inventions disclosed herein.
Any process descriptions, elements, or blocks in the flow diagrams described herein and/or depicted in the attached figures should be understood as potentially representing modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in the process. Alternate implementations are included within the scope of the embodiments described herein in which elements or functions may be deleted, executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those skilled in the art.
It should be emphasized that many variations and modifications may be made to the above-described embodiments, the elements of which are to be understood as being among other acceptable examples. All such modifications and variations are intended to be included herein within the scope of this disclosure. The foregoing description details certain embodiments of the invention. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the invention can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the invention should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the invention with which that terminology is associated.
Number | Name | Date | Kind |
---|---|---|---|
5515488 | Hoppe et al. | May 1996 | A |
6430305 | Decker | Aug 2002 | B1 |
6820135 | Dingman | Nov 2004 | B1 |
6978419 | Kantrowitz | Dec 2005 | B1 |
6980984 | Huffman et al. | Dec 2005 | B1 |
7168039 | Bertram | Jan 2007 | B2 |
7461077 | Greenwood | Dec 2008 | B1 |
7617232 | Gabbert et al. | Nov 2009 | B2 |
7756843 | Palmer | Jul 2010 | B1 |
7800796 | Saito | Sep 2010 | B2 |
7908559 | Denise | Mar 2011 | B1 |
7917376 | Bellin et al. | Mar 2011 | B2 |
7941321 | Greenstein et al. | May 2011 | B2 |
8036971 | Aymeloglu et al. | Oct 2011 | B2 |
8037046 | Udezue et al. | Oct 2011 | B2 |
8046283 | Burns | Oct 2011 | B2 |
8054756 | Chand et al. | Nov 2011 | B2 |
8214490 | Vos et al. | Jul 2012 | B1 |
8229902 | Vishniac et al. | Jul 2012 | B2 |
8290838 | Thakur et al. | Oct 2012 | B1 |
8302855 | Ma et al. | Nov 2012 | B2 |
8386377 | Xiong et al. | Feb 2013 | B1 |
8473454 | Evanitsky et al. | Jun 2013 | B2 |
8484115 | Aymeloglu et al. | Jul 2013 | B2 |
8489641 | Seefeld et al. | Jul 2013 | B1 |
8577911 | Stepinski et al. | Nov 2013 | B1 |
8589273 | Creeden et al. | Nov 2013 | B2 |
8688573 | Ruknoic et al. | Apr 2014 | B1 |
8744890 | Bernier | Jun 2014 | B1 |
8799799 | Cervelli et al. | Aug 2014 | B1 |
8806355 | Twiss et al. | Aug 2014 | B2 |
8812960 | Sun et al. | Aug 2014 | B1 |
8924388 | Elliot et al. | Dec 2014 | B2 |
8924389 | Elliot et al. | Dec 2014 | B2 |
8938686 | Erenrich et al. | Jan 2015 | B1 |
8949164 | Mohler | Feb 2015 | B1 |
9069842 | Melby | Jun 2015 | B2 |
9100428 | Visbal | Aug 2015 | B1 |
9111281 | Stibel et al. | Aug 2015 | B2 |
9129219 | Robertson et al. | Sep 2015 | B1 |
9129321 | Boding et al. | Sep 2015 | B2 |
9256664 | Chakerian et al. | Feb 2016 | B2 |
9280618 | Bruce et al. | Mar 2016 | B1 |
9286373 | Elliot et al. | Mar 2016 | B2 |
9335911 | Elliot et al. | May 2016 | B1 |
9338013 | Castellucci et al. | May 2016 | B2 |
9516052 | Chauhan | Dec 2016 | B1 |
10027473 | Castellucci et al. | Jul 2018 | B2 |
20020065708 | Senay et al. | May 2002 | A1 |
20020095360 | Joao | Jul 2002 | A1 |
20020095658 | Shulman | Jul 2002 | A1 |
20020103705 | Brady | Aug 2002 | A1 |
20020147805 | Leshem et al. | Oct 2002 | A1 |
20030126102 | Borthwick | Jul 2003 | A1 |
20040034570 | Davis | Feb 2004 | A1 |
20040111480 | Yue | Jun 2004 | A1 |
20040153418 | Hanweck | Aug 2004 | A1 |
20040236688 | Bozeman | Nov 2004 | A1 |
20050010472 | Quatse et al. | Jan 2005 | A1 |
20050086207 | Heuer et al. | Apr 2005 | A1 |
20050154628 | Eckart et al. | Jul 2005 | A1 |
20050154769 | Eckart et al. | Jul 2005 | A1 |
20050234909 | Bade et al. | Oct 2005 | A1 |
20060026120 | Carolan et al. | Feb 2006 | A1 |
20060026170 | Kreitler et al. | Feb 2006 | A1 |
20060080283 | Shipman | Apr 2006 | A1 |
20060143034 | Rothermel | Jun 2006 | A1 |
20060143075 | Carr et al. | Jun 2006 | A1 |
20060143079 | Basak et al. | Jun 2006 | A1 |
20070000999 | Kubo et al. | Jan 2007 | A1 |
20070011304 | Error | Jan 2007 | A1 |
20070038646 | Thota | Feb 2007 | A1 |
20070150801 | Chidlovskii et al. | Jun 2007 | A1 |
20070156673 | Maga | Jul 2007 | A1 |
20070162454 | D'Albora et al. | Jul 2007 | A1 |
20070185867 | Maga | Aug 2007 | A1 |
20070192122 | Routson et al. | Aug 2007 | A1 |
20070208737 | Li | Sep 2007 | A1 |
20070284433 | Domenica et al. | Dec 2007 | A1 |
20080065655 | Chakravarthy et al. | Mar 2008 | A1 |
20080069081 | Chand et al. | Mar 2008 | A1 |
20080077642 | Carbone et al. | Mar 2008 | A1 |
20080103996 | Forman et al. | May 2008 | A1 |
20080208735 | Balet et al. | Aug 2008 | A1 |
20080222295 | Robinson et al. | Sep 2008 | A1 |
20080243711 | Aymeloglu et al. | Oct 2008 | A1 |
20080255973 | El Wade et al. | Oct 2008 | A1 |
20080270328 | Lafferty et al. | Oct 2008 | A1 |
20080294663 | Heinley et al. | Nov 2008 | A1 |
20080313132 | Hao et al. | Dec 2008 | A1 |
20090076845 | Bellin et al. | Mar 2009 | A1 |
20090094166 | Aymeloglu et al. | Apr 2009 | A1 |
20090094270 | Alirez et al. | Apr 2009 | A1 |
20090106178 | Chu | Apr 2009 | A1 |
20090112745 | Stefanescu | Apr 2009 | A1 |
20090125359 | Knapic | May 2009 | A1 |
20090125459 | Norton et al. | May 2009 | A1 |
20090132953 | Reed et al. | May 2009 | A1 |
20090157732 | Hao et al. | Jun 2009 | A1 |
20090187546 | Whyte et al. | Jul 2009 | A1 |
20090187548 | Ji et al. | Jul 2009 | A1 |
20090249244 | Robinson et al. | Oct 2009 | A1 |
20090254842 | Leacock et al. | Oct 2009 | A1 |
20090259636 | Labrou et al. | Oct 2009 | A1 |
20090271343 | Vaiciulis et al. | Oct 2009 | A1 |
20090271637 | Takekawa et al. | Oct 2009 | A1 |
20090307049 | Elliott et al. | Dec 2009 | A1 |
20090313463 | Pang et al. | Dec 2009 | A1 |
20090319418 | Herz | Dec 2009 | A1 |
20090319515 | Minton et al. | Dec 2009 | A1 |
20090319891 | MacKinlay | Dec 2009 | A1 |
20100030722 | Goodson et al. | Feb 2010 | A1 |
20100031141 | Summers et al. | Feb 2010 | A1 |
20100042922 | Bradateanu et al. | Feb 2010 | A1 |
20100057622 | Faith et al. | Mar 2010 | A1 |
20100070842 | Aymeloglu et al. | Mar 2010 | A1 |
20100098318 | Anderson | Apr 2010 | A1 |
20100106752 | Eckardt et al. | Apr 2010 | A1 |
20100114887 | Conway et al. | May 2010 | A1 |
20100131502 | Fordham | May 2010 | A1 |
20100161735 | Sharma | Jun 2010 | A1 |
20100191563 | Schlaifer et al. | Jul 2010 | A1 |
20100211535 | Rosenberger | Aug 2010 | A1 |
20100235915 | Memon et al. | Sep 2010 | A1 |
20100262688 | Hussain et al. | Oct 2010 | A1 |
20100293174 | Bennett et al. | Nov 2010 | A1 |
20100312837 | Bodapati et al. | Dec 2010 | A1 |
20110040776 | Najm et al. | Feb 2011 | A1 |
20110061013 | Bilicki et al. | Mar 2011 | A1 |
20110078173 | Seligmann et al. | Mar 2011 | A1 |
20110093327 | Fordyce et al. | Apr 2011 | A1 |
20110099133 | Chang et al. | Apr 2011 | A1 |
20110153384 | Horne et al. | Jun 2011 | A1 |
20110173093 | Psota et al. | Jul 2011 | A1 |
20110208565 | Ross et al. | Aug 2011 | A1 |
20110208724 | Jones et al. | Aug 2011 | A1 |
20110213655 | Henkin | Sep 2011 | A1 |
20110218955 | Tang | Sep 2011 | A1 |
20110270604 | Qi et al. | Nov 2011 | A1 |
20110270834 | Sokolan et al. | Nov 2011 | A1 |
20110289397 | Eastmond et al. | Nov 2011 | A1 |
20110295649 | Fine | Dec 2011 | A1 |
20110314007 | Dassa et al. | Dec 2011 | A1 |
20110314024 | Chang et al. | Dec 2011 | A1 |
20120004904 | Shin et al. | Jan 2012 | A1 |
20120011238 | Rathod | Jan 2012 | A1 |
20120011245 | Gillette et al. | Jan 2012 | A1 |
20120022945 | Falkenborg et al. | Jan 2012 | A1 |
20120054284 | Rakshit | Mar 2012 | A1 |
20120059853 | Jagota | Mar 2012 | A1 |
20120066166 | Curbera et al. | Mar 2012 | A1 |
20120079363 | Folting et al. | Mar 2012 | A1 |
20120084117 | Tavares et al. | Apr 2012 | A1 |
20120084287 | Lakshminarayan et al. | Apr 2012 | A1 |
20120089606 | Eshwar et al. | Apr 2012 | A1 |
20120131512 | Takeuchi et al. | May 2012 | A1 |
20120144335 | Abeln et al. | Jun 2012 | A1 |
20120158527 | Cannelongo et al. | Jun 2012 | A1 |
20120159362 | Brown et al. | Jun 2012 | A1 |
20120173381 | Smith | Jul 2012 | A1 |
20120215784 | King et al. | Aug 2012 | A1 |
20120221553 | Wittmer et al. | Aug 2012 | A1 |
20120226523 | Weiss | Sep 2012 | A1 |
20120245976 | Kumar et al. | Sep 2012 | A1 |
20120323888 | Osann, Jr. | Dec 2012 | A1 |
20130016106 | Yip et al. | Jan 2013 | A1 |
20130054306 | Bhalla | Feb 2013 | A1 |
20130055145 | Antony | Feb 2013 | A1 |
20130057551 | Ebert et al. | Mar 2013 | A1 |
20130096988 | Grossman et al. | Apr 2013 | A1 |
20130110746 | Ahn | May 2013 | A1 |
20130151453 | Bhanot et al. | Jun 2013 | A1 |
20130166348 | Scotto | Jun 2013 | A1 |
20130166480 | Popescu et al. | Jun 2013 | A1 |
20130173610 | Hu | Jul 2013 | A1 |
20130185245 | Anderson | Jul 2013 | A1 |
20130185307 | El-Yaniv et al. | Jul 2013 | A1 |
20130218879 | Park et al. | Aug 2013 | A1 |
20130226318 | Procyk | Aug 2013 | A1 |
20130238616 | Rose et al. | Sep 2013 | A1 |
20130246170 | Gross et al. | Sep 2013 | A1 |
20130246537 | Gaddala | Sep 2013 | A1 |
20130246597 | Iizawa et al. | Sep 2013 | A1 |
20130263019 | Castellanos et al. | Oct 2013 | A1 |
20130268520 | Fisher et al. | Oct 2013 | A1 |
20130282696 | John et al. | Oct 2013 | A1 |
20130290825 | Arndt et al. | Oct 2013 | A1 |
20130297619 | Chandrasekaran et al. | Nov 2013 | A1 |
20130304770 | Boero et al. | Nov 2013 | A1 |
20130318604 | Coates et al. | Nov 2013 | A1 |
20140012796 | Petersen et al. | Jan 2014 | A1 |
20140040371 | Gurevich et al. | Feb 2014 | A1 |
20140053091 | Hou et al. | Feb 2014 | A1 |
20140058914 | Song et al. | Feb 2014 | A1 |
20140068487 | Steiger et al. | Mar 2014 | A1 |
20140082513 | Mills | Mar 2014 | A1 |
20140095509 | Patton | Apr 2014 | A1 |
20140108380 | Gotz et al. | Apr 2014 | A1 |
20140108985 | Scott et al. | Apr 2014 | A1 |
20140123279 | Bishop et al. | May 2014 | A1 |
20140136285 | Carvalho | May 2014 | A1 |
20140143009 | Brice et al. | May 2014 | A1 |
20140156527 | Grigg et al. | Jun 2014 | A1 |
20140157172 | Peery et al. | Jun 2014 | A1 |
20140164502 | Khodorenko et al. | Jun 2014 | A1 |
20140189536 | Lange et al. | Jul 2014 | A1 |
20140189870 | Singla et al. | Jul 2014 | A1 |
20140195515 | Baker et al. | Jul 2014 | A1 |
20140222521 | Chait | Aug 2014 | A1 |
20140222793 | Sadkin et al. | Aug 2014 | A1 |
20140229554 | Grunin et al. | Aug 2014 | A1 |
20140280056 | Kelly | Sep 2014 | A1 |
20140282160 | Zarpas | Sep 2014 | A1 |
20140344230 | Krause et al. | Nov 2014 | A1 |
20140358829 | Hurwitz | Dec 2014 | A1 |
20140366132 | Stiansen et al. | Dec 2014 | A1 |
20150073929 | Psota et al. | Mar 2015 | A1 |
20150073954 | Braff | Mar 2015 | A1 |
20150095773 | Gonsalves et al. | Apr 2015 | A1 |
20150100897 | Sun et al. | Apr 2015 | A1 |
20150106170 | Bonica | Apr 2015 | A1 |
20150106379 | Elliot et al. | Apr 2015 | A1 |
20150134599 | Banerjee et al. | May 2015 | A1 |
20150135256 | Hoy et al. | May 2015 | A1 |
20150188872 | White | Jul 2015 | A1 |
20150242401 | Liu | Aug 2015 | A1 |
20150319203 | Jeremias | Nov 2015 | A1 |
20150338233 | Cervelli et al. | Nov 2015 | A1 |
20150363289 | Brough | Dec 2015 | A1 |
20150379413 | Robertson et al. | Dec 2015 | A1 |
20160004764 | Chakerian et al. | Jan 2016 | A1 |
20160012654 | Sherony | Jan 2016 | A1 |
20160132608 | Rathod | May 2016 | A1 |
20170031565 | Chauhan | Feb 2017 | A1 |
20170302753 | Larumbe | Oct 2017 | A1 |
20180302216 | Castellucci et al. | Oct 2018 | A1 |
Number | Date | Country |
---|---|---|
102546446 | Jul 2012 | CN |
103167093 | Jun 2013 | CN |
102054015 | May 2014 | CN |
102014204827 | Sep 2014 | DE |
102014204830 | Sep 2014 | DE |
102014204834 | Sep 2014 | DE |
1962222 | Aug 2008 | EP |
2487610 | Aug 2012 | EP |
2858018 | Apr 2015 | EP |
2869211 | May 2015 | EP |
2889814 | Jul 2015 | EP |
2892197 | Jul 2015 | EP |
2963595 | Jan 2016 | EP |
2996053 | Mar 2016 | EP |
3035214 | Jun 2016 | EP |
3038002 | Jun 2016 | EP |
3040885 | Jul 2016 | EP |
2897051 | Aug 2017 | EP |
3255549 | Dec 2017 | EP |
WO 2005116851 | Dec 2005 | WO |
WO 2012061162 | May 2012 | WO |
Entry |
---|
J. Lee, M. Park, J. Eom and T. Chung, “Multi-level Intrusion Detection System and log management in Cloud Computing,” 13th International Conference on Advanced Communication Technology (ICACT2011), Seoul, 2011, pp. 552-555. (Year: 2011). |
Amnet, “5 Great Tools for Visualizing Your Twitter Followers,” posted Aug. 4, 2010, http://www.amnetblog.com/component/content/article/115-5-grate-tools-for-visualizing-your-twitter-followers.html. |
Appacts, “Smart Thinking for Super Apps,” http://www.appacts.com Printed Jul. 18, 2013 in 4 pages. |
Apsalar, “Data Powered Mobile Advertising,” “Free Mobile App Analytics” and various analytics related screen shots http://apsalar.com Printed Jul. 18, 2013 in 8 pages. |
Capptain—Pilot Your Apps, http://www.capptain.com Printed Jul. 18, 2013 in 6 pages. |
Celik, Tantek, “CSS Basic User Interface Module Level 3 (CSS3 UI),” Section 8 Resizing and Overflow, Jan. 17, 2012, retrieved from internet http://www.w3.org/TR/2012/WD-css3-ui-20120117/#resizing-amp-overflow retrieved on May 18, 2015. |
Chaudhuri et al., “An Overview of Business Intelligence Technology,” Communications of the ACM, Aug. 2011, vol. 54, No. 8. |
Cohn, et al., “Semi-supervised clustering with user feedback,” Constrained Clustering: Advances in Algorithms, Theory, and Applications 4.1 (2003): 17-32. |
Countly Mobile Analytics, http://count.ly/ Printed Jul. 18, 2013 in 9 pages. |
DISTIMO—App Analytics, http://www.distimo.com/app-analytics Printed Jul. 18, 2013 in 5 pages. |
Flurry Analytics, http://www.flurry.com/ Printed Jul. 18, 2013 in 14 pages. |
Gill et al., “Computerised Linking of Medical Records: Methodological Guidelines,” Journal of Epidemiology and Community Health, 1993, vol. 47, pp. 316-319. |
Google Analytics Official Website—Web Analytics & Reporting, http://www.google.com/analytics.index.html Printed Jul. 18, 2013 in 22 pages. |
Gorr et al., “Crime Hot Spot Forecasting: Modeling and Comparative Evaluation”, Grant 98-IJ-CX-K005, May 6, 2002, 37 pages. |
Gu et al., “Record Linkage: Current Practice and Future Directions,” Jan. 15, 2004, pp. 32. |
Hansen et al., “Analyzing Social Media Networks with NodeXL: Insights from a Connected World”, Chapter 4, pp. 53-67 and Chapter 10, pp. 143-164, published Sep. 2010. |
Hua et al., “A Multi-attribute Data Structure with Parallel Bloom Filters for Network Services”, HiPC 2006, LNCS 4297, pp. 277-288, 2006. |
“HunchLab: Heat Map and Kernel Density Calculation for Crime Analysis,” Azavea Journal, printed from www.azavea.com/blogs/newsletter/v4i4/kernel-density-capabilities-added-to-hunchlab/ on Sep. 9, 2014, 2 pages. |
Keylines.com, “An Introduction to KeyLines and Network Visualization,” Mar. 2014, http://keylines.com/wp-content/uploads/2014/03/KeyLines-White-Paper.pdf downloaded May 12, 2014 in 8 pages. |
Keylines.com, “KeyLines Datasheet,” Mar. 2014, http://keylines.com/wp-content/uploads/2014/03/KeyLines-datasheet.pdf downloaded May 12, 2014 in 2 pages. |
Keylines.com, “Visualizing Threats: Improved Cyber Security Through Network Visualization,” Apr. 2014, http://keylines.com/wp-content/uploads/2014/04/Visualizing-Threats1.pdf downloaded May 12, 2014 in 10 pages. |
Kontagent Mobile Analytics, http://www.kontagent.com/ Printed Jul. 18, 2013 in 9 pages. |
Localytics—Mobile App Marketing & Analytics, http://www.localytics.com/ Printed Jul. 18, 2013 in 12 pages. |
Manno et al., “Introducing Collaboration in Single-user Applications through the Centralized Control Architecture,” 2010, pp. 10. |
Mixpanel—Mobile Analytics, https://mixpanel.com/ Printed Jul. 18, 2013 in 13 pages. |
Open Web Analytics (OWA), http://www.openwebanalytics.com/ Printed Jul. 19, 2013 in 5 pages. |
Piwik—Free Web Analytics Software. http://piwik.org/ Printed Jul. 19, 2013 in18 pages. |
“Refresh CSS Ellipsis When Resizing Container—Stack Overflow,” Jul. 31, 2013, retrieved from internet http://stackoverflow.com/questions/17964681/refresh-css-ellipsis-when-resizing-container, retrieved on May 18, 2015. |
“SAP BusinessObjects Explorer Online Help,” Mar. 19, 2012, retrieved on Apr. 21, 2016 http://help.sap.com/businessobject/product_guides/boexir4/en/xi4_exp_user_en.pdf. |
Sigrist, et al., “PROSITE, a Protein Domain Database for Functional Characterization and Annotation,” Nucleic Acids Research, 2010, vol. 38, pp. D161-D166. |
StatCounter—Free Invisible Web Tracker, Hit Counter and Web Stats, http://statcounter.com/ Printed Jul. 19, 2013 in 17 pages. |
TestFlight—Beta Testing on the Fly, http://testflightapp.com/ Printed Jul. 18, 2013 in 3 pages. |
trak.io, http://trak.io/ printed Jul. 18, 2013 in 3 pages. |
UserMetrix, http://usermetrix.com/android-analytics printed Jul. 18, 2013 in 3 pages. |
Valentini et al., “Ensembles of Learning Machines”, M. Marinaro and R. Tagliaferri (Eds.): WIRN VIETRI 2002, LNCS 2486, pp. 3-20. |
Vose et al., “Help File for ModelRisk Version 5,” 2007, Vose Software, pp. 349-353. [Uploaded in 2 Parts]. |
Wang et al., “Research on a Clustering Data De-Duplication Mechanism Based on Bloom Filter,” IEEE 2010, 5 pages. |
Wikipedia, “Multimap,” Jan. 1, 2013, https://en.wikipedia.org/w/index.php?title-Multimap&oldid=530800748. |
Wikipedia, “Mobile Web,” Jan. 23, 2015, retrieved from the internet on Mar. 15, 2016 https://en.wikipedia.org/w/index.php?title-Mobile_Web&oldid=643800164. |
Winkler, William E., “Bureau of the Census Statistical Research Division Record Linkage Software and Methods for Merging Administrative Lists,” Statistical Research Report Series No. RR2001/03, Jul. 23, 2001, https://www.census.gov/srd/papers/pdf/rr2001-03.pdf, retrieved on Mar. 9, 2016. |
Notice of Allowance for U.S. Appl. No. 14/225,084 dated May 4, 2015. |
Notice of Allowance for U.S. Appl. No. 14/319,161 dated May 4, 2015. |
Notice of Allowance for U.S. Appl. No. 14/323,935 dated Oct. 1, 2015. |
Notice of Allowance for U.S. Appl. No. 14/479,863 dated Mar. 31, 2015. |
Notice of Allowance for U.S. Appl. No. 14/483,527 dated Apr. 29, 2016. |
Notice of Allowance for U.S. Appl. No. 14/552,336 dated Nov. 3, 2015. |
Notice of Allowance for U.S. Appl. No. 14/746,671 dated Jan. 21, 2016. |
Notice of Allowance for U.S. Appl. No. 14/858,647 dated Mar. 4, 2016. |
Official Communication for European Patent Application No. 14187996.5 dated Feb. 12, 2015. |
Official Communication for European Patent Application No. 14187996.5 dated Feb. 19, 2016. |
Official Communication for European Patent Application No. 14191540.5 dated May 27, 2015. |
Official Communication for European Patent Application No. 14200246.8 dated May 29, 2015. |
Official Communication for European Patent Application No. 14200298.9 dated May 13, 2015. |
Official Communication for European Patent Application No. 15181419.1 dated Sep. 29, 2015. |
Official Communication for European Patent Application No. 15184764.7 dated Dec. 14, 2015. |
Official Communication for European Patent Application No. 15200073.3 dated Mar. 30, 2016. |
Official Communication for European Patent Application No. 15201924.6 dated Apr. 25, 2016. |
Official Communication for European Patent Application No. 16152984.7 dated Mar. 24, 2016. |
Official Communication for Great Britain Patent Application No. 1404486.1 dated May 21, 2015. |
Official Communication for Great Britain Patent Application No. 1404486.1 dated Aug. 27, 2014. |
Official Communication for Great Britain Patent Application No. 1404489.5 dated May 21, 2015. |
Official Communication for Great Britain Patent Application No. 1404489.5 dated Aug. 27, 2014. |
Official Communication for Great Britain Patent Application No. 1404499.4 dated Jun. 11, 2015. |
Official Communication for Great Britain Patent Application No. 1404499.4 dated Aug. 20, 2014. |
Official Communication for Netherlands Patent Application No. 2012417 dated Sep. 18, 2015. |
Official Communication for Netherlands Patent Application No. 2012421 dated Sep. 18, 2015. |
Official Communication for Netherlands Patent Application No. 2012438 dated Sep. 21, 2015. |
Official Communication for New Zealand Patent Application No. 622473 dated Jun. 19, 2014. |
Official Communication for New Zealand Patent Application No. 622473 dated Mar. 27, 2014. |
Official Communication for New Zealand Patent Application No. 622513 dated Apr. 3, 2014. |
Official Communication for New Zealand Patent Application No. 628161 dated Aug. 25, 2014. |
Official Communication for U.S. Appl. No. 13/827,491 dated Dec. 1, 2014. |
Official Communication for U.S. Appl. No. 13/827,491 dated Jun. 22, 2015. |
Official Communication for U.S. Appl. No. 13/827,491 dated Oct. 9, 2015. |
Official Communication for U.S. Appl. No. 14/141,252 dated Apr. 14, 2016. |
Official Communication for U.S. Appl. No. 14/141,252 dated Oct. 8, 2015. |
Official Communication for U.S. Appl. No. 14/225,006 dated Sep. 10, 2014. |
Official Communication for U.S. Appl. No. 14/225,006 dated Sep. 2, 2015. |
Official Communication for U.S. Appl. No. 14/225,006 dated Dec. 21, 2015. |
Official Communication for U.S. Appl. No. 14/225,006 dated Feb. 27, 2015. |
Official Communication for U.S. Appl. No. 14/225,084 dated Sep. 11, 2015. |
Official Communication for U.S. Appl. No. 14/225,084 dated Sep. 2, 2014. |
Official Communication for U.S. Appl. No. 14/225,084 dated Feb. 20, 2015. |
Official Communication for U.S. Appl. No. 14/225,084 dated Feb. 26, 2016. |
Official Communication for U.S. Appl. No. 14/225,084 dated Jan. 4, 2016. |
Official Communication for U.S. Appl. No. 14/225,160 dated Feb. 11, 2015. |
Official Communication for U.S. Appl. No. 14/225,160 dated Aug. 12, 2015. |
Official Communication for U.S. Appl. No. 14/225,160 dated Jun. 16, 2016. |
Official Communication for U.S. Appl. No. 14/225,160 dated May 20, 2015. |
Official Communication for U.S. Appl. No. 14/225,160 dated Apr. 22, 2016. |
Official Communication for U.S. Appl. No. 14/225,160 dated Oct. 22, 2014. |
Official Communication for U.S. Appl. No. 14/225,160 dated Jan. 25, 2016. |
Official Communication for U.S. Appl. No. 14/225,160 dated Jul. 29, 2014. |
Official Communication for U.S. Appl. No. 14/306,138 dated Dec. 24, 2015. |
Official Communication for U.S. Appl. No. 14/306,138 dated Dec. 3, 2015. |
Official Communication for U.S. Appl. No. 14/306,147 dated Dec. 24, 2015. |
Official Communication for U.S. Appl. No. 14/319,161 dated Jan. 23, 2015. |
Official Communication for U.S. Appl. No. 14/319,765 dated Feb. 1, 2016. |
Official Communication for U.S. Appl. No. 14/451,221 dated Oct. 21, 2014. |
Official Communication for U.S. Appl. No. 14/463,615 dated Sep. 10, 2015. |
Official Communication for U.S. Appl. No. 14/463,615 dated Nov. 13, 2014. |
Official Communication for U.S. Appl. No. 14/463,615 dated May 21, 2015. |
Official Communication for U.S. Appl. No. 14/463,615 dated Jan. 28, 2015. |
Official Communication for U.S. Appl. No. 14/463,615 dated Dec. 9, 2015. |
Official Communication for U.S. Appl. No. 14/479,863 dated Dec. 26, 2014. |
Official Communication for U.S. Appl. No. 14/483,527 dated Jun. 22, 2015. |
Official Communication for U.S. Appl. No. 14/483,527 dated Jan. 28, 2015. |
Official Communication for U.S. Appl. No. 14/483,527 dated Oct. 28, 2015. |
Official Communication for U.S. Appl. No. 14/552,336 dated Jul. 20, 2015. |
Official Communication for U.S. Appl. No. 14/562,524 dated Nov. 10, 2015. |
Official Communication for U.S. Appl. No. 14/562,524 dated Sep. 14, 2015. |
Official Communication for U.S. Appl. No. 14/571,098 dated Nov. 10, 2015. |
Official Communication for U.S. Appl. No. 14/571,098 dated Mar. 11, 2015. |
Official Communication for U.S. Appl. No. 14/571,098 dated Feb. 23, 2016. |
Official Communication for U.S. Appl. No. 14/571,098 dated Aug. 24, 2015. |
Official Communication for U.S. Appl. No. 14/571,098 dated Aug. 5, 2015. |
Official Communication for U.S. Appl. No. 14/631,633 dated Sep. 10, 2015. |
Official Communication for U.S. Appl. No. 14/676,621 dated Oct. 29, 2015. |
Official Communication for U.S. Appl. No. 14/676,621 dated Jul. 30, 2015. |
Official Communication for U.S. Appl. No. 14/746,671 dated Nov. 12, 2015. |
Official Communication for U.S. Appl. No. 14/800,447 dated Dec. 10, 2015. |
Official Communication for U.S. Appl. No. 14/813,749 dated Sep. 28, 2015. |
Official Communication for U.S. Appl. No. 14/813,749 dated Apr. 8, 2016. |
Official Communication for U.S. Appl. No. 14/842,734 dated Nov. 19, 2015. |
Official Communication for U.S. Appl. No. 14/929,584 dated May 25, 2016. |
Official Communication for U.S. Appl. No. 14/929,584 dated Feb. 4, 2016. |
Number | Date | Country | |
---|---|---|---|
62272496 | Dec 2015 | US |