Applications connected by network infrastructure communicate with each other in order to share data and perform business operations. The connection between a source application and a destination application is established by the source application, which requests a connection from its Internet Protocol (IP) address to the IP address of the destination application, typically over a specific port. Typically, existing host-based network security technologies, such as personal firewalls, allow or restrict directional access specifically at the egress or ingress point of the communication on the host on which the communication is occurring. For example, the firewall running on the host on which the source application executes typically monitors the outbound connection attempt to the destination IP address, while the firewall running on the host on which the destination application executes typically monitors the inbound connection attempt from the source IP address. Each such security component operates in relative isolation from the other, and generally only has visibility into the network-related information of the other side (e.g., IP address, port, protocol), and not into the identity of the application executing on the other host.
The limited information available to each host in such a communication restricts the types of decisions that existing security technologies can make, and allows for the hosts that are party to communications to be exploited, such as by spoofing their legitimate IP addresses to make or receive unauthorized communications.
A system validates the establishment and/or continuation of a connection between two applications over a network using a two-stage process: (1) a local security agent executing on the same source system as the source application validates the connection against a set of policies stored locally on the source system; and (2) a local security agent executing on the same destination system as the destination application validates the connection against a set of policies stored locally on the destination system. The connection is allowed or blocked depending on the outcome of the two-stage validation. Before the validation process, a policy enforcement engine distributes copies of a trusted public certificate to the source and destination local security agents, which extend their local copies of the certificate to enable them to enforce policies without the use of a backend system. This validation system protects against policy violations that are not detected by traditional systems, and does so without requiring alterations to the source application, the destination application, or the network traffic between them.
Other features and advantages of various aspects and embodiments of the present invention will become apparent from the following description and from the claims.
Embodiments of the present invention perform symmetrical validation of communication between applications (or services) over a network, using agents installed on the same systems as the applications (or services), and without the need for validation by a central system. Such validation enables an imposter application to be detected and prevented from communicating even if the imposter application communicates, or attempts to communicate, using the same name and communication content as a permitted application. Embodiments of the present invention achieve this result by validating applications using application fingerprints that can distinguish permitted from prohibited applications based on features other than mere application name and communication content. Additional details and embodiments of the present invention will be described in more detail below.
The term “application,” as used herein, includes both applications and services. Therefore, any reference herein to an “application” should be understood to refer to an application or a service.
Referring to
The system 100 includes a source system 102a and a destination system 102b. A “system,” as that term is used herein (e.g., the source system 102a and/or destination system 102b), may be any device and/or software operating environment that is addressable over an Internet Protocol (IP) network. For example, each of the source system 102a and the destination system 102b may be any type of physical or virtual computing device, such as a server computer, virtual machine, desktop computer, laptop computer, tablet computer, smartphone, or wearable computer. The source system 102a and the destination system 102b may have the same or different characteristics. For example, the source system 102a may be a smartphone and the destination system 102b may be a server computer. A system (such as the source system 102a and/or destination system 102b) may include one or more other systems, and/or be included within another system. As merely one example, a system may include a plurality of virtual machines, one of which may include the source system 102a and/or destination system 102b.
The source system 102a and destination system 102b are labeled as such in
The source system 102a includes a source application 104a (which may, for example, be installed and executing on the source system 102a) and the destination system 102b includes a destination application 104b (which may, for example, be installed and executing on the destination system 102b). Each of these applications 104a and 104b may be any kind of application, as that term is used herein. The source application 104a and the destination application 104b may have the same or different characteristics. For example, the source application 104a and destination application 104b may both be the same type of application or even be instances of the same application. As another example, the source application 104a may be a client application and the destination application 104b may be a server application, or vice versa.
An embodiment will now be described for enforcing security policies on a communication that the source system 102a attempts to initiate with the destination system 102b. In this embodiment, the source system 102a includes a local security agent 106a and the destination system 102b includes a local security agent 106b. More generally, a local security agent may be contained within (e.g., installed and executing on) any system that executes one or more applications to which the security techniques disclosed herein are to be applied. A local security agent may, for example, execute within the same operating system on the same system as the application(s) that the local security agent monitors. Each such local security agent (e.g., the local security agents 106a and 106b) may include any combination of hardware and/or software for performing the functions disclosed herein.
The system 100 also includes a policy management engine 110. The policy management engine may include any combination of hardware and/or software for performing the functions disclosed herein. In the particular embodiment illustrated in
Some or all of the local security agents 106a-b may report the state of the local applications as well as the state of the network on their system to the policy management engine 110 (
Similarly, the local security agent 106b on the destination system 102b may obtain and transmit state information for the destination application 104b (and for any other applications executing on the destination system 102b) and for the network configuration information of destination system 102b and transmit such information via communication 116 to the policy management engine 110 in any of the ways disclosed above in connection with the local security agent 106a, the source system 102a, the source application 104a, and the communication 114.
The policy management engine 110 may receive the transmitted state information 114 and 116 and store some or all of it in any suitable form (
The policy management engine 110 may include or otherwise have access to a set of policies 118, which may be stored in the remote system 112. In general, each of the policies 118 specifies both a source application and a destination application, and indicates that the source application is authorized (or not authorized) to communicate with the destination application. A policy may specify, for the source and/or destination application, any number of additional attributes of the source and/or destination application, such as any one or more of the following, in any combination: user(s) who are executing the application (identified, e.g., by username, group membership, or other identifier), system(s), network subnet, and time(s). A policy may identify its associated source and/or destination application using an application fingerprint which may, for example, identify the application by its name and any other attribute(s) which may be used to authenticate the validity and identify of an application, such as any one or more of the following in any combination: filename, file size, cryptographic hash of contents, and digital code signing certificates associated with the application. An application fingerprint in a policy may include other information for its associated source and/or destination application, such as the IP address and port used by the application to communicate, whether or not such information is used to define the application.
The policy management engine 118 provides, to one or more systems in the system 100 (e.g., the source system 102a and destination system 102b), policy data, obtained and/or derived from the policies, representing some or all of the policies that are relevant to the system to which the policy data is transmitted, which may include translating applications into IP address/port combinations (
The policy management engine 110 may identify the subset of the policies 118 that are relevant to a particular system (e.g., the source system 102a and/or the destination system 102b) in any of a variety of ways. For example, the policy management engine 110 may identify a policy as relevant to a system if the policy refers to an IP address of the system or an application that is installed and/or executing on the system.
The policy management engine 110 may extract the policy data that is relevant to the systems 102a and 102b and transmit the resulting policy data communications 120 and 122 in response to any of a variety of triggers. For example, the policy management engine 110 may extract and transmit relevant policy data (in the form of instances of the communications 120 and 122) to the systems 102a and 102b:
The policy management engine 110 may only transmit updated policy data to one of the systems 102a and 102b if the updates are relevant to that system. Regardless of the trigger, in response to receiving the relevant policy data 120 and 122, the systems 102a and 102b may update their local policy data 124a and 124b in accordance with the received communications 120 and 122, respectively. Receiving and maintaining updated copies of relevant policy data enables local systems, such as the systems 102a and 102b, to apply the policies that are relevant to them without the need to communicate with a remote system or component, such as the remote system 112 or policy management engine 110.
Before describing the system 100 and methods 200a-c in more detail, it will be useful to note that the system 100 may operate in one of at least three security modes in relation to any particular connection between two applications (e.g., the source application 104a and the destination application 104b):
Note that the system 100 may, but need not, operate in the same security mode for all connections within the system 100. The system 100 may, for example, operate in optimistic security mode for some connections, operate in pessimistic security mode for other connections, and operate in blocking security mode for yet other connections. As yet another example, the system 100 may switch from one mode to another for any given connection or set of connections in response to detected conditions, as will be described in more detail below.
Referring now to
Now consider an example in which the source application 104a makes a network request to communicate with the destination application 104b. Although this particular example will be described in connection with this particular request, the techniques disclosed herein may be applied more generally to any request made by any application to communication with any other application.
The local security agent that is on the same system as the requesting application, which in this example is the local security agent 106a that is on the same system 102a as the requesting application 104a, detects that the requesting application 104a has made the communication request, intercepts the request, and blocks the request from proceeding further at least until the source local security agent 106a has evaluated whether the request matches a local policy (
The local security agent 106a determines, based on its evaluation, whether one of the local policies 124a covers the communication request (
If the covering policy is current, then the local security agent 106a sets its security mode to optimistic mode (
If, in operation 232 of
If, in operation 214, the local security agent 106a determines that none of the local policies 124a covers the request, or, in operation 216, the local security agent 106a determines that the covering policy denies the request, then the local security agent 106a determines whether its current security mode is blocking security mode (
If the local security agent 106a's current security mode is blocking security mode, then the local security agent 106a transmits the request to the policy management engine 110 and awaits a response from the policy management engine 110 (
Regardless of whether the local security agent 106a allows or denies the request (
The local security agent 106a may or may not wait to receive a response from the reconciliation engine 128 before proceeding, depending on the local security agent 106a's current security mode. More specifically, the local security agent 106a determines whether it previously denied the connection request 130 in operation 228 or allowed the connection request 130 in operation 232 (
If, instead, the connection request was allowed and was accepted by the destination system 102b, then the local security agent 106a determines whether it is currently operating in pessimistic security mode (
If the local security agent 106a is not currently operating in pessimistic security mode (
Referring now to
The destination local security agent 106b intercepts the inbound connection request 130 transmitted by the source local security agent 106a, and blocks the request from proceeding further at least until the destination local security agent 106b has evaluated whether the request 130 matches a local policy (
The local security agent 106b determines, based on its evaluation, whether one of the local policies 124b covers the communication request 130 (
If the covering policy is current, then the local security agent 106b sets its security mode to optimistic mode (
If, in operation 272 of
If, in operation 254, the local security agent 106b determines that none of the local policies 124b covers the request 130, or, in operation 256, the local security agent 106b determines that the covering policy denies the request 130, then the local security agent 106b determines whether its current security mode is blocking security mode (
Regardless of whether the local security agent 106b allows or denies the request 130 (
The local security agent 106b may or may not wait to receive a response from the reconciliation engine 128 before proceeding, depending on the local security agent 106b's current security mode. More specifically, the local security agent 106b determines whether it previously denied the connection request 130 in operation 268 or allowed the connection request 130 in operation 272 (
If, instead, the connection request was allowed and was accepted by the destination application 104b, then the local security agent 106b determines whether it is currently operating in pessimistic security mode (
If the local security agent 106b is not currently operating in pessimistic security mode (
As described above, the source and destination local security agents 106a-b notify the reconciliation engine 128 of their decisions regarding the connection request, in operation 234 of
The net effect of the method 200 shown in
A specific example of an application of the system 100 of
The local security agent 106a reports to the policy management engine that it is running application “WebApp” and that its system has an IP address of 192.168.1.1 (communication 114). The local security agent 106b reports to the policy management engine 110 that the application “Database” is running and it is listening on IP address 192.168.1.2, port 3306 (communication 116). The policy management engine 110 informs the source local security agent 106a that application “WebApp” may communicate with 192.168.1.2 over port 3306 (communication 120). The policy management engine 110 informs the destination local security agent 106b that application “Database” may receive communication from 192.168.1.1 (communication 114).
The “WebApp” application initiates a connection request to IP address 192.168.1.2, port 3306. Because this matches a local policy that was received from the policy management engine 110, the local security agent 106a uses the techniques disclosed above to allow the connection request 130 to be transmitted to the destination system 102b and to inform the reconciliation engine that the application named “WebApp” that is executing has initiated a connection request from IP address 192.168.1.1 to IP address 192.168.1.2, port 3306.
On the destination system 102b, IP address 192.168.1.2 on port 3306 receives an inbound request from IP address 192.168.1.1. Because this matches a local policy that was received from the policy management engine 110, the destination local security agent 106b uses the techniques disclosed above to receive the connection request 130, to allow the connection request 130 to be provided to the “Database” application, and to informs the reconciliation engine 128 that the application named “Database” that is executing and listening on IP address 192.168.1.2, port 3306, has received a connection request from IP address 192.168.1.1.
The reconciliation engine 128 collates the information it has received from the source and destination local security agents 106a-b, using any of a variety of data in the received information (e.g., timestamp and/or packet header information). In this example, there are two pieces of information: “‘WebApp’ requested an outbound connection from 192.168.1.1 to 192.168.1.2:3306” and “‘Database’ listening on 192.168.1.2:3306 received an inbound connection request from 192.168.1.1”. The result of this collation is a conclusion by the reconciliation engine 128 that an application named “WebApp” is attempting to make a connection from 192.168.1.1 to an application named “Database” on 192.168.1.2, port 3306. The reconciliation engine 128 determines that this connection request matches the policy which indicates that the “Database” application is permitted to receive connections from “WebApp” applications and, in response to this determination, sends a positive confirmation back to the source local security agent 106a and the destination local security agent 106b, indicating that the requested connection satisfies the policies 118. In response to receiving these confirmations, the source and destination local security agents 106a-b take no further action.
Although in the embodiment of
Similarly, if the reconciliation engine 128 notifies the destination local security agent 106b that the request 130 violates one of the policies 118, even after the source local security agent 106a has transmitted the request 130 to the destination system 102b, then the destination local security agent 106b may, in response to such a notification, either deny the request 130 and not provide the request 130 to the destination application 104b, or terminate the connection if it has already been allowed. As a result, it would not be necessary for the reconciliation engine 128 to notify the source local security agent 106a of the policy violation in order to prevent a connection from being established between the source application 104a and the destination application 104b.
Furthermore, although both the source system 102a and the destination system 102b in
Although the policy management engine 110 is shown in
Similarly, although the reconciliation engine 128 is shown in
Although the local security agents 106a and 106b are shown in
The description herein refers to blocking or not allowing network connections to be created, and to terminating existing network connections, in response to determining that a policy would be or has been violated. Such blocking/terminating may be applied to: (1) the specific connection that would violate or has violated a policy; (2) all connections that originate from the same source as a connection that would violate or has violated a policy, and which exist or have been requested at the time the policy violation has been detected; (3) all connections that originate from the same source as a connection that would violate or has violated a policy, including both connections that exist or have been requested at the time the policy violation has been detected, and connections requested in the future (possibly until some time limit has been reached or some other condition has been satisfied); and (4) throttling connections originating from the same source as the connection that has been determined to violate the policy.
Although certain embodiments have been described herein as being applied to a request to establish a network connection (such as the request 130), this is merely an example and not a limitation of the present invention. Alternatively or additionally, embodiments of the present invention may apply the techniques disclosed herein to all content (e.g., every packet) communicated within an existing connection, or to selected content (e.g., periodically sampled packets) within an existing connection.
Referring to
The system 100 includes a source system 302a and a destination system 302b. The source system 302a of
The source system 302a includes a source application 304a (which may, for example, be installed and executing on the source system 302a) and the destination system 302b includes a destination application 304b (which may, for example, be installed and executing on the destination system 302b). The source application 304a of
An embodiment will now be described for enforcing security policies on a communication that the source system 302a attempts to initiate with the destination system 302b. In this embodiment, the source system 302a includes a local security agent 306a (which may have any of the characteristics of the local security agent 106a of
The system 300 also includes a policy management engine 310, which may have any of the characteristics of the policy management engine 110 of
Similarly, the local security agent 306b on the destination system 302b may obtain and transmit state information for the destination application 304b (and for any other applications executing on the destination system 302b) and for the network configuration information of destination system 103b and transmit such information via communication 316 to the policy management engine 310 in any of the ways disclosed above in connection with the local security agent 306a, the source system 302a, the source application 304a, and the communication 314.
The policy management engine 310 may receive the transmitted state information 314 and 316 and store some or all of it in any suitable form (
The policy management engine 310 may include or otherwise have access to a set of policies 318, which may be stored in the remote system 312. In general, each of the policies 318 specifies both a source application and a destination application, and indicates that the source application is authorized (or not authorized) to communicate with the destination application. The policies 318 may have any of the characteristics disclosed herein in connection with the policies 118 of
The policy management engine 310 provides, to one or more systems in the system 300 (e.g., the source system 302a and destination system 302b), policy data, obtained and/or derived from the policies, representing some or all of the policies that are relevant to the system to which the policy data is transmitted, which may include translating applications into IP address/port combinations (
Like the system 100 of
The policy management engine 310 creates a trusted public key certificate 340 (such as an X.509 root certificate) (
Although X.509 is provided above as an example of a public key certificate infrastructure, this is merely an example and not a limitation of the present invention. Other public key certificate infrastructures may be used. One benefit of X.509 is that it allows a host or website to create a document that proves the ownership of a public key. It used public-key encryption to guarantee that the document is valid. In addition to identity, the certificate may include other information. As described below, embodiments of the present invention may use the information in the X.509 certificate to create a “web of trust” among the agents 106a-b, so that they can trust the information they have received from a (putative) other agent and act on it.
Referring now to
Now consider an example in which the source application 304a makes a network request to communicate with the destination application 304b. Although this particular example will be described in connection with this particular request, the techniques disclosed herein may be applied more generally to any request made by any application to communication with any other application.
The local security agent that is on the same system as the requesting application, which in this example is the local security agent 306a that is on the same system 302a as the requesting application 304a, detects that the requesting application 304a has made the communication request, intercepts the request, and blocks the request from proceeding further at least until the source local security agent 306a has evaluated whether the request matches a local policy (
Recall that the local security agents 306a-b have already received and stored intermediate signing certificates 356a-b, respectively, from the policy management engine 310. The policy management engine 310 is a source that is trusted a priori by both of the local security agents 306a-b. Furthermore, the intermediate certificates 356a-b are derived from common root certificate 340, which is known only to the policy management engine 310.
After the source local security agent 306a intercepts the outgoing communication request, the source local security agent 306a creates its own local certificate 358a, referred to herein as a “client certificate,” based on the local intermediate certificate 356a (
Similarly, the destination local security agent 306b creates its own local client certificate 358b based on the local intermediate certificate 356b (
The local security agents 306a-b then exchange their respective client certificates 358a-b, such as by using the mTLS protocol (
The client certificates 358a-b are based on the root certificate 340. The root certificate 340 has already been signed by the policy management engine 310, and also received by the security agents 306a-b, and this ends the involvement of the policy management engine 310. Because the root certificate 340 includes a cryptographic signature, proving it originates from the backend (e.g., the policy management engine 310), the client certificates 358a-b, which extend the root certificate 340, are also trusted just as the root certificate 340 is trusted. When the client certificates 358a-b are exchanged, the receiver of the client certificate can trust that the sender possesses a root certificate and hence that the information it sends may be trusted.
Both of the local security agents 306a-b then have the information required to decide whether their local policies 324a-b, respectively, will allow (or refuse) the communication request from the source application 304a, without the involvement of the remote system 312. Specific examples of techniques for making the allow/refuse decision will now be described.
The local security agent 306a evaluates the request against the locally stored policies 324a in order to determine whether to allow or deny the request based on any one or more of the following, in any combination: the identity of the source application 304a, the IP address and port of the destination application 304b, some or all of the contents of the request, and the local policy data 324a (
The local security agent 306a determines, based on its evaluation, whether one of the local policies 324a covers the communication request (
If the covering policy is current, then the local security agent 306a sets its security mode to optimistic mode (
If, in operation 428 of
If, in operation 426, the local security agent 306a determines that none of the local policies 324a covers the request, or, in operation 428, the local security agent 306a determines that the covering policy denies the request, then the local security agent 306a determines whether its current security mode is blocking security mode (
If the local security agent 306a's current security mode is blocking security mode, then the local security agent 306a waits until both the client certification exchange is completed and until the information from the certificate has been used to check with respect to the relevant set of policies whether to allow or deny the communication (
Referring now to
The destination local security agent 306b intercepts the inbound connection request 330 transmitted by the source local security agent 306a, and blocks the request 330 from proceeding further at least until the destination local security agent 306b has evaluated whether the request 330 matches a local policy (
The local security agent 306b evaluates the request 330 against the locally stored policies 324b in order to determine whether to allow or deny the request 330 based on any one or more of the following, in any combination: the identity of the destination application 304b, the IP address and port of the source application 304a, some or all of the contents of the request 330, and the local policy data 324b (
The local security agent 306b determines, based on its evaluation, whether one of the local policies 324b covers the communication request 330 (
If the covering policy is current, then the local security agent 306b sets its security mode to optimistic mode (
If, in operation 472 of
If, in operation 454, the local security agent 306b determines that none of the local policies 324b covers the request 330, or, in operation 456, the local security agent 306b determines that the covering policy denies the request 330, then the local security agent 306b determines whether its current security mode is blocking security mode (
If the local security agent 306b's current security mode is blocking security mode, then the local security agent 306b waits until both the client certification exchange is completed and until the information from the certificate has been used to check with respect to the relevant set of policies whether to allow or deny the communication (
The net effect of the method 400 shown in
One of the advantages of embodiments of the invention shown in
One of the advantages of embodiments of the present invention is that they may be used to protect against policy violations without requiring alterations to the source application 104a, the destination application 104b, or the network traffic between them (e.g., the communication request 130). This ability simplifies the installation, configuration, and maintenance of the system 100 greatly in comparison to systems which require applications and/or network traffic to be modified in order to detect policy violations.
Another advantage of embodiments of the present invention is that they have visibility into the network-related information of both the source and destination sides of a network communication, thereby enabling network security policies to be validated based on such information from both sides. This provides significant advantages over prior art systems, which use only information from the source or the destination, and which therefore lack, for example, information about the identity of the application executing on the other side of the communication. Access to information from both sides of network communications enables embodiments of the present invention to identify and prevent violations of network security policies which cannot be identified accurately using prior art techniques that rely solely on information from one side of the communication.
It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims. For example, elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions.
Any of the functions disclosed herein may be implemented using means for performing those functions. Such means include, but are not limited to, any of the components disclosed herein, such as the computer-related components described below.
The techniques described above may be implemented, for example, in hardware, one or more computer programs tangibly stored on one or more computer-readable media, firmware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on (or executable by) a programmable computer including any combination of any number of the following: a processor, a storage medium readable and/or writable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), an input device, and an output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output using the output device.
Embodiments of the present invention include features which are only possible and/or feasible to implement with the use of one or more computers, computer processors, and/or other elements of a computer system. Such features are either impossible or impractical to implement mentally and/or manually. For example, embodiments of the present invention intercept and then may block network connection requests. Such features are applicable only within the context of networked communications and cannot be performed mentally and/or manually.
Any claims herein which affirmatively require a computer, a processor, a memory, or similar computer-related elements, are intended to require such elements, and should not be interpreted as if such elements are not present in or required by such claims. Such claims are not intended, and should not be interpreted, to cover methods and/or systems which lack the recited computer-related elements. For example, any method claim herein which recites that the claimed method is performed by a computer, a processor, a memory, and/or similar computer-related element, is intended to, and should only be interpreted to, encompass methods which are performed by the recited computer-related element(s). Such a method claim should not be interpreted, for example, to encompass a method that is performed mentally or by hand (e.g., using pencil and paper). Similarly, any product claim herein which recites that the claimed product includes a computer, a processor, a memory, and/or similar computer-related element, is intended to, and should only be interpreted to, encompass products which include the recited computer-related element(s). Such a product claim should not be interpreted, for example, to encompass a product that does not include the recited computer-related element(s).
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by one or more computer processors executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives (reads) instructions and data from a memory (such as a read-only memory and/or a random access memory) and writes (stores) instructions and data to the memory. Storage devices suitable for tangibly embodying computer program instructions and data include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive (read) programs and data from, and write (store) programs and data to, a non-transitory computer-readable storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
Any data disclosed herein may be implemented, for example, in one or more data structures tangibly stored on a non-transitory computer-readable medium. Embodiments of the invention may store such data in such data structure(s) and read such data from such data structure(s).
Number | Name | Date | Kind |
---|---|---|---|
6009475 | Shrader | Dec 1999 | A |
6138162 | Pistriotto | Oct 2000 | A |
7316029 | Parker | Jan 2008 | B1 |
7383569 | Elgressy | Jun 2008 | B1 |
7620985 | Bush | Nov 2009 | B1 |
8166533 | Yuan | Apr 2012 | B2 |
8499348 | Rubin | Jul 2013 | B1 |
8677471 | Karels | Mar 2014 | B2 |
9773107 | White | Sep 2017 | B2 |
10154067 | Smith | Dec 2018 | B2 |
10348599 | O'Neil et al. | Jul 2019 | B2 |
10362048 | Alexander | Jul 2019 | B2 |
10439985 | O'Neil | Oct 2019 | B2 |
10505899 | Singh | Dec 2019 | B1 |
20050193222 | Greene | Sep 2005 | A1 |
20060095970 | Rajagopal | May 2006 | A1 |
20170078329 | Hwang | Mar 2017 | A1 |
20170272465 | Steele | Sep 2017 | A1 |
20180041471 | Sudo | Feb 2018 | A1 |
20190349283 | O'Neil et al. | Nov 2019 | A1 |
20200028820 | O'Neil | Jan 2020 | A1 |
Entry |
---|
International Preliminary Report on Patentability dated Aug. 22, 2019, by the International Bureau in International Patent Application No. PCT/US2018/059924, 6 pages. |
International Preliminary Report on Patentability, dated Aug. 29, 2019, in international patent application PCT/US2018/018325, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20200021618 A1 | Jan 2020 | US |
Number | Date | Country | |
---|---|---|---|
62457508 | Feb 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15883534 | Jan 2018 | US |
Child | 16214843 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16214843 | Dec 2018 | US |
Child | 16578175 | US |