As companies, government agencies, and other entities collect and store personal information, the protection of the personal data has become increasingly important. This stored personal information is processed by software. The routine practice of software logging relevant data to a log file is useful for a number of reasons. As personal information is collected and processed, the personal information may be logged. Logging such personal information may expose that personal information. This exposure may conflict with data privacy laws. In addition, legacy software that already logs personal information may require retrofitting to eliminate logging of personal information. A flexible approach that protects personal information from being logged in clear text is needed.
Data collected about individuals continues to increase. Accordingly, the importance of protecting this data has also increased. Data related to individuals may contain personally identifiable information (PII). PII allows an individual to be identified. Countries, states, and industries have different and sometimes conflicting regulations regarding data collection of PII.
In addition to the different regulations, internal considerations may also warrant treating data differently in various scenarios. For example, clients, groups, divisions, departments, etc., may want to store the same or similar data, but with different levels of protection. Previous solutions allowed a database to be encrypted or for tables or columns of a database to be encrypted. These solutions, however, were inflexible. The work required for changes to data protection was substantial. For example, if a database table was to have encryption turned off, all of the data would be decrypted at once. Various embodiments allow for encryption to be turned off without requiring the data to be decrypted at once. Rather, the data may remain encrypted until the data is written back into the database.
As another example of flexibility, individual columns, rows, or intersection of a column and a row may be encrypted differently. For example, a database may contain data from multiple entities. Each entity may have different data protection requirements. As an example, data in a column may be encrypted for one entity and not encrypted for another. Various embodiments allow the data to be protected as required by the entities and stored in the same table or column. Various embodiments also allow different cryptographic algorithms or different keys to be used to encrypt data.
The data values stored in the columns 220 and 230 may be encrypted or not encrypted. In addition, the data may contain a security prefix that provides information regarding how the data is stored.
In some examples, the encrypted data and the security prefix are stored together in a data store. Accordingly, the stored data is self-referencing in that the data contains the security prefix used to decrypt the encrypted data.
In various embodiments, the security prefix 300 may include just a key identifier. The key identifier is then used to determine the appropriate cryptography algorithm and key version. In other embodiments, the security prefix 300 includes the key identifier and the cryptography algorithm, but does not include a key version identifier. These embodiments, however, are not as flexible as embodiments with a security prefix as shown in
Returning to
As an example, the ID row 001 includes encrypted data in the data1 column and unencrypted data, blue, in the data2 column. The data stored in the data2 column may be stored as plaintext. When reading the data1 data, the security prefix “key1:crypto1:v1” is used to decrypt the encrypted data stored in the data1 column. The security prefix is analyzed to determine the key name, the cryptographic algorithm to use, and the key version to use. In this case, the values “key1” and “v1” are used to determine a cryptographic key to decrypt the data using the cryptographic algorithm associated with the “crypto1” identifier.
The same application or a different application may access the data stored in the row associated with ID 002. The data in the data1 column 220 is analyzed to determine the data includes a security prefix. In an example, the security prefix may be identified by searching for four sets of data separated by a separator such as “:”. If the data stored in the data1 column1 220 includes four sets of data, a security prefix is potentially found. Additional analysis may be done to determine if the four sets of data contains valid data. For example, the available cryptographic algorithms may be known. Accordingly, if the data that identifies a cryptographic algorithm contains an unknown value, a security prefix may be assumed to not be found. An error or warning may also be logged to account for errors or known but unsupported cryptographic algorithms.
Once a valid security prefix is found an application uses the key name and key version to identify the appropriate key. In various embodiments, the key is not stored in the data store 200 due to data security practices. In an example, an application has an associated configuration that is used to identify the appropriate key using the key name and key version. In addition, the application or a data API may be used to provide the key and data to the cryptographic algorithm indicated in the security prefix. The data stored in rows associated with IDs 003 and 004 illustrate security prefixes that use a different cryptographic algorithm, crypto2, and a different key identifier, v2.
Data may also be stored unencrypted in the data store 200. Unencrypted data may be associated with a security or stored without a security prefix. For example, the row associated with ID 005 includes a security prefix with a cryptographic algorithm of void. The void value, or any appropriate identifier, indicates that the data is unencrypted and there is no need to decrypt the data before providing the data to an application. In another example, the stored data does not contain any security prefix, such as the row associated with ID 006. In this example, the data would be analyzed and no security prefix would be found. Based on not finding a security prefix, the data is assumed to be unencrypted and provided to a requesting application without any decryption. In another example, there is a default security prefix or default portions of a security prefix. If a security prefix or any part of the security prefix is not found, the default values are used to encrypt/decrypt the data.
The stored data may include protected data that is intermixed with unprotected or other protected data, but with different types of protection. In addition, data may be protected in one column but not another. For example, the row associated with ID 007 shows data protected in the data2 column 230 but not in the data1 column 220. In addition, data in multiple columns may be protected. The data in each column, however, may have different security prefixes, indicating that the data is protected in different ways. For example, the rows associated with IDs 009, 010, and 011 illustrate different security prefixes between the data1 column 220 and the data2 column.
As shown in
Writing data to a data store includes creating the security prefix to add to the data. Before writing data to the data store, a data API determines if the data is to be protected. This decision may be based on configuration data. If data security is needed, the key, the cryptography algorithm, and the version of the key is determined. The data is then encrypted. The encrypted form of data along with the security prefix are then stored in the data store. In an example, the encrypted data is combined with the security prefix and stored in a single column or cell of the data store.
Some embodiments are implemented as part of a data API, such as the data interface 120. In these embodiments, multiple applications may use the data interface 120, as shown in
As the security prefix may be stored with the data and the data API is able to process the data based on the security prefix, an application does not need to encrypt or decrypt any data. Accordingly, an application may work with unencrypted data and may be unaware that the data is stored in an encrypted format. The application receives unencrypted data from the data API and sends unencrypted data to the data API. The application relies on the data API to provide the appropriate data security.
Various disclosed embodiments store the combination of the security prefix and data as text or a character string. Applications, however, may want to store data that is not text or a character string. For example, an application may want to store an integer. The data API may encrypt the integer and store the resulting encrypted string. While the data API may store a string, the data API provides an integer to the application. This may be accomplished by the data API converting the decrypted value from a string into an integer. In one example, the data API provides a mechanism to receive an integer rather than a string. For example, the data API may provide a getInteger method. In addition, when storing an integer, the data API may accept an integer and then encrypt the integer or change the integer into a string and then encrypt. In another example, the data type may be added to the security prefix. In this example, when reading data, the data API may convert the unencrypted data into the appropriate data type.
As an example of storing data types, an instantiated class object in an application may be serialized and then stored. The data type stored with the security prefix would indicate the class of the object. The data API may decrypt the data and then instantiate the object using known serialization methods.
Other applications, such as the applications 112 and 114, may write to the database 432 using data interfaces 424 and 426, respectively. The sync service 440 may monitor databases, such as the databases 430 and 432, for modifications to data. In another example, a data interface, such as the data interfaces 420, 424, or 426, may communicate changes to data to the sync service 440.
In some examples, the sync service 440 manages the encryption between different databases. For example, data stored in one database may be encrypted one way and the data synced to a different database may be stored encrypted in a different way. As an example, the application 112 may store data in the database 432 using a cryptographic algorithm. In some examples, the cryptographic algorithm is the one used by the Java Cryptography API. The data in the database 432 may be synced to a different database, such as the database 430. Data stored in the synced database may be encrypted using a different cryptographic algorithm. For example, data stored in the synced database may be encrypted using an online encryption service, such as, Vault by HashiCorp.
Continuing the above example, the sync service 440 may read encrypted data from the database 430. Using the security prefix, the sync service 440 may decrypt the data as described above. Prior to writing the data to the sync database, the sync service 440 may encrypt the data using the online encryption service. In addition, the sync service 440 may create the corresponding security prefix. The sync service 440 may then write the encrypted data along with the security prefix to the sync database.
At 510, a request for a first data value is received. In some examples, the data interface receives the request. The first data value may be an unencrypted data value that is stored in a data store. To protect the first data value, the first data value may be stored in an encrypted form. At 520, a data store is queried for a first stored data value that is associated with the first data value. For example, the first stored data value may be the encrypted version of the first data value. In some examples, the first stored data value is stored in a single field in the data store. For example, the first stored data value may be stored in a single column in a table of a relational database. In another example, the first stored data value is stored in a single field in a non-relational database.
At 530, the first stored data value is received from the data store. At 540, the first stored data value is analyzed to determine if the first stored data value includes a security prefix and encrypted data. In some examples, the stored data value is searched for one or more separators or delimiters. For example, the stored data value may be searched for “:”, “1”, etc. If the appropriate number of separators is found, the stored data value may be broken up into different values. For example, the security prefix and the encrypted data may be extracted from the stored data value.
The security prefix may include data describing how the encrypted data is encrypted. For example, the security prefix may include a cryptography algorithm and a key name. The security prefix may also include a separator or delimiter to demark the different parts of the security prefix. In one example, the same separator or delimiter is used to separate fields of the security prefix and the encrypted data. In another example, a different separator or delimiter is used. An example of using different separators is shown in the row associated with ID 013 of
At 570, the encrypted data is decrypted using the key and the determined cryptography algorithm. The unencrypted value is the requested first data value. At 580, the first data value is returned.
In some examples, the stored data value is stored in the data store as a character string. The corresponding data value, however, may be a different type. For example, the data value may be an integer, a float, a Boolean, a date, etc., value. After decrypting the stored data value, the result may be an unencrypted string. The data type of the data value may be determined to not be a character or string type. Based on this determination, the unencrypted string may be converted into the appropriate data type of the data value. For example, the unencrypted string may be converted into a date, a Boolean, a integer, etc. The converted data may be returned as the first data value. Accordingly, the requesting application is not required to be aware that the data value is stored is an encrypted string. This feature allows flexibility in how data is encrypted without requiring software changes.
As described above, a first stored data value may include a security prefix. This security prefix may be created and stored when the data is written to the data store. In an example, the first data value is received to be stored in the data store. The first cryptography algorithm is determined. In some examples, an application that is storing the data will indicate or be configured to indicate the cryptography algorithm and key to use to encrypt the data. In another example, the data interface may also determine the cryptography algorithm and key to use via configuration data. As another example, the cryptography algorithm may be selected based on available resources. For example, if the load on a system is high a cheaper to compute cryptography algorithm may be selected. The load on a system may be determined using processor usage, memory usage, I/O latency, network latency, etc. In some embodiments, when the data encrypted for a cheaper to compute cryptography algorithm is written back to a data store, a new cryptography algorithm may be selected based on currently available resources. As another example, data may be written using a first cryptography algorithm, such as a cheaper to compute algorithm. Later as resources allow, data protected using the first cryptography algorithm may be searched for and rewritten using a different cryptography algorithm. This type of updating may also be used to help migrate data to a different cryptography algorithm, a new key, or a new version of a key. Accordingly, components of the security prefix may be used to query for data. The found data may be decrypted using the stored security prefix. The decrypted data may then be encrypted with updated parameters, such as a new cryptography algorithm, a new key, or a new key version. In addition, an updated security prefix that reflects the updated parameters is created. The encrypted data using the updated parameters along with the updated security prefix may then be written back to the data store, replacing the original data entry.
The first data value may be encrypted using the determined cryptography algorithm. In addition, the determined key may also be used. In some examples, a version of the key to use is determined and used to select the key used to encrypt the data. A security prefix is generated based on the cryptography algorithm. The security prefix includes an indication of the cryptography algorithm used to encrypt the data. The security prefix may also in an indication of the key used. In some examples, the security prefix may also include an indication of the version of the key used. The security prefix may be combined with the encrypted data and stored in a single field of the data store. In some examples, the security prefix may be stored in a separate field from the encrypted data. In these examples, the encrypted data has a corresponding security prefix stored in the data store. For example, there may be a one-to-one correspondence between a stored encrypted data value and a corresponding security prefix. This correspondence allows data security flexibility, as the key, key version, or cryptography algorithm may be updated on a value-by-value basis. This alleviates the need to port data when changes are made.
Stored data may also be synced across multiple data stores. Different data stores, however, may protect the data in different ways. In an example, a second cryptography algorithm associated with a second data store is determined. The first data value may then be encrypted with the second cryptography algorithm. In some examples, the second cryptography algorithm is different from the cryptography algorithm used to encrypt the first data value for the first data store. In addition, different keys or different versions of a key may be used to encrypt the first data value for the second data store. A second security prefix is created based on the second cryptography algorithm. In addition, the second security prefix may also include an indication of the second key and/or the version of the second key. The first data encrypted using the second security prefix may then be stored in a second data store, different from the original data store.
As described above, using security prefixes for values stored in a data store allows for flexibility in how data is protected. For example, different data values may use different cryptography algorithms, different keys, or different versions of a key. As an example, a table in a relational database may have a column. Data stored in this column in different rows may be protected differently from one another. For example, a request for two or more fields may be received. Data received from the data store may include multiple rows of data. Two data values, which may be from the same column or from the same row, may include the first stored data value and a second stored data value. The second stored data value is analyzed or searched for a second security prefix and a second encrypted data value. The second security prefix is used to determine a second cryptography algorithm and a second key. The second cryptography algorithm may be different from the first cryptography algorithm. The second key may be different from the first key used to decrypt the first data value. The second cryptography algorithm and the second key are used to decrypt the second encrypted data value. The decrypted second data value may then be returned along with the first data value.
While various examples describe how data may be protected by storing encrypted data, the disclosed examples are also able to work with data that is stored in an unencrypted format. For example, a third data value may be retrieved from a data store. The third data value may be data in the same column as the first data value or data in the same row as the first data value. The third data value is analyzed to determine the third data value is not encrypted. In some examples, this may be determine by not finding any separators or the wrong number of separators. In another example, a security prefix may be found. The security prefix may indicate that the data is not encrypted. For example, the cryptography algorithm in the security prefix may be “none” or “void” to indicate that the third data value is not encrypted. In these cases, the third data value may be returned without having to decrypt the third data value.
As another example of data protect flexibility, data may have its security prefix updated when the data is written to a data store. The data may originally be written having no encryption or using a first security prefix. Later, the same data may be written using a different security prefix. For example, the first data value may be encrypted using a key different from the first key as updated first encrypted data. An updated security prefix that includes an indication of the key different from the first key is generated. The updated security prefix along with the updated first encrypted data may then be stored in the single field in the data store. Writing the updated first encrypted data does not require any other data to be updated. For example, other protected data values remain unchanged. This allows encryption to be turned off or on without requiring data to be ported. Accordingly, data stores remain available and applications are not required to stop operation. This feature also allows encryption algorithms, keys, or the version of a key to change without requiring porting of other data to the different encryption algorithm, key, or version of a key.
As described above, a security prefix coupled to stored data allows increased data protection flexibility. Data encryption may be turned on or off without requiring any data porting. Further, the encryption algorithm, key, or key version may also change without requiring any data porting. As the data interface is able to use the security prefix to determine how to decrypt the data, previous encryption algorithms, keys, versions, may be used to access data. Then when the data is written back to the database using different encryption algorithm, key, or version, the security prefix is updated accordingly.
As an example of the flexibility of certain examples, a key rotation process may be implemented without extra overhead regarding data porting. An application of a data interface may rotate to a new version of a key. When reading previously written encrypted data, an older version of the key may be used to decrypt the data. The older version of the key is specified in the security prefix. When data is written back to a data store, the new version of the key may be used to encrypt the data. The data encrypted with the new version of the key along with an updated security prefix that indicates the new version of the key may be written back to the data store. Accordingly, data may be moved to the new version of the key as data is accessed. This is in contrast to having to port all the encrypted data to a new version of key when the key is rotated.
PII may also be logged as part of normal logging. Logging may be done for debugging or diagnostic reasons. Logged PII may also need to be protected. Legacy software may log PII in clear text. Logging PII in clear text may violate company policies or legal requirements which may expose the company to liability. Various examples disclosed herein allow PII to be masked or protected without requiring major changes to legacy software. For example, the source code that requests the PII be logged may remain unchanged, while a new logger searches the logged data for PII. If PII is found, the PII may be masked or encrypted prior to logging the data to a data store.
In one example, patterns are constructed that match the various sensitive data that should be protected. Each of the patterns may be used to compare data that is to be logged to determine if sensitive data is attempting to be logged. Any found sensitive data may be removed, masked, or encrypted. In one example, regular expressions are used at the patterns.
A masked log 606 shows the original logged data after being processed with the masked logger prior to be logged. The login pattern 610 matches the User login string and masks the third character on with “*”'s 620. The password string matches the password pattern 612 and replaces the password with ‘*’s. In one example, the masked logger may mask each matching character with a masking character, such as with an asterisk or ‘x’. In another example, any matching string is replaced with the same number of masking characters. For example, each matching string may be replaced with . . . ′ regardless of how many characters matched a pattern. Using a fixed matching string obfuscates the length of the matching string, further protecting the sensitive data. In another example, the matching string is a random number of matching characters for each matched pattern. In some examples, matched sensitive data is replaced with a random string of characters rather than a repetitive single character.
In the above examples, sensitive data is removed from any log in such a way that the log cannot be used to reconstruct the sensitive data. These examples provide complete protection of the sensitive data. In some examples, however, the sensitive data may need to be reconstructed for later analysis. In one example, the matched sensitive data is encrypted as described above. For example, a key and a cryptographic algorithm ARE used to encrypt the matched sensitive data. A security prefix is generated as described above for the encrypted sensitive data. In these examples, the log contains the security prefix and the encrypted data. For example, the matched sensitive data may be replaced with “key1:crypto1:v1|9adgj$JT9pug”. If the sensitive data is needed after the log is created, a decrypt process may analyze the logged data. When a security prefix is found, the encrypted data may be decrypted as described above. A log with the sensitive data may then be created and reviewed. When analysis is done, the log with the sensitive data may then be deleted.
In another example, the matched sensitive data is stored in a database as described above. As part of storing the sensitive data in a data store, the sensitive data is encrypted and stored along with its security prefix. In this example, an identifier that identifies the sensitive data from other sensitive data within a log file may also be stored in the database. This identifier may be used to replace the matched sensitive data within the masked logged. For example, a password may be replaced with “MSK_1412.” The MSK_1412 or “1412” may be used as the identifier to retrieve the sensitive data from the database.
In one example, a log reader may be implemented that automatically detects encrypted sensitive data. For example, the log reader may search for security prefixes or for masked identifiers. When a user of the log reader highlights masked sensitive data or hovers their mouse over sensitive data, the log reader may decrypt the sensitive data and show the unencrypted sensitive data. After the user moves the mouse away from the sensitive data or moves a cursor, the log ready may replace sensitive data with the masked sensitive data. In another example, the log reader may decrypt all sensitive data for a limited amount of time. After a certain amount of time passes or after a certain amount of inactivity, the unprotected sensitive data may be replaced once again with the corresponding masked sensitive data.
At 710, patterns are received. For example, patterns may be read from a configuration file. The patterns may be regular expressions. In other examples, the patterns may be parser constructs that are used to identify substrings of text. At 720, a request to log a string of text is received. The request may include the string of text. In some examples, the request is sent from a legacy program with the intention of logging the entire string of text, including any sensitive data within the string of text. In some examples, a masked logger replaces the logger used by the legacy system. In these examples, no changes to the legacy system's source code are required to protect sensitive data that would have been logged. Substantial resources and time may be saved by not having to update legacy source code while gaining the benefit of protecting sensitive data as part of the logging process.
At 730, the string of text is searched for a match using the plurality of patterns. For example, each pattern may be used to search the string of text for one or more matches. At 740, a first substring from the string of text that is a match based on a first pattern of the patterns is found. For example, a pattern may indicate that everything after the string “SSN” is to be masked. If the string of text contains “SSN=123-12-123”, then the first substring would be “=123-12-123”. The pattern may also indicate the specific data that is to be matched. For example, the pattern may indicate to ignore spaces or other characters like ‘=’. In this example, the matched substring may be “123-12-123”.
At 750, a first replacement string is determined. The replacement string replace the matched substring with the sensitive data. The first replacement string may be a single character repeated. For example, the replacement string “xxxxxxxxxx” may be used for the above social security number. In another example, the replacement string may only replace certain characters, such as number. In this example, the replacement string may be “xxx-xx-xxx”. In another example, the length of the replacement string may be the same for all matches or for all matches associated with a particular pattern. The length of the replacement string may be configurable and received as part of receiving the patterns. In another example, the replacement string may be of a random length. In yet another example, the replacement string may be a random string of characters.
The replacement string may also be one that both protects the sensitive data and allows the sensitive data to be recovered. In one example, the substring is encrypted with a cryptographic algorithm and a key. In some examples, a version of the key is used to determine which key to use. A security prefix based on the cryptographic algorithm and key is generated. The security prefix may also indicate the version of the key if needed. The security prefix along with the encrypted sensitive data may be combined to generated the replacement. In another example, the sensitive data and the security prefix is stored in a data store as described above. A unique identifier associated with the stored security prefix and encrypted sensitive data is used as the replacement string. The unique identifier may be an index from the data store. In another example, the logger may generate a unique identifier that is stored in the data store. The unique identifier is associated with the security prefix and encrypted sensitive data in the data store.
At 760, the replacement string replaces the first substring within the string of text. The updated string of text no longer contains the matching sensitive data. At 770, the updated string of text without the matching sensitive data is logged. For example, logging may include writing the string of text to disk or sending to a logging service over a network.
The masked logger may search the string of text for multiple matches of the same pattern. Accordingly, if a string of text contains two birthdays, both birthdays may be found and masked. In addition, the masked logger may search the string of text with each of the patterns. Accordingly, the masked logger may mask and protect all sensitive data within the string of text rather than the first found sensitive data. The replacement string for each match may be different.
Computing device 800 may include a hardware processor 802 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), a hardware processor core, or any combination thereof), a main memory 804 and a static memory 806, some or all of which may communicate with each other via a link (e.g., bus) 808. The computing device 800 may further include a display unit 800, an input device 812 (e.g., a keyboard), and a user interface (UI) navigation device 814 (e.g., a mouse). In an example, the display unit 810, input device 812, and UI navigation device 814 may be a touch screen display. In an example, the input device 812 may include a touchscreen, a microphone, a camera (e.g., a panoramic or high-resolution camera), physical keyboard, trackball, or other input devices.
The computing device 800 may additionally include a storage device (e.g., drive unit) 816, a signal generation device 818 (e.g., a speaker, a projection device, or any other type of information output device), a network interface device 820, and one or more sensors, such as a global positioning system (GPS) sensor, compass, accelerometer, motion detector, or other sensor. The computing device 800 may include an input/output controller 828, such as a serial (e.g., universal serial bus (USB), parallel, or other wired or wireless (e.g., infrared (IR), near field communication (NFC), etc.) connection to communicate or control one or more peripheral devices (e.g., a printer, card reader, etc.) via one or more input/output ports.
The storage device 816 may include a computing-readable (or machine-readable) storage media 822, on which is stored one or more sets of data structures or instructions 824 (e.g., software) embodying or utilized by any one or more of the techniques or functions described herein. In an example, at least a portion of the software may include an operating system and/or one or more applications (or apps) implementing one or more of the functionalities described herein. The instructions 824 may also reside, completely or at least partially, within the main memory 804, within the static memory 806, and/or within the hardware processor 802 during execution thereof by the computing device 800. In an example, one or any combination of the hardware processor 802, the main memory 804, the static memory 806, or the storage device 816 may constitute computing device (or machine) readable media.
While the computer-readable storage media 822 is illustrated as a single medium, a “computer-readable storage media” or “machine-readable storage media” may include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) configured to store the one or more instructions 824.
In an example, a computer-readable storage media or machine-readable storage media may include any medium that is capable of storing, encoding, or carrying instructions for execution by the computing device 800 and that cause the computing device 800 to perform any one or more of the techniques of the present disclosure, or that is capable of storing, encoding or carrying data structures used by or associated with such instructions. Non-limiting computer-readable storage media examples may include solid-state memories, and optical and magnetic media. Specific examples of computer-readable storage media may include: non-volatile memory, such as semiconductor memory devices (e.g., Electrically Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM)) and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; Random Access Memory (RAM); and optical media disks. The computer-readable storage media is non-transitory in that the storage media does not consist of transitory propagating signals.
The instructions 824 may further be transmitted or received over a communications network 826 using a transmission medium via the network interface device 820 utilizing any one of a number of transfer protocols (e.g., frame relay, internet protocol (IP), transmission control protocol (TCP), user datagram protocol (UDP), hypertext transfer protocol (HTTP), etc.). Example communication networks may include a local area network (LAN), a wide area network (WAN), a packet data network (e.g., the Internet), mobile telephone networks (e.g., cellular networks), Plain Old Telephone (POTS) networks, and wireless data networks (e.g., Institute of Electrical and Electronics Engineers (IEEE) 802.11 family of standards known as Wi-Fi®, IEEE 802.16 family of standards known as WiMax®), IEEE 802.15.4 family of standards, a Long Term Evolution (LTE) family of standards, a Universal Mobile Telecommunications System (UMTS) family of standards, peer-to-peer (P2P) networks, among others. The network interface device 820 may use the transfer protocols to transmit data using transitory propagating signals.
In an example, the network interface device 820 may include one or more physical jacks (e.g., Ethernet, coaxial, or phone jacks) or one or more antennas to connect to the communications network 826. In an example, the network interface device 820 may include one or more wireless modems, such as a Bluetooth modem, a Wi-Fi modem or one or more modems or transceivers operating under any of the communication standards mentioned herein. In an example, the network interface device 820 may include a plurality of antennas to wirelessly communicate using at least one of single-input multiple-output (SIMO), multiple-input multiple-output (MIMO), or multiple-input single-output (MISO) techniques. In some examples, the network interface device 820 may wirelessly communicate using Multiple User MIMO techniques. In an example, a transmission medium may include any intangible medium that is capable of storing, encoding or carrying instructions for execution by the computing device 800, and includes digital or analog communications signals or like communication media to facilitate communication of such software.
Any of the computer-executable instructions for implementing the disclosed techniques as well as any data created and used during implementation of the disclosed embodiments can be stored on one or more computer-readable storage media. The computer-executable instructions can be part of, for example, a dedicated software application or a software application that is accessed or downloaded via a web browser or other software application (such as a remote computing application). Such software can be executed, for example, on a single local computer (e.g., any suitable commercially available computer) or in a network environment (e.g., via the Internet, a wide-area network, a local-area network, a client-server network (such as a cloud computing network), or other such network) using one or more network computers.
The above description is intended to be illustrative, and not restrictive. For example, the above-described examples (or one or more aspects thereof) may be used in combination with others. Other embodiments may be used, such as by one of ordinary skill in the art upon reviewing the above description. Further, the following claims are hereby incorporated into the Detailed Description, with a claim standing on its own as a separate embodiment. The scope of the embodiments disclosed herein is to be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.