[go: up one dir, main page]

US20190052604A1 - Network isolation - Google Patents

Network isolation Download PDF

Info

Publication number
US20190052604A1
US20190052604A1 US16/059,381 US201816059381A US2019052604A1 US 20190052604 A1 US20190052604 A1 US 20190052604A1 US 201816059381 A US201816059381 A US 201816059381A US 2019052604 A1 US2019052604 A1 US 2019052604A1
Authority
US
United States
Prior art keywords
host computer
computer system
network
computing environment
sandboxed computing
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.)
Granted
Application number
US16/059,381
Other versions
US11240207B2 (en
Inventor
Glenn Coleman
Peter Martz
Kenneth Moritz
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Croga Innovations Ltd
Original Assignee
L3 Technologies Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by L3 Technologies Inc filed Critical L3 Technologies Inc
Priority to US16/059,381 priority Critical patent/US11240207B2/en
Publication of US20190052604A1 publication Critical patent/US20190052604A1/en
Assigned to L3 TECHNOLOGIES, INC. reassignment L3 TECHNOLOGIES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Moritz, Kenneth, COLEMAN, GLENN, Martz, Peter
Application granted granted Critical
Publication of US11240207B2 publication Critical patent/US11240207B2/en
Assigned to CROGA INNOVATIONS LIMITED reassignment CROGA INNOVATIONS LIMITED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: EAGLE TECHNOLOGY, HARRIS CORPORATION, HARRIS GLOBAL COMMUNICATIONS, INC., L3 TECHNOLOGIES, INC., L3HARRIS TECHNOLOGIES, INC.
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0281Proxies
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/52Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
    • G06F21/53Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow by executing in a restricted environment, e.g. sandbox or secure virtual machine
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/57Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0209Architectural arrangements, e.g. perimeter networks or demilitarized zones
    • H04L63/0218Distributed architectures, e.g. distributed firewalls
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0227Filtering policies
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1441Countermeasures against malicious traffic
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45583Memory management, e.g. access or allocation
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45587Isolation or security of virtual machine instances
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45595Network integration; Enabling network access in virtual machine instances
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1441Countermeasures against malicious traffic
    • H04L63/145Countermeasures against malicious traffic the attack involving the propagation of malware through the network, e.g. viruses, trojans or worms

Definitions

  • the Internet provides access to a large number of systems from which beneficial and/or harmful data may be retrieved by a host computer system attached to and communicating over the Internet. Harmful data that can be accessed through the Internet includes a variety of viral software constructs, generally referred to as malicious software or malware. Malware may be downloaded to a host computer system unintentionally, for example, by and/or without the knowledge of the user of the host computer system.
  • a host computer system that has downloaded malware may be referred to as an infected host computer system.
  • An infected host computer system may result in possible security losses, reduction of efficiency, and/or malfunctions.
  • Security losses may include, but are not limited to, the loss of some or all data that is accessible by the infected host computer system, the installation of additional malware onto the infected host computer system, and/or the loss of command and control of the infected host computer system.
  • Reduction of efficiency may be incurred from, but not limited to, additional processor demand, additional memory usage, and/or additional network access by the executing malware
  • the security and privacy of the user of the infected host computer system may be compromised by malware.
  • Both information located on the infected host computer system and/or information stored on or communicated via a local area network may be susceptible to attack by the malware.
  • an infected host computer may be used by the malware as a vehicle to stage an attack on other network resources that are accessible from the infected host computer system. Such an attack method is often undetected by the user of the host computer system and/or network administrators.
  • An infected host computer system may lose command and control.
  • the loss of command and control of the infected host computer system may include performing one or more actions the author of the downloaded malware may desire.
  • the malware may perform a reconnaissance of the infected host computer system, determine system privileges, access (e.g., communicate with) local files, access security tokens, and/or attempt infection or access of other network resources accessible from the infected computer system
  • An Internet isolation system may include a network, a host computer system, a border firewall, an authorization device, and/or proxy device (e.g., such as a web proxy).
  • the host computer system may include a processor and memory.
  • the network may include one or more of a local area network (LAN), a wide area network (WAN), a cellular network, a Wi-Fi network, a digital subscribers line (DSL) network, a cloud computing network, a data center, an ad-hoc network, a satellite network, a cable modem network, and/or the like.
  • the cloud computing network may include one or more of an Infrastructure as a Service (IaaS) or a Platform as a Service (PaaS) applications.
  • the networked computer system may be configured to implement network isolation between one or more untrusted network destinations and various untrusted network(s).
  • the network isolation may be implemented via one or more of a host-based firewall on a host computer system, a border firewall around a portion of a network that includes the host computing system, an authorization device, a proxy device, an internal isolation firewall on the host computer system, and/or a segregation of a trusted memory space and an untrusted memory space.
  • the host computer system may be configured to communicate with (e.g., access) one or more untrusted network destinations via a first communication channel.
  • the host computer system may be configured to communicate with one or more trusted network destinations via a second communication channel.
  • the host computer system may be configured to enforce separation of the first communication channel and the second communication channel. Even if malware may be introduced to the host computer system, the host computer system and/or network nodes may be configured to implement network isolation techniques that prevent the malware from moving to other devices on the networked computer system.
  • a host-based firewall may be configured to prevent lateral communication and/or movement of malware between the host computer system and other devices on the networked computer system.
  • a proxy device/server may be configured to prevent unauthorized communication between the host computer system and the one or more untrusted network destinations (e.g., Internet destinations).
  • the segregation of the trusted memory space and the untrusted memory space may be enforced by the internal isolation firewall.
  • the host based computer system may be configured to run one or more applications and/or processes in the untrusted memory space that are configured to communicate with the one or more untrusted network destinations.
  • the host computer system may be configured to run one or more applications and/or processes in the trusted memory space that are configured to communicate with one or more devices on the network (e.g., trusted devices on the network). Applications running in the untrusted memory space may be blocked from communicating with trusted destinations and applications running in the trusted memory space may be blocked from communicating with untrusted destinations.
  • An internet isolation system may include a network having one or more host computer systems, an authorization device, a proxy device, and/or a border firewall.
  • a host computer system may be configured to connect to a network.
  • the host computer system may be configured to implement an operating system.
  • the operating system may enable operation of a workspace.
  • the workspace may be configured to enable operation of a first set of one or more applications and/or processes.
  • the workspace may be enabled by and/or executed using a first memory space.
  • the host computer system may be configured to implement a sandboxed computing environment.
  • the sandboxed computing environment may be configured to enable operation of a second set of one or more applications and/or processes.
  • the sandboxed computing environment may be considered an untrusted memory space.
  • the sandboxed computing environment may be configured to authenticate with the authorization device.
  • the sandboxed computing environment may be configured to classify a network destination as trusted or untrusted based on a whitelist including a list of trusted network destinations and/or a blacklist including a list of untrusted network destinations.
  • the trusted network destinations may be communicated with via one or more of the first set of one or more applications and/or processes associated with the workspace.
  • the sandboxed computing environment may be enforced by a sandbox container process.
  • the sandboxed computing environment may be enabled by and/or executed using a second memory space. The first memory space and the second memory space may be isolated, for example, by the sandbox container process.
  • the host computer system may be configured to isolate, using an internal isolation firewall, the sandboxed computing environment from the workspace.
  • the internal isolation firewall may enforce a separation of the sandboxed computing environment and the workspace.
  • the internal isolation firewall may segregate storage memory associated with the workspace from storage memory associated with the sandboxed computing environment.
  • the internal isolation firewall may allow a predefined set of processes to be executed within the sandboxed computing environment.
  • the sandbox container process may prevent execution in the sandboxed computing environment of any processes outside of the predefined set of processes.
  • the internal isolation firewall may be configured to prevent data from being communicated between the sandboxed computing environment and the workspace, for example, without an explicit user input.
  • the sandbox container process may enable the internal isolation firewall.
  • the host computer system may prevent, using a host-based firewall, communication between the host computer system and one or more other devices on the network.
  • the host-based firewall may be configured to block incoming traffic from one or more devices on the network and/or one or more devices on the Internet.
  • the host computer system may communicate, using the second set of one or more applications and/or process operating on the sandboxed computing environment, with untrusted network destinations via the proxy device.
  • the authorizing device and the proxy device may be the same device (e.g., a single device). At least one of the untrusted network destinations is located on the Internet and may be communicated with, using the proxy device, via a browser process operating within the sandboxed computing environment upon authentication via the authorization device.
  • the border firewall may be configured to block unauthorized communications between the network and the untrusted network destinations.
  • FIG. 1 depicts an example host computer system.
  • FIG. 2 depicts an example host computer system using a sandbox based network isolation system.
  • FIG. 3 depicts an example host computer system connected to a local area network (LAN), the example host computer system using a sandbox based network isolation system.
  • LAN local area network
  • FIG. 4 depicts an example host computer system connected to a wide area network (WAN), the example host computer system using a sandbox based network isolation system.
  • WAN wide area network
  • FIG. 5 depicts an example host computer system connected to a cellular radio access network (RAN), the example host computer system using a sandbox based network isolation system.
  • RAN radio access network
  • Systems and methods are disclosed for isolation of a host machine's communication with one or more untrusted network destinations. Isolating the host machine's communication with one or more untrusted network destinations may protect the host machine from one or more of command and control infection, data exfiltration, or general automated infection that can occur from communicating with the untrusted network destinations.
  • a host computer system may securely browse, access, and/or communicate with untrusted network destinations, including but not limited to resources accessible via the Internet.
  • the host computer system may be a laptop computer, a mobile phone, a tablet, etc.
  • the host computer system may be connected to a network (e.g., a local area network (LAN), a wide area network (WAN), a cellular network, a Wi-Fi network, a digital subscribers line (DSL) network, a cloud computing network, a data center, an ad-hoc network, a satellite network, a cable modem network, etc.).
  • a network e.g., a local area network (LAN), a wide area network (WAN), a cellular network, a Wi-Fi network, a digital subscribers line (DSL) network, a cloud computing network, a data center, an ad-hoc network, a satellite network, a cable modem network, etc.
  • the host computer system may be a physical machine, a virtual machine, or a combination thereof.
  • the isolation may be enforced via the host computer system itself and/or via one or more network entities located within the network.
  • Communication isolation may isolate communications associated with one or more web-based applications from other network environment communications.
  • the web-based applications may communicate via a first communication channel and the other network environment communications may use one or more other communication channels.
  • the first communication channel may be isolated from the one or more other communication channels.
  • the first communication channel may be established with a proxy device (e.g., such as a web proxy).
  • the web-based applications may include web browsers, file transfer applications, email applications, chat or instant messaging applications, peer-to-peer (P2P) file sharing applications, automatic web backup applications (e.g., to cloud services), anti-virus and other security applications, collaboration software applications, remote desktop applications, screen and resource sharing applications, gaming applications, applications that rely on cloud resources for processing resources, and/or the like.
  • P2P peer-to-peer
  • Examples of web browsers may include Internet Explorer, Safari, Mozilla, Chrome, etc.
  • the file transfer applications may include FileZilla, WinSCP, CyberDuck, FireFTP, etc.
  • the collaboration software applications may include WebEx, LiveMeeting, HP Virtual Room, etc.
  • the communication isolation may protect a network from a computer system operating within the network, that runs a collaboration software.
  • the computer system may isolate the collaboration software from other applications and/or processes operating on the computer system.
  • Communication isolation may be provided via untrusted memory space segregation.
  • the host computer system may have a sandbox protected application or process and/or an internal isolation firewall running thereon.
  • a sandbox protected application or process running thereon.
  • one or more of the web browsers, file transfer applications, email applications, chat or instant messaging application, P2P file sharing applications, automatic web backup application, anti-virus and other security applications, collaboration software applications, remote desktop applications, screen and resource sharing applications, gaming applications, applications that rely on cloud resources for processing resources, and/or the like may wholly or partially be contained in a sandboxed computing environment.
  • other isolation methods such as operating the applications within a virtual machine may be used.
  • the sandbox protected application or process may operate within a sandboxed computing environment.
  • the sandboxed computing environment may include resources (e.g., a limited set of resources) allocated for operation of a sandbox container process.
  • the host computer system may implement the sandboxed computing environment.
  • the sandboxed computing environment may be enforced via the sandbox container process.
  • the sandbox container process may be a security mechanism used to separate the sandboxed computing environment from other applications and/or processes that may be running on a workspace of the host computer system.
  • the sandbox computing environment may be configured to enable operation of one or more applications and/or processes.
  • the sandboxed container process may be configured to enable the one or more applications and/or processes (e.g., such as a browser process) being executed within the sandboxed computing environment to access the resources allocated for operation of the sandbox container process.
  • the one or more applications and/or processes being operated within the sandboxed computing environment may be allowed to access memory associated with the sandboxed computing environment.
  • the memory associated with the sandboxed computing environment may be separate from memory that is configured to enable storage and operation of the workspace.
  • the host computer system may communicate with (e.g., access), using the application and/or process operating on the sandboxed computing environment, untrusted network destinations via a proxy device.
  • the proxy device may be a web proxy, as described herein.
  • the host computer system may be configured to implement an operating system that enables operation of the workspace.
  • the workspace may include one or more applications and/or processes operating within the operating system that are not restricted by the sandbox container process.
  • the operating system of the host computer system may include a set of resources configured to enable operation of the workspace and the sandbox container process.
  • the sandbox container process may have access to one or more operating system and/or kernel processes in order to enforce isolation between the workspace associated with the first memory space and the sandboxed computing environment associated with the second memory space.
  • the sandbox container process may enforce the segregation using techniques such as namespace isolation such that processes running in the sandboxed computing environment in the second memory space are restricted from accessing the first memory space including the workspace (e.g., and vice versa).
  • the sandbox container process may restrict access to certain resources by processes running in the sandboxed computing environment.
  • the sandboxed container process may allow the workspace and the sandboxed computing environment to share access to the host operating system and host operating resources (e.g., including the kernel and libraries) while enforcing the segregation of the memory spaces access by the workspace and the sandboxed computing environment.
  • the sandbox container process may permit isolation of the sandboxed computing environment without requiring the sandboxed computing environment to boot a separate operating system, load separate libraries, etc., which would require separate private memory for those files.
  • the one or more processes or applications operating within the sandboxed computing environment may be permitted to communicate with untrusted network destinations via an access connection device.
  • the access connection device may be a proxy device, for example.
  • the one or more processes or applications operating within the sandboxed computing environment may connect to the untrusted network destinations as a dedicated network interface device with using a specific Internet Protocol (IP) address.
  • IP Internet Protocol
  • the one or more processes or applications operating within the sandboxed computing environment may be referred to as sandboxed processes or applications.
  • the host computer system may maintain a list of untrusted network destinations and/or a list of trusted network destinations.
  • the list of trusted network destinations may be a whitelist.
  • the list of untrusted network destinations may be a blacklist.
  • the whitelist and the blacklist may be refined based on username and/or machine identification (ID).
  • ID machine identification
  • the lists of trusted and untrusted network destinations may be different for different users and/or machines associated with a respective network.
  • the whitelist and/or the blacklist may be associated with one or more access levels.
  • a first whitelist and a first blacklist may be assigned to a first access level.
  • An untrusted network destination may be an untrusted resource, an untrusted device, an untrusted website, and/or the like.
  • the untrusted network destinations may be sources of malware
  • the one or more processes or applications operating within the sandboxed computing environment may be allowed to communicate with the untrusted network destination(s), but other communication from the host computer system (e.g., communications originating from outside the sandboxed computing environment such as from within the workspace) to the untrusted network destination(s) may be prevented.
  • Communication isolation may be provided via a host-based firewall.
  • the host computer system may prevent, using the host-based firewall, communication between the host computer system and one or more other devices on the network.
  • the host-based firewall may be configured to prevent unauthorized communication between applications and/or processes operating in the workspace of the host computer system to other devices on the network over which the host computer is communicating.
  • the host-based firewall may be configured to block incoming communications to the workspace of the host computer system, except for predetermined trusted devices and/or predetermined network ports.
  • the host-based firewall may allow outgoing communications to be sent from a process in the workspace to a non-web-based (e.g., LAN destination).
  • the host-based firewall may be configured to block outgoing communications sent from a process in the workspace to web-based (e.g., non-LAN) destinations.
  • Communication isolation may be provided via an internal isolation firewall.
  • the sandbox container process may enable the internal isolation firewall.
  • the internal isolation firewall may enable separation between the sandboxed computing environment and the workspace.
  • the internal isolation firewall may be configured to prevent data from being communicated between the sandboxed computing environment and the operating system, for example, without an explicit user input.
  • the applications and/or processes operating within the sandboxed computing environment may be prevented from accessing any additional resources of the host computer system or may be prevented from accessing any additional resources of the host computer system without explicit user action.
  • the internal isolation firewall may generate a command prompt that enables a user selection if an application and/or process operating within the sandboxed computing environment is requesting access to resources outside of the sandbox memory space.
  • malware that is designed to attempt to remain transparent to the user may be limited to operation within the sandboxed computing environment.
  • the malware within the sandboxed computing environment may be unable to access other resources available to the host system generally, such as local area networks and secure memory regions.
  • the internal isolation firewall may allow certain actions to be performed with approval of the user of the host system. For example, an application and/or process operating within the sandboxed computing environment may be allowed access to the host system to perform one or more of a cut or copy of data, a paste of data, a printing of data to a local printer, a file transfer, and/or the like.
  • the host computer system may prevent one or more other transfers of data between the sandboxed computing environment and the workspace except those user initiated actions described herein.
  • the sandbox container process may prevent unauthorized data transfers between the sandboxed computing environment and the workspace.
  • FIG. 1 illustrates an example of a host computer system that may implement one or more applications in a sandboxed environment.
  • a Host Computer System 10 may include one or more Processor(s) 12 , Memory 14 , one or more Input and/or Output (I/O) Devices 16 , and one or more Network Interface Adapter(s) 18 .
  • the Host Computer System 10 may be any computing device capable of communicating over a network and/or performing processing tasks.
  • the examples set forth herein may be described in terms general purpose computing workstations, the systems and methods disclosed herein may be equally applicable to any computing device or communication device for which internet isolation is desired.
  • systems and methods disclosed herein may be applicable for providing sandbox based internet isolation for cell phones, pagers, personal computers (PCs), laptops, vehicles, kiosks, facilities, servers, workstations, tablets, smartphones, routers, controllers, microcontrollers, and/or any other processing and/or communication device.
  • PCs personal computers
  • laptops laptops
  • vehicles kiosks
  • facilities servers
  • workstations tablets
  • smartphones routers
  • controllers microcontrollers
  • microcontrollers microcontrollers
  • Processor(s) 12 may include one or more of a general purpose processor, a special purpose processor, a conventional processor, a digital signal processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, Application Specific Integrated Circuits (ASICs), Field Programmable Gate Array (FPGA) circuits, any other type of integrated circuit (IC), a state machine, and/or the like.
  • the Processor(s) 12 may perform data processing, input/output processing, instantiate operating system(s), execute application(s), and/or any other functionality that enables the use of sandbox isolation of one or more applications and/or processes.
  • Memory 14 may include volatile and/or non-volatile memory.
  • Memory 14 may include read-only memory (ROM), random access memory (RAM), a register, cache memory, semiconductor memory devices, magnetic media such as, but not limited to, internal hard disks and removable disks, magneto-optical media, and/or optical media such as CD-ROM disks, and/or digital versatile disks (DVDs), and/or the like.
  • Memory 14 may be configured to store computer readable instructions that when implemented by Processor(s) 12 may cause Processor(s) 12 to implement one or more of the functions or procedures described herein.
  • Memory 14 may be configured to store software code implemented by Processor(s) 12 that instantiate a restricted operating system environment for operation of the sandboxed browser and/or other sandboxed applications(s) and/or process(es).
  • the software may restrict sandbox-based access to one more file descriptors, memory, file system space, etc.
  • the applications and/or processes operating within the sandboxed computing environment may be permitted to certain portions of Memory 14 but may not be allowed access to other portions of Memory 14 .
  • Memory 14 may be partitioned into a first memory space and a second memory space.
  • the first memory space may be configured to enable storage and/or operation of a workspace configured to execute a first set of one or more applications and/or processes running on the operating system of the Host Computer System 10 .
  • the second memory space may be configured to enable storage and/or operation of a second set of one or more applications and/or processes running within the sandboxed computing environment.
  • the sandboxed computing environment may be enforced via a sandbox container process.
  • the sandbox container process may segregate the workspace associated with the first memory space from the sandboxed computing environment associated with the second memory space.
  • the sandbox container process may include an internal isolation firewall. The internal isolation firewall may enforce the segregation of the first and second memory spaces.
  • the Host Computer System 10 may include I/O Device(s) 16 .
  • the I/O Devices 16 may include one or more of a monitor, keyboard, mouse, touchscreen interface, digital camera, a digital display, a graphical user interface, and/or the like.
  • the I/O Device(s) 16 can allow user interaction with the Host Computer System 10 , for example to allow certain interactions between an application or a process operating within the sandboxed computing environment and non-sandboxed resources.
  • the Network Interface Adapter(s) 18 may be configured to allow communication between the Host Computer System 10 and other devices.
  • the Network Interface Adapter(s) 18 may include one or more wired and/or wireless communication devices.
  • the sandbox container process may be configured to protect the host computer system from one or more malware toolsets.
  • the Network Interface Adapter(s) 18 may include one or more of a modem, Ethernet adapter, radio, wired and/or wireless transceiver, computer port, network socket, network interface controller, and/or the like.
  • the Processor(s) 12 may maintain rules related to access to the Network Interface Adapter(s) 18 for both access via the sandboxed computing environment and via the workspace. Further, the Processor(s) 12 may enforce a host-based firewall that implements additional rules related to access to the Network Interface Adapter(s) 18 .
  • a sandbox protected application or process may be used for communicating with untrusted sources, such as Internet based resources.
  • untrusted sources such as Internet based resources.
  • the sandbox container process may prevent the malware toolset from performing a reconnaissance of the host computer system to assess what data is available from the host computer system, such as computing resources, files, network information, additional network connectivity, etc.
  • the sandbox container process e.g., the internal isolation firewall
  • the sandbox container process may prevent the malware toolset from determining user system privileges of the host computer system, which can be used to access data on any associated network or local area network. For example, applications and/or processes operating within the sandboxed computing environment may not have access and/or authorization to such host computer configurations.
  • the sandbox container process may prevent the malware toolset from accessing local files stored on the host computer system.
  • the sandbox container process may isolate the first memory space from the second memory space. Such isolation can help prevent the malware from attempting to transmit such information back to the remote device that is the source of the malware.
  • the malware toolset may attempt to transmit a local security database from which additional user credentials can be derived, including potential privileged user credentials. These user credentials may be used by the malware to attempt to gain access to other resources on any associated network or the local area network. Where the user credentials are for a privileged user account, these credentials may be used to gain privileged access to other resources on any associated network or local area network.
  • the sandbox container process may prevent the malware toolset from accessing a security token and/or hash of the host computer user from the memory of the host computer system and/or a network data stream.
  • This security token or hash can be used to gain access to other resources on any associated network or the local area network.
  • this security token or hash may be used to gain privileged access to other resources on any associated network or local area network.
  • the sandbox container process may prevent the malware toolset from enabling remote control and/or communication with (e.g., access) of the host computer system by a remote device that is unknown to the user.
  • the remote device may be able to control one or more (e.g., all) operations of an infected host computer system and perform whatever alternative uses that an enslaved, infected host computer system can perform.
  • a remote device may download additional data to an infected host computer system, communicate with other websites for denial of service attacks, and/or convert the infected host computer system into a source of malicious software from which toolsets or secondary payloads are downloaded to other, subsequently infected, host computer systems.
  • FIG. 2 depicts an example host computer system 212 using a sandbox based internet isolation system.
  • the sandbox based internet isolation system may include a network 230 , an authorization device 235 , a proxy device 236 , and/or a border firewall 238 .
  • the network 230 may include one or more host computer systems (e.g., such as the host computer system 212 ).
  • the host computer system 212 may include a host-based firewall 214 , an operating system 226 , a sandboxed computing environment 220 , an internal isolation firewall 218 , and a workspace 216 .
  • the host computer system 212 may be any host computer system, such as a cell phone, a pager, a personal computer (PC), a laptop, a vehicle computer system, a kiosk computer system, a server, a workstation, a tablet, a smartphone, a router, a controller, a microcontroller, and/or any other processing and/or communication device.
  • the host computer system 212 may be operatively connected with one or more user-accessible data entry devices, a display device viewable by a user, and/or a computer-accessible data storage.
  • One or more application programs may run on the operating system 226 .
  • the trusted host computer system 212 may be a PC, with 4 GB RAM and 146 GB hard disk computer-accessible storage, a monitor, a keyboard, and a mouse.
  • the operating system 226 may be Windows-based, Linux-Based, Macintosh-based, and/or the like.
  • the computer-accessible storage may store data corresponding to one or more software programs (e.g., computer-readable instructions) stored on the trusted host computer system 212 for common operation.
  • the software programs may include word processing programs, accounting programs, remote connectivity programs, and/or other types of applications.
  • the host computer system 212 may be configured to isolate communication with untrusted network destinations.
  • the host computer system 212 may isolate communication with untrusted network destinations using one or more of the host-based firewall 214 , the border firewall 238 , the proxy device 236 , the authorization device 235 , an internal isolation firewall 218 , or a segregation of untrusted memory space.
  • the host-based firewall 214 may enable isolation of the host computer system's communication with one or more untrusted network destinations by preventing lateral communication with other devices connected to the network 230 .
  • the host computer system 212 may receive untrusted traffic from the network 230 .
  • the host-based firewall 214 may be configured to block the untrusted traffic from the network 230 .
  • the host-based firewall 214 may be configured to block all incoming traffic from the network 230 .
  • the host-based firewall 214 may be configured to allow traffic received by the host computer system 212 via one or more predetermined devices and/or ports.
  • One or more devices (e.g., predetermined devices) connected to the network 230 may bypass the host-based firewall 214 , for example, using a predetermined set of protocols and/or ports.
  • the host-based firewall 214 may be implemented using software and/or hardware.
  • the host-based firewall 214 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc.
  • the host-based firewall 214 may be implemented using software inherent in the operating system 226 of the host computer system 212 , for example the Windows operating system firewall.
  • the host-based firewall 214 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 212 .
  • the proxy device 236 may enable isolation of the host computer system 212 from one or more untrusted network destinations.
  • the proxy device 236 may be a web proxy.
  • the proxy device 236 may proxy communication between untrusted network destinations and the sandboxed computing environment 220 (e.g., when the sandboxed computing environment 220 has authenticated with the authorization device 235 and/or the proxy device 236 ).
  • the network 230 may be configured to utilize a Web Cache Control Protocol.
  • the network 230 may redirect web related traffic that is intended for an untrusted resource or network destination (e.g., such as the Internet 242 ) to the proxy device 236 , for example, using the Web Cache Control Protocol.
  • the network 230 may receive traffic via web related traffic from the host computer system 212 .
  • the network 230 e.g., a router in the network 230
  • the Web Cache Control Protocol may route the web-related traffic to the proxy device 236 via a predetermined network port, for example, network port 4321 as shown.
  • the proxy device 236 may determine (e.g., uniquely distinguish) that the traffic received from the network 230 is via the Web Cache Control Protocol, for example, based on the network port.
  • the proxy device 236 may be configured to block traffic associated with an untrusted network destination.
  • the proxy device 236 may receive requests from one or more applications and/or processes operating within the workspace 216 of the host computer system 212 .
  • the proxy device 236 may be configured to block one or more requests sent from the one or more applications and/or processes operating within the workspace 216 of the trusted host computer system 212 , for example, based on the one or more requests being associated with the network port on which it is received, for example 4321 .
  • the proxy device 236 may be configured to allow one or more processes and/or applications (e.g., browser process 222 ) operating within the sandboxed computing environment 220 of the trusted host computer system 212 to communicate with an untrusted network destination.
  • a sandbox container process may enable the sandboxed computing environment 220 .
  • the sandboxed computing environment 220 may authenticate with an authorization device 235 .
  • the sandboxed computing environment 220 may send authentication credential(s) to the authorization device 235 .
  • the authorization device 235 may provide authentication information associated with the sandboxed computing environment 220 to the proxy device 236 .
  • the sandboxed computing environment 220 may authenticate with the proxy device 236 .
  • the sandbox container process may authenticate with the authorization device 235 and/or the proxy device 236 on behalf of the one or more processes and/or applications operating within the sandboxed computing environment.
  • the sandbox container process may be configured to authenticate with the authorization device and/or the proxy device 236 using preconfigured credentials stored within an encrypted configuration file.
  • the proxy device 236 may allow the one or more processes and/or applications operating within the sandboxed computing environment 220 to communicate with the untrusted network destination.
  • the authorization device 235 and the proxy device 236 may be the same device (e.g., a single combined device).
  • the border firewall 238 may enable isolation of the host computer system 212 (e.g., the workspace 216 ) from one or more untrusted network destinations.
  • the border firewall 238 may be configured to restrict traffic to the untrusted network destinations (e.g., the Internet 242 ) from the proxy device 236 and/or the network 230 (e.g., enterprise router 234 .
  • the host computer systems 212 may communicate with a whitelisted web server and/or an untrusted web server, for example, via the border firewall 238 .
  • the border firewall 238 may be configured to block communication between the host computer system 212 and one or more untrusted network destinations, for example the Internet 242 .
  • the border firewall 238 may be configured to block untrusted traffic that is not routed through the proxy device 236 .
  • the sandboxed computing environment 220 may include resources (e.g., a limited set of resources) allocated to operation of a sandbox container process.
  • the sandboxed computing environment 220 may be enforced via the sandbox container process.
  • the sandbox container process may be a security mechanism used to separate resources associated with the sandboxed computing environment 220 from other applications and/or processes that may be running on a workspace 216 of the host computer system 212 .
  • the sandboxed container process may be configured to enable one or more applications and/or processes (e.g., such as browser process 222 ) being executed within the sandboxed computing environment 220 to access the resources allocated for operation of the sandbox container process.
  • the one or more applications and/or processes being operated within the sandboxed computing environment 220 may be allowed to access memory associated with the sandboxed computing environment 220 .
  • the memory associated with the sandboxed computing environment 220 may be separate from memory that is configured to enable storage and operation of the workspace 216 .
  • the workspace 216 may include one or more processes operating within the operating system 226 that are not restricted by the sandbox container process.
  • the operating system 226 of the host computer system 212 may include a set of resources configured to enable operation of the workspace 216 and the sandbox container process.
  • the host computer system 212 may enable the host-based firewall 214 .
  • the host-based firewall 214 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 212 and other devices on the network 230 .
  • Each device on the network 230 may include a host-based firewall (e.g., such as the host-based firewall 214 ).
  • the host-based firewall 214 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 212 and other devices within the network 230 .
  • the host-based firewall 214 may be configured to block incoming traffic from the other devices within the network 230 .
  • the host-based firewall 214 may allow traffic received by the host computer system 212 via one or more predetermined devices and/or ports.
  • one or more devices (e.g., predetermined devices) on the network 230 may bypass the host-based firewall 214 , for example, using a predetermined set of protocols and/or ports.
  • the host-based firewall 214 may be implemented using software and/or hardware.
  • the host-based firewall 214 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc.
  • the host-based firewall 214 may be implemented using software inherent in the operating system 226 of the trusted host computer system 212 , for example the Windows operating system firewall.
  • the host-based firewall 214 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 212 .
  • the host computer system 212 may run the sandboxed computing environment 220 .
  • the sandboxed computing environment 220 may run within the operating system 226 of the host computer system 212 .
  • the sandboxed computing environment 220 may be configured to run within a second memory space of the host computer system 212 .
  • a first memory space may be configured to enable storage and operation of a workspace configured to execute a first set of one or more applications and/or processes running on the operating system 226 of the host computer system 212 .
  • a browser process 222 may operate within the sandboxed computing environment 220 .
  • the sandboxed computing environment 220 may be prohibited from communicating with other devices within the network 230 .
  • the browser process 222 may be configured to enable communication with untrusted network destinations.
  • Browser solutions running within the workspace 216 of the host computer system 212 may be utilized for communication between the host computer system 212 and trusted network destinations.
  • the one or more applications or processes running within the workspace 216 of the host computer system 212 may enable communication with the trusted network destinations.
  • the sandboxed computing environment 220 and/or the sandbox container process may be implemented using software and/or hardware.
  • the sandboxed computing environment 220 and/or the sandbox container process may be implemented using software that is commercially available, for example, such as Invincea Endpoint Protection, Tanium Endpoint Platform, Bromium Advanced Endpoint Security, etc.
  • the sandboxed computing environment 220 may provide separate and/or isolated memory space from the workspace 216 of the host computer system 212 .
  • the sandboxed computing environment 220 may be enforced using a sandbox container process.
  • the sandbox container process may segregate the workspace 216 from the sandboxed computing environment 220 .
  • the first memory space e.g., the workspace memory
  • the operating system 226 may enable operation of the sandboxed computing environment 220 .
  • the second memory space may enable storage and/or operation of one or more applications and/or processes associated with the sandboxed computing environment 220 .
  • the second memory space may be reserved for storage and/or operation of the applications and/or processes running within the sandboxed computing environment 220 .
  • the sandbox container process may isolate the first memory space and the second memory space.
  • the sandbox container process may enable the internal isolation firewall 218 .
  • the internal isolation firewall 218 may enforce a separation of the first and second memory spaces.
  • the internal isolation firewall 218 may allow a predefined set of processes to be executed within the sandboxed computing environment 220 .
  • the internal isolation firewall 218 may prevent execution, in the sandboxed computing environment 220 , of any processes outside of the predefined set of processes.
  • the second memory space may be referred to as a separate and/or isolated memory space.
  • the sandbox container process may segregate the second memory space, any additional processes and/or memory usage required for usage of untrusted network destination related content during an established communication session. Separation and/or isolation of computer resources may be referred to as a virtual air gapped solution.
  • the first memory space and the second memory space may be separate physical memory locations.
  • the first memory space and the second memory space may be collocated on a physical memory.
  • the first memory space and the second memory space may be enforced via a software partition.
  • malware in a sandboxed computing environment 220 is able to communicate with (e.g., access) the resources, assets, and/or files of the operating system 226
  • the host computer system 212 may be considered infected and untrusted.
  • the malware may bypass the internal isolation firewall 218 via explicit user input.
  • the host-based firewall 214 may prohibit the introduced malware from communicating with any other device on the network 230 .
  • the host-based firewall 214 may be configured to block incoming traffic from the network 230 .
  • Malware may be introduced to the operating system 226 from a source other than communication with the Internet 242 .
  • malware may be introduced to the operating system 226 via an infected email, an infected USB memory stick, and/or another infected hardware device.
  • An infected and/or untrusted host computer system may have no communication (e.g., direct communication) with the Internet 242 .
  • the border firewall 238 may prevent the infected and/or untrusted host computer system from communicating with the Internet 242 .
  • the introduced malware may be prevented from performing many toolset functions described herein or any other function that an enslaved, infected and/or untrusted host computer system may perform.
  • the introduced malware may not be able to transfer any data from the infected and/or untrusted host computer system to the Internet 242 .
  • the host computer system 212 and/or the network 230 may limit the adverse effects associated with a received malware. For example, the host computer system 212 and/or the network 230 may prevent the received malware from using its vector to communicate data from the host computer system 212 .
  • the host computer system 212 and/or the network 230 may prevent data of an infected and/or untrusted host computer system that may have been compromised and/or collected by the malware from being communicated to the author of the malware.
  • the host computer system 212 may prevent communication between an infected and/or untrusted host computer system and the Internet 242 (e.g., the author of the malware via the Internet 242 ).
  • FIG. 3 depicts an example host computer system 312 A (e.g., such as the host computer system 212 shown in FIG. 2 ) connected to a local area network (LAN) 310 , the example host computer system 312 A using a sandbox based network isolation system.
  • the LAN 310 may include a plurality of physical and/or virtual devices.
  • the LAN 310 may include a plurality of host computer systems 312 A, 312 B, 312 C. Each of the host computer systems may transmit electrical data signals to one or more other host computer systems on the LAN 310 .
  • Each of the host computer systems may be identified by a unique local area network address.
  • the LAN 310 may include a router 328 .
  • the host computer systems 312 A, 312 B, 312 C may send web traffic and/or non-web traffic to a trusted network 330 via the router 328 .
  • the LAN 310 may send web traffic to one or more untrusted network destinations using one or more of the trusted network 330 , a border firewall 338 , or a proxy device 336 .
  • the LAN 310 may communicate with the internet 342 and/or a device 344 on the internet 342 via the trusted network 330 , the border firewall 338 , and/or the proxy device 336 .
  • the web traffic sent to the trusted network 330 may be destined for trusted destinations.
  • the LAN 310 may enable a connection to a cloud-based computing system.
  • the connection to the cloud-based computing system may be a direct connection.
  • the LAN 310 may be part of a cloud interexchange.
  • the LAN 310 may be part of a cloud “meet me” point of presence.
  • Each of the host computer systems 312 A, 312 B, 312 C may enable a host-based firewall 314 .
  • the host-based firewall 314 may prohibit and/or prevent communication (e.g., direct communication) between the respective host computer system 312 A, 312 B, 312 C and other devices on the LAN 310 .
  • the host-based firewall 314 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 312 A and other devices within the trusted network 330 .
  • the host-based firewall 314 may be configured to block incoming traffic from the other devices within the LAN 310 and/or the trusted network 330 .
  • the host-based firewall 314 may allow traffic to be received by the host computer system 312 A via one or more predetermined devices and/or ports.
  • one or more devices e.g., predetermined devices
  • the trusted network 330 may bypass the host-based firewall 314 , for example, using a predetermined set of protocols and/or ports.
  • the host-based firewall 314 may be implemented using software and/or hardware.
  • the host-based firewall 314 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc.
  • the host-based firewall 314 may be implemented using software inherent in the operating system 326 of the host computer system 312 A, for example the Windows operating system firewall.
  • the host-based firewall 314 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 312 A.
  • FIG. 4 depicts an example host computer system 412 A (e.g., such as host computer system 212 , 312 A shown in FIGS. 2 and 3 , respectively) connected to a wide area network (WAN) 400
  • the example host computer system 412 A may include a sandbox based network isolation system.
  • the WAN 400 may include a plurality of LANs 410 A, 410 B, 410 C; a trusted network 430 , a proxy device 436 (e.g., such as the proxy device 236 , 336 shown in FIGS. 2 and 3 , respectively), and a border firewall 438 (e.g., such as the border firewall 238 , 338 shown in FIGS. 2 and 3 , respectively).
  • the WAN 400 may include virtual and/or physical devices.
  • the WAN 400 may be configured to enable communicate with the internet 442 and/or a device 444 on the internet 442 via the border firewall 438 .
  • the WAN 400 may enable a connection to a cloud-based computing system.
  • the connection to the cloud-based computing system may be a direct connection.
  • the WAN 400 may be part of a cloud interexchange.
  • the WAN 400 may be part of a cloud “meet me” point of presence.
  • Each of the LANs 410 A, 410 B, 410 C may include a plurality of host computer systems.
  • LAN 410 A may include host computer systems 412 A, 412 B, 412 C, 412 D.
  • Each host computer system of a respective LAN may be configured to send electrical data signals to one or more other host computer systems on the respective LAN.
  • the host computer systems 412 A, 412 B, 412 C, 412 D of the LAN 410 A may send data to each other.
  • Each of the host computer systems may be identified by a unique local area network address.
  • the LANs 410 A, 410 B, 410 C may send web traffic and/or non-web traffic to a trusted network 430 .
  • the web traffic sent to the trusted network 430 may be destined for trusted destinations.
  • Each of the host computer systems may enable a host-based firewall.
  • host computer system 412 A may enable the host-based firewall 414 .
  • the host-based firewall 414 may prohibit and/or prevent communication (e.g., direct communication) between the respective host computer systems 412 A, 412 B, 412 C, 412 D and other devices on the LAN 410 A.
  • the host-based firewall 414 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 412 A and other devices within the WAN 400 .
  • the host-based firewall 414 may be configured to block incoming traffic from the other devices within the LAN 410 A and/or the WAN 400 .
  • the host-based firewall 414 may allow traffic to be received by the host computer system 412 A via one or more predetermined devices and/or ports.
  • one or more devices (e.g., predetermined devices) on the LAN 410 A and/or the WAN 400 may bypass the host-based firewall 414 , for example, using a predetermined set of protocols and/or ports.
  • the host-based firewall 414 may be implemented using software and/or hardware.
  • the host-based firewall 414 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc.
  • the host-based firewall 414 may be implemented using software inherent in the operating system 426 of the host computer system 412 A, for example the Windows operating system firewall.
  • the host-based firewall 414 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 412 A.
  • the border firewall 438 may prevent unauthorized communication between the WAN 400 and the internet 442 .
  • the border firewall 438 may prevent unauthorized communication between one or more devices in the WAN 400 and the internet 442 .
  • the WAN 400 may include multiple border firewalls.
  • each LAN of the WAN 400 may include a border firewall.
  • Mobile phones, tablets, and/or other connected devices may enter and leave the WAN 400 .
  • devices may join and leave the WAN 400 more frequently than a LAN.
  • a device may move from a first WAN (e.g., the WAN 400 ) to a second WAN.
  • the host-based firewall may protect the device in both the first WAN and the second WAN.
  • An infected device may join the WAN 400 .
  • the host-based firewall of the other devices in the WAN 400 may be configured to isolate communication from the infected device.
  • FIG. 5 depicts an example host computer system 512 (e.g., such as host computer system 212 , 312 A, 412 A shown in FIGS. 2, 3, and 4 , respectively) connected to a cellular radio access network (RAN) 500
  • the example host computer system 512 may include a sandbox based network isolation system.
  • the RAN 500 may include a plurality of eNodeBs 530 A, 530 B, 530 C; one or more serving gateways (GWs) 532 A, 532 B, and a packet GW 534 .
  • Virtual and/or physical devices may connect to the RAN 500 .
  • a device may connect to the RAN 500 via a virtual private network (VPN) client.
  • VPN virtual private network
  • the RAN 500 may be configured to enable communication with the internet 542 via the packet GW 534 .
  • the host computer system 512 may send web traffic to one or more untrusted network destinations via the eNodeB 530 A, the serving GW 532 A, and the packet GW 534 .
  • the host computer system 512 may send web traffic to one or more trusted destinations via the eNodeB 530 A.
  • the host computer system 512 may send non-web traffic to the eNodeB 530 A.
  • a proxy device e.g., such as proxy device 236 shown in FIG. 2 , proxy device 336 shown in FIG. 3 , and/or proxy device 436 shown in FIG.
  • the proxy device may be included within a serving GW 532 A, 532 B and/or the packet GW 534 .
  • the proxy device may receive, from the host computer system 512 , the web traffic destined for the one or more untrusted network destinations.
  • the proxy device may authenticate the host computer system 512 .
  • the host computer system 512 may enable a host-based firewall 514 .
  • the host-based firewall 514 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 512 and other devices connected to the RAN 500 .
  • the host-based firewall 514 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 512 and other devices on the internet 542 .
  • the host-based firewall 514 may be configured to block incoming traffic from the eNodeB 530 A.
  • the host-based firewall 514 may allow traffic to be received by the host computer system 512 via one or more predetermined devices and/or ports.
  • the eNodeB 530 A may bypass the host-based firewall 514 , for example, using a predetermined set of protocols and/or ports.
  • the host-based firewall 514 may be implemented using software and/or hardware.
  • the host-based firewall 514 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc.
  • the host-based firewall 514 may be implemented using software inherent in the operating system 526 of the host computer system 512 , for example the Windows operating system firewall.
  • the host-based firewall 514 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 512 .
  • a sandbox based network isolation system may be used in a data center.
  • the data center may be local or cloud-based.
  • one or more servers, databases, switches, and/or hubs of the data center may include a sandbox based network isolation system.
  • the sandbox based network isolation system may prevent data from passing between the devices of the data center, for example, except for predetermined devices and/or ports. If a database of the data center becomes infected with malware, the other devices in the data center may prevent infection because communication from the other devices in the data center may be blocked by their respective host-based firewalls.
  • a database in a data center may enable multiple segregated storage spaces, as described herein. The storage spaces may be segregated such that data may not be exchanged.
  • An internal isolation firewall may enable segregation of storage spaces.
  • each storage space may be associated with an internal isolation firewall. If a storage space in the database of the data center becomes infected with malware, the database may prevent infection of the other storage spaces in the database because communication between the storage spaces may be blocked, for example, by their respective internal isolation firewalls.
  • a device with a sandbox based network isolation system may travel between, connect to, and/or communicate with more than one network environment.
  • a device with a sandbox based network isolation system may travel between, connect to, and/or communicate with one or more of a LAN, a WAN, a WWAN, a cellular network, a digital subscriber line (DSL) network, a Wi-Fi network, a LPWA network, a satellite network, an infrastructure as a service (IaaS) network, a platform as a service (PaaS) network, and/or the like.
  • the device may be configured to provide network isolation by using a host-based firewall, an internal isolation firewall, and/or a segregation of memory space.
  • the host-based firewall may enable network isolation of the device across different network environments. For example, the host-based firewall may prevent communications from other devices in the different network environments.
  • a device having sensitive, private, and/or security data may include a sandbox based network isolation system.
  • a device having access to sensitive, private, and/or security data may include a sandbox based network isolation system.
  • the sandbox based network isolation system may be configured to prevent access by unauthorized devices to the sensitive, private, and/or security data.
  • the sensitive, private, and/or security data may be stored in a first memory space of the host computer system.
  • the host computer system may enable communication with untrusted network destinations via a second memory space.
  • the host computer system may enforce segregation of the first memory space and the second memory space. For example, any malware introduced to the second memory space from communication with the untrusted network destinations may be prevented from accessing the first memory space.
  • the segregation of the first memory space and the second memory space may be software-based and/or hardware-based.
  • the first memory space may be enabled by a first hard drive and the second memory space may be enabled by a second hard drive.
  • the first memory space and the second memory space may be enabled by a single hard drive.
  • the first memory space and the second memory space may be associated with one or more partitions in the single hard drive.
  • An internal isolation firewall as described herein, may enforce the segregation of the first memory space and the second memory space.
  • a sandbox based network isolation system may be used to prevent malware from establishing command and control on a computer system (e.g., a desktop computer, a laptop computer, a tablet, a mobile phone, etc.).
  • a computer system e.g., a desktop computer, a laptop computer, a tablet, a mobile phone, etc.
  • the sandbox based network isolation system may be configured to operate on a computer system running Windows, Linux, MacOS, iOS, Android, Windows Mobile, and/or some other operating system.
  • a sandbox based network isolation system may prevent malware from moving from a first computer system to a second computer system on the same network environment. For example, when a computer system in a network environment is infected with malware, the sandbox based network isolation system may prevent proliferation of the malware within the network environment.
  • a sandbox based network isolation system may increase the security posture of an enterprise network (e.g., a WAN, a LAN, and/or a VM infrastructure).
  • an enterprise network e.g., a WAN, a LAN, and/or a VM infrastructure.
  • the sandbox based network isolation system may protect the enterprise network from malware, command and control attacks, viruses, and/or data exfiltration attacks.
  • Embodiments may take the form of a tangible computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
  • Examples of a computer-usable or computer-readable medium include tangible computer media such as semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk.
  • Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
  • a processor may be configured to execute instructions stored in memory to perform the various functions and/or functional modules described herein.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computing Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

Methods and systems are disclosed for isolation of communications between a host computer system and one or more untrusted network destinations. An Internet isolation system may include a network, one or more host computer systems, a border firewall, an authorization device, and/or a proxy device. The Internet isolation system may be configured to implement network isolation between one or more untrusted network destinations, the one or more host computer systems, and/or the network. The network isolation may be implemented via one or more of a host-based firewall on each of the one or more host computer systems, the border firewall, the authorization device, the proxy device, an internal isolation firewall on each of the one or more host computer systems, and/or a segregation of a trusted memory space and an untrusted memory space on each of the one or more host computer systems.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application claims the benefit of U.S. Provisional Patent Application No. 62/544,024, filed Aug. 11, 2017, the contents of which is hereby incorporated by reference in its entirety.
  • BACKGROUND
  • The Internet provides access to a large number of systems from which beneficial and/or harmful data may be retrieved by a host computer system attached to and communicating over the Internet. Harmful data that can be accessed through the Internet includes a variety of viral software constructs, generally referred to as malicious software or malware. Malware may be downloaded to a host computer system unintentionally, for example, by and/or without the knowledge of the user of the host computer system.
  • A host computer system that has downloaded malware may be referred to as an infected host computer system. An infected host computer system may result in possible security losses, reduction of efficiency, and/or malfunctions. Security losses may include, but are not limited to, the loss of some or all data that is accessible by the infected host computer system, the installation of additional malware onto the infected host computer system, and/or the loss of command and control of the infected host computer system. Reduction of efficiency may be incurred from, but not limited to, additional processor demand, additional memory usage, and/or additional network access by the executing malware
  • The security and privacy of the user of the infected host computer system may be compromised by malware. Both information located on the infected host computer system and/or information stored on or communicated via a local area network may be susceptible to attack by the malware. In many instances, an infected host computer may be used by the malware as a vehicle to stage an attack on other network resources that are accessible from the infected host computer system. Such an attack method is often undetected by the user of the host computer system and/or network administrators.
  • An infected host computer system may lose command and control. The loss of command and control of the infected host computer system may include performing one or more actions the author of the downloaded malware may desire. For example, the malware may perform a reconnaissance of the infected host computer system, determine system privileges, access (e.g., communicate with) local files, access security tokens, and/or attempt infection or access of other network resources accessible from the infected computer system
  • SUMMARY OF THE INVENTION
  • Methods and systems are disclosed for isolation of communications between a host computer system and one or more untrusted network devices or destinations. An Internet isolation system may include a network, a host computer system, a border firewall, an authorization device, and/or proxy device (e.g., such as a web proxy). The host computer system may include a processor and memory. The network may include one or more of a local area network (LAN), a wide area network (WAN), a cellular network, a Wi-Fi network, a digital subscribers line (DSL) network, a cloud computing network, a data center, an ad-hoc network, a satellite network, a cable modem network, and/or the like. The cloud computing network may include one or more of an Infrastructure as a Service (IaaS) or a Platform as a Service (PaaS) applications. The networked computer system may be configured to implement network isolation between one or more untrusted network destinations and various untrusted network(s). The network isolation may be implemented via one or more of a host-based firewall on a host computer system, a border firewall around a portion of a network that includes the host computing system, an authorization device, a proxy device, an internal isolation firewall on the host computer system, and/or a segregation of a trusted memory space and an untrusted memory space.
  • The host computer system may be configured to communicate with (e.g., access) one or more untrusted network destinations via a first communication channel. The host computer system may be configured to communicate with one or more trusted network destinations via a second communication channel. The host computer system may be configured to enforce separation of the first communication channel and the second communication channel. Even if malware may be introduced to the host computer system, the host computer system and/or network nodes may be configured to implement network isolation techniques that prevent the malware from moving to other devices on the networked computer system.
  • For example, a host-based firewall may be configured to prevent lateral communication and/or movement of malware between the host computer system and other devices on the networked computer system. A proxy device/server may be configured to prevent unauthorized communication between the host computer system and the one or more untrusted network destinations (e.g., Internet destinations). The segregation of the trusted memory space and the untrusted memory space may be enforced by the internal isolation firewall. The host based computer system may be configured to run one or more applications and/or processes in the untrusted memory space that are configured to communicate with the one or more untrusted network destinations. The host computer system may be configured to run one or more applications and/or processes in the trusted memory space that are configured to communicate with one or more devices on the network (e.g., trusted devices on the network). Applications running in the untrusted memory space may be blocked from communicating with trusted destinations and applications running in the trusted memory space may be blocked from communicating with untrusted destinations.
  • An internet isolation system may include a network having one or more host computer systems, an authorization device, a proxy device, and/or a border firewall. A host computer system may be configured to connect to a network. The host computer system may be configured to implement an operating system. The operating system may enable operation of a workspace. The workspace may be configured to enable operation of a first set of one or more applications and/or processes. The workspace may be enabled by and/or executed using a first memory space. The host computer system may be configured to implement a sandboxed computing environment. The sandboxed computing environment may be configured to enable operation of a second set of one or more applications and/or processes. The sandboxed computing environment may be considered an untrusted memory space. The sandboxed computing environment may be configured to authenticate with the authorization device. The sandboxed computing environment may be configured to classify a network destination as trusted or untrusted based on a whitelist including a list of trusted network destinations and/or a blacklist including a list of untrusted network destinations. The trusted network destinations may be communicated with via one or more of the first set of one or more applications and/or processes associated with the workspace. The sandboxed computing environment may be enforced by a sandbox container process. The sandboxed computing environment may be enabled by and/or executed using a second memory space. The first memory space and the second memory space may be isolated, for example, by the sandbox container process.
  • The host computer system may be configured to isolate, using an internal isolation firewall, the sandboxed computing environment from the workspace. For example, the internal isolation firewall may enforce a separation of the sandboxed computing environment and the workspace. The internal isolation firewall may segregate storage memory associated with the workspace from storage memory associated with the sandboxed computing environment. The internal isolation firewall may allow a predefined set of processes to be executed within the sandboxed computing environment. The sandbox container process may prevent execution in the sandboxed computing environment of any processes outside of the predefined set of processes. The internal isolation firewall may be configured to prevent data from being communicated between the sandboxed computing environment and the workspace, for example, without an explicit user input. The sandbox container process may enable the internal isolation firewall.
  • The host computer system may prevent, using a host-based firewall, communication between the host computer system and one or more other devices on the network. The host-based firewall may be configured to block incoming traffic from one or more devices on the network and/or one or more devices on the Internet. The host computer system may communicate, using the second set of one or more applications and/or process operating on the sandboxed computing environment, with untrusted network destinations via the proxy device. The authorizing device and the proxy device may be the same device (e.g., a single device). At least one of the untrusted network destinations is located on the Internet and may be communicated with, using the proxy device, via a browser process operating within the sandboxed computing environment upon authentication via the authorization device. The border firewall may be configured to block unauthorized communications between the network and the untrusted network destinations.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 depicts an example host computer system.
  • FIG. 2 depicts an example host computer system using a sandbox based network isolation system.
  • FIG. 3 depicts an example host computer system connected to a local area network (LAN), the example host computer system using a sandbox based network isolation system.
  • FIG. 4 depicts an example host computer system connected to a wide area network (WAN), the example host computer system using a sandbox based network isolation system.
  • FIG. 5 depicts an example host computer system connected to a cellular radio access network (RAN), the example host computer system using a sandbox based network isolation system.
  • DETAILED DESCRIPTION
  • Systems and methods are disclosed for isolation of a host machine's communication with one or more untrusted network destinations. Isolating the host machine's communication with one or more untrusted network destinations may protect the host machine from one or more of command and control infection, data exfiltration, or general automated infection that can occur from communicating with the untrusted network destinations. A host computer system may securely browse, access, and/or communicate with untrusted network destinations, including but not limited to resources accessible via the Internet. The host computer system may be a laptop computer, a mobile phone, a tablet, etc. The host computer system may be connected to a network (e.g., a local area network (LAN), a wide area network (WAN), a cellular network, a Wi-Fi network, a digital subscribers line (DSL) network, a cloud computing network, a data center, an ad-hoc network, a satellite network, a cable modem network, etc.). The host computer system may be a physical machine, a virtual machine, or a combination thereof. The isolation may be enforced via the host computer system itself and/or via one or more network entities located within the network.
  • Communication isolation may isolate communications associated with one or more web-based applications from other network environment communications. For example, the web-based applications may communicate via a first communication channel and the other network environment communications may use one or more other communication channels. The first communication channel may be isolated from the one or more other communication channels. The first communication channel may be established with a proxy device (e.g., such as a web proxy). The web-based applications may include web browsers, file transfer applications, email applications, chat or instant messaging applications, peer-to-peer (P2P) file sharing applications, automatic web backup applications (e.g., to cloud services), anti-virus and other security applications, collaboration software applications, remote desktop applications, screen and resource sharing applications, gaming applications, applications that rely on cloud resources for processing resources, and/or the like. Examples of web browsers may include Internet Explorer, Safari, Mozilla, Chrome, etc. The file transfer applications may include FileZilla, WinSCP, CyberDuck, FireFTP, etc. The collaboration software applications may include WebEx, LiveMeeting, HP Virtual Room, etc. As may be appreciated, many of these types of applications rely on robust communication networks that allow the application to connect to and communicate with remote locations. However, such reliance can create avenues of attack for malware and other exploits that can utilize the capacities and resources offered to these applications as a means to attack and or control the host computing system.
  • Systems and methods are described to provide a layer of isolation between these diverse types of applications and untrusted network destinations in order to prevent malware from effectively exfiltrating data from the host computer system and/or establishing command and control channels with an attacker resources in order to attempt to gain control of the host computing system. For example, the communication isolation may protect a network from a computer system operating within the network, that runs a collaboration software. The computer system may isolate the collaboration software from other applications and/or processes operating on the computer system.
  • Communication isolation may be provided via untrusted memory space segregation. The host computer system may have a sandbox protected application or process and/or an internal isolation firewall running thereon. For example, one or more of the web browsers, file transfer applications, email applications, chat or instant messaging application, P2P file sharing applications, automatic web backup application, anti-virus and other security applications, collaboration software applications, remote desktop applications, screen and resource sharing applications, gaming applications, applications that rely on cloud resources for processing resources, and/or the like may wholly or partially be contained in a sandboxed computing environment. In an example, other isolation methods such as operating the applications within a virtual machine may be used.
  • The sandbox protected application or process may operate within a sandboxed computing environment. The sandboxed computing environment may include resources (e.g., a limited set of resources) allocated for operation of a sandbox container process. The host computer system may implement the sandboxed computing environment. The sandboxed computing environment may be enforced via the sandbox container process. The sandbox container process may be a security mechanism used to separate the sandboxed computing environment from other applications and/or processes that may be running on a workspace of the host computer system. The sandbox computing environment may be configured to enable operation of one or more applications and/or processes. The sandboxed container process may be configured to enable the one or more applications and/or processes (e.g., such as a browser process) being executed within the sandboxed computing environment to access the resources allocated for operation of the sandbox container process. For example, the one or more applications and/or processes being operated within the sandboxed computing environment may be allowed to access memory associated with the sandboxed computing environment. The memory associated with the sandboxed computing environment may be separate from memory that is configured to enable storage and operation of the workspace. The host computer system may communicate with (e.g., access), using the application and/or process operating on the sandboxed computing environment, untrusted network destinations via a proxy device. The proxy device may be a web proxy, as described herein.
  • The host computer system may be configured to implement an operating system that enables operation of the workspace. The workspace may include one or more applications and/or processes operating within the operating system that are not restricted by the sandbox container process. The operating system of the host computer system may include a set of resources configured to enable operation of the workspace and the sandbox container process.
  • The sandbox container process may have access to one or more operating system and/or kernel processes in order to enforce isolation between the workspace associated with the first memory space and the sandboxed computing environment associated with the second memory space. The sandbox container process may enforce the segregation using techniques such as namespace isolation such that processes running in the sandboxed computing environment in the second memory space are restricted from accessing the first memory space including the workspace (e.g., and vice versa). The sandbox container process may restrict access to certain resources by processes running in the sandboxed computing environment. The sandboxed container process may allow the workspace and the sandboxed computing environment to share access to the host operating system and host operating resources (e.g., including the kernel and libraries) while enforcing the segregation of the memory spaces access by the workspace and the sandboxed computing environment. In this manner, the sandbox container process may permit isolation of the sandboxed computing environment without requiring the sandboxed computing environment to boot a separate operating system, load separate libraries, etc., which would require separate private memory for those files.
  • The one or more processes or applications operating within the sandboxed computing environment may be permitted to communicate with untrusted network destinations via an access connection device. The access connection device may be a proxy device, for example. The one or more processes or applications operating within the sandboxed computing environment may connect to the untrusted network destinations as a dedicated network interface device with using a specific Internet Protocol (IP) address. The one or more processes or applications operating within the sandboxed computing environment may be referred to as sandboxed processes or applications. The host computer system may maintain a list of untrusted network destinations and/or a list of trusted network destinations. The list of trusted network destinations may be a whitelist. The list of untrusted network destinations may be a blacklist. The whitelist and the blacklist may be refined based on username and/or machine identification (ID). For example, the lists of trusted and untrusted network destinations may be different for different users and/or machines associated with a respective network. The whitelist and/or the blacklist may be associated with one or more access levels. For example, a first whitelist and a first blacklist may be assigned to a first access level. An untrusted network destination may be an untrusted resource, an untrusted device, an untrusted website, and/or the like. Since the untrusted network destinations may be sources of malware, the one or more processes or applications operating within the sandboxed computing environment may be allowed to communicate with the untrusted network destination(s), but other communication from the host computer system (e.g., communications originating from outside the sandboxed computing environment such as from within the workspace) to the untrusted network destination(s) may be prevented.
  • Communication isolation may be provided via a host-based firewall. The host computer system may prevent, using the host-based firewall, communication between the host computer system and one or more other devices on the network. The host-based firewall may be configured to prevent unauthorized communication between applications and/or processes operating in the workspace of the host computer system to other devices on the network over which the host computer is communicating. The host-based firewall may be configured to block incoming communications to the workspace of the host computer system, except for predetermined trusted devices and/or predetermined network ports. The host-based firewall may allow outgoing communications to be sent from a process in the workspace to a non-web-based (e.g., LAN destination). The host-based firewall may be configured to block outgoing communications sent from a process in the workspace to web-based (e.g., non-LAN) destinations.
  • Communication isolation may be provided via an internal isolation firewall. The sandbox container process may enable the internal isolation firewall. The internal isolation firewall may enable separation between the sandboxed computing environment and the workspace. The internal isolation firewall may be configured to prevent data from being communicated between the sandboxed computing environment and the operating system, for example, without an explicit user input. The applications and/or processes operating within the sandboxed computing environment may be prevented from accessing any additional resources of the host computer system or may be prevented from accessing any additional resources of the host computer system without explicit user action. For example, the internal isolation firewall may generate a command prompt that enables a user selection if an application and/or process operating within the sandboxed computing environment is requesting access to resources outside of the sandbox memory space. By prompting the user to confirm that the applications and/or processes operating within the sandboxed computing environment are permitted to access additional resources outside the sandbox memory space, malware that is designed to attempt to remain transparent to the user may be limited to operation within the sandboxed computing environment. Thus, the malware within the sandboxed computing environment may be unable to access other resources available to the host system generally, such as local area networks and secure memory regions.
  • The internal isolation firewall may allow certain actions to be performed with approval of the user of the host system. For example, an application and/or process operating within the sandboxed computing environment may be allowed access to the host system to perform one or more of a cut or copy of data, a paste of data, a printing of data to a local printer, a file transfer, and/or the like. The host computer system may prevent one or more other transfers of data between the sandboxed computing environment and the workspace except those user initiated actions described herein. For example, the sandbox container process may prevent unauthorized data transfers between the sandboxed computing environment and the workspace.
  • FIG. 1 illustrates an example of a host computer system that may implement one or more applications in a sandboxed environment. For example, a Host Computer System 10 may include one or more Processor(s) 12, Memory 14, one or more Input and/or Output (I/O) Devices 16, and one or more Network Interface Adapter(s) 18. Generally, the Host Computer System 10 may be any computing device capable of communicating over a network and/or performing processing tasks. Although the examples set forth herein may be described in terms general purpose computing workstations, the systems and methods disclosed herein may be equally applicable to any computing device or communication device for which internet isolation is desired. For example, the systems and methods disclosed herein may be applicable for providing sandbox based internet isolation for cell phones, pagers, personal computers (PCs), laptops, vehicles, kiosks, facilities, servers, workstations, tablets, smartphones, routers, controllers, microcontrollers, and/or any other processing and/or communication device.
  • Processor(s) 12 may include one or more of a general purpose processor, a special purpose processor, a conventional processor, a digital signal processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, Application Specific Integrated Circuits (ASICs), Field Programmable Gate Array (FPGA) circuits, any other type of integrated circuit (IC), a state machine, and/or the like. The Processor(s) 12 may perform data processing, input/output processing, instantiate operating system(s), execute application(s), and/or any other functionality that enables the use of sandbox isolation of one or more applications and/or processes.
  • Memory 14 may include volatile and/or non-volatile memory. Memory 14 may include read-only memory (ROM), random access memory (RAM), a register, cache memory, semiconductor memory devices, magnetic media such as, but not limited to, internal hard disks and removable disks, magneto-optical media, and/or optical media such as CD-ROM disks, and/or digital versatile disks (DVDs), and/or the like. Memory 14 may be configured to store computer readable instructions that when implemented by Processor(s) 12 may cause Processor(s) 12 to implement one or more of the functions or procedures described herein. For example, Memory 14 may be configured to store software code implemented by Processor(s) 12 that instantiate a restricted operating system environment for operation of the sandboxed browser and/or other sandboxed applications(s) and/or process(es). The software may restrict sandbox-based access to one more file descriptors, memory, file system space, etc. For example, the applications and/or processes operating within the sandboxed computing environment may be permitted to certain portions of Memory 14 but may not be allowed access to other portions of Memory 14. As an example, Memory 14 may be partitioned into a first memory space and a second memory space. The first memory space may be configured to enable storage and/or operation of a workspace configured to execute a first set of one or more applications and/or processes running on the operating system of the Host Computer System 10. The second memory space may be configured to enable storage and/or operation of a second set of one or more applications and/or processes running within the sandboxed computing environment. The sandboxed computing environment may be enforced via a sandbox container process. The sandbox container process may segregate the workspace associated with the first memory space from the sandboxed computing environment associated with the second memory space. For example, the sandbox container process may include an internal isolation firewall. The internal isolation firewall may enforce the segregation of the first and second memory spaces.
  • The Host Computer System 10 may include I/O Device(s) 16. The I/O Devices 16 may include one or more of a monitor, keyboard, mouse, touchscreen interface, digital camera, a digital display, a graphical user interface, and/or the like. The I/O Device(s) 16 can allow user interaction with the Host Computer System 10, for example to allow certain interactions between an application or a process operating within the sandboxed computing environment and non-sandboxed resources.
  • The Network Interface Adapter(s) 18 may be configured to allow communication between the Host Computer System 10 and other devices. The Network Interface Adapter(s) 18 may include one or more wired and/or wireless communication devices.
  • The sandbox container process may be configured to protect the host computer system from one or more malware toolsets. For example, the Network Interface Adapter(s) 18 may include one or more of a modem, Ethernet adapter, radio, wired and/or wireless transceiver, computer port, network socket, network interface controller, and/or the like. The Processor(s) 12 may maintain rules related to access to the Network Interface Adapter(s) 18 for both access via the sandboxed computing environment and via the workspace. Further, the Processor(s) 12 may enforce a host-based firewall that implements additional rules related to access to the Network Interface Adapter(s) 18.
  • As described herein, a sandbox protected application or process may be used for communicating with untrusted sources, such as Internet based resources. In this manner, if malware is transferred back to the host computer system due to interactions with the untrusted source, the malware may be isolated to the sandboxed computing environment, which may make it difficult for the malware to infect the workspace of the host computer system. For example, the sandbox container process may prevent the malware toolset from performing a reconnaissance of the host computer system to assess what data is available from the host computer system, such as computing resources, files, network information, additional network connectivity, etc. The sandbox container process (e.g., the internal isolation firewall) may prevent the data on the host computer system from being reported back to the remote device that sent the malware to the host computer and/or any other remote devices.
  • The sandbox container process may prevent the malware toolset from determining user system privileges of the host computer system, which can be used to access data on any associated network or local area network. For example, applications and/or processes operating within the sandboxed computing environment may not have access and/or authorization to such host computer configurations.
  • The sandbox container process may prevent the malware toolset from accessing local files stored on the host computer system. For example, the sandbox container process may isolate the first memory space from the second memory space. Such isolation can help prevent the malware from attempting to transmit such information back to the remote device that is the source of the malware. For example, the malware toolset may attempt to transmit a local security database from which additional user credentials can be derived, including potential privileged user credentials. These user credentials may be used by the malware to attempt to gain access to other resources on any associated network or the local area network. Where the user credentials are for a privileged user account, these credentials may be used to gain privileged access to other resources on any associated network or local area network.
  • The sandbox container process may prevent the malware toolset from accessing a security token and/or hash of the host computer user from the memory of the host computer system and/or a network data stream. This security token or hash can be used to gain access to other resources on any associated network or the local area network. Where the security token or hash is for a privileged user account, this security token or hash may be used to gain privileged access to other resources on any associated network or local area network.
  • The sandbox container process may prevent the malware toolset from enabling remote control and/or communication with (e.g., access) of the host computer system by a remote device that is unknown to the user. When malware enables remote control and/or access, the remote device may be able to control one or more (e.g., all) operations of an infected host computer system and perform whatever alternative uses that an enslaved, infected host computer system can perform. For example, a remote device may download additional data to an infected host computer system, communicate with other websites for denial of service attacks, and/or convert the infected host computer system into a source of malicious software from which toolsets or secondary payloads are downloaded to other, subsequently infected, host computer systems.
  • FIG. 2 depicts an example host computer system 212 using a sandbox based internet isolation system. The sandbox based internet isolation system may include a network 230, an authorization device 235, a proxy device 236, and/or a border firewall 238. The network 230 may include one or more host computer systems (e.g., such as the host computer system 212). The host computer system 212 may include a host-based firewall 214, an operating system 226, a sandboxed computing environment 220, an internal isolation firewall 218, and a workspace 216. The host computer system 212 may be any host computer system, such as a cell phone, a pager, a personal computer (PC), a laptop, a vehicle computer system, a kiosk computer system, a server, a workstation, a tablet, a smartphone, a router, a controller, a microcontroller, and/or any other processing and/or communication device. The host computer system 212 may be operatively connected with one or more user-accessible data entry devices, a display device viewable by a user, and/or a computer-accessible data storage. One or more application programs may run on the operating system 226.
  • As an example, the trusted host computer system 212 may be a PC, with 4 GB RAM and 146 GB hard disk computer-accessible storage, a monitor, a keyboard, and a mouse. The operating system 226 may be Windows-based, Linux-Based, Macintosh-based, and/or the like. The computer-accessible storage may store data corresponding to one or more software programs (e.g., computer-readable instructions) stored on the trusted host computer system 212 for common operation. The software programs may include word processing programs, accounting programs, remote connectivity programs, and/or other types of applications.
  • The host computer system 212 may be configured to isolate communication with untrusted network destinations. The host computer system 212 may isolate communication with untrusted network destinations using one or more of the host-based firewall 214, the border firewall 238, the proxy device 236, the authorization device 235, an internal isolation firewall 218, or a segregation of untrusted memory space.
  • The host-based firewall 214 may enable isolation of the host computer system's communication with one or more untrusted network destinations by preventing lateral communication with other devices connected to the network 230. For example, the host computer system 212 may receive untrusted traffic from the network 230. The host-based firewall 214 may be configured to block the untrusted traffic from the network 230. The host-based firewall 214 may be configured to block all incoming traffic from the network 230. The host-based firewall 214 may be configured to allow traffic received by the host computer system 212 via one or more predetermined devices and/or ports. One or more devices (e.g., predetermined devices) connected to the network 230 may bypass the host-based firewall 214, for example, using a predetermined set of protocols and/or ports.
  • The host-based firewall 214 may be implemented using software and/or hardware. For example, the host-based firewall 214 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc. The host-based firewall 214 may be implemented using software inherent in the operating system 226 of the host computer system 212, for example the Windows operating system firewall. The host-based firewall 214 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 212.
  • The proxy device 236 may enable isolation of the host computer system 212 from one or more untrusted network destinations. The proxy device 236 may be a web proxy. The proxy device 236 may proxy communication between untrusted network destinations and the sandboxed computing environment 220 (e.g., when the sandboxed computing environment 220 has authenticated with the authorization device 235 and/or the proxy device 236). The network 230 may be configured to utilize a Web Cache Control Protocol. The network 230 may redirect web related traffic that is intended for an untrusted resource or network destination (e.g., such as the Internet 242) to the proxy device 236, for example, using the Web Cache Control Protocol. For example, the network 230 may receive traffic via web related traffic from the host computer system 212. The network 230 (e.g., a router in the network 230) may redirect the web related traffic to the proxy device 236, for example. The Web Cache Control Protocol may route the web-related traffic to the proxy device 236 via a predetermined network port, for example, network port 4321 as shown. The proxy device 236 may determine (e.g., uniquely distinguish) that the traffic received from the network 230 is via the Web Cache Control Protocol, for example, based on the network port. The proxy device 236 may be configured to block traffic associated with an untrusted network destination. The proxy device 236 may receive requests from one or more applications and/or processes operating within the workspace 216 of the host computer system 212. The proxy device 236 may be configured to block one or more requests sent from the one or more applications and/or processes operating within the workspace 216 of the trusted host computer system 212, for example, based on the one or more requests being associated with the network port on which it is received, for example 4321.
  • The proxy device 236 may be configured to allow one or more processes and/or applications (e.g., browser process 222) operating within the sandboxed computing environment 220 of the trusted host computer system 212 to communicate with an untrusted network destination. A sandbox container process may enable the sandboxed computing environment 220. The sandboxed computing environment 220 may authenticate with an authorization device 235. The sandboxed computing environment 220 may send authentication credential(s) to the authorization device 235. The authorization device 235 may provide authentication information associated with the sandboxed computing environment 220 to the proxy device 236. Alternatively, the sandboxed computing environment 220 may authenticate with the proxy device 236. For example, the sandbox container process may authenticate with the authorization device 235 and/or the proxy device 236 on behalf of the one or more processes and/or applications operating within the sandboxed computing environment. The sandbox container process may be configured to authenticate with the authorization device and/or the proxy device 236 using preconfigured credentials stored within an encrypted configuration file. When the sandbox container process has successfully authenticated with the authorization device 235 and/or the proxy device 236, the proxy device 236 may allow the one or more processes and/or applications operating within the sandboxed computing environment 220 to communicate with the untrusted network destination. The authorization device 235 and the proxy device 236 may be the same device (e.g., a single combined device).
  • The border firewall 238 may enable isolation of the host computer system 212 (e.g., the workspace 216) from one or more untrusted network destinations. The border firewall 238 may be configured to restrict traffic to the untrusted network destinations (e.g., the Internet 242) from the proxy device 236 and/or the network 230 (e.g., enterprise router 234. The host computer systems 212 may communicate with a whitelisted web server and/or an untrusted web server, for example, via the border firewall 238. The border firewall 238 may be configured to block communication between the host computer system 212 and one or more untrusted network destinations, for example the Internet 242. For example, the border firewall 238 may be configured to block untrusted traffic that is not routed through the proxy device 236.
  • The sandboxed computing environment 220 may include resources (e.g., a limited set of resources) allocated to operation of a sandbox container process. The sandboxed computing environment 220 may be enforced via the sandbox container process. The sandbox container process may be a security mechanism used to separate resources associated with the sandboxed computing environment 220 from other applications and/or processes that may be running on a workspace 216 of the host computer system 212. The sandboxed container process may be configured to enable one or more applications and/or processes (e.g., such as browser process 222) being executed within the sandboxed computing environment 220 to access the resources allocated for operation of the sandbox container process. For example, the one or more applications and/or processes being operated within the sandboxed computing environment 220 may be allowed to access memory associated with the sandboxed computing environment 220. The memory associated with the sandboxed computing environment 220 may be separate from memory that is configured to enable storage and operation of the workspace 216.
  • The workspace 216 may include one or more processes operating within the operating system 226 that are not restricted by the sandbox container process. The operating system 226 of the host computer system 212 may include a set of resources configured to enable operation of the workspace 216 and the sandbox container process.
  • The host computer system 212 may enable the host-based firewall 214. The host-based firewall 214 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 212 and other devices on the network 230. Each device on the network 230 may include a host-based firewall (e.g., such as the host-based firewall 214). The host-based firewall 214 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 212 and other devices within the network 230. For example, the host-based firewall 214 may be configured to block incoming traffic from the other devices within the network 230. The host-based firewall 214 may allow traffic received by the host computer system 212 via one or more predetermined devices and/or ports. For example, one or more devices (e.g., predetermined devices) on the network 230 may bypass the host-based firewall 214, for example, using a predetermined set of protocols and/or ports.
  • The host-based firewall 214 may be implemented using software and/or hardware. For example, the host-based firewall 214 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc. The host-based firewall 214 may be implemented using software inherent in the operating system 226 of the trusted host computer system 212, for example the Windows operating system firewall. The host-based firewall 214 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 212.
  • The host computer system 212 may run the sandboxed computing environment 220. The sandboxed computing environment 220 may run within the operating system 226 of the host computer system 212. For example, the sandboxed computing environment 220 may be configured to run within a second memory space of the host computer system 212. A first memory space may be configured to enable storage and operation of a workspace configured to execute a first set of one or more applications and/or processes running on the operating system 226 of the host computer system 212. For example, a browser process 222 may operate within the sandboxed computing environment 220. The sandboxed computing environment 220 may be prohibited from communicating with other devices within the network 230. The browser process 222 may be configured to enable communication with untrusted network destinations.
  • Browser solutions running within the workspace 216 of the host computer system 212 may be utilized for communication between the host computer system 212 and trusted network destinations. For example, the one or more applications or processes running within the workspace 216 of the host computer system 212 may enable communication with the trusted network destinations.
  • The sandboxed computing environment 220 and/or the sandbox container process may be implemented using software and/or hardware. For example, the sandboxed computing environment 220 and/or the sandbox container process may be implemented using software that is commercially available, for example, such as Invincea Endpoint Protection, Tanium Endpoint Platform, Bromium Advanced Endpoint Security, etc.
  • The sandboxed computing environment 220 may provide separate and/or isolated memory space from the workspace 216 of the host computer system 212. For example, the sandboxed computing environment 220 may be enforced using a sandbox container process. The sandbox container process may segregate the workspace 216 from the sandboxed computing environment 220. The first memory space (e.g., the workspace memory) may enable storage and/or operation of the workspace 216. The operating system 226 may enable operation of the sandboxed computing environment 220. The second memory space may enable storage and/or operation of one or more applications and/or processes associated with the sandboxed computing environment 220. For example, the second memory space may be reserved for storage and/or operation of the applications and/or processes running within the sandboxed computing environment 220. The sandbox container process may isolate the first memory space and the second memory space. For example, the sandbox container process may enable the internal isolation firewall 218. The internal isolation firewall 218 may enforce a separation of the first and second memory spaces. For example, the internal isolation firewall 218 may allow a predefined set of processes to be executed within the sandboxed computing environment 220. The internal isolation firewall 218 may prevent execution, in the sandboxed computing environment 220, of any processes outside of the predefined set of processes. The second memory space may be referred to as a separate and/or isolated memory space. The sandbox container process may segregate the second memory space, any additional processes and/or memory usage required for usage of untrusted network destination related content during an established communication session. Separation and/or isolation of computer resources may be referred to as a virtual air gapped solution. The first memory space and the second memory space may be separate physical memory locations. The first memory space and the second memory space may be collocated on a physical memory. The first memory space and the second memory space may be enforced via a software partition.
  • If malware in a sandboxed computing environment 220 is able to communicate with (e.g., access) the resources, assets, and/or files of the operating system 226, the host computer system 212 may be considered infected and untrusted. For example, the malware may bypass the internal isolation firewall 218 via explicit user input. The host-based firewall 214 may prohibit the introduced malware from communicating with any other device on the network 230. For example, the host-based firewall 214 may be configured to block incoming traffic from the network 230.
  • Malware may be introduced to the operating system 226 from a source other than communication with the Internet 242. For example, malware may be introduced to the operating system 226 via an infected email, an infected USB memory stick, and/or another infected hardware device.
  • An infected and/or untrusted host computer system (e.g., regardless of the introduced malware's vector) may have no communication (e.g., direct communication) with the Internet 242. For example, the border firewall 238 may prevent the infected and/or untrusted host computer system from communicating with the Internet 242. Without a connection to (e.g., communication with) the Internet 242, the introduced malware may be prevented from performing many toolset functions described herein or any other function that an enslaved, infected and/or untrusted host computer system may perform. Without a connection to the Internet 242, the introduced malware may not be able to transfer any data from the infected and/or untrusted host computer system to the Internet 242.
  • The host computer system 212 and/or the network 230 may limit the adverse effects associated with a received malware. For example, the host computer system 212 and/or the network 230 may prevent the received malware from using its vector to communicate data from the host computer system 212.
  • An author of the malware may not be aware of any level of efficacy of the introduced malware and/or its successful attack vector. The host computer system 212 and/or the network 230 may prevent data of an infected and/or untrusted host computer system that may have been compromised and/or collected by the malware from being communicated to the author of the malware. For example, the host computer system 212 may prevent communication between an infected and/or untrusted host computer system and the Internet 242 (e.g., the author of the malware via the Internet 242).
  • FIG. 3 depicts an example host computer system 312A (e.g., such as the host computer system 212 shown in FIG. 2) connected to a local area network (LAN) 310, the example host computer system 312A using a sandbox based network isolation system. The LAN 310 may include a plurality of physical and/or virtual devices. The LAN 310 may include a plurality of host computer systems 312A, 312B, 312C. Each of the host computer systems may transmit electrical data signals to one or more other host computer systems on the LAN 310. Each of the host computer systems may be identified by a unique local area network address. The LAN 310 may include a router 328. The host computer systems 312A, 312B, 312C may send web traffic and/or non-web traffic to a trusted network 330 via the router 328. The LAN 310 may send web traffic to one or more untrusted network destinations using one or more of the trusted network 330, a border firewall 338, or a proxy device 336. For example, the LAN 310 may communicate with the internet 342 and/or a device 344 on the internet 342 via the trusted network 330, the border firewall 338, and/or the proxy device 336.
  • The web traffic sent to the trusted network 330 may be destined for trusted destinations. The LAN 310 may enable a connection to a cloud-based computing system. The connection to the cloud-based computing system may be a direct connection. The LAN 310 may be part of a cloud interexchange. The LAN 310 may be part of a cloud “meet me” point of presence.
  • Each of the host computer systems 312A, 312B, 312C may enable a host-based firewall 314. The host-based firewall 314 may prohibit and/or prevent communication (e.g., direct communication) between the respective host computer system 312A, 312B, 312C and other devices on the LAN 310. The host-based firewall 314 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 312A and other devices within the trusted network 330. For example, the host-based firewall 314 may be configured to block incoming traffic from the other devices within the LAN 310 and/or the trusted network 330. The host-based firewall 314 may allow traffic to be received by the host computer system 312A via one or more predetermined devices and/or ports. For example, one or more devices (e.g., predetermined devices) on the LAN 310 and/or the trusted network 330 may bypass the host-based firewall 314, for example, using a predetermined set of protocols and/or ports.
  • The host-based firewall 314 may be implemented using software and/or hardware. For example, the host-based firewall 314 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc. The host-based firewall 314 may be implemented using software inherent in the operating system 326 of the host computer system 312A, for example the Windows operating system firewall. The host-based firewall 314 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 312A.
  • FIG. 4 depicts an example host computer system 412A (e.g., such as host computer system 212, 312A shown in FIGS. 2 and 3, respectively) connected to a wide area network (WAN) 400, the example host computer system 412A may include a sandbox based network isolation system. The WAN 400 may include a plurality of LANs 410A, 410B, 410C; a trusted network 430, a proxy device 436 (e.g., such as the proxy device 236, 336 shown in FIGS. 2 and 3, respectively), and a border firewall 438 (e.g., such as the border firewall 238, 338 shown in FIGS. 2 and 3, respectively). The WAN 400 may include virtual and/or physical devices. The WAN 400 may be configured to enable communicate with the internet 442 and/or a device 444 on the internet 442 via the border firewall 438. The WAN 400 may enable a connection to a cloud-based computing system. The connection to the cloud-based computing system may be a direct connection. The WAN 400 may be part of a cloud interexchange. The WAN 400 may be part of a cloud “meet me” point of presence.
  • Each of the LANs 410A, 410B, 410C may include a plurality of host computer systems. For example, LAN 410A may include host computer systems 412A, 412B, 412C, 412D. Each host computer system of a respective LAN may be configured to send electrical data signals to one or more other host computer systems on the respective LAN. For example, the host computer systems 412A, 412B, 412C, 412D of the LAN 410A may send data to each other. Each of the host computer systems may be identified by a unique local area network address. The LANs 410A, 410B, 410C (e.g., each host computer system in the LANs 410A, 410B, 410C) may send web traffic and/or non-web traffic to a trusted network 430. The web traffic sent to the trusted network 430 may be destined for trusted destinations.
  • Each of the host computer systems (e.g., host computer systems 412A, 412B, 412C, 412D of LAN 410A) may enable a host-based firewall. For example, host computer system 412A may enable the host-based firewall 414. The host-based firewall 414 may prohibit and/or prevent communication (e.g., direct communication) between the respective host computer systems 412A, 412B, 412C, 412D and other devices on the LAN 410A. The host-based firewall 414 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 412A and other devices within the WAN 400. For example, the host-based firewall 414 may be configured to block incoming traffic from the other devices within the LAN 410A and/or the WAN 400. The host-based firewall 414 may allow traffic to be received by the host computer system 412A via one or more predetermined devices and/or ports. For example, one or more devices (e.g., predetermined devices) on the LAN 410A and/or the WAN 400 may bypass the host-based firewall 414, for example, using a predetermined set of protocols and/or ports.
  • The host-based firewall 414 may be implemented using software and/or hardware. For example, the host-based firewall 414 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc. The host-based firewall 414 may be implemented using software inherent in the operating system 426 of the host computer system 412A, for example the Windows operating system firewall. The host-based firewall 414 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 412A.
  • The border firewall 438 may prevent unauthorized communication between the WAN 400 and the internet 442. The border firewall 438 may prevent unauthorized communication between one or more devices in the WAN 400 and the internet 442. The WAN 400 may include multiple border firewalls. For example, each LAN of the WAN 400 may include a border firewall.
  • Mobile phones, tablets, and/or other connected devices may enter and leave the WAN 400. For example, due to the large geographic area covered by the WAN 400, devices may join and leave the WAN 400 more frequently than a LAN. A device may move from a first WAN (e.g., the WAN 400) to a second WAN. The host-based firewall may protect the device in both the first WAN and the second WAN. An infected device may join the WAN 400. The host-based firewall of the other devices in the WAN 400 may be configured to isolate communication from the infected device.
  • FIG. 5 depicts an example host computer system 512 (e.g., such as host computer system 212, 312A, 412A shown in FIGS. 2, 3, and 4, respectively) connected to a cellular radio access network (RAN) 500, the example host computer system 512 may include a sandbox based network isolation system. The RAN 500 may include a plurality of eNodeBs 530A, 530B, 530C; one or more serving gateways (GWs) 532A, 532B, and a packet GW 534. Virtual and/or physical devices may connect to the RAN 500. A device may connect to the RAN 500 via a virtual private network (VPN) client. The RAN 500 may be configured to enable communication with the internet 542 via the packet GW 534. For example, the host computer system 512 may send web traffic to one or more untrusted network destinations via the eNodeB 530A, the serving GW 532A, and the packet GW 534. The host computer system 512 may send web traffic to one or more trusted destinations via the eNodeB 530A. The host computer system 512 may send non-web traffic to the eNodeB 530A. A proxy device (e.g., such as proxy device 236 shown in FIG. 2, proxy device 336 shown in FIG. 3, and/or proxy device 436 shown in FIG. 4) may be included within a serving GW 532A, 532B and/or the packet GW 534. The proxy device may receive, from the host computer system 512, the web traffic destined for the one or more untrusted network destinations. The proxy device may authenticate the host computer system 512.
  • The host computer system 512 may enable a host-based firewall 514. The host-based firewall 514 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 512 and other devices connected to the RAN 500. The host-based firewall 514 may prohibit and/or prevent communication (e.g., direct communication) between the host computer system 512 and other devices on the internet 542. For example, the host-based firewall 514 may be configured to block incoming traffic from the eNodeB 530A. The host-based firewall 514 may allow traffic to be received by the host computer system 512 via one or more predetermined devices and/or ports. For example, the eNodeB 530A may bypass the host-based firewall 514, for example, using a predetermined set of protocols and/or ports.
  • The host-based firewall 514 may be implemented using software and/or hardware. For example, the host-based firewall 514 may be implemented using software that is commercially available, for example, such as Symantec Endpoint Protection, MacAfee Host Based Security Systems, etc. The host-based firewall 514 may be implemented using software inherent in the operating system 526 of the host computer system 512, for example the Windows operating system firewall. The host-based firewall 514 may be implemented using software for configuring and/or implementing restrictive ingress and/or egress policies on the host computer system 512.
  • A sandbox based network isolation system may be used in a data center. The data center may be local or cloud-based. For example, one or more servers, databases, switches, and/or hubs of the data center may include a sandbox based network isolation system. The sandbox based network isolation system may prevent data from passing between the devices of the data center, for example, except for predetermined devices and/or ports. If a database of the data center becomes infected with malware, the other devices in the data center may prevent infection because communication from the other devices in the data center may be blocked by their respective host-based firewalls. As another example, a database in a data center may enable multiple segregated storage spaces, as described herein. The storage spaces may be segregated such that data may not be exchanged. An internal isolation firewall may enable segregation of storage spaces. For example, each storage space may be associated with an internal isolation firewall. If a storage space in the database of the data center becomes infected with malware, the database may prevent infection of the other storage spaces in the database because communication between the storage spaces may be blocked, for example, by their respective internal isolation firewalls.
  • A device with a sandbox based network isolation system may travel between, connect to, and/or communicate with more than one network environment. For example, a device with a sandbox based network isolation system may travel between, connect to, and/or communicate with one or more of a LAN, a WAN, a WWAN, a cellular network, a digital subscriber line (DSL) network, a Wi-Fi network, a LPWA network, a satellite network, an infrastructure as a service (IaaS) network, a platform as a service (PaaS) network, and/or the like. The device may be configured to provide network isolation by using a host-based firewall, an internal isolation firewall, and/or a segregation of memory space. The host-based firewall may enable network isolation of the device across different network environments. For example, the host-based firewall may prevent communications from other devices in the different network environments.
  • A device having sensitive, private, and/or security data may include a sandbox based network isolation system. A device having access to sensitive, private, and/or security data may include a sandbox based network isolation system. The sandbox based network isolation system may be configured to prevent access by unauthorized devices to the sensitive, private, and/or security data. For example, the sensitive, private, and/or security data may be stored in a first memory space of the host computer system. The host computer system may enable communication with untrusted network destinations via a second memory space. The host computer system may enforce segregation of the first memory space and the second memory space. For example, any malware introduced to the second memory space from communication with the untrusted network destinations may be prevented from accessing the first memory space. The segregation of the first memory space and the second memory space may be software-based and/or hardware-based. For example, the first memory space may be enabled by a first hard drive and the second memory space may be enabled by a second hard drive. As another example, the first memory space and the second memory space may be enabled by a single hard drive. The first memory space and the second memory space may be associated with one or more partitions in the single hard drive. An internal isolation firewall, as described herein, may enforce the segregation of the first memory space and the second memory space.
  • A sandbox based network isolation system may be used to prevent malware from establishing command and control on a computer system (e.g., a desktop computer, a laptop computer, a tablet, a mobile phone, etc.). For example, the sandbox based network isolation system may be configured to operate on a computer system running Windows, Linux, MacOS, iOS, Android, Windows Mobile, and/or some other operating system.
  • A sandbox based network isolation system may prevent malware from moving from a first computer system to a second computer system on the same network environment. For example, when a computer system in a network environment is infected with malware, the sandbox based network isolation system may prevent proliferation of the malware within the network environment.
  • A sandbox based network isolation system may increase the security posture of an enterprise network (e.g., a WAN, a LAN, and/or a VM infrastructure). For example, the sandbox based network isolation system may protect the enterprise network from malware, command and control attacks, viruses, and/or data exfiltration attacks.
  • The terms used herein should be seen to be terms of description rather than of limitation. It is understood that those of skill in the art with this disclosure may devise alternatives, modifications, or variations of the principles of the invention. It is intended that all such alternatives, modifications, or variations be considered as within the spirit and scope of this invention, as defined by the following claims.
  • Embodiments may take the form of a tangible computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. Examples of a computer-usable or computer-readable medium include tangible computer media such as semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD. A processor may be configured to execute instructions stored in memory to perform the various functions and/or functional modules described herein.

Claims (20)

What is claimed:
1. A host computer system configured to connect to a network, wherein the host computer system comprises:
a memory; and
a processor configured to:
implement an operating system that enables operation of a workspace, the workspace configured to enable operation of a first set of one or more applications or processes;
implement a sandboxed computing environment that is configured to enable operation of a second set of one or more applications or processes, the sandboxed computing environment configured to authenticate with an authorization device;
isolate, using an internal isolation firewall, the sandboxed computing environment from the workspace, the internal isolation firewall being configured to prevent data from being communicated between the sandboxed computing environment and the workspace without an explicit user input;
prevent, using a host-based firewall, communication between the host computer system and one or more other devices on the network; and
communicate, using the second set of one or more applications or processes operating on the sandboxed computing environment, with untrusted network destinations via a proxy device.
2. The host computer system of claim 1, wherein the sandboxed computing environment is enforced by a sandbox container process that enables the internal isolation firewall.
3. The host computer system of claim 2, wherein the workspace is enabled by and executed using a first memory space, and wherein the sandboxed computing environment is enabled by and executed using a second memory space, and wherein the first memory space and the second memory space are isolated by the sandbox container process.
4. The host computer system of claim 2, wherein the internal isolation firewall enforces a separation of the sandboxed computing environment and the workspace by:
segregating storage memory associated with the workspace from storage memory associated with the sandboxed computing environment; and
allowing a predefined set of processes to be executed within the sandboxed computing environment, wherein the sandbox container process prevents execution in the sandboxed computing environment of any processes outside of the predefined set of processes.
5. The host computer system of claim 1, wherein the sandboxed computing environment is configured to classify a network destination as trusted or untrusted based on one or more of a whitelist comprising a list of trusted network destinations or a blacklist comprising a list of untrusted network destinations.
6. The host computer system of claim 5, wherein the trusted network destinations are communicated with via one or more of the first set of one or more applications and processes associated with the workspace.
7. The host computer system of claim 6, wherein at least one of the untrusted network destinations is located on the Internet and is communicated with, using the proxy device, via a browser process operating within the sandboxed computing environment upon authentication via the authorization device.
8. The host computer system of claim 1, wherein the host-based firewall is configured to block incoming traffic from the one or more devices on the network and one or more devices on the Internet.
9. The host computer system of claim 1, wherein the authorization device and the proxy device are the same device.
10. A system comprising:
an authorization device configured to:
receive authentication credentials from a sandboxed computing environment operating on a host computer system on a network, the sandboxed computing environment being isolated from a workspace associated with an operating system of the host computer system; and
authenticate the sandboxed computing environment of the host computer system using the received authentication credentials; and
a proxy device configured to:
receive, from a first application or process operating in the authenticated sandboxed computing environment of the host computer system, a first request to communicate with a first untrusted network destination;
allow the first application or process operating in the authenticated sandboxed computing environment to communicate with the first untrusted network destination;
receive, from a second application or process operating on the workspace of the host computer system, a second request to communicate with a second untrusted network destination; and
prevent the second application or process operating on the workspace of the host computer system from communicating with the second untrusted network destination.
11. The system of claim 10, wherein the authentication credentials are first authentication credentials, the sandboxed computing environment is a first sandboxed computing environment, the workspace is a first workspace, and the host computer system is a first host computer system, and wherein the authorization device is further configured to:
receive second authentication credentials from a second sandboxed computing environment operating on a second host computer on the network, the second sandboxed computing environment being isolated from a second workspace of the second host computer system; and
authenticate the second sandboxed computing environment of the second host computer system using the received second authentication credentials.
12. The system of claim 11, wherein the proxy device is further configured to:
receive, from a third application or process operating in the authenticated second sandboxed computing environment of the second host computer system, a third request to communicate with a third untrusted network destination; and
allow the third application or process operating in the authenticated second sandboxed computing environment to communicate with the third untrusted network destination.
13. The system of claim 10, wherein a network destination is classified as trusted or untrusted based on one or more of a whitelist comprising a list of trusted network destinations or a blacklist comprising a list of untrusted network destinations, and wherein the proxy device is further configured to:
receive, from the network, a third request to communicate with the network destination;
determine that the network destination is a trusted network destination on the whitelist; and
allow, based on the determination that the network destination is a trusted network destination, communication between the network destination and the network.
14. The system of claim 10, wherein the authentication credentials comprise preconfigured credentials stored within an encrypted configuration file.
15. The system of claim 10, wherein the proxy device is further configured to establish a communication channel between the host computer system and the first untrusted network destination.
16. The system of claim 10, further comprising a border firewall that is configured to prevent unauthorized communication between the network and untrusted network destinations.
17. An Internet isolation system comprising:
a network having a plurality of host computer systems, each of the plurality of host computer systems configured to:
prevent, using a host-based firewall, communication and data transfer between the other host computer systems of the plurality of host computer systems,
implement an operating system and a sandboxed computing environment, the operating system configured to enable operation of a workspace that is configured to enable operation of a first set of one or more applications or processes, the sandboxed computing environment configured to enable operation of a second set of one or more applications or processes, and
isolate, using an internal isolation firewall, the sandboxed computing environment from the workspace;
an authorization device configured to authenticate the sandboxed computing environments of each of the plurality of host computer systems upon receipt of authentication credentials from the respective sandboxed computing environments;
a proxy device configured to:
proxy communication between untrusted network destinations and the authenticated sandboxed computing environments of each of the plurality of host computer systems, and
prevent communication between respective workspaces of each of the plurality of host computer systems and the untrusted network destinations; and
a border firewall configured to block unauthorized communications between the network and the untrusted network destinations.
18. The Internet isolation system of claim 17, wherein if malware infects a sandboxed computing environment of a host computer system of the plurality of host computer systems, the internet isolation system is configured to:
prevent the malware from communicating with the workspace of the host computer system; and
prevent the malware from communicating with data associated with the workspace.
19. The Internet isolation system of claim 17, wherein if malware infects a workspace of a host computer system of the plurality of host computer systems, the internet isolation system is configured to:
prevent the malware from communicating with the other host computer systems of the plurality of host computer systems; and
prevent the malware from communicating with untrusted network destinations.
20. The Internet isolation system of claim 19, wherein the respective host-based firewalls of each of the plurality of host computer systems prevent the malware from communicating with the respective workspaces of the plurality of host computer systems, and wherein the proxy device and the border firewall prevent the malware from communicating with the untrusted network destinations.
US16/059,381 2017-08-11 2018-08-09 Network isolation Active 2038-11-10 US11240207B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/059,381 US11240207B2 (en) 2017-08-11 2018-08-09 Network isolation

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201762544024P 2017-08-11 2017-08-11
US16/059,381 US11240207B2 (en) 2017-08-11 2018-08-09 Network isolation

Publications (2)

Publication Number Publication Date
US20190052604A1 true US20190052604A1 (en) 2019-02-14
US11240207B2 US11240207B2 (en) 2022-02-01

Family

ID=65275639

Family Applications (1)

Application Number Title Priority Date Filing Date
US16/059,381 Active 2038-11-10 US11240207B2 (en) 2017-08-11 2018-08-09 Network isolation

Country Status (1)

Country Link
US (1) US11240207B2 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110311901A (en) * 2019-06-21 2019-10-08 南京尓嘉网络科技有限公司 A lightweight network sandbox setting method based on container technology
US10757009B2 (en) * 2018-11-20 2020-08-25 Amazon Technologies, Inc. Global-scale connectivity using scalable virtual traffic hubs
US11341234B1 (en) * 2019-06-05 2022-05-24 EMC IP Holding Company LLC System for securely recovering backup and data protection infrastructure
US11483339B1 (en) * 2019-11-27 2022-10-25 Pulse Secure, Llc Detecting attacks and quarantining malware infected devices
US11824773B2 (en) 2021-03-30 2023-11-21 Amazon Technologies, Inc. Dynamic routing for peered virtual routers
US12021743B1 (en) 2023-03-27 2024-06-25 Amazon Technologies, Inc. Software-defined multi-network-segment gateways for scalable routing of traffic between customer-premise network segments and cloud-based virtual networks
US12160366B2 (en) 2021-03-30 2024-12-03 Amazon Technologies, Inc. Multi-tenant offloaded protocol processing for virtual routers

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US12388829B1 (en) 2025-02-03 2025-08-12 Morgan Stanley Services Group Inc. Enterprise application management and migration on a web proxy

Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130145463A1 (en) * 2011-12-02 2013-06-06 Invincea, Inc. Methods and apparatus for control and detection of malicious content using a sandbox environment
US20130318594A1 (en) * 2011-01-27 2013-11-28 L-3 Communications Corporation Internet isolation for avoiding internet security threats
US20140115646A1 (en) * 2012-10-18 2014-04-24 Broadcom Corporation Integration of Untrusted Applications and Frameworks with a Secure Operating System Environment
US8966464B1 (en) * 2014-03-21 2015-02-24 Amazon Technologies, Inc. Isolating tenants executing in multi-tenant software containers
US20150156203A1 (en) * 2013-12-02 2015-06-04 At&T Intellectual Property I, L.P. Secure Browsing Via A Transparent Network Proxy
US9386021B1 (en) * 2011-05-25 2016-07-05 Bromium, Inc. Restricting network access to untrusted virtual machines
US20160226834A1 (en) * 2015-01-29 2016-08-04 WebCloak, LLC Safechannel encrypted messaging system
US9531715B1 (en) * 2014-05-07 2016-12-27 Skyport Systems, Inc. Method and system for protecting credentials
US20170076092A1 (en) * 2012-07-03 2017-03-16 Bromium, Inc. Micro-virtual machine forensics and detection
US20170208067A1 (en) * 2016-01-14 2017-07-20 Avecto Limited Computer Device and Method for Controlling Access to a Web Resource
US20170353496A1 (en) * 2016-06-02 2017-12-07 Microsoft Technology Licensing, Llc Hardware-Based Virtualized Security Isolation
US20180139178A1 (en) * 2015-12-24 2018-05-17 Huawei Technologies Co., Ltd. Method, Apparatus, and System for Detecting Terminal Security Status
US20180198824A1 (en) * 2017-01-09 2018-07-12 Microsoft Technology Licensing, Llc Distribution and Management of Services in Virtual Environments
US20180276396A1 (en) * 2017-03-24 2018-09-27 AO Kaspersky Lab System and method of controlling access to content using an accessibility api

Family Cites Families (102)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6453348B1 (en) 1998-11-06 2002-09-17 Ameritech Corporation Extranet architecture
US20020040439A1 (en) 1998-11-24 2002-04-04 Kellum Charles W. Processes systems and networks for secure exchange of information and quality of service maintenance using computer hardware
US6754831B2 (en) 1998-12-01 2004-06-22 Sun Microsystems, Inc. Authenticated firewall tunneling framework
MXPA02012728A (en) 2000-07-05 2004-09-10 Ernst & Young Llp Method and apparatus for providing computer services.
GB0020441D0 (en) 2000-08-18 2000-10-04 Hewlett Packard Co Performance of a service on a computing platform
US20020069366A1 (en) 2000-12-01 2002-06-06 Chad Schoettger Tunnel mechanis for providing selective external access to firewall protected devices
EP1410559A4 (en) 2001-03-01 2004-11-24 Invicta Networks Inc Systems and methods that provide external network access from a protected network
US7467408B1 (en) 2002-09-09 2008-12-16 Cisco Technology, Inc. Method and apparatus for capturing and filtering datagrams for network security monitoring
US7694328B2 (en) 2003-10-21 2010-04-06 Google Inc. Systems and methods for secure client applications
JP2005197823A (en) 2003-12-26 2005-07-21 Fujitsu Ltd Unauthorized access control device between firewall and router
US20050193429A1 (en) 2004-01-23 2005-09-01 The Barrier Group Integrated data traffic monitoring system
US7840763B2 (en) 2004-03-12 2010-11-23 Sca Technica, Inc. Methods and systems for achieving high assurance computing using low assurance operating systems and processes
US20060282795A1 (en) 2004-09-13 2006-12-14 Network Solutions, Llc Domain bar
US20060070066A1 (en) 2004-09-30 2006-03-30 Grobman Steven L Enabling platform network stack control in a virtualization platform
US7698442B1 (en) 2005-03-03 2010-04-13 Voltage Security, Inc. Server-based universal resource locator verification service
US7716720B1 (en) 2005-06-17 2010-05-11 Rockwell Collins, Inc. System for providing secure and trusted computing environments
US20070074191A1 (en) 2005-08-30 2007-03-29 Geisinger Nile J Software executables having virtual hardware, operating systems, and networks
US7836303B2 (en) 2005-12-09 2010-11-16 University Of Washington Web browser operating system
US20070174429A1 (en) 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
US20070220187A1 (en) 2006-03-20 2007-09-20 Lawrence Kates Virus-resistant computer with data interface for filtering data
US8381287B2 (en) 2006-07-19 2013-02-19 Secure Exchange Solutions, Llc Trusted records using secure exchange
US7926086B1 (en) 2006-10-31 2011-04-12 Oracle America, Inc. Access control mechanism for shareable interface communication access control
US8488576B2 (en) 2006-12-15 2013-07-16 Research In Motion Limited Methods and apparatus for establishing WLAN communications using an ESSID created based on a predetermined algorithm and a domain name
US8176486B2 (en) 2007-02-15 2012-05-08 Clearcube Technology, Inc. Maintaining a pool of free virtual machines on a server computer
US8024790B2 (en) 2007-04-11 2011-09-20 Trend Micro Incorporated Portable secured computing environment for performing online confidential transactions in untrusted computers
US8769268B2 (en) 2007-07-20 2014-07-01 Check Point Software Technologies, Inc. System and methods providing secure workspace sessions
US8539551B2 (en) 2007-12-20 2013-09-17 Fujitsu Limited Trusted virtual machine as a client
WO2009085977A2 (en) 2007-12-20 2009-07-09 Virtual Computer, Inc. Virtual computing management systems and methods
US8146147B2 (en) 2008-03-27 2012-03-27 Juniper Networks, Inc. Combined firewalls
US9009657B2 (en) 2008-04-20 2015-04-14 Microsoft Technology Licensing, Llc Component-oriented architecture for web mashups
US7478330B1 (en) 2008-04-30 2009-01-13 International Business Machines Corporation Systems and methods involving improved web browsing
US10127059B2 (en) 2008-05-02 2018-11-13 Skytap Multitenant hosted virtual machine infrastructure
JP2010009396A (en) 2008-06-27 2010-01-14 Toshiba Corp Computer system, and device control method for the same
US8434093B2 (en) 2008-08-07 2013-04-30 Code Systems Corporation Method and system for virtualization of software applications
US9098698B2 (en) 2008-09-12 2015-08-04 George Mason Research Foundation, Inc. Methods and apparatus for application isolation
US7805516B2 (en) 2008-10-14 2010-09-28 Dell Products L.P. Enabling throttling of resources on a virtualization enabled information handling system
US20100138829A1 (en) 2008-12-01 2010-06-03 Vincent Hanquez Systems and Methods for Optimizing Configuration of a Virtual Machine Running At Least One Process
CN101819564B (en) 2009-02-26 2013-04-17 国际商业机器公司 Method and device for assisting communication between virtual machines
US8464252B2 (en) 2009-02-27 2013-06-11 Red Hat, Inc. Per process virtual machines
WO2010117623A2 (en) 2009-03-31 2010-10-14 Coach Wei System and method for access management and security protection for network accessible computer services
US8090797B2 (en) 2009-05-02 2012-01-03 Citrix Systems, Inc. Methods and systems for launching applications into existing isolation environments
RU2406138C1 (en) 2009-06-18 2010-12-10 Корпорация "САМСУНГ ЭЛЕКТРОНИКС Ко., Лтд." Security system for virtual computer sytem
US9684785B2 (en) 2009-12-17 2017-06-20 Red Hat, Inc. Providing multiple isolated execution environments for securely accessing untrusted content
US8869300B2 (en) 2010-05-10 2014-10-21 Citrix Sytems, Inc. Redirection of information from secure virtual machines to unsecure virtual machines
US9148428B1 (en) 2011-05-25 2015-09-29 Bromium, Inc. Seamless management of untrusted data using virtual machines
US9323921B2 (en) 2010-07-13 2016-04-26 Microsoft Technology Licensing, Llc Ultra-low cost sandboxing for application appliances
US20120023593A1 (en) 2010-07-26 2012-01-26 Puder George System and method for filtering internet content & blocking undesired websites by secure network appliance
US8539561B2 (en) 2010-08-24 2013-09-17 International Business Machines Corporation Systems and methods to control device endpoint behavior using personae and policies
US8739147B2 (en) 2011-04-15 2014-05-27 International Business Machines Corporation Class isolation to minimize memory usage in a device
US8839363B2 (en) 2011-04-18 2014-09-16 Bank Of America Corporation Trusted hardware for attesting to authenticity in a cloud environment
US9921860B1 (en) 2011-05-25 2018-03-20 Bromium, Inc. Isolation of applications within a virtual machine
US20140040979A1 (en) 2011-10-11 2014-02-06 Citrix Systems, Inc. Policy-Based Application Management
US20130132948A1 (en) 2011-11-21 2013-05-23 Adiseshu Hari Personal cloud computing and virtual distributed cloud computing system
US10291619B2 (en) 2012-04-06 2019-05-14 Wayne Odom System, method, and device for delivering communications and storing and delivering data
US20140007189A1 (en) 2012-06-28 2014-01-02 International Business Machines Corporation Secure access to shared storage resources
US9087191B2 (en) 2012-08-24 2015-07-21 Vmware, Inc. Method and system for facilitating isolated workspace for applications
US10171540B2 (en) 2012-09-07 2019-01-01 High Sec Labs Ltd Method and apparatus for streaming video security
US20140108558A1 (en) 2012-10-12 2014-04-17 Citrix Systems, Inc. Application Management Framework for Secure Data Sharing in an Orchestration Framework for Connected Devices
US9781118B2 (en) 2013-03-14 2017-10-03 Intel Corporation Differentiated containerization and execution of web content based on trust level and other attributes
US9124626B2 (en) 2013-05-20 2015-09-01 International Business Machines Corporation Firewall based botnet detection
JP6089349B2 (en) 2013-05-28 2017-03-08 ▲ホア▼▲ウェイ▼技術有限公司Huawei Technologies Co.,Ltd. Method and system for supporting resource separation in a multi-core architecture
US9300629B1 (en) 2013-05-31 2016-03-29 Palo Alto Networks, Inc. Password constraint enforcement used in external site authentication
US9268948B2 (en) 2013-06-24 2016-02-23 Intel Corporation Secure access enforcement proxy
US10762204B2 (en) 2013-11-28 2020-09-01 Blackberry Limited Managing containerized applications
US9560081B1 (en) 2016-06-24 2017-01-31 Varmour Networks, Inc. Data network microsegmentation
US9202046B2 (en) 2014-03-03 2015-12-01 Bitdefender IPR Management Ltd. Systems and methods for executing arbitrary applications in secure environments
US20150281176A1 (en) 2014-04-01 2015-10-01 Bret Banfield Method And Technique for Automated Collection, Analysis, and Distribution of Network Security Threat Information
US9646309B2 (en) 2014-04-04 2017-05-09 Mobilespaces Method for authentication and assuring compliance of devices accessing external services
US9680873B1 (en) 2014-06-30 2017-06-13 Bromium, Inc. Trusted network detection
US20170206351A1 (en) 2014-07-22 2017-07-20 Viasat, Inc. Mobile device security monitoring and notification
US9509715B2 (en) 2014-08-21 2016-11-29 Salesforce.Com, Inc. Phishing and threat detection and prevention
US10021088B2 (en) 2014-09-30 2018-07-10 Citrix Systems, Inc. Fast smart card logon
GB2532055B (en) 2014-11-07 2016-12-14 Ibm Sticky and transient markers for a packet parser
US9639706B2 (en) 2015-02-19 2017-05-02 International Business Machines Corporation Inter-virtual machine communication
US10027700B2 (en) 2015-02-20 2018-07-17 Authentic8, Inc. Secure analysis application for accessing web resources via URL forwarding
EP3262815B1 (en) 2015-02-24 2020-10-14 Cisco Technology, Inc. System and method for securing an enterprise computing environment
US9294492B1 (en) 2015-03-10 2016-03-22 Iboss, Inc. Software program identification based on program behavior
US9609026B2 (en) 2015-03-13 2017-03-28 Varmour Networks, Inc. Segmented networks that implement scanning
US9438634B1 (en) 2015-03-13 2016-09-06 Varmour Networks, Inc. Microsegmented networks that implement vulnerability scanning
US9465734B1 (en) 2015-04-08 2016-10-11 Apple Inc. Coalition based memory management
US9729579B1 (en) 2015-04-27 2017-08-08 Symantec Corporation Systems and methods for increasing security on computing systems that launch application containers
EP3125502A1 (en) 2015-07-31 2017-02-01 GridSystronic Energy GmbH Method for providing access to a web server
US9894036B2 (en) * 2015-11-17 2018-02-13 Cyber Adapt, Inc. Cyber threat attenuation using multi-source threat data analysis
US10333948B2 (en) 2016-02-29 2019-06-25 Palo Alto Networks, Inc. Alerting and tagging using a malware analysis platform for threat intelligence made actionable
US20170293432A1 (en) 2016-04-08 2017-10-12 David Oldcorn Memory management with reduced fragmentation
US20170317978A1 (en) 2016-04-28 2017-11-02 Microsoft Technology Licensing, Llc Secure interface isolation
GB2551200B (en) 2016-06-10 2019-12-11 Sophos Ltd Combined security and QOS coordination among devices
US9787639B1 (en) 2016-06-24 2017-10-10 Varmour Networks, Inc. Granular segmentation using events
GB2567071B (en) 2016-06-29 2021-10-13 Sophos Ltd Sandbox environment for document preview and analysis
US10798063B2 (en) 2016-10-21 2020-10-06 Nebbiolo Technologies, Inc. Enterprise grade security for integrating multiple domains with a public cloud
US10375111B2 (en) 2016-11-12 2019-08-06 Microsoft Technology Licensing, Llc Anonymous containers
US10831894B2 (en) 2017-01-11 2020-11-10 Morgan State University Decentralized root-of-trust framework for heterogeneous networks
US11386343B2 (en) 2017-05-09 2022-07-12 Elasticsearch B.V. Real time detection of cyber threats using behavioral analytics
US20180367528A1 (en) 2017-06-12 2018-12-20 Cyberark Software Ltd. Seamless Provision of Authentication Credential Data to Cloud-Based Assets on Demand
US10521612B2 (en) 2017-06-21 2019-12-31 Ca, Inc. Hybrid on-premises/software-as-service applications
US10558798B2 (en) 2017-06-29 2020-02-11 L3Harris Technologies, Inc. Sandbox based Internet isolation in a trusted network
US10554475B2 (en) 2017-06-29 2020-02-04 L3Harris Technologies, Inc. Sandbox based internet isolation in an untrusted network
US10397273B1 (en) 2017-08-03 2019-08-27 Amazon Technologies, Inc. Threat intelligence system
US10873589B2 (en) 2017-08-08 2020-12-22 Sonicwall Inc. Real-time prevention of malicious content via dynamic analysis
US10992642B2 (en) 2017-09-22 2021-04-27 L3 Technologies, Inc. Document isolation
US10931669B2 (en) 2017-09-28 2021-02-23 L3 Technologies, Inc. Endpoint protection and authentication
US11120125B2 (en) 2017-10-23 2021-09-14 L3 Technologies, Inc. Configurable internet isolation and security for laptops and similar devices

Patent Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130318594A1 (en) * 2011-01-27 2013-11-28 L-3 Communications Corporation Internet isolation for avoiding internet security threats
US9386021B1 (en) * 2011-05-25 2016-07-05 Bromium, Inc. Restricting network access to untrusted virtual machines
US20130145463A1 (en) * 2011-12-02 2013-06-06 Invincea, Inc. Methods and apparatus for control and detection of malicious content using a sandbox environment
US20170076092A1 (en) * 2012-07-03 2017-03-16 Bromium, Inc. Micro-virtual machine forensics and detection
US20140115646A1 (en) * 2012-10-18 2014-04-24 Broadcom Corporation Integration of Untrusted Applications and Frameworks with a Secure Operating System Environment
US20150156203A1 (en) * 2013-12-02 2015-06-04 At&T Intellectual Property I, L.P. Secure Browsing Via A Transparent Network Proxy
US8966464B1 (en) * 2014-03-21 2015-02-24 Amazon Technologies, Inc. Isolating tenants executing in multi-tenant software containers
US9531715B1 (en) * 2014-05-07 2016-12-27 Skyport Systems, Inc. Method and system for protecting credentials
US20160226834A1 (en) * 2015-01-29 2016-08-04 WebCloak, LLC Safechannel encrypted messaging system
US20180139178A1 (en) * 2015-12-24 2018-05-17 Huawei Technologies Co., Ltd. Method, Apparatus, and System for Detecting Terminal Security Status
US20170208067A1 (en) * 2016-01-14 2017-07-20 Avecto Limited Computer Device and Method for Controlling Access to a Web Resource
US20170353496A1 (en) * 2016-06-02 2017-12-07 Microsoft Technology Licensing, Llc Hardware-Based Virtualized Security Isolation
US20180198824A1 (en) * 2017-01-09 2018-07-12 Microsoft Technology Licensing, Llc Distribution and Management of Services in Virtual Environments
US20180276396A1 (en) * 2017-03-24 2018-09-27 AO Kaspersky Lab System and method of controlling access to content using an accessibility api

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10757009B2 (en) * 2018-11-20 2020-08-25 Amazon Technologies, Inc. Global-scale connectivity using scalable virtual traffic hubs
US11451467B2 (en) 2018-11-20 2022-09-20 Amazon Technologies, Inc. Global-scale connectivity using scalable virtual traffic hubs
US12212482B2 (en) 2018-11-20 2025-01-28 Amazon Technologies, Inc. Global-scale connectivity using scalable virtual traffic hubs
US11341234B1 (en) * 2019-06-05 2022-05-24 EMC IP Holding Company LLC System for securely recovering backup and data protection infrastructure
CN110311901A (en) * 2019-06-21 2019-10-08 南京尓嘉网络科技有限公司 A lightweight network sandbox setting method based on container technology
US11483339B1 (en) * 2019-11-27 2022-10-25 Pulse Secure, Llc Detecting attacks and quarantining malware infected devices
US11930036B2 (en) * 2019-11-27 2024-03-12 Pulse Secure, Llc Detecting attacks and quarantining malware infected devices
US11824773B2 (en) 2021-03-30 2023-11-21 Amazon Technologies, Inc. Dynamic routing for peered virtual routers
US12160366B2 (en) 2021-03-30 2024-12-03 Amazon Technologies, Inc. Multi-tenant offloaded protocol processing for virtual routers
US12021743B1 (en) 2023-03-27 2024-06-25 Amazon Technologies, Inc. Software-defined multi-network-segment gateways for scalable routing of traffic between customer-premise network segments and cloud-based virtual networks

Also Published As

Publication number Publication date
US11240207B2 (en) 2022-02-01

Similar Documents

Publication Publication Date Title
US11601467B2 (en) Service provider advanced threat protection
US11178104B2 (en) Network isolation with cloud networks
US10992642B2 (en) Document isolation
US11120125B2 (en) Configurable internet isolation and security for laptops and similar devices
US10931669B2 (en) Endpoint protection and authentication
US11240207B2 (en) Network isolation
US11170096B2 (en) Configurable internet isolation and security for mobile devices
US10554475B2 (en) Sandbox based internet isolation in an untrusted network
US11425097B2 (en) Cloud-based virtual private access systems and methods for application access
US10728246B2 (en) Service driven split tunneling of mobile network traffic
US11184323B2 (en) Threat isolation using a plurality of containers
US10558798B2 (en) Sandbox based Internet isolation in a trusted network
US11552987B2 (en) Systems and methods for command and control protection
US11550898B2 (en) Browser application implementing sandbox based internet isolation
US11349881B2 (en) Security-on-demand architecture
US11363022B2 (en) Use of DHCP for location information of a user device for automatic traffic forwarding
US11223601B2 (en) Network isolation for collaboration software
US9948675B2 (en) Identity-based internet protocol networking
US8875223B1 (en) Configuring and managing remote security devices
US20170063927A1 (en) User-Aware Datacenter Security Policies
US11044233B2 (en) Browser switching system and methods
US10171504B2 (en) Network access with dynamic authorization
EP3247082B1 (en) Cloud-based virtual private access systems and methods
US12328256B2 (en) Supporting overlapping network addresses universally
US11374906B2 (en) Data exfiltration system and methods

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS

AS Assignment

Owner name: L3 TECHNOLOGIES, INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:COLEMAN, GLENN;MARTZ, PETER;MORITZ, KENNETH;SIGNING DATES FROM 20180911 TO 20180914;REEL/FRAME:058403/0978

STPP Information on status: patent application and granting procedure in general

Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT RECEIVED

STPP Information on status: patent application and granting procedure in general

Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: CROGA INNOVATIONS LIMITED, IRELAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:L3HARRIS TECHNOLOGIES, INC.;EAGLE TECHNOLOGY;L3 TECHNOLOGIES, INC.;AND OTHERS;REEL/FRAME:066001/0843

Effective date: 20230914

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4