US20170147678A1 - Information exchange engine providing a critical infrastructure layer and methods of use thereof - Google Patents
Information exchange engine providing a critical infrastructure layer and methods of use thereof Download PDFInfo
- Publication number
- US20170147678A1 US20170147678A1 US15/371,180 US201615371180A US2017147678A1 US 20170147678 A1 US20170147678 A1 US 20170147678A1 US 201615371180 A US201615371180 A US 201615371180A US 2017147678 A1 US2017147678 A1 US 2017147678A1
- Authority
- US
- United States
- Prior art keywords
- information
- user
- vob
- field
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/288—Entity relationship models
 
- 
        - G06F17/30604—
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/10—Office automation; Time management
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/25—Integrating or interfacing systems involving database management systems
- G06F16/258—Data format conversion from or to a database
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/285—Clustering or classification
 
- 
        - G06F17/30312—
 
- 
        - G06F17/30598—
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/04—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
- H04L63/0428—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/04—Protocols specially adapted for terminals or networks with limited capabilities; specially adapted for terminal portability
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/55—Push-based network services
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/40—Network security protocols
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
- H04L67/568—Storing data temporarily at an intermediate stage, e.g. caching
 
- 
        - H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/30—Definitions, standards or architectural aspects of layered protocol stacks
- H04L69/32—Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
- H04L69/322—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
- H04L69/329—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
 
Definitions
- the present invention relates generally to information technology, and more particularly to systems and methods for providing dynamic creation, storage and exchange of personal information.
- the information exchange system provides a tool for dynamically defining data records and dynamically allocating instances of those records.
- the system further provides a tool for facilitating electronic exchange of personal information represented by the data, such as contact, payment, shipping, and other information, between individuals and the people and businesses with which they interact.
- the system allows editing and sharing of information at a data field level, in addition to supporting information transactions at a complex level, defined as a combination of related fields.
- the architecture of one embodiment is such that the system can be coupled with a conventional relational database application.
- the information exchange system comprises an interface layer providing a tool for users to interact with the system through a plurality of client-side platforms.
- the system also comprises an application layer comprising a vault providing a storage mechanism for individual and business users to store information about themselves and/or their business, and a contact manager providing a utility for saving information about static and dynamic contacts.
- the system further comprises a critical exchange engine layer comprising an account manager, a virtual record manager, a data exchange engine, and an encryption engine which provides the capability to save and access raw data that has been encrypted in a relational database.
- the virtual record manager is configured to manage the storage of data, whereby support for complex data records is supported while maintaining access and control of data on an individual field basis.
- the data exchange engine supports the exchange of information between system users and the definition and enforcement of rule-based behaviors on the availability of information.
- a database is provided in one embodiment for storage of encrypted personal information of system users, for storage of metadata describing the structure and description of the personal information stored in the database, and for storage of permissions data describing sharing and accessibility rules related to the fields of information.
- the system generally provides a private, accurate, convenient, and secure method of maintaining and accessing up-to-date information at any time from anywhere. Users are able to expand and customize their information readily and in real-time.
- the information in the robust data repository can be accessed through a WAN such as the Internet or through various handheld wireless devices. Upon a change of information, all persons that have permission to view that information field are alerted and updated automatically with the new data.
- Exemplary uses for an individual user which are provided by the system include: (1) requesting a summary of information that has changed for people, groups, or businesses in their network of contacts, possibly through a personal newsletter or as highlighted boxes on a system home page, thus being automatically informed of changes; (2) maintaining a community address book whereby clubs, organizations, chat groups, etc.
- FIG. 1 depicts a preferred operating architecture of an information exchange system, according to an embodiment of the invention.
- FIG. 1 depicts a preferred operating architecture 100 of the information exchange system 102 described herein.
- the overall system architecture 100 is based on a network client-server model, wherein various client 110 platforms communicate with a layer of applications 140 through a network 120 . Since the information exchange system 102 supports a plurality of client platforms (which are discussed in detail below), an interface layer 130 comprising interface servers is provided for interacting with the plurality of client-side platforms.
- the information that is exchanged by users of the system 102 is maintained in a database 160 .
- the critical infrastructure layer that primarily provides the operational capability of the system 102 to facilitate the storage, modification, and exchange of information for people and businesses lies in the exchange engine layer 150 .
- the application layer 140 and its components are described prior to the detailed description of the interface layer 130 , so it is noted that a client user interacts with the system 102 and its application layer 140 through the interface layer 130 .
- the application layer 140 contains a vault 142 and a contact manager 148 .
- the vault is depicted as containing constituent elements for individual 144 and business 146 applications for didactic purposes, but configurations are contemplated wherein the needs of both individual and business users are provided by a single vault 142 application.
- the vault 142 is an application that provides a storage mechanism for registered individual and business users of the system 102 to store information about themselves and/or their business.
- Non-limiting examples of an individual user's information include name, home and office addresses, home, office, mobile phone and various other phone numbers, date of birth, as well as similar information about the user's spouse and children. Additional examples include names and membership numbers related to various organizations of which the user is a member, bank and mortgage information, and similar information.
- a user's information may be described within the system 102 in relation to various permission groups to facilitate management by the user, e.g., groups such as “family,” “work,” “financial,” “social,” “recreational,” etc.
- Non-limiting examples of a business user's information include the business name, address of their headquarters and branch offices, names of the company executives, Dun and Bradstreet number, tax identification number, bank account information, membership in various organizations, etc.
- the vault 142 presents the registered user with a number of fields with predefined semantics. To this end, the vault 142 utilizes information stored and managed by the account manager engine 152 , to know if the user is a business user or an individual user. For example, the vault 142 may present “name” and “home address” fields to an individual user, whereas it may present “office phone number” and “D&B number” fields to a business user. The number of fields of information and the nature of the fields are decided by each registered user of the system, and are not limited to those presented. Consequently, the exchange system 102 is configured to facilitate the exchange of dynamic, user-defined information and types of information.
- the vault 142 invokes the virtual record manager (VRM) 154 of exchange engine layer 150 to actually store and retrieve the information.
- VRM virtual record manager
- the vault 142 queries the VRM 154 using an internal account ID of the registered user as a parameter of the query.
- the VRM 154 provides the name, value, and an internal ID of every field in which the user has stored information.
- the vault 142 also provides to the user the information stored in each of these fields.
- the vault 142 Upon user modification of any of the user's information fields, the vault 142 provides to the VRM 154 the fields that have changed and the VRM 154 subsequently stores the modifications in the database 160 .
- the vault 142 directs the VRM 154 to allocate memory for the new field.
- the VRM 154 operates to allocate sufficient memory to store the new field and the related information depending on the type of the field created, such as text or numeral, simple or complex, and the like.
- the contact manager 148 is an application similar to a conventional address book application, but providing a number of novel features.
- the contact manager 148 provides to users a utility for saving information about their contacts, i.e., people with whom the users desire to keep communicative contact.
- the contact manager 148 differentiates between two types of contacts, static and dynamic contacts.
- Static contacts are defined as those in which information is provided to the system 102 by a user. For example, an individual user could employ the system to store the name of a friend and an associated home and work phone numbers and home address, whereby this information is not provided to the system directly by friend. If the friend were to change residence (and hence home address and home phone number), the user would need to re-enter these changes into the system 102 .
- dynamic contacts are those in which information is provided to the system 102 directly by the contact person and is shared with others through operation of embodiments of the system 102 .
- a user desires to have a friend's information in a personal list of contacts managed in the system 102 and if the friend is a registered user of the system 102 , the user does not need to provide the friend's information to the system.
- the friend would directly save personal information in the system 102 , utilizing the vault 142 application as previously described.
- the friend would then permit the system 102 to share portions of personal information, e.g., home and office phone numbers, with the user.
- the user would consequently find the personal list of contacts to include the friend with the relevant information that the user has is permitted to access and view.
- the system 102 primarily through operation of a data exchange engine 156 of exchange engine layer 150 and permissions data 166 of database 160 , provides the capability for the friend to manage access to personal information by directing the contact manager 148 to share this or any other personal information with the user for a defined period of time only. After expiration of this defined period, the user will no longer be able to view the friend's information.
- the contact manager 148 manages the information about each registered user's static contacts by storing these in the database 160 and retrieving it when necessary.
- the contact manager 148 invokes the VRM 154 and the data exchange engine (DXE) 156 .
- the contact manager 148 first invokes the account manager 152 to verify that the user logging in to the system 102 is a registered user and to retrieve the internal account ID of the user.
- the contact manager 148 would then communicate with the VRM 154 , providing the VRM 154 with the account ID of the registered user.
- the VRM 154 is operative to retrieve from the database 160 and to present to the user the names and account IDs of the user's dynamic contacts.
- the contact manager 148 then invokes the DXE 156 to determine which fields of each dynamic contact are being shared with this registered user.
- the contact manager 148 invokes the VRM 154 to read the contents of the shared fields.
- the system 102 is capable of then providing the content of these fields to the appropriate interface layer server 131 - 139 , for transmission to the associated client platform 111 - 119 .
- the contact manager 148 provides a rich set of information about a user's contacts, including every piece of information that the contact registered user allows one to see.
- the contact manager 148 provides the capability for the user to query the contact manager 148 in order to determine who has actually viewed which personal information fields in their information repository.
- the system 102 will automatically stop sharing this information upon expiration of the associated time limit.
- the exchange engine layer 150 which comprises the account manager 152 , the virtual record manager (VRM) 154 , the data exchange engine (DXE) 156 , and the encryption engine 158 .
- the account manager 152 manages account information about each registered user. This information includes, but is not limited to, whether a user is a business or individual user, their internal account ID and password, the last time they logged into the system 102 , whether their registration is still active, etc.
- the account manager 152 also implements security rules that inactivate a registered user's account upon certain occurrences or non-occurrences. For example, registered users are considered inactive and thus their accounts inactivated if they do not login to the system 102 at least once every six months. Additionally, users may be locked out of the system 102 for a 24-hour period if they unsuccessfully attempt to login four times during any four-month window.
- the account manager 152 preferably stores the relevant account information in a table of a relational database. Each row of the table is configured to store information about one registered user. The columns of the table are preferably configured to represent the registered user's password, the last time they logged in to the system 102 , whether the user is locked out for a security reason, whether the user has changed the login name and the previous login name, and the like. Those skilled in the art may recognize that the information stored and managed by the account manager may include more than those items listed above and still be within the scope of the present invention.
- the virtual record manager (VRM) 154 is configured to manage the storage of data preferably utilizing a conventional relational database.
- the VRM 154 supports complex data type (record) modeling while maintaining access and control of data on an individual field basis.
- the VRM 154 architecture supports operations on a single-field record, an entire complex (multi-field) record, or an individual field within a complex record.
- the VRM 154 is configured to provide a fully dynamic extensible data store mechanism whereby new instances of data records as well as entirely new and possibly unique data types may be defined “on the fly,” or substantially instantaneous, for each user, without the need for any system downtime to perform such operations.
- the VRM 154 operates at the level of a single field of information. For instance, each field of information is assigned a unique ID so that operations can be performed on individual fields.
- the fields are also defined for a particular user of the system, although sharing of fields between users is possible by employing the DXE 156 .
- the information fields are also typed, allowing type-specific behavior (input data validation, for example) to be implemented.
- VRM utilizes the concept of a virtual object (VOB) (not shown).
- VOB defines a record structure (logical collection of individual data fields), and also supports the ability to arbitrarily nest record structures. Any number of VOB types can be defined, either globally accessible by all users or per user of the system, and each VOB type is assigned a unique VOB type ID.
- VOB type information provides the metadata, which is generally a definition or description of the data, for the VRM 156 to dynamically support arbitrary data types and is stored in the VOB and VOB Field of the following database 160 table.
- VOB Metadata for Virtual Objects describing elements such as the VOB type name, VOB Type ID, etc. There is one row for each VOB type defined.
- VOB_Field Metadata describing the individual fields defined for each VOB. There is one row for each field within a virtual object.
- the VRM 154 searches for the metadata for the requested VOB type (via it's unique VOB type ID) and creates a record to reflect the VOB instance (in the VOB_Data table), in addition to all of the individual fields defined for the VOB (in the VOB_Field_Data table).
- This data structure is depicted in the following database 160 table.
- VOB_Data Instances of VOB types There is one record for every VOB that is instantiated. Each VOB is instantiated for a particular user account.
- VOB_Field_Data Data for each VOB instance. There is a row for each field defined for an instantiated VOB type.
- the VRM 154 also supports the ability to control the VOB types available to a particular user based on their user class. For example, the VOB types available to business users can be defined to be different than those available for individual users.
- the VRM 154 also supports two additional concepts, InfoCards and VRecords.
- InfoCards provide a convenient way for users to share their information using the DXE 156 .
- An InfoCard allows a user to define a specific collection of information fields. It is noted that InfoCards differ from VOBs in that they can only be defined from a set of already defined fields, and that the fields selected can actually span across VOBs. To ensure a minimum set of data may be exchanged between any two user accounts, the VRM 154 may pre-populate every user account with a minimum set of VOBs, and define a set of system-defined InfoCards that use those VOBs. The operability of the InfoCard feature is provided primarily by the database 160 table depicted.
- Field_Group Contains InfoCards. There is a row for each InfoCard defined for a user account.
- Field_Group_Data Defines the fields that belong to each InfoCard defined. There is a row for each field that is defined within an InfoCard.
- VRecords provide a generic mechanism for the electronic exchange of information with third-party systems, a valuable feature for business-to-business (B2B) electronic commerce.
- a third party has a data record format that they wish to have returned from the system 102 when requesting information about a particular registered user of the system 102 .
- the VRecord defines a mapping between the third party record format, and the native system 102 record structure as primarily defined by the metadata 164 of database 160 . Employment of a VRecords further allows a user to define a mapping based on the user class (e.g. a different mapping can be defined for business and individual users).
- This VRecords feature operates by correlating a field ID for each class of user with an output field name selected by the VRecord author. The operability of the VRecords feature is provided primarily by the database 160 table depicted.
- VRecord Contains VRecords.
- VRecord_Dynamic_Data Defines field mapping for obtaining information from system 102 member accounts.
- VRecord_Static_Data Defines field mapping for obtaining information for static contacts defined in the system 102 contact manager 148 for the requesting party. Primarily useful for synchronization applications.
- VRM 154 Some of the operational capability of the VRM 154 is exemplified below by describing the effect that occurs in certain tables of database 160 when a transaction is implemented.
- This example demonstrates the database 160 changes that occur when a new VOB type is defined in the system 102 .
- a user desires to define a new record named “Friend” that has the following fields:
- This example demonstrates the database 160 changes that occur when a user adds a new data record to the system 102 . Assume that a user wishes to add a new data record to their account of type “Friend” as was defined in the previous example, with the following values:
- VOB_Data table Assuming that the user's account ID is 250, the last VOB_ID used for the account was 500, the last Field_ID used for the account was 1250 and the user wishes to name this record “Tom Smith”, this operation creates the following row in the VOB_Data table:
- the primary database 160 tables with which the VRM 154 interacts to provide the capabilities described above are presented. Presentation of these exemplary tables is not intended to limit practice of the invention to use of only these tables or the specific data table structure presented, for those skilled in the art will recognize that a different data and table architecture may be implemented and still fall within the scope of the invention.
- VOB_Type_ID Number Yes Unique ID in the scope of Account_ID for this VOB type.
- VOB_Name Text No Name of the VOB type.
- VOB_Description Text No A description of the VOB type.
- XML_Tag_Name Text No A name to use for this type when translating to an XML representation.
- VOB_Field table structure for an exemplary embodiment is as follows:
- Field_Order Number Yes Specifies the relative order of this field within the VOB Type.
- Field_Default_Value Text No Default value for the field.
- VOB_Field_Data table structure for an exemplary embodiment is as follows:
- VOB_Field_Data Primary Column Type Key Description
- Account_ID Number Yes Unique ID that identifies the user account for which the VOB instance is defined.
- Field_ID Number Yes Unique ID of this field record in the scope of Account_ID.
- VOB_ID Number No ID of the VOB that is the owner of this field. See VOB_Data::VOB_ID.
- Field_Order Number No Order of this field within the parent VOB.
- Field_Value Text No Value of the field.
- Encryption Number No Indicates the type of encryption applied to the field.
- Public_Field_ID Text No Field ID that may be used via the B2B interface 119 to reference this field.
- the Field_Group table structure for an exemplary embodiment utilizing the InfoCard feature is as follows:
- the Field_Group_Data table structure for an exemplary embodiment utilizing the InfoCard feature is as follows:
- the VRecord_Dynamic_Data table structure for an exemplary embodiment is as follows:
- Account_Type_ID Number Yes Indicates the user class that this mapping record applies to (e.g. business or individual account).
- the VRecord_Static_Data table structure for an exemplary embodiment is as follows:
- the data exchange engine (DXE) 156 supports the exchange of information between users of the system 102 .
- the DXE 156 provides interfaces to enable users to request information from each other, approve or deny requests for information, and provide authorized information.
- the DXE 156 also supports the definition and enforcement of rule-based behaviors on the availability of information, sharing of information in a global space (public directory), sharing of simple text messages, and event triggers based on requests and changes to authorized information.
- registered users may request either globally defined InfoCards (see the description of InfoCards above) of information, or globally defined fields of information from the other user.
- the DXE 156 provides event notification hooks for requests for information and messages. Users may approve or deny the request by InfoCard or field, and apply rules regarding access to any provided information, e.g., specifying an expiration date for access to the information. Furthermore, users may also provide any field or InfoCard to another user at any time.
- the DXE 156 further provides interfaces for registered users to view information made available to them from other registered users. It is noted that when a user changes a field that has been shared, the changed information is available to other users immediately. This functionality is operative due to the DXE 156 architecture, which provides event notification hooks for changes to information that is available to other users.
- the DXE 156 is operative to track relationships between users in a Data_Sharing table. Each record represents what is shared from user A to user B. A record exists only if user A is sharing one or fields with user B. In addition, if user B shares information with user A, an additional record appears in the Data_Sharing table. It is in this table that any rules regarding the sharing of information between the two users is defined.
- users can share information either by specifying individual fields of information, or by using the InfoCards feature.
- This sharing information is tracked by the DXE 156 in the Data_Sharing_Field_ID and Data_Sharing_Group_ID tables (shown below), respectively.
- the DXE 156 architecture explicitly normalizes this data in the database 160 to enable the capability to perform reverse lookups of shared information, e.g., finding all users that you are sharing your home phone number with. It is noted that there is one InfoCard that the DXE 156 treats specially, the Directory InfoCard.
- the Directory InfoCard is given the same ID for all users (which uniquely identifies it as the Directory InfoCard) and has the behavior attribute that all fields defined within this Infocard are implicitly shared with all other users. For example, when an application in the application layer 140 requests the information being shared by user A with user B, the system 102 returns all of the fields explicitly shared by A with B, and all the fields that A has placed in his/her Directory InfoCard.
- the primary database 160 tables with which the DXE 156 interacts to provide the capabilities described above are presented. Presentation of these exemplary tables is not intended to limit practice of the invention to utilization of only these tables or the specific data table structure presented, for those skilled in the art will recognize that a different data and table architecture may be implemented and still fall within the scope of the invention.
- the Data_Sharing table structure for an exemplary embodiment is as follows:
- Expiration_Date Date/Time No Access to information expires on this date. Date_Granted Date/Time No Access to information was originally granted on this date. Date_Modified Date/Time No Access to information was last modified on this date.
- the Data_Sharing_Field_ID table structure for an exemplary embodiment is as follows:
- the Data_Sharing_Group_ID table structure for an exemplary embodiment is as follows:
- the encryption engine 158 provides to the VRM 154 and the DXE 156 the capability to save and access raw data that has been encrypted in the relational database 160 . This feature is critical to ensuring the security of data that is saved by the system 102 , for unencrypted data in a database is very vulnerable to attack, even within what is considered a secure network.
- All data read and write requests to the database 160 are implemented through the encryption engine 158 , making the task of encrypting and decrypting transparent to all other layers of the system 102 architecture.
- the encryption engine 158 supports a plurality of conventional encryption schemes on a per field basis. For example, one field in a record may be encrypted using 128-bit symmetric encryption, while another field in the same record may be saved with no encryption at all.
- the encryption engine 158 architecture also allows encryption keys to be stored physically separate from the database 160 server hosting the encrypted data. Employment of this feature makes it even more difficult to covertly obtain raw information from the database 160 .
- the database 160 comprises data 162 (user personal information) encrypted by the encryption engine 158 , metadata 164 as described above primarily in reference to the VRM 154 , and permissions information 166 as described above primarily in reference to the DXE 156 .
- data 162 user personal information
- metadata 164 as described above primarily in reference to the VRM 154
- permissions information 166 as described above primarily in reference to the DXE 156 .
- the VRM 154 and the DXE 156 interact with the database 160 any time a user's personal information is created, edited, or accessed.
- the interface layer 130 preferably comprising the WAP (wireless application protocol) interface server 131 , the web clipping interface server 133 , the sync interface server 135 , the web interface server 137 , and the B2B interface server 139 .
- the interface layer 130 is configured to manage the user interaction with the system 102 .
- the different interface servers 131 - 139 communicate with various client side devices or software across a network 120 , preferably a WAN such as the Internet, and manage the user interaction with the system 102 utilizing the communication protocol that is appropriate for the client side device or client side software.
- the interface servers 131 - 139 invoke various internal components of the system 102 , namely the account manager 152 , the vault 142 and the DXE 156 , to retrieve, edit, and store information.
- the WAP interface server 131 is focused on interfacing with WAP devices 111 utilizing the wireless application protocol, such as Internet-enabled mobile phones or similar wireless communication devices.
- the web clipping interface server 133 is focused on interfacing with wireless handheld electronic devices 113 , such as personal digital assistants (PDAs), communicating over a wireless medium utilizing the web clipping protocol.
- the web interface server 137 is focused on interfacing with users accessing the system 102 via a conventional web browser 117 .
- the web interface server 137 preferably utilizes the secure hypertext transfer protocol (https).
- the contact manager 148 manages the list of contacts of a user as described above.
- the sync interface server 135 provides the interface for synchronizing the contact information stored in the system 102 with other conventional client address books resident on various user handheld or desktop devices.
- the sync interface server 135 is configured to communicate with client synchronization software 115 residing on the various user handheld or desktop devices, via the network 102 .
- the B2B interface server 139 provides an application programming interface (API) for registered users to login to the system 102 and to query for their information or for information about their contacts. Additional exemplary operations include changing (add/delete/edit) their personal information, sharing their personal information with others, requesting others to share their information, and all the other functionality offered by the vault 142 and the contact manager 148 applications.
- the B2B interface server 139 communicates with client users utilizing https. Upon a client transmission of a request to do a certain action (e.g., manipulate information data 162 or permissions data 166 ), the request is made to the system 102 using the POST command of http and, possibly, described using XML (eXtended Markup Language).
- the B2B interface server 139 processes the request and invokes the account manager 152 , the vault 142 , and the contact manager 148 to perform appropriate subtasks within the request. These three subsystems return information or completion status to the B2B interface server 139 , which then appropriately replies to the client request using the language of XML. Through this XML request-reply mechanism, the user can exercise all the functionality of the system 102 described above.
- the B2B interface client 119 depicts any software that can communicate over the https protocol and send requests and receive replies from the B2B interface server 139 .
- the B2B interface client 119 application is intended to be written by users of the system 102 , with the goal of integrating the information exchange service provided by the system 102 with other user databases containing personal or business information. For example, if a user of the system 102 maintains a list of customers and their contact information in an enterprise database, this user can write a B2B interface client 119 application to interface with the B2B interface server 139 , and thus the system 102 .
- the user can access contact information about his customers from the system 102 and store this contact information in the local enterprise database. This feature enables the user's customer information stored on the enterprise database to maintain synchronization with the information in the system 102 .
- a business model is contemplated that would utilize the system 102 to provide a myriad of information services to businesses for a fee.
- the services provided by the system 102 assist the business in minimizing their database maintenance costs, reducing customer service/call center costs, and improving sales and marketing activities.
- Some exemplary services may include, but are not limited to, the following: (1) providing accurate, timely customer record updates, thus increasing the efficiency of marketing programs; (2) reducing customer service costs through minimization of call length by facilitating the identification of callers through their system 102 ID, thus providing instant access to the information necessary to resolve the customer complaint/inquiry; (3) maintaining company employee and vendor information through the system 102 , either in a distributed manner as described above in reference to the contact manager 148 or through an independent system 102 licensed to the company; (4) listing company information in a business directory maintained by the system 102 , which could be used in lieu of or to augment conventional directories such as the white and yellow pages; (5) simplifying customer electronic purchases by enabling customers to register with their site and perform transactions utilizing their system 102 ID and associated information, thus increasing the volume of completed transactions; (6) displaying privacy policies to customers and matching those policies with privacy preferences of the customer maintained by the system 102 ; (7) maintaining a digital certificate registry to search and track digital certificates of users so that the certificate authority can be automatically notified when a user
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Business, Economics & Management (AREA)
- Computer Security & Cryptography (AREA)
- Strategic Management (AREA)
- Human Resources & Organizations (AREA)
- Entrepreneurship & Innovation (AREA)
- Economics (AREA)
- General Business, Economics & Management (AREA)
- Tourism & Hospitality (AREA)
- Quality & Reliability (AREA)
- Operations Research (AREA)
- Marketing (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- Software Systems (AREA)
- Storage Device Security (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
A virtual record manager and a data exchange engine are provided for dynamically defining data records in a database and for dynamically allocating instances of defined data records. These components are capable of mediating between the database and application and client interface layers to facilitate exchange of information over a network. Embodiments are configured to allow complex data records having a plurality of related fields, and to allow management and exchange of information at both the data field level and data record level.
  Description
-  This application is a Continuation of and claims priority to U.S. patent application Ser. No. 14/987,716, filed Jan. 4, 2016, of same title, recently allowed, which application is a Continuation of and claims priority to U.S. patent application Ser. No. 14/461,346, filed Aug. 15, 2014, of same title, now U.S. Pat. No. 9,229,962, which is a Continuation and claims priority to U.S. patent application Ser. No. 13/327,719, filed Dec. 15, 2011, of same title, now U.S. Pat. No. 8,812,548, which is a Continuation-in-Part and claims priority to U.S. patent application Ser. No. 12/848,166, filed Jul. 31, 2010, of same title, now U.S. Pat. No. 8,099,435, which is a Continuation-in-Part of and claims priority to U.S. patent application Ser. No. 09/742,699, filed on Dec. 20, 2000, of same title, now U.S. Pat. No. 7,788,222, which application claims priority from U.S. Provisional Patent Application No. 60/172,977, filed on Dec. 20, 1999, entitled “Web-Based Personal Data Repository and Access Management System and Methods of Use Thereof,” which all applications are incorporated herein in their entirety by this reference.
-  Field of the Invention
-  The present invention relates generally to information technology, and more particularly to systems and methods for providing dynamic creation, storage and exchange of personal information.
-  Description of Related Art
-  With the evolution of social interaction, people feel the need to exchange personal and business information with each other. In addition, with the advancement and proliferation of communication technology, people have acquired more and more personal contact information, such as electronic mail addresses, mobile phone numbers, and the like. These issues, coupled with the dynamic nature of society, has created a need for an easier, more accurate way to store personal information, to maintain its accuracy and currentness, and to exchange it with others.
-  With the advancement and proliferation of computer network technology, people and businesses have increasingly relied on computers, computer networks, handheld electronic devices, and the like to manage their vast amount of personal and business information. Thus, there is a further need for convergence of a robust data management system with network communication technologies to fill the need for a flexible, easily updateable, real-time information exchange mechanism.
-  An information exchange system which provides a critical infrastructure layer, and methods of user thereof, are described. The information exchange system provides a tool for dynamically defining data records and dynamically allocating instances of those records. The system further provides a tool for facilitating electronic exchange of personal information represented by the data, such as contact, payment, shipping, and other information, between individuals and the people and businesses with which they interact. The system allows editing and sharing of information at a data field level, in addition to supporting information transactions at a complex level, defined as a combination of related fields. The architecture of one embodiment is such that the system can be coupled with a conventional relational database application.
-  The information exchange system comprises an interface layer providing a tool for users to interact with the system through a plurality of client-side platforms. The system also comprises an application layer comprising a vault providing a storage mechanism for individual and business users to store information about themselves and/or their business, and a contact manager providing a utility for saving information about static and dynamic contacts.
-  The system further comprises a critical exchange engine layer comprising an account manager, a virtual record manager, a data exchange engine, and an encryption engine which provides the capability to save and access raw data that has been encrypted in a relational database. The virtual record manager is configured to manage the storage of data, whereby support for complex data records is supported while maintaining access and control of data on an individual field basis. The data exchange engine supports the exchange of information between system users and the definition and enforcement of rule-based behaviors on the availability of information.
-  A database is provided in one embodiment for storage of encrypted personal information of system users, for storage of metadata describing the structure and description of the personal information stored in the database, and for storage of permissions data describing sharing and accessibility rules related to the fields of information.
-  The system generally provides a private, accurate, convenient, and secure method of maintaining and accessing up-to-date information at any time from anywhere. Users are able to expand and customize their information readily and in real-time. The information in the robust data repository can be accessed through a WAN such as the Internet or through various handheld wireless devices. Upon a change of information, all persons that have permission to view that information field are alerted and updated automatically with the new data.
-  Although uses of the information exchange system described herein are many, several are provided for exemplary purposes. Exemplary uses for an individual user which are provided by the system include: (1) requesting a summary of information that has changed for people, groups, or businesses in their network of contacts, possibly through a personal newsletter or as highlighted boxes on a system home page, thus being automatically informed of changes; (2) maintaining a community address book whereby clubs, organizations, chat groups, etc. can maintain current information on members which can be reflected in distribution lists or instant messaging buddy lists linked to the system; (3) drawing on information already stored in the system to save time filling out on-line registration, commerce, and site log-in forms preferably by supplying a system ID to the site of interest which is linked to personal, commerce, and site specific user name/password information of the user; and (4) automatically notify friends, relatives, and businesses when a user moves, providing the new personal information immediately.
-  The present invention is illustrated by way of example, and not by way of limitation, in the FIGURES of the accompanying drawing and in which like reference numerals refer to similar elements and in which:
-  FIG. 1 depicts a preferred operating architecture of an information exchange system, according to an embodiment of the invention.
-  The present invention will now be described in detail with reference to several embodiments thereof as illustrated in the accompanying drawings. In the following description, numerous specific details are set forth in order to provide a thorough understanding of embodiments of the present invention. It will be apparent, however, to one skilled in the art, that embodiments may be practiced without some or all of these specific details. In other instances, well known process steps and/or structures have not been described in detail in order to not unnecessarily obscure the present invention. The features and advantages of embodiments may be better understood with reference to the drawings and discussions that follow.
-  Aspects, features and advantages of exemplary embodiments of the present invention will become better understood with regard to the following description in connection with the accompanying drawing(s). It should be apparent to those skilled in the art that the described embodiments of the present invention provided herein are illustrative only and not limiting, having been presented by way of example only. All features disclosed in this description may be replaced by alternative features serving the same or similar purpose, unless expressly stated otherwise. Therefore, numerous other embodiments of the modifications thereof are contemplated as falling within the scope of the present invention as defined herein and equivalents thereto. Hence, use of absolute and/or sequential terms, such as, for example, “will,” “will not,” “shall,” “shall not,” “must,” “must not,” “consist”, “only,” “first,” “initially,” “next,” “subsequently,” “before,” “after,” “lastly,” and “finally,” are not meant to limit the scope of the present invention as the embodiments disclosed herein are merely exemplary.
-  FIG. 1 depicts a preferredoperating architecture 100 of the information exchange system 102 described herein. Theoverall system architecture 100 is based on a network client-server model, whereinvarious client 110 platforms communicate with a layer ofapplications 140 through anetwork 120. Since the information exchange system 102 supports a plurality of client platforms (which are discussed in detail below), aninterface layer 130 comprising interface servers is provided for interacting with the plurality of client-side platforms. The information that is exchanged by users of the system 102 is maintained in adatabase 160. The critical infrastructure layer that primarily provides the operational capability of the system 102 to facilitate the storage, modification, and exchange of information for people and businesses lies in theexchange engine layer 150.
-  Theapplication layer 140 and its components are described prior to the detailed description of theinterface layer 130, so it is noted that a client user interacts with the system 102 and itsapplication layer 140 through theinterface layer 130. Theapplication layer 140 contains avault 142 and acontact manager 148. The vault is depicted as containing constituent elements for individual 144 andbusiness 146 applications for didactic purposes, but configurations are contemplated wherein the needs of both individual and business users are provided by asingle vault 142 application.
-  Thevault 142 is an application that provides a storage mechanism for registered individual and business users of the system 102 to store information about themselves and/or their business. Non-limiting examples of an individual user's information include name, home and office addresses, home, office, mobile phone and various other phone numbers, date of birth, as well as similar information about the user's spouse and children. Additional examples include names and membership numbers related to various organizations of which the user is a member, bank and mortgage information, and similar information. A user's information may be described within the system 102 in relation to various permission groups to facilitate management by the user, e.g., groups such as “family,” “work,” “financial,” “social,” “recreational,” etc. Non-limiting examples of a business user's information include the business name, address of their headquarters and branch offices, names of the company executives, Dun and Bradstreet number, tax identification number, bank account information, membership in various organizations, etc.
-  Thevault 142 presents the registered user with a number of fields with predefined semantics. To this end, thevault 142 utilizes information stored and managed by theaccount manager engine 152, to know if the user is a business user or an individual user. For example, thevault 142 may present “name” and “home address” fields to an individual user, whereas it may present “office phone number” and “D&B number” fields to a business user. The number of fields of information and the nature of the fields are decided by each registered user of the system, and are not limited to those presented. Consequently, the exchange system 102 is configured to facilitate the exchange of dynamic, user-defined information and types of information.
-  Thevault 142 invokes the virtual record manager (VRM) 154 ofexchange engine layer 150 to actually store and retrieve the information. In managing the information, thevault 142 queries theVRM 154 using an internal account ID of the registered user as a parameter of the query. TheVRM 154 provides the name, value, and an internal ID of every field in which the user has stored information. Thevault 142 also provides to the user the information stored in each of these fields. Upon user modification of any of the user's information fields, thevault 142 provides to theVRM 154 the fields that have changed and theVRM 154 subsequently stores the modifications in thedatabase 160. Upon user creation of a new field of a particular type, thevault 142 directs theVRM 154 to allocate memory for the new field. TheVRM 154 operates to allocate sufficient memory to store the new field and the related information depending on the type of the field created, such as text or numeral, simple or complex, and the like.
-  Thecontact manager 148 is an application similar to a conventional address book application, but providing a number of novel features. Thecontact manager 148 provides to users a utility for saving information about their contacts, i.e., people with whom the users desire to keep communicative contact. Thecontact manager 148 differentiates between two types of contacts, static and dynamic contacts.
-  Static contacts are defined as those in which information is provided to the system 102 by a user. For example, an individual user could employ the system to store the name of a friend and an associated home and work phone numbers and home address, whereby this information is not provided to the system directly by friend. If the friend were to change residence (and hence home address and home phone number), the user would need to re-enter these changes into the system 102.
-  In contrast, dynamic contacts are those in which information is provided to the system 102 directly by the contact person and is shared with others through operation of embodiments of the system 102. For example, if a user desires to have a friend's information in a personal list of contacts managed in the system 102 and if the friend is a registered user of the system 102, the user does not need to provide the friend's information to the system. The friend would directly save personal information in the system 102, utilizing thevault 142 application as previously described. The friend would then permit the system 102 to share portions of personal information, e.g., home and office phone numbers, with the user. The user would consequently find the personal list of contacts to include the friend with the relevant information that the user has is permitted to access and view. If the friend were to modify any portion of the information that is being shared with the user, the user will be able to view the new information when viewing the personal contact list. In addition, the system 102, primarily through operation of adata exchange engine 156 ofexchange engine layer 150 andpermissions data 166 ofdatabase 160, provides the capability for the friend to manage access to personal information by directing thecontact manager 148 to share this or any other personal information with the user for a defined period of time only. After expiration of this defined period, the user will no longer be able to view the friend's information.
-  Thecontact manager 148 manages the information about each registered user's static contacts by storing these in thedatabase 160 and retrieving it when necessary. In contrast, to manage dynamic contacts thecontact manager 148 invokes theVRM 154 and the data exchange engine (DXE) 156. Thecontact manager 148 first invokes theaccount manager 152 to verify that the user logging in to the system 102 is a registered user and to retrieve the internal account ID of the user. Thecontact manager 148 would then communicate with theVRM 154, providing theVRM 154 with the account ID of the registered user. TheVRM 154 is operative to retrieve from thedatabase 160 and to present to the user the names and account IDs of the user's dynamic contacts. Thecontact manager 148 then invokes theDXE 156 to determine which fields of each dynamic contact are being shared with this registered user.
-  Once thecontact manager 148 is familiar with the fields (represented as field IDs) shared by one registered user with another (i.e., shared by the dynamic contact with the logged-in user), it invokes theVRM 154 to read the contents of the shared fields. The system 102 is capable of then providing the content of these fields to the appropriate interface layer server 131-139, for transmission to the associated client platform 111-119.
-  It is noteworthy that thecontact manager 148 provides a rich set of information about a user's contacts, including every piece of information that the contact registered user allows one to see. In addition, thecontact manager 148 provides the capability for the user to query thecontact manager 148 in order to determine who has actually viewed which personal information fields in their information repository. Furthermore, if a personal information field has been constructed as time-limited, the system 102 will automatically stop sharing this information upon expiration of the associated time limit.
-  Reference is directed to theexchange engine layer 150, which comprises theaccount manager 152, the virtual record manager (VRM) 154, the data exchange engine (DXE) 156, and theencryption engine 158. Theaccount manager 152 manages account information about each registered user. This information includes, but is not limited to, whether a user is a business or individual user, their internal account ID and password, the last time they logged into the system 102, whether their registration is still active, etc. Theaccount manager 152 also implements security rules that inactivate a registered user's account upon certain occurrences or non-occurrences. For example, registered users are considered inactive and thus their accounts inactivated if they do not login to the system 102 at least once every six months. Additionally, users may be locked out of the system 102 for a 24-hour period if they unsuccessfully attempt to login four times during any four-month window.
-  Theaccount manager 152 preferably stores the relevant account information in a table of a relational database. Each row of the table is configured to store information about one registered user. The columns of the table are preferably configured to represent the registered user's password, the last time they logged in to the system 102, whether the user is locked out for a security reason, whether the user has changed the login name and the previous login name, and the like. Those skilled in the art may recognize that the information stored and managed by the account manager may include more than those items listed above and still be within the scope of the present invention.
-  The virtual record manager (VRM) 154 is configured to manage the storage of data preferably utilizing a conventional relational database. TheVRM 154 supports complex data type (record) modeling while maintaining access and control of data on an individual field basis. For example, theVRM 154 architecture supports operations on a single-field record, an entire complex (multi-field) record, or an individual field within a complex record. Furthermore, theVRM 154 is configured to provide a fully dynamic extensible data store mechanism whereby new instances of data records as well as entirely new and possibly unique data types may be defined “on the fly,” or substantially instantaneous, for each user, without the need for any system downtime to perform such operations.
-  TheVRM 154 operates at the level of a single field of information. For instance, each field of information is assigned a unique ID so that operations can be performed on individual fields. The fields are also defined for a particular user of the system, although sharing of fields between users is possible by employing theDXE 156. The information fields are also typed, allowing type-specific behavior (input data validation, for example) to be implemented.
-  To support record-level data modeling, the VRM utilizes the concept of a virtual object (VOB) (not shown). The VOB defines a record structure (logical collection of individual data fields), and also supports the ability to arbitrarily nest record structures. Any number of VOB types can be defined, either globally accessible by all users or per user of the system, and each VOB type is assigned a unique VOB type ID. VOB type information provides the metadata, which is generally a definition or description of the data, for theVRM 156 to dynamically support arbitrary data types and is stored in the VOB and VOB Field of the followingdatabase 160 table.
-  TABLE 1 Database Table Description VOB Metadata for Virtual Objects (VOBs) describing elements such as the VOB type name, VOB Type ID, etc. There is one row for each VOB type defined. VOB_Field Metadata describing the individual fields defined for each VOB. There is one row for each field within a virtual object. 
-  When a new VOB is defined by a user, theVRM 154 searches for the metadata for the requested VOB type (via it's unique VOB type ID) and creates a record to reflect the VOB instance (in the VOB_Data table), in addition to all of the individual fields defined for the VOB (in the VOB_Field_Data table). This data structure is depicted in the followingdatabase 160 table.
-  TABLE 2 Database Table Description VOB_Data Instances of VOB types. There is one record for every VOB that is instantiated. Each VOB is instantiated for a particular user account. VOB_Field_Data Data for each VOB instance. There is a row for each field defined for an instantiated VOB type. 
-  TheVRM 154 also supports the ability to control the VOB types available to a particular user based on their user class. For example, the VOB types available to business users can be defined to be different than those available for individual users.
-  In addition to VOBs, theVRM 154 also supports two additional concepts, InfoCards and VRecords. InfoCards provide a convenient way for users to share their information using theDXE 156. An InfoCard allows a user to define a specific collection of information fields. It is noted that InfoCards differ from VOBs in that they can only be defined from a set of already defined fields, and that the fields selected can actually span across VOBs. To ensure a minimum set of data may be exchanged between any two user accounts, theVRM 154 may pre-populate every user account with a minimum set of VOBs, and define a set of system-defined InfoCards that use those VOBs. The operability of the InfoCard feature is provided primarily by thedatabase 160 table depicted.
-  TABLE 3 Database Table Description Field_Group Contains InfoCards. There is a row for each InfoCard defined for a user account. Field_Group_Data Defines the fields that belong to each InfoCard defined. There is a row for each field that is defined within an InfoCard. 
-  VRecords provide a generic mechanism for the electronic exchange of information with third-party systems, a valuable feature for business-to-business (B2B) electronic commerce. In many cases, a third party has a data record format that they wish to have returned from the system 102 when requesting information about a particular registered user of the system 102. The VRecord defines a mapping between the third party record format, and the native system 102 record structure as primarily defined by themetadata 164 ofdatabase 160. Employment of a VRecords further allows a user to define a mapping based on the user class (e.g. a different mapping can be defined for business and individual users). This VRecords feature operates by correlating a field ID for each class of user with an output field name selected by the VRecord author. The operability of the VRecords feature is provided primarily by thedatabase 160 table depicted.
-  TABLE 4 Database Table Description VRecord Contains VRecords. VRecord_Dynamic_Data Defines field mapping for obtaining information from system 102 member accounts. VRecord_Static_Data Defines field mapping for obtaining information for static contacts defined in the system 102 contact manager 148 for the requesting party. Primarily useful for synchronization applications. 
-  Some of the operational capability of theVRM 154 is exemplified below by describing the effect that occurs in certain tables ofdatabase 160 when a transaction is implemented.
-  This example demonstrates thedatabase 160 changes that occur when a new VOB type is defined in the system 102. Assume that a user desires to define a new record named “Friend” that has the following fields:
-  - First Name
- Last Name
- PhoneNumber
 
-  Assuming this is done for user account 250, and that the last VOB Type ID used was 200, this operation creates the following row in the VOB table:
-  TABLE 5 Account_ID VOB_Type_ID VOB_Name VOB_Description 250 205 Friend Record for adding a friend 
-  It also creates the following rows in the VOB_Field table:
-  TABLE 6 Account_ID VOB_Type_ID Field_Order Field_Label Field_Type_ID 250 205 5 First Name 1 250 205 10 Last Name 1 250 205 15 PhoneNumber 1 
 Note that in this example, the Field_Type_ID of 1 indicates that these are text fields.
-  This example demonstrates thedatabase 160 changes that occur when a user adds a new data record to the system 102. Assume that a user wishes to add a new data record to their account of type “Friend” as was defined in the previous example, with the following values:
-  - First Name: Tom
- Last Name: Smith
- Phone Number: 555-1212
 
-  Assuming that the user's account ID is 250, the last VOB_ID used for the account was 500, the last Field_ID used for the account was 1250 and the user wishes to name this record “Tom Smith”, this operation creates the following row in the VOB_Data table:
-  TABLE 7 Account_ID VOB_ID VOB_Type_ID VOB_Label 250 505 205 Tom Smith 
-  It also creates the following rows in the VOB_Field_Data table:
-  TABLE 8 Account_ID Field_ID VOB_ID Field_Order Field_Value 250 1255 505 5 Tom 250 1260 505 10 Smith 250 1265 505 15 555-1212 
-  In at least one embodiment, theprimary database 160 tables with which theVRM 154 interacts to provide the capabilities described above are presented. Presentation of these exemplary tables is not intended to limit practice of the invention to use of only these tables or the specific data table structure presented, for those skilled in the art will recognize that a different data and table architecture may be implemented and still fall within the scope of the invention.
-  The VOB table structure for an exemplary embodiment is as follows:
-  TABLE 9 Primary VOB Table Column Type Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VOB type is defined. VOB_Type_ID Number Yes Unique ID in the scope of Account_ID for this VOB type. VOB_Name Text No Name of the VOB type. VOB_Description Text No A description of the VOB type. XML_Tag_Name Text No A name to use for this type when translating to an XML representation. 
-  The VOB_Field table structure for an exemplary embodiment is as follows:
-  TABLE 10 Primary VOB_Field Column Type Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VOB type is defined. VOB_Type_ID Number Yes ID of the VOB Type of which this field is a member. Field_Order Number Yes Specifies the relative order of this field within the VOB Type. Field_Label Text No Name of this field. Field_Type_ID Number No ID representing the Type of field (text, date, CC Type, Country, etc.). Field_Default_Value Text No Default value for the field. XML_Tag_Name Text No A name to use for this field when translating to an XML representation. 
-  The VOB Data table structure for an exemplary embodiment is as follows:
-  TABLE 11 VOB_Data Table Column Type Primary Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VOB instance is defined. VOB_ID Number Yes Unique ID in the scope of Account_ID for this VOB instance. VOB_Type_ID Number No ID of the VOB Type of this VOB instance. VOB_Label Text No Label to use for this VOB instance (for User Interface display purposes). Category_ID Number No Category under which this VOB is organized. VOB_Order Number No Order of this VOB within the specified category. Show_VOB Number No Allows the fields within this VOB to be displayed or not. 0 = VOB fields are hidden, 1 = VOB fields are shown. Public_VOB_ID Text No VOB ID that is used by the B2B interface 119.
-  The VOB_Field_Data table structure for an exemplary embodiment is as follows:
-  TABLE 12 VOB_Field_Data Primary Column Type Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VOB instance is defined. Field_ID Number Yes Unique ID of this field record in the scope of Account_ID. VOB_ID Number No ID of the VOB that is the owner of this field. See VOB_Data::VOB_ID. Field_Order Number No Order of this field within the parent VOB. See VOB_Field::Field_Order. Field_Value Text No Value of the field. Field_Mod Date/Time No Last time the field value was modified. Encryption Number No Indicates the type of encryption applied to the field. Public_Field_ID Text No Field ID that may be used via the B2B interface 119 toreference this field. 
-  The Field_Group table structure for an exemplary embodiment utilizing the InfoCard feature is as follows:
-  TABLE 13 Field_Group Column Type Primary Key Description Account_ID Number Yes Unique ID that identifies the user account for which the InfoCard is defined. Group_ID Number Yes Unique ID of this InfoCard in the scope of Account_ID. Group_Name Text No Name of this InfoCard. Required Number No 1 = this InfoCard is defined by the system and cannot be removed. Read_Only Number No 1 = You cannot edit the InfoCard. 0 = You can edit the InfoCard. Hidden Number No 1 = this group cannot be edited or seen. 
-  The Field_Group_Data table structure for an exemplary embodiment utilizing the InfoCard feature is as follows:
-  TABLE 14 Field_Group_Data Column Type Primary Key Description Account_ID Number Yes Unique Id that identifies the user account for which the InfoCard is defined. Group_ID Number Yes ID of the InfoCard to which this field belongs. Field_ID Number Yes Field_ID of the field to include in the InfoCard. 
-  The VRecord table structure for an exemplary embodiment is as follows:
-  TABLE 15 VRecord Column Type Primary Key Description Account_ID Number Yes Unique Id that identifies the user account for which the VRecord is defined. VRecord_ID Number Yes Unique ID in the scope of Account_ID for this VRecord. VRecord_Name Text No Name of the VRecord. Label Text No Printable name for the VRecord. 
-  The VRecord_Dynamic_Data table structure for an exemplary embodiment is as follows:
-  TABLE 16 VRecord_Dynamic_Data Column Type Primary Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VRecord is defined. VRecord_ID Number Yes ID of the VRecord to which this field belongs. See VRecord::VRecord_ID. Account_Type_ID Number Yes Indicates the user class that this mapping record applies to (e.g. business or individual account). Field_Order Number Yes Order within the VRecord that this field should be mapped. Field_ID Number No Field_ID of the field to include in the Vrecord. Label Text No Printable name of the field within the Vrecord. 
-  The VRecord_Static_Data table structure for an exemplary embodiment is as follows:
-  TABLE 17 VRecord_Static_Data Primary Column Type Key Description Account_ID Number Yes Unique ID that identifies the user account for which the VRecord is defined. VRecord_ID Number Yes ID of the VRecord that this field belongs. See VRecord::VRecord_ID. Column_Name Text Yes Name of the column in Contact table to use for the field. Column_Order Number No Order of the column within the Vrecord. Label Text No Printable name for the field. 
-  The data exchange engine (DXE) 156 supports the exchange of information between users of the system 102. TheDXE 156 provides interfaces to enable users to request information from each other, approve or deny requests for information, and provide authorized information. TheDXE 156 also supports the definition and enforcement of rule-based behaviors on the availability of information, sharing of information in a global space (public directory), sharing of simple text messages, and event triggers based on requests and changes to authorized information.
-  In requesting information from another system 102 user, registered users may request either globally defined InfoCards (see the description of InfoCards above) of information, or globally defined fields of information from the other user. TheDXE 156 provides event notification hooks for requests for information and messages. Users may approve or deny the request by InfoCard or field, and apply rules regarding access to any provided information, e.g., specifying an expiration date for access to the information. Furthermore, users may also provide any field or InfoCard to another user at any time.
-  TheDXE 156 further provides interfaces for registered users to view information made available to them from other registered users. It is noted that when a user changes a field that has been shared, the changed information is available to other users immediately. This functionality is operative due to theDXE 156 architecture, which provides event notification hooks for changes to information that is available to other users.
-  TheDXE 156 is operative to track relationships between users in a Data_Sharing table. Each record represents what is shared from user A to user B. A record exists only if user A is sharing one or fields with user B. In addition, if user B shares information with user A, an additional record appears in the Data_Sharing table. It is in this table that any rules regarding the sharing of information between the two users is defined.
-  As previously described, users can share information either by specifying individual fields of information, or by using the InfoCards feature. This sharing information is tracked by theDXE 156 in the Data_Sharing_Field_ID and Data_Sharing_Group_ID tables (shown below), respectively. TheDXE 156 architecture explicitly normalizes this data in thedatabase 160 to enable the capability to perform reverse lookups of shared information, e.g., finding all users that you are sharing your home phone number with. It is noted that there is one InfoCard that theDXE 156 treats specially, the Directory InfoCard. The Directory InfoCard is given the same ID for all users (which uniquely identifies it as the Directory InfoCard) and has the behavior attribute that all fields defined within this Infocard are implicitly shared with all other users. For example, when an application in theapplication layer 140 requests the information being shared by user A with user B, the system 102 returns all of the fields explicitly shared by A with B, and all the fields that A has placed in his/her Directory InfoCard.
-  In at least one embodiment, theprimary database 160 tables with which theDXE 156 interacts to provide the capabilities described above are presented. Presentation of these exemplary tables is not intended to limit practice of the invention to utilization of only these tables or the specific data table structure presented, for those skilled in the art will recognize that a different data and table architecture may be implemented and still fall within the scope of the invention.
-  The Data_Sharing table structure for an exemplary embodiment is as follows:
-  TABLE 18 Primary Column Type Key Description Account_ID Number Yes Unique identifier for the user account that is sharing information. Recipient_Account_ID Number Yes Unique identifier for the user that is receiving the information. Sharing_Record_ID Number Yes Unique identifier for this record. Expiration_Date Date/Time No Access to information expires on this date. Date_Granted Date/Time No Access to information was originally granted on this date. Date_Modified Date/Time No Access to information was last modified on this date. 
-  The Data_Sharing_Field_ID table structure for an exemplary embodiment is as follows:
-  TABLE 19 Primary Column Type Key Description Account_ID Number Yes Unique identifier for the user account that is sharing information. Recipient_Account_ID Number Yes Unique identifier for the user that is receiving the information. Field_ID Number Yes ID of the field that is being shared. See VOB_Field_Data:: Field_ID. 
-  The Data_Sharing_Group_ID table structure for an exemplary embodiment is as follows:
-  TABLE 20 Primary Column Type Key Description Account_ID Number Yes Unique identifier for the user account that is sharing information. Recipient_Account_ID Number Yes Unique identifier for the user that is receiving the information. Group_ID Number Yes ID of the InfoCard that is being shared. See Field_Group::Group_ID. 
-  Theencryption engine 158 provides to theVRM 154 and theDXE 156 the capability to save and access raw data that has been encrypted in therelational database 160. This feature is critical to ensuring the security of data that is saved by the system 102, for unencrypted data in a database is very vulnerable to attack, even within what is considered a secure network.
-  All data read and write requests to thedatabase 160 are implemented through theencryption engine 158, making the task of encrypting and decrypting transparent to all other layers of the system 102 architecture. Theencryption engine 158 supports a plurality of conventional encryption schemes on a per field basis. For example, one field in a record may be encrypted using 128-bit symmetric encryption, while another field in the same record may be saved with no encryption at all. Theencryption engine 158 architecture also allows encryption keys to be stored physically separate from thedatabase 160 server hosting the encrypted data. Employment of this feature makes it even more difficult to covertly obtain raw information from thedatabase 160.
-  Thedatabase 160 comprises data 162 (user personal information) encrypted by theencryption engine 158,metadata 164 as described above primarily in reference to theVRM 154, andpermissions information 166 as described above primarily in reference to theDXE 156. As described above, theVRM 154 and theDXE 156 interact with thedatabase 160 any time a user's personal information is created, edited, or accessed.
-  Attention is directed to theinterface layer 130, preferably comprising the WAP (wireless application protocol)interface server 131, the webclipping interface server 133, thesync interface server 135, theweb interface server 137, and theB2B interface server 139. Theinterface layer 130 is configured to manage the user interaction with the system 102. The different interface servers 131-139 communicate with various client side devices or software across anetwork 120, preferably a WAN such as the Internet, and manage the user interaction with the system 102 utilizing the communication protocol that is appropriate for the client side device or client side software. The interface servers 131-139 invoke various internal components of the system 102, namely theaccount manager 152, thevault 142 and theDXE 156, to retrieve, edit, and store information.
-  TheWAP interface server 131 is focused on interfacing withWAP devices 111 utilizing the wireless application protocol, such as Internet-enabled mobile phones or similar wireless communication devices. The webclipping interface server 133 is focused on interfacing with wireless handheldelectronic devices 113, such as personal digital assistants (PDAs), communicating over a wireless medium utilizing the web clipping protocol. Theweb interface server 137 is focused on interfacing with users accessing the system 102 via aconventional web browser 117. Theweb interface server 137 preferably utilizes the secure hypertext transfer protocol (https).
-  Thecontact manager 148 manages the list of contacts of a user as described above. Thesync interface server 135 provides the interface for synchronizing the contact information stored in the system 102 with other conventional client address books resident on various user handheld or desktop devices. Thesync interface server 135 is configured to communicate withclient synchronization software 115 residing on the various user handheld or desktop devices, via the network 102.
-  Finally, theB2B interface server 139 provides an application programming interface (API) for registered users to login to the system 102 and to query for their information or for information about their contacts. Additional exemplary operations include changing (add/delete/edit) their personal information, sharing their personal information with others, requesting others to share their information, and all the other functionality offered by thevault 142 and thecontact manager 148 applications. TheB2B interface server 139 communicates with client users utilizing https. Upon a client transmission of a request to do a certain action (e.g., manipulateinformation data 162 or permissions data 166), the request is made to the system 102 using the POST command of http and, possibly, described using XML (eXtended Markup Language). TheB2B interface server 139 processes the request and invokes theaccount manager 152, thevault 142, and thecontact manager 148 to perform appropriate subtasks within the request. These three subsystems return information or completion status to theB2B interface server 139, which then appropriately replies to the client request using the language of XML. Through this XML request-reply mechanism, the user can exercise all the functionality of the system 102 described above.
-  TheB2B interface client 119 depicts any software that can communicate over the https protocol and send requests and receive replies from theB2B interface server 139. TheB2B interface client 119 application is intended to be written by users of the system 102, with the goal of integrating the information exchange service provided by the system 102 with other user databases containing personal or business information. For example, if a user of the system 102 maintains a list of customers and their contact information in an enterprise database, this user can write aB2B interface client 119 application to interface with theB2B interface server 139, and thus the system 102. Through communication between the proprietaryB2B interface client 119 and theB2B interface server 139, the user can access contact information about his customers from the system 102 and store this contact information in the local enterprise database. This feature enables the user's customer information stored on the enterprise database to maintain synchronization with the information in the system 102.
-  In addition to the API provided for businesses to link to the system 102, a business model is contemplated that would utilize the system 102 to provide a myriad of information services to businesses for a fee. The services provided by the system 102 assist the business in minimizing their database maintenance costs, reducing customer service/call center costs, and improving sales and marketing activities. Some exemplary services may include, but are not limited to, the following: (1) providing accurate, timely customer record updates, thus increasing the efficiency of marketing programs; (2) reducing customer service costs through minimization of call length by facilitating the identification of callers through their system 102 ID, thus providing instant access to the information necessary to resolve the customer complaint/inquiry; (3) maintaining company employee and vendor information through the system 102, either in a distributed manner as described above in reference to the contact manager 148 or through an independent system 102 licensed to the company; (4) listing company information in a business directory maintained by the system 102, which could be used in lieu of or to augment conventional directories such as the white and yellow pages; (5) simplifying customer electronic purchases by enabling customers to register with their site and perform transactions utilizing their system 102 ID and associated information, thus increasing the volume of completed transactions; (6) displaying privacy policies to customers and matching those policies with privacy preferences of the customer maintained by the system 102; (7) maintaining a digital certificate registry to search and track digital certificates of users so that the certificate authority can be automatically notified when a user changes relevant information; and (8) providing a data escrow service thereby escrowing credit card and other transaction information for on-line auction participants.
-  It will be recognized by those skilled in the art that while the invention has been described above in terms of preferred embodiments, it is not limited thereto. Various features and aspects of the above-described invention may be used individually or jointly. Further, although the invention has been described in the context of its implementation in a particular environment and for particular applications, those skilled in the art will recognize that its usefulness is not limited thereto and that it can be utilized in any number of environments and applications and that its scope is limited only by the claims appended hereto.
Claims (10)
 1.-10. (canceled)
     11. An infoCard for enabling a plurality of users to share information, the InfoCard configured to:
    pre-populate a plurality of user accounts with a minimum set of Virtual Objects (VOBs); and
 allow a user of one of the plurality of user accounts to select a specific collection of pre-defined information fields.
  12. The InfoCard of claim 11  wherein the at least a portion of the pre-defined information fields is shared for a defined period of time over a network.
     13. The InfoCard of claim 11  wherein a portion of the selected information fields spans across VOBs.
     14. The InfoCard of claim 11  wherein a minimum set of data is exchangeable between any two of the plurality of user accounts.
     15. A distributed Biz-to-Biz Electronic Information Exchange having a native record format, the Exchange configured to:
    define a mapping between a third party record format and a native record format of the Exchange; and
 correlate a field ID for each class of a plurality of users with an output field name.
  16. The Exchange of claim 15  wherein a portion of information associated with some of the plurality of users is shared for a defined period of time over a network.
     17. The Exchange of claim 15  wherein the mapping is defined by a VRecord and wherein the output field name is selected by an author of the VRecord.
     18. The Exchange of claim 15  wherein the mapping is based on at least two user classes.
     19. The Exchange of claim 18  where the plurality of users include business users and individual users.
    Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| US15/371,180 US20170147678A1 (en) | 1999-12-20 | 2016-12-06 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
Applications Claiming Priority (7)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| US17297799P | 1999-12-20 | 1999-12-20 | |
| US09/742,699 US7788222B2 (en) | 1999-12-20 | 2000-12-20 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US12/848,166 US8099435B2 (en) | 1999-12-20 | 2010-07-31 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US13/327,719 US8812548B2 (en) | 1999-12-20 | 2011-12-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/461,346 US9229962B2 (en) | 1999-12-20 | 2014-08-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/987,716 US9535976B2 (en) | 1999-12-20 | 2016-01-04 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US15/371,180 US20170147678A1 (en) | 1999-12-20 | 2016-12-06 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
Related Parent Applications (1)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| US14/987,716 Continuation US9535976B2 (en) | 1999-12-20 | 2016-01-04 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
Publications (1)
| Publication Number | Publication Date | 
|---|---|
| US20170147678A1 true US20170147678A1 (en) | 2017-05-25 | 
Family
ID=22629978
Family Applications (6)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| US09/742,699 Active - Reinstated 2029-03-13 US7788222B2 (en) | 1999-12-20 | 2000-12-20 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US12/848,166 Expired - Fee Related US8099435B2 (en) | 1999-12-20 | 2010-07-31 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US13/327,719 Expired - Fee Related US8812548B2 (en) | 1999-12-20 | 2011-12-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/461,346 Expired - Fee Related US9229962B2 (en) | 1999-12-20 | 2014-08-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/987,716 Expired - Fee Related US9535976B2 (en) | 1999-12-20 | 2016-01-04 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US15/371,180 Abandoned US20170147678A1 (en) | 1999-12-20 | 2016-12-06 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
Family Applications Before (5)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| US09/742,699 Active - Reinstated 2029-03-13 US7788222B2 (en) | 1999-12-20 | 2000-12-20 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US12/848,166 Expired - Fee Related US8099435B2 (en) | 1999-12-20 | 2010-07-31 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US13/327,719 Expired - Fee Related US8812548B2 (en) | 1999-12-20 | 2011-12-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/461,346 Expired - Fee Related US9229962B2 (en) | 1999-12-20 | 2014-08-15 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
| US14/987,716 Expired - Fee Related US9535976B2 (en) | 1999-12-20 | 2016-01-04 | Information exchange engine providing a critical infrastructure layer and methods of use thereof | 
Country Status (3)
| Country | Link | 
|---|---|
| US (6) | US7788222B2 (en) | 
| AU (1) | AU2909401A (en) | 
| WO (1) | WO2001046825A1 (en) | 
Families Citing this family (279)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US7167842B1 (en) * | 2000-06-27 | 2007-01-23 | Ncr Corp. | Architecture and method for operational privacy in business services | 
| EP1170684A1 (en) * | 2000-07-06 | 2002-01-09 | Richard Macartan Humphreys | An information directory system | 
| AU2001290904A1 (en) * | 2000-09-15 | 2002-03-26 | Learnframe, Inc. | Construction of virtual objects based on run-time type information | 
| US20020174372A1 (en) * | 2001-05-18 | 2002-11-21 | Buvana Venkataraman | Method and apparatus for providing synchronized data | 
| US7249357B2 (en) * | 2001-08-20 | 2007-07-24 | Silicon Graphics, Inc. | Transparent distribution and execution of data in a multiprocessor environment | 
| US20030097451A1 (en) * | 2001-11-16 | 2003-05-22 | Nokia, Inc. | Personal data repository | 
| EP3401794A1 (en) | 2002-01-08 | 2018-11-14 | Seven Networks, LLC | Connection architecture for a mobile network | 
| US20030149869A1 (en) * | 2002-02-01 | 2003-08-07 | Paul Gleichauf | Method and system for securely storing and trasmitting data by applying a one-time pad | 
| US7958144B2 (en) * | 2002-08-30 | 2011-06-07 | Boss Logic, Llc | System and method for secure reciprocal exchange of data | 
| US7917468B2 (en) * | 2005-08-01 | 2011-03-29 | Seven Networks, Inc. | Linking of personal information management data | 
| US7853563B2 (en) * | 2005-08-01 | 2010-12-14 | Seven Networks, Inc. | Universal data aggregation | 
| US8468126B2 (en) | 2005-08-01 | 2013-06-18 | Seven Networks, Inc. | Publishing data in an information community | 
| GB2398712B (en) * | 2003-01-31 | 2006-06-28 | Hewlett Packard Development Co | Privacy management of personal data | 
| JP2006523341A (en) | 2003-03-17 | 2006-10-12 | ロバート・ダント | Network-based communication system | 
| US7310730B1 (en) | 2003-05-27 | 2007-12-18 | Cisco Technology, Inc. | Method and apparatus for communicating an encrypted broadcast to virtual private network receivers | 
| US20050044061A1 (en) * | 2003-08-22 | 2005-02-24 | Klemow Jason L. | Method and system for providing interactive business directory services | 
| US7254567B2 (en) * | 2003-12-10 | 2007-08-07 | The Boeing Company | Systems and methods for aggregating information exchange requirements | 
| US7395319B2 (en) * | 2003-12-31 | 2008-07-01 | Checkfree Corporation | System using contact list to identify network address for accessing electronic commerce application | 
| JP2005316890A (en) * | 2004-04-30 | 2005-11-10 | Sony Corp | Program, computer, data processing method, communication system, and method therefor | 
| US20060007915A1 (en) * | 2004-07-09 | 2006-01-12 | Andrew Frame | Connecting a VOIP phone call using a shared POTS line | 
| US8010082B2 (en) | 2004-10-20 | 2011-08-30 | Seven Networks, Inc. | Flexible billing architecture | 
| WO2006045102A2 (en) | 2004-10-20 | 2006-04-27 | Seven Networks, Inc. | Method and apparatus for intercepting events in a communication system | 
| US7706781B2 (en) | 2004-11-22 | 2010-04-27 | Seven Networks International Oy | Data security in a mobile e-mail service | 
| FI117152B (en) | 2004-12-03 | 2006-06-30 | Seven Networks Internat Oy | E-mail service provisioning method for mobile terminal, involves using domain part and further parameters to generate new parameter set in list of setting parameter sets, if provisioning of e-mail service is successful | 
| US7877703B1 (en) | 2005-03-14 | 2011-01-25 | Seven Networks, Inc. | Intelligent rendering of information in a limited display environment | 
| US20060236100A1 (en) * | 2005-04-19 | 2006-10-19 | Guruprasad Baskaran | System and method for enhanced layer of security to protect a file system from malicious programs | 
| US7796742B1 (en) | 2005-04-21 | 2010-09-14 | Seven Networks, Inc. | Systems and methods for simplified provisioning | 
| US8438633B1 (en) | 2005-04-21 | 2013-05-07 | Seven Networks, Inc. | Flexible real-time inbox access | 
| US8195658B2 (en) * | 2005-04-28 | 2012-06-05 | Samsung Electronics Co., Ltd. | Method of storing phone book data in mobile communication terminal and a mobile communication terminal implementing the same | 
| WO2006136660A1 (en) | 2005-06-21 | 2006-12-28 | Seven Networks International Oy | Maintaining an ip connection in a mobile network | 
| US8069166B2 (en) * | 2005-08-01 | 2011-11-29 | Seven Networks, Inc. | Managing user-to-user contact with inferred presence information | 
| US7769395B2 (en) * | 2006-06-20 | 2010-08-03 | Seven Networks, Inc. | Location-based operations and messaging | 
| US20080001717A1 (en) * | 2006-06-20 | 2008-01-03 | Trevor Fiatal | System and method for group management | 
| US7885932B2 (en) * | 2006-11-01 | 2011-02-08 | Ab Initio Technology Llc | Managing storage of individually accessible data units | 
| US10469556B2 (en) * | 2007-05-31 | 2019-11-05 | Ooma, Inc. | System and method for providing audio cues in operation of a VoIP service | 
| US8805425B2 (en) | 2007-06-01 | 2014-08-12 | Seven Networks, Inc. | Integrated messaging | 
| US8693494B2 (en) | 2007-06-01 | 2014-04-08 | Seven Networks, Inc. | Polling | 
| US9225626B2 (en) | 2007-06-20 | 2015-12-29 | Ooma, Inc. | System and method for providing virtual multiple lines in a communications system | 
| US8056890B2 (en) * | 2007-07-02 | 2011-11-15 | William Thomas Engel | Cut mat | 
| US8364181B2 (en) | 2007-12-10 | 2013-01-29 | Seven Networks, Inc. | Electronic-mail filtering for mobile devices | 
| US9002828B2 (en) | 2007-12-13 | 2015-04-07 | Seven Networks, Inc. | Predictive content delivery | 
| US8793305B2 (en) | 2007-12-13 | 2014-07-29 | Seven Networks, Inc. | Content delivery to a mobile device from a content service | 
| US20090168755A1 (en) * | 2008-01-02 | 2009-07-02 | Dennis Peng | Enforcement of privacy in a VoIP system | 
| US8107921B2 (en) | 2008-01-11 | 2012-01-31 | Seven Networks, Inc. | Mobile virtual network operator | 
| US8862657B2 (en) | 2008-01-25 | 2014-10-14 | Seven Networks, Inc. | Policy based content service | 
| US20090193338A1 (en) | 2008-01-28 | 2009-07-30 | Trevor Fiatal | Reducing network and battery consumption during content delivery and playback | 
| US8515021B2 (en) * | 2008-02-25 | 2013-08-20 | Ooma, Inc. | System and method for providing personalized reverse 911 service | 
| US8302017B2 (en) | 2008-03-05 | 2012-10-30 | Microsoft Corporation | Definition for service interface | 
| US8787947B2 (en) | 2008-06-18 | 2014-07-22 | Seven Networks, Inc. | Application discovery on mobile devices | 
| US8078158B2 (en) | 2008-06-26 | 2011-12-13 | Seven Networks, Inc. | Provisioning applications for a mobile device | 
| US20100037288A1 (en) * | 2008-08-06 | 2010-02-11 | International Business Machines Corporation | Inherited Access Authorization to a Social Network | 
| US8433805B2 (en) * | 2008-09-19 | 2013-04-30 | Apple Inc. | Method and system for facilitating contacting people using electronic devices | 
| US8909759B2 (en) | 2008-10-10 | 2014-12-09 | Seven Networks, Inc. | Bandwidth measurement | 
| US8818412B2 (en) * | 2009-03-18 | 2014-08-26 | Wavemarket, Inc. | System for aggregating and disseminating location information | 
| US20100242097A1 (en) | 2009-03-20 | 2010-09-23 | Wavemarket, Inc. | System and method for managing application program access to a protected resource residing on a mobile device | 
| US8683554B2 (en) * | 2009-03-27 | 2014-03-25 | Wavemarket, Inc. | System and method for managing third party application program access to user information via a native application program interface (API) | 
| US20100274852A1 (en) * | 2009-04-28 | 2010-10-28 | Nokia Corporation | Method and Apparatus for Sharing Context to One or More Users | 
| US20110137817A1 (en) * | 2009-06-01 | 2011-06-09 | Wavemarket, Inc. | System and method for aggregating and disseminating personal data | 
| US8429138B2 (en) | 2009-10-21 | 2013-04-23 | Telefonaktiebolaget L M Ericsson (Publ) | Method and apparatus for data exchange in a distributed system | 
| WO2011126889A2 (en) | 2010-03-30 | 2011-10-13 | Seven Networks, Inc. | 3d mobile user interface with configurable workspace management | 
| CA2857458A1 (en) | 2010-07-26 | 2012-02-09 | Michael Luna | Mobile application traffic optimization | 
| CA2806527A1 (en) | 2010-07-26 | 2012-02-09 | Seven Networks, Inc. | Mobile network traffic coordination across multiple applications | 
| WO2012018477A2 (en) | 2010-07-26 | 2012-02-09 | Seven Networks, Inc. | Distributed implementation of dynamic wireless traffic policy | 
| US8838783B2 (en) | 2010-07-26 | 2014-09-16 | Seven Networks, Inc. | Distributed caching for resource and mobile network traffic management | 
| US9330196B2 (en) | 2010-11-01 | 2016-05-03 | Seven Networks, Llc | Wireless traffic management system cache optimization using http headers | 
| WO2012060996A2 (en) | 2010-11-01 | 2012-05-10 | Michael Luna | Caching adapted for mobile application behavior and network conditions | 
| US8484314B2 (en) | 2010-11-01 | 2013-07-09 | Seven Networks, Inc. | Distributed caching in a wireless network of content delivered for a mobile application over a long-held request | 
| US8843153B2 (en) | 2010-11-01 | 2014-09-23 | Seven Networks, Inc. | Mobile traffic categorization and policy for network use optimization while preserving user experience | 
| US9060032B2 (en) | 2010-11-01 | 2015-06-16 | Seven Networks, Inc. | Selective data compression by a distributed traffic management system to reduce mobile data traffic and signaling traffic | 
| WO2012060995A2 (en) | 2010-11-01 | 2012-05-10 | Michael Luna | Distributed caching in a wireless network of content delivered for a mobile application over a long-held request | 
| WO2012061430A2 (en) | 2010-11-01 | 2012-05-10 | Michael Luna | Distributed management of keep-alive message signaling for mobile network resource conservation and optimization | 
| WO2012060997A2 (en) | 2010-11-01 | 2012-05-10 | Michael Luna | Application and network-based long poll request detection and cacheability assessment therefor | 
| US8190701B2 (en) | 2010-11-01 | 2012-05-29 | Seven Networks, Inc. | Cache defeat detection and caching of content addressed by identifiers intended to defeat cache | 
| WO2012071283A1 (en) | 2010-11-22 | 2012-05-31 | Michael Luna | Aligning data transfer to optimize connections established for transmission over a wireless network | 
| GB2500327B (en) | 2010-11-22 | 2019-11-06 | Seven Networks Llc | Optimization of resource polling intervals to satisfy mobile device requests | 
| WO2012094675A2 (en) | 2011-01-07 | 2012-07-12 | Seven Networks, Inc. | System and method for reduction of mobile network traffic used for domain name system (dns) queries | 
| GB2504411A (en) | 2011-04-19 | 2014-01-29 | Seven Networks Inc | Shared resource and virtual resource management in a networked environment | 
| EP2702500B1 (en) | 2011-04-27 | 2017-07-19 | Seven Networks, LLC | Detecting and preserving state for satisfying application requests in a distributed proxy and cache system | 
| GB2493473B (en) | 2011-04-27 | 2013-06-19 | Seven Networks Inc | System and method for making requests on behalf of a mobile device based on atomic processes for mobile network traffic relief | 
| US20130013605A1 (en) | 2011-07-08 | 2013-01-10 | Stanfill Craig W | Managing Storage of Data for Range-Based Searching | 
| WO2013015995A1 (en) | 2011-07-27 | 2013-01-31 | Seven Networks, Inc. | Automatic generation and distribution of policy information regarding malicious mobile traffic in a wireless network | 
| US8918503B2 (en) | 2011-12-06 | 2014-12-23 | Seven Networks, Inc. | Optimization of mobile traffic directed to private networks and operator configurability thereof | 
| US8868753B2 (en) | 2011-12-06 | 2014-10-21 | Seven Networks, Inc. | System of redundantly clustered machines to provide failover mechanisms for mobile traffic management and network resource conservation | 
| US9277443B2 (en) | 2011-12-07 | 2016-03-01 | Seven Networks, Llc | Radio-awareness of mobile device for sending server-side control signals using a wireless network optimized transport protocol | 
| US9009250B2 (en) | 2011-12-07 | 2015-04-14 | Seven Networks, Inc. | Flexible and dynamic integration schemas of a traffic management system with various network operators for network traffic alleviation | 
| US9832095B2 (en) | 2011-12-14 | 2017-11-28 | Seven Networks, Llc | Operation modes for mobile traffic optimization and concurrent management of optimized and non-optimized traffic | 
| US8861354B2 (en) | 2011-12-14 | 2014-10-14 | Seven Networks, Inc. | Hierarchies and categories for management and deployment of policies for distributed wireless traffic optimization | 
| EP2792188B1 (en) | 2011-12-14 | 2019-03-20 | Seven Networks, LLC | Mobile network reporting and usage analytics system and method using aggregation of data in a distributed traffic optimization system | 
| EP2801236A4 (en) | 2012-01-05 | 2015-10-21 | Seven Networks Inc | Detection and management of user interactions with foreground applications on a mobile device in distributed caching | 
| WO2013116856A1 (en) | 2012-02-02 | 2013-08-08 | Seven Networks, Inc. | Dynamic categorization of applications for network access in a mobile network | 
| US9326189B2 (en) | 2012-02-03 | 2016-04-26 | Seven Networks, Llc | User as an end point for profiling and optimizing the delivery of content and data in a wireless network | 
| US8812695B2 (en) | 2012-04-09 | 2014-08-19 | Seven Networks, Inc. | Method and system for management of a virtual network connection without heartbeat messages | 
| US10263899B2 (en) | 2012-04-10 | 2019-04-16 | Seven Networks, Llc | Enhanced customer service for mobile carriers using real-time and historical mobile application and traffic or optimization data associated with mobile devices in a mobile network | 
| US9047294B2 (en) | 2012-06-11 | 2015-06-02 | Oracle International Corporation | Model for generating custom file plans towards management of content as records | 
| US9436687B2 (en) * | 2012-07-09 | 2016-09-06 | Facebook, Inc. | Acquiring structured user data using composer interface having input fields corresponding to acquired structured data | 
| WO2014011216A1 (en) | 2012-07-13 | 2014-01-16 | Seven Networks, Inc. | Dynamic bandwidth adjustment for browsing or streaming activity in a wireless network based on prediction of user behavior when interacting with mobile applications | 
| US9032247B2 (en) * | 2012-07-26 | 2015-05-12 | Apple Inc. | Intermediate database management layer | 
| US9424552B2 (en) * | 2012-08-06 | 2016-08-23 | International Business Machines Corporation | Managing website registrations | 
| US9161258B2 (en) | 2012-10-24 | 2015-10-13 | Seven Networks, Llc | Optimized and selective management of policy deployment to mobile clients in a congested network to prevent further aggravation of network congestion | 
| US9307493B2 (en) | 2012-12-20 | 2016-04-05 | Seven Networks, Llc | Systems and methods for application management of mobile device radio state promotion and demotion | 
| US9271238B2 (en) | 2013-01-23 | 2016-02-23 | Seven Networks, Llc | Application or context aware fast dormancy | 
| US8874761B2 (en) | 2013-01-25 | 2014-10-28 | Seven Networks, Inc. | Signaling optimization in a wireless network for traffic utilizing proprietary and non-proprietary protocols | 
| US9326185B2 (en) | 2013-03-11 | 2016-04-26 | Seven Networks, Llc | Mobile network congestion recognition for optimization of mobile traffic | 
| US9065765B2 (en) | 2013-07-22 | 2015-06-23 | Seven Networks, Inc. | Proxy server associated with a mobile carrier for enhancing mobile traffic management in a mobile network | 
| US9560198B2 (en) | 2013-09-23 | 2017-01-31 | Ooma, Inc. | Identifying and filtering incoming telephone calls to enhance privacy | 
| US9386148B2 (en) | 2013-09-23 | 2016-07-05 | Ooma, Inc. | Identifying and filtering incoming telephone calls to enhance privacy | 
| US10769931B2 (en) | 2014-05-20 | 2020-09-08 | Ooma, Inc. | Network jamming detection and remediation | 
| US10553098B2 (en) | 2014-05-20 | 2020-02-04 | Ooma, Inc. | Appliance device integration with alarm systems | 
| US9633547B2 (en) | 2014-05-20 | 2017-04-25 | Ooma, Inc. | Security monitoring and control | 
| US11330100B2 (en) | 2014-07-09 | 2022-05-10 | Ooma, Inc. | Server based intelligent personal assistant services | 
| US9729583B1 (en) | 2016-06-10 | 2017-08-08 | OneTrust, LLC | Data processing systems and methods for performing privacy assessments and monitoring of new versions of computer code for privacy compliance | 
| US10181051B2 (en) | 2016-06-10 | 2019-01-15 | OneTrust, LLC | Data processing systems for generating and populating a data inventory for processing data access requests | 
| US10007955B2 (en) * | 2014-10-23 | 2018-06-26 | Dun & Bradstreet Emerging Businesses Corp. | Base-business cards | 
| US20160204933A1 (en) * | 2015-01-14 | 2016-07-14 | Corrado Ronchi | Personal information management system, method and service | 
| US9521069B2 (en) | 2015-05-08 | 2016-12-13 | Ooma, Inc. | Managing alternative networks for high quality of service communications | 
| US10771396B2 (en) | 2015-05-08 | 2020-09-08 | Ooma, Inc. | Communications network failure detection and remediation | 
| US10009286B2 (en) | 2015-05-08 | 2018-06-26 | Ooma, Inc. | Communications hub | 
| US10911368B2 (en) | 2015-05-08 | 2021-02-02 | Ooma, Inc. | Gateway address spoofing for alternate network utilization | 
| US11171875B2 (en) | 2015-05-08 | 2021-11-09 | Ooma, Inc. | Systems and methods of communications network failure detection and remediation utilizing link probes | 
| US10116796B2 (en) | 2015-10-09 | 2018-10-30 | Ooma, Inc. | Real-time communications-based internet advertising | 
| US11004125B2 (en) | 2016-04-01 | 2021-05-11 | OneTrust, LLC | Data processing systems and methods for integrating privacy information management systems with data loss prevention tools or other tools for privacy design | 
| US11244367B2 (en) | 2016-04-01 | 2022-02-08 | OneTrust, LLC | Data processing systems and methods for integrating privacy information management systems with data loss prevention tools or other tools for privacy design | 
| US12288233B2 (en) | 2016-04-01 | 2025-04-29 | OneTrust, LLC | Data processing systems and methods for integrating privacy information management systems with data loss prevention tools or other tools for privacy design | 
| US10706447B2 (en) | 2016-04-01 | 2020-07-07 | OneTrust, LLC | Data processing systems and communication systems and methods for the efficient generation of privacy risk assessments | 
| US11636171B2 (en) | 2016-06-10 | 2023-04-25 | OneTrust, LLC | Data processing user interface monitoring systems and related methods | 
| US10796260B2 (en) | 2016-06-10 | 2020-10-06 | OneTrust, LLC | Privacy management systems and methods | 
| US11403377B2 (en) | 2016-06-10 | 2022-08-02 | OneTrust, LLC | Privacy management systems and methods | 
| US10440062B2 (en) | 2016-06-10 | 2019-10-08 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US10706131B2 (en) | 2016-06-10 | 2020-07-07 | OneTrust, LLC | Data processing systems and methods for efficiently assessing the risk of privacy campaigns | 
| US10878127B2 (en) | 2016-06-10 | 2020-12-29 | OneTrust, LLC | Data subject access request processing systems and related methods | 
| US10713387B2 (en) | 2016-06-10 | 2020-07-14 | OneTrust, LLC | Consent conversion optimization systems and related methods | 
| US11416109B2 (en) | 2016-06-10 | 2022-08-16 | OneTrust, LLC | Automated data processing systems and methods for automatically processing data subject access requests using a chatbot | 
| US11295316B2 (en) | 2016-06-10 | 2022-04-05 | OneTrust, LLC | Data processing systems for identity validation for consumer rights requests and related methods | 
| US10848523B2 (en) | 2016-06-10 | 2020-11-24 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US11057356B2 (en) | 2016-06-10 | 2021-07-06 | OneTrust, LLC | Automated data processing systems and methods for automatically processing data subject access requests using a chatbot | 
| US11343284B2 (en) | 2016-06-10 | 2022-05-24 | OneTrust, LLC | Data processing systems and methods for performing privacy assessments and monitoring of new versions of computer code for privacy compliance | 
| US11625502B2 (en) | 2016-06-10 | 2023-04-11 | OneTrust, LLC | Data processing systems for identifying and modifying processes that are subject to data subject access requests | 
| US10798133B2 (en) | 2016-06-10 | 2020-10-06 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10204154B2 (en) | 2016-06-10 | 2019-02-12 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10454973B2 (en) | 2016-06-10 | 2019-10-22 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US11366786B2 (en) | 2016-06-10 | 2022-06-21 | OneTrust, LLC | Data processing systems for processing data subject access requests | 
| US11520928B2 (en) | 2016-06-10 | 2022-12-06 | OneTrust, LLC | Data processing systems for generating personal data receipts and related methods | 
| US11100444B2 (en) | 2016-06-10 | 2021-08-24 | OneTrust, LLC | Data processing systems and methods for providing training in a vendor procurement process | 
| US10169609B1 (en) | 2016-06-10 | 2019-01-01 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US11341447B2 (en) | 2016-06-10 | 2022-05-24 | OneTrust, LLC | Privacy management systems and methods | 
| US11157600B2 (en) | 2016-06-10 | 2021-10-26 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10565397B1 (en) | 2016-06-10 | 2020-02-18 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US10496846B1 (en) | 2016-06-10 | 2019-12-03 | OneTrust, LLC | Data processing and communications systems and methods for the efficient implementation of privacy by design | 
| US10509894B2 (en) | 2016-06-10 | 2019-12-17 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10572686B2 (en) | 2016-06-10 | 2020-02-25 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11023842B2 (en) | 2016-06-10 | 2021-06-01 | OneTrust, LLC | Data processing systems and methods for bundled privacy policies | 
| US11336697B2 (en) | 2016-06-10 | 2022-05-17 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US11416589B2 (en) | 2016-06-10 | 2022-08-16 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US11228620B2 (en) | 2016-06-10 | 2022-01-18 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10885485B2 (en) | 2016-06-10 | 2021-01-05 | OneTrust, LLC | Privacy management systems and methods | 
| US10437412B2 (en) | 2016-06-10 | 2019-10-08 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11087260B2 (en) | 2016-06-10 | 2021-08-10 | OneTrust, LLC | Data processing systems and methods for customizing privacy training | 
| US10706176B2 (en) | 2016-06-10 | 2020-07-07 | OneTrust, LLC | Data-processing consent refresh, re-prompt, and recapture systems and related methods | 
| US11025675B2 (en) | 2016-06-10 | 2021-06-01 | OneTrust, LLC | Data processing systems and methods for performing privacy assessments and monitoring of new versions of computer code for privacy compliance | 
| US11562097B2 (en) | 2016-06-10 | 2023-01-24 | OneTrust, LLC | Data processing systems for central consent repository and related methods | 
| US10496803B2 (en) | 2016-06-10 | 2019-12-03 | OneTrust, LLC | Data processing systems and methods for efficiently assessing the risk of privacy campaigns | 
| US11416798B2 (en) | 2016-06-10 | 2022-08-16 | OneTrust, LLC | Data processing systems and methods for providing training in a vendor procurement process | 
| US10706174B2 (en) | 2016-06-10 | 2020-07-07 | OneTrust, LLC | Data processing systems for prioritizing data subject access requests for fulfillment and related methods | 
| US10586075B2 (en) | 2016-06-10 | 2020-03-10 | OneTrust, LLC | Data processing systems for orphaned data identification and deletion and related methods | 
| US11475136B2 (en) | 2016-06-10 | 2022-10-18 | OneTrust, LLC | Data processing systems for data transfer risk identification and related methods | 
| US11727141B2 (en) | 2016-06-10 | 2023-08-15 | OneTrust, LLC | Data processing systems and methods for synching privacy-related user consent across multiple computing devices | 
| US10706379B2 (en) | 2016-06-10 | 2020-07-07 | OneTrust, LLC | Data processing systems for automatic preparation for remediation and related methods | 
| US10873606B2 (en) | 2016-06-10 | 2020-12-22 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10949170B2 (en) | 2016-06-10 | 2021-03-16 | OneTrust, LLC | Data processing systems for integration of consumer feedback with data subject access requests and related methods | 
| US11586700B2 (en) | 2016-06-10 | 2023-02-21 | OneTrust, LLC | Data processing systems and methods for automatically blocking the use of tracking tools | 
| US10839102B2 (en) | 2016-06-10 | 2020-11-17 | OneTrust, LLC | Data processing systems for identifying and modifying processes that are subject to data subject access requests | 
| US10438017B2 (en) | 2016-06-10 | 2019-10-08 | OneTrust, LLC | Data processing systems for processing data subject access requests | 
| US11151233B2 (en) | 2016-06-10 | 2021-10-19 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10318761B2 (en) | 2016-06-10 | 2019-06-11 | OneTrust, LLC | Data processing systems and methods for auditing data request compliance | 
| US10510031B2 (en) | 2016-06-10 | 2019-12-17 | OneTrust, LLC | Data processing systems for identifying, assessing, and remediating data processing risks using data modeling techniques | 
| US11188615B2 (en) | 2016-06-10 | 2021-11-30 | OneTrust, LLC | Data processing consent capture systems and related methods | 
| US11301796B2 (en) | 2016-06-10 | 2022-04-12 | OneTrust, LLC | Data processing systems and methods for customizing privacy training | 
| US10776517B2 (en) | 2016-06-10 | 2020-09-15 | OneTrust, LLC | Data processing systems for calculating and communicating cost of fulfilling data subject access requests and related methods | 
| US10803200B2 (en) | 2016-06-10 | 2020-10-13 | OneTrust, LLC | Data processing systems for processing and managing data subject access in a distributed environment | 
| US10607028B2 (en) | 2016-06-10 | 2020-03-31 | OneTrust, LLC | Data processing systems for data testing to confirm data deletion and related methods | 
| US11418492B2 (en) | 2016-06-10 | 2022-08-16 | OneTrust, LLC | Data processing systems and methods for using a data model to select a target data asset in a data migration | 
| US11222309B2 (en) * | 2016-06-10 | 2022-01-11 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10708305B2 (en) | 2016-06-10 | 2020-07-07 | OneTrust, LLC | Automated data processing systems and methods for automatically processing requests for privacy-related information | 
| US11354435B2 (en) | 2016-06-10 | 2022-06-07 | OneTrust, LLC | Data processing systems for data testing to confirm data deletion and related methods | 
| US11074367B2 (en) | 2016-06-10 | 2021-07-27 | OneTrust, LLC | Data processing systems for identity validation for consumer rights requests and related methods | 
| US10909265B2 (en) | 2016-06-10 | 2021-02-02 | OneTrust, LLC | Application privacy scanning systems and related methods | 
| US11227247B2 (en) | 2016-06-10 | 2022-01-18 | OneTrust, LLC | Data processing systems and methods for bundled privacy policies | 
| US12052289B2 (en) | 2016-06-10 | 2024-07-30 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10944725B2 (en) | 2016-06-10 | 2021-03-09 | OneTrust, LLC | Data processing systems and methods for using a data model to select a target data asset in a data migration | 
| US10909488B2 (en) | 2016-06-10 | 2021-02-02 | OneTrust, LLC | Data processing systems for assessing readiness for responding to privacy-related incidents | 
| US10614247B2 (en) | 2016-06-10 | 2020-04-07 | OneTrust, LLC | Data processing systems for automated classification of personal information from documents and related methods | 
| US11138242B2 (en) | 2016-06-10 | 2021-10-05 | OneTrust, LLC | Data processing systems and methods for automatically detecting and documenting privacy-related aspects of computer software | 
| US10769301B2 (en) | 2016-06-10 | 2020-09-08 | OneTrust, LLC | Data processing systems for webform crawling to map processing activities and related methods | 
| US10565236B1 (en) | 2016-06-10 | 2020-02-18 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10997318B2 (en) | 2016-06-10 | 2021-05-04 | OneTrust, LLC | Data processing systems for generating and populating a data inventory for processing data access requests | 
| US11038925B2 (en) | 2016-06-10 | 2021-06-15 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10452864B2 (en) | 2016-06-10 | 2019-10-22 | OneTrust, LLC | Data processing systems for webform crawling to map processing activities and related methods | 
| US11222139B2 (en) | 2016-06-10 | 2022-01-11 | OneTrust, LLC | Data processing systems and methods for automatic discovery and assessment of mobile software development kits | 
| US10242228B2 (en) | 2016-06-10 | 2019-03-26 | OneTrust, LLC | Data processing systems for measuring privacy maturity within an organization | 
| US11144622B2 (en) | 2016-06-10 | 2021-10-12 | OneTrust, LLC | Privacy management systems and methods | 
| US11138299B2 (en) | 2016-06-10 | 2021-10-05 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10853501B2 (en) | 2016-06-10 | 2020-12-01 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10896394B2 (en) | 2016-06-10 | 2021-01-19 | OneTrust, LLC | Privacy management systems and methods | 
| US10678945B2 (en) | 2016-06-10 | 2020-06-09 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US10783256B2 (en) | 2016-06-10 | 2020-09-22 | OneTrust, LLC | Data processing systems for data transfer risk identification and related methods | 
| US11188862B2 (en) | 2016-06-10 | 2021-11-30 | OneTrust, LLC | Privacy management systems and methods | 
| US10726158B2 (en) | 2016-06-10 | 2020-07-28 | OneTrust, LLC | Consent receipt management and automated process blocking systems and related methods | 
| US10452866B2 (en) | 2016-06-10 | 2019-10-22 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US11294939B2 (en) | 2016-06-10 | 2022-04-05 | OneTrust, LLC | Data processing systems and methods for automatically detecting and documenting privacy-related aspects of computer software | 
| US12299065B2 (en) | 2016-06-10 | 2025-05-13 | OneTrust, LLC | Data processing systems and methods for dynamically determining data processing consent configurations | 
| US10509920B2 (en) | 2016-06-10 | 2019-12-17 | OneTrust, LLC | Data processing systems for processing data subject access requests | 
| US11238390B2 (en) | 2016-06-10 | 2022-02-01 | OneTrust, LLC | Privacy management systems and methods | 
| US11222142B2 (en) | 2016-06-10 | 2022-01-11 | OneTrust, LLC | Data processing systems for validating authorization for personal data collection, storage, and processing | 
| US11416590B2 (en) | 2016-06-10 | 2022-08-16 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US10846433B2 (en) | 2016-06-10 | 2020-11-24 | OneTrust, LLC | Data processing consent management systems and related methods | 
| US11438386B2 (en) | 2016-06-10 | 2022-09-06 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US12118121B2 (en) | 2016-06-10 | 2024-10-15 | OneTrust, LLC | Data subject access request processing systems and related methods | 
| US10949565B2 (en) | 2016-06-10 | 2021-03-16 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10606916B2 (en) | 2016-06-10 | 2020-03-31 | OneTrust, LLC | Data processing user interface monitoring systems and related methods | 
| US10353673B2 (en) | 2016-06-10 | 2019-07-16 | OneTrust, LLC | Data processing systems for integration of consumer feedback with data subject access requests and related methods | 
| US10467432B2 (en) | 2016-06-10 | 2019-11-05 | OneTrust, LLC | Data processing systems for use in automatically generating, populating, and submitting data subject access requests | 
| US11651106B2 (en) | 2016-06-10 | 2023-05-16 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US11651104B2 (en) | 2016-06-10 | 2023-05-16 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US10997315B2 (en) | 2016-06-10 | 2021-05-04 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US10565161B2 (en) | 2016-06-10 | 2020-02-18 | OneTrust, LLC | Data processing systems for processing data subject access requests | 
| US12045266B2 (en) | 2016-06-10 | 2024-07-23 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US12136055B2 (en) | 2016-06-10 | 2024-11-05 | OneTrust, LLC | Data processing systems for identifying, assessing, and remediating data processing risks using data modeling techniques | 
| US11461500B2 (en) | 2016-06-10 | 2022-10-04 | OneTrust, LLC | Data processing systems for cookie compliance testing with website scanning and related methods | 
| US10503926B2 (en) | 2016-06-10 | 2019-12-10 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11277448B2 (en) | 2016-06-10 | 2022-03-15 | OneTrust, LLC | Data processing systems for data-transfer risk identification, cross-border visualization generation, and related methods | 
| US10685140B2 (en) | 2016-06-10 | 2020-06-16 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US10282559B2 (en) | 2016-06-10 | 2019-05-07 | OneTrust, LLC | Data processing systems for identifying, assessing, and remediating data processing risks using data modeling techniques | 
| US10592648B2 (en) | 2016-06-10 | 2020-03-17 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11366909B2 (en) | 2016-06-10 | 2022-06-21 | OneTrust, LLC | Data processing and scanning systems for assessing vendor risk | 
| US11544667B2 (en) * | 2016-06-10 | 2023-01-03 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10642870B2 (en) | 2016-06-10 | 2020-05-05 | OneTrust, LLC | Data processing systems and methods for automatically detecting and documenting privacy-related aspects of computer software | 
| US10282700B2 (en) * | 2016-06-10 | 2019-05-07 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10740487B2 (en) | 2016-06-10 | 2020-08-11 | OneTrust, LLC | Data processing systems and methods for populating and maintaining a centralized database of personal data | 
| US10416966B2 (en) | 2016-06-10 | 2019-09-17 | OneTrust, LLC | Data processing systems for identity validation of data subject access requests and related methods | 
| US12381915B2 (en) | 2016-06-10 | 2025-08-05 | OneTrust, LLC | Data processing systems and methods for performing assessments and monitoring of new versions of computer code for compliance | 
| US10284604B2 (en) | 2016-06-10 | 2019-05-07 | OneTrust, LLC | Data processing and scanning systems for generating and populating a data inventory | 
| US11328092B2 (en) | 2016-06-10 | 2022-05-10 | OneTrust, LLC | Data processing systems for processing and managing data subject access in a distributed environment | 
| US10275614B2 (en) | 2016-06-10 | 2019-04-30 | OneTrust, LLC | Data processing systems for generating and populating a data inventory | 
| US10776514B2 (en) | 2016-06-10 | 2020-09-15 | OneTrust, LLC | Data processing systems for the identification and deletion of personal data in computer systems | 
| US10585968B2 (en) | 2016-06-10 | 2020-03-10 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US11200341B2 (en) | 2016-06-10 | 2021-12-14 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11210420B2 (en) | 2016-06-10 | 2021-12-28 | OneTrust, LLC | Data subject access request processing systems and related methods | 
| US11481710B2 (en) | 2016-06-10 | 2022-10-25 | OneTrust, LLC | Privacy management systems and methods | 
| US11134086B2 (en) | 2016-06-10 | 2021-09-28 | OneTrust, LLC | Consent conversion optimization systems and related methods | 
| US11392720B2 (en) | 2016-06-10 | 2022-07-19 | OneTrust, LLC | Data processing systems for verification of consent and notice processing and related methods | 
| US10762236B2 (en) | 2016-06-10 | 2020-09-01 | OneTrust, LLC | Data processing user interface monitoring systems and related methods | 
| US10776518B2 (en) | 2016-06-10 | 2020-09-15 | OneTrust, LLC | Consent receipt management systems and related methods | 
| US11146566B2 (en) | 2016-06-10 | 2021-10-12 | OneTrust, LLC | Data processing systems for fulfilling data subject access requests and related methods | 
| US10592692B2 (en) | 2016-06-10 | 2020-03-17 | OneTrust, LLC | Data processing systems for central consent repository and related methods | 
| US11354434B2 (en) | 2016-06-10 | 2022-06-07 | OneTrust, LLC | Data processing systems for verification of consent and notice processing and related methods | 
| US11675929B2 (en) | 2016-06-10 | 2023-06-13 | OneTrust, LLC | Data processing consent sharing systems and related methods | 
| US10013577B1 (en) | 2017-06-16 | 2018-07-03 | OneTrust, LLC | Data processing systems for identifying whether cookies contain personally identifying information | 
| US10824758B2 (en) * | 2017-11-27 | 2020-11-03 | Accenture Global Solutions Limited | System and method for managing enterprise data | 
| US11144675B2 (en) | 2018-09-07 | 2021-10-12 | OneTrust, LLC | Data processing systems and methods for automatically protecting sensitive data within privacy management systems | 
| US10803202B2 (en) | 2018-09-07 | 2020-10-13 | OneTrust, LLC | Data processing systems for orphaned data identification and deletion and related methods | 
| US11544409B2 (en) | 2018-09-07 | 2023-01-03 | OneTrust, LLC | Data processing systems and methods for automatically protecting sensitive data within privacy management systems | 
| US11909859B2 (en) * | 2020-06-02 | 2024-02-20 | Sap Se | Removing access to blockchain data | 
| US11797528B2 (en) | 2020-07-08 | 2023-10-24 | OneTrust, LLC | Systems and methods for targeted data discovery | 
| US11444976B2 (en) | 2020-07-28 | 2022-09-13 | OneTrust, LLC | Systems and methods for automatically blocking the use of tracking tools | 
| US11475165B2 (en) | 2020-08-06 | 2022-10-18 | OneTrust, LLC | Data processing systems and methods for automatically redacting unstructured data from a data subject access request | 
| US11436373B2 (en) | 2020-09-15 | 2022-09-06 | OneTrust, LLC | Data processing systems and methods for detecting tools for the automatic blocking of consent requests | 
| WO2022061270A1 (en) | 2020-09-21 | 2022-03-24 | OneTrust, LLC | Data processing systems and methods for automatically detecting target data transfers and target data processing | 
| US12265896B2 (en) | 2020-10-05 | 2025-04-01 | OneTrust, LLC | Systems and methods for detecting prejudice bias in machine-learning models | 
| WO2022099023A1 (en) | 2020-11-06 | 2022-05-12 | OneTrust, LLC | Systems and methods for identifying data processing activities based on data discovery results | 
| WO2022159901A1 (en) | 2021-01-25 | 2022-07-28 | OneTrust, LLC | Systems and methods for discovery, classification, and indexing of data in a native computing system | 
| US11442906B2 (en) | 2021-02-04 | 2022-09-13 | OneTrust, LLC | Managing custom attributes for domain objects defined within microservices | 
| US11494515B2 (en) | 2021-02-08 | 2022-11-08 | OneTrust, LLC | Data processing systems and methods for anonymizing data samples in classification analysis | 
| US11601464B2 (en) | 2021-02-10 | 2023-03-07 | OneTrust, LLC | Systems and methods for mitigating risks of third-party computing system functionality integration into a first-party computing system | 
| US11775348B2 (en) | 2021-02-17 | 2023-10-03 | OneTrust, LLC | Managing custom workflows for domain objects defined within microservices | 
| US11546661B2 (en) | 2021-02-18 | 2023-01-03 | OneTrust, LLC | Selective redaction of media content | 
| WO2022192269A1 (en) | 2021-03-08 | 2022-09-15 | OneTrust, LLC | Data transfer discovery and analysis systems and related methods | 
| US11562078B2 (en) | 2021-04-16 | 2023-01-24 | OneTrust, LLC | Assessing and managing computational risk involved with integrating third party computing functionality within a computing system | 
| US12153704B2 (en) | 2021-08-05 | 2024-11-26 | OneTrust, LLC | Computing platform for facilitating data exchange among computing environments | 
| US11620142B1 (en) | 2022-06-03 | 2023-04-04 | OneTrust, LLC | Generating and customizing user interfaces for demonstrating functions of interactive user environments | 
Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US5838918A (en) * | 1993-12-13 | 1998-11-17 | International Business Machines Corporation | Distributing system configuration information from a manager machine to subscribed endpoint machines in a distrubuted computing environment | 
| US6748580B1 (en) * | 1999-04-22 | 2004-06-08 | International Business Machines Corporation | Method and apparatus for creating software tools using a JTML interface | 
Family Cites Families (12)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US5694546A (en) * | 1994-05-31 | 1997-12-02 | Reisman; Richard R. | System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list | 
| US5675782A (en) * | 1995-06-06 | 1997-10-07 | Microsoft Corporation | Controlling access to objects on multiple operating systems | 
| CA2261262C (en) * | 1996-07-22 | 2007-08-21 | Cyva Research Corporation | Personal information security and exchange tool | 
| US5963642A (en) * | 1996-12-30 | 1999-10-05 | Goldstein; Benjamin D. | Method and apparatus for secure storage of data | 
| US5890129A (en) * | 1997-05-30 | 1999-03-30 | Spurgeon; Loren J. | System for exchanging health care insurance information | 
| JP3564262B2 (en) * | 1997-06-24 | 2004-09-08 | 富士通株式会社 | Information management system and device | 
| US6269369B1 (en) * | 1997-11-02 | 2001-07-31 | Amazon.Com Holdings, Inc. | Networked personal contact manager | 
| EP0926591B1 (en) * | 1997-12-26 | 2005-08-24 | Casio Computer Co., Ltd. | Network-access management system and method | 
| US6216131B1 (en) * | 1998-02-06 | 2001-04-10 | Starfish Software, Inc. | Methods for mapping data fields from one data set to another in a data processing environment | 
| US6535917B1 (en) * | 1998-02-09 | 2003-03-18 | Reuters, Ltd. | Market data domain and enterprise system implemented by a master entitlement processor | 
| US7003546B1 (en) * | 1998-10-13 | 2006-02-21 | Chris Cheah | Method and system for controlled distribution of contact information over a network | 
| US6735591B2 (en) * | 1999-01-26 | 2004-05-11 | Joseph M. Khan | Universal information warehouse system and method | 
- 
        2000
        - 2000-12-20 US US09/742,699 patent/US7788222B2/en active Active - Reinstated
- 2000-12-20 AU AU29094/01A patent/AU2909401A/en not_active Abandoned
- 2000-12-20 WO PCT/US2000/034660 patent/WO2001046825A1/en active Application Filing
 
- 
        2010
        - 2010-07-31 US US12/848,166 patent/US8099435B2/en not_active Expired - Fee Related
 
- 
        2011
        - 2011-12-15 US US13/327,719 patent/US8812548B2/en not_active Expired - Fee Related
 
- 
        2014
        - 2014-08-15 US US14/461,346 patent/US9229962B2/en not_active Expired - Fee Related
 
- 
        2016
        - 2016-01-04 US US14/987,716 patent/US9535976B2/en not_active Expired - Fee Related
- 2016-12-06 US US15/371,180 patent/US20170147678A1/en not_active Abandoned
 
Patent Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US5838918A (en) * | 1993-12-13 | 1998-11-17 | International Business Machines Corporation | Distributing system configuration information from a manager machine to subscribed endpoint machines in a distrubuted computing environment | 
| US6748580B1 (en) * | 1999-04-22 | 2004-06-08 | International Business Machines Corporation | Method and apparatus for creating software tools using a JTML interface | 
Also Published As
| Publication number | Publication date | 
|---|---|
| US7788222B2 (en) | 2010-08-31 | 
| US20150046498A1 (en) | 2015-02-12 | 
| US8812548B2 (en) | 2014-08-19 | 
| US8099435B2 (en) | 2012-01-17 | 
| US20120151605A1 (en) | 2012-06-14 | 
| US9535976B2 (en) | 2017-01-03 | 
| WO2001046825A1 (en) | 2001-06-28 | 
| US20160196333A1 (en) | 2016-07-07 | 
| US20020035556A1 (en) | 2002-03-21 | 
| AU2909401A (en) | 2001-07-03 | 
| US20100293138A1 (en) | 2010-11-18 | 
| US9229962B2 (en) | 2016-01-05 | 
Similar Documents
| Publication | Publication Date | Title | 
|---|---|---|
| US9535976B2 (en) | Information exchange engine providing a critical infrastructure layer and methods of use thereof | |
| US8966445B2 (en) | System for supporting collaborative activity | |
| US9367571B2 (en) | Techniques for integrating parameterized information requests into a system for collaborative work | |
| US6820204B1 (en) | System and method for selective information exchange | |
| US7630974B2 (en) | Multi-language support for enterprise identity and access management | |
| US20030050911A1 (en) | Schema-based services for identity-based access to profile data | |
| US20040199869A1 (en) | Schema-based service for identity-based data access to financial data | |
| US20040168066A1 (en) | Web site management system and method | |
| US20070214144A1 (en) | System and method for managing user profiles | |
| US20040060002A1 (en) | Schema-based service for identity-based access to lists | |
| US20040006564A1 (en) | Schema-based service for identity-based data access to category data | |
| US20040006590A1 (en) | Service for locating centralized schema-based services | |
| US7093285B2 (en) | Supplier portal for global procurement e-business applications | |
| US20070255712A1 (en) | Methods and systems for enabling the collaborative management of information using controlled access electronic workspace | |
| US20030041065A1 (en) | Schema-based services for identity-based access to contacts data | |
| US7284197B2 (en) | Schema-based services for identity-based data access to application settings data | |
| US7246122B2 (en) | Schema-based services for identity-based data access to favorite website data | |
| JP4550087B2 (en) | Search mediation system | |
| WO2006076199A1 (en) | Methods and systems for enabling the collaborative management of information | |
| JP3925635B2 (en) | Information distribution system and information distribution method | |
| JP4900469B2 (en) | Search mediation system | |
| Thakur et al. | A Survey of Directory and Database Protocols for Data Extraction | |
| Reagle et al. | The Platform For Privacy Preferences Web sites can bolster user confidence by clarifying their privacy practices upfront, allowing visitors to become active players in the decision-making process. | |
| Master | Digital Identities Can Tame the Wild, Wild Web. | |
| JP2002351890A (en) | Sharing method of presentation material data, and system for realizing its sharing method | 
Legal Events
| Date | Code | Title | Description | 
|---|---|---|---|
| AS | Assignment | Owner name: PLANETID, LLC, CALIFORNIA Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE ASSIGNMENT DOCUMENT PREVIOUSLY RECORDED AT REEL: 011688 FRAME: 0476. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT;ASSIGNORS:SHAH, AJIT S.;THAKUR, MADHUKAR;HU, DAVE;AND OTHERS;REEL/FRAME:044346/0080 Effective date: 20170928 | |
| STPP | Information on status: patent application and granting procedure in general | Free format text: FINAL REJECTION MAILED | |
| STCB | Information on status: application discontinuation | Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION | 
 
        
        