US20200403977A1 - One-click reputation adjustment - Google Patents
One-click reputation adjustment Download PDFInfo
- Publication number
- US20200403977A1 US20200403977A1 US16/993,660 US202016993660A US2020403977A1 US 20200403977 A1 US20200403977 A1 US 20200403977A1 US 202016993660 A US202016993660 A US 202016993660A US 2020403977 A1 US2020403977 A1 US 2020403977A1
- Authority
- US
- United States
- Prior art keywords
- dxl
- reputation
- network
- interface
- database
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
- 238000000034 method Methods 0.000 claims description 49
- 238000003860 storage Methods 0.000 claims description 35
- 230000006870 function Effects 0.000 claims description 7
- 238000010586 diagram Methods 0.000 description 28
- 230000006854 communication Effects 0.000 description 16
- 238000004891 communication Methods 0.000 description 16
- 230000004044 response Effects 0.000 description 15
- 238000007726 management method Methods 0.000 description 14
- 230000008569 process Effects 0.000 description 7
- 230000009471 action Effects 0.000 description 5
- 230000003044 adaptive effect Effects 0.000 description 5
- 238000004458 analytical method Methods 0.000 description 5
- 238000013461 design Methods 0.000 description 5
- 230000000694 effects Effects 0.000 description 5
- 239000004744 fabric Substances 0.000 description 5
- 238000012423 maintenance Methods 0.000 description 5
- 238000012545 processing Methods 0.000 description 5
- 230000008901 benefit Effects 0.000 description 4
- 230000004075 alteration Effects 0.000 description 3
- 230000002155 anti-virotic effect Effects 0.000 description 3
- 230000006399 behavior Effects 0.000 description 3
- 230000007613 environmental effect Effects 0.000 description 3
- 230000010354 integration Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 241000894007 species Species 0.000 description 3
- 238000006467 substitution reaction Methods 0.000 description 3
- 230000015572 biosynthetic process Effects 0.000 description 2
- 230000001413 cellular effect Effects 0.000 description 2
- 239000003795 chemical substances by application Substances 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000008878 coupling Effects 0.000 description 2
- 238000010168 coupling process Methods 0.000 description 2
- 238000005859 coupling reaction Methods 0.000 description 2
- 238000011156 evaluation Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 230000001360 synchronised effect Effects 0.000 description 2
- 238000003786 synthesis reaction Methods 0.000 description 2
- 230000005971 DNA damage repair Effects 0.000 description 1
- 102000002706 Discoidin Domain Receptors Human genes 0.000 description 1
- 108010043648 Discoidin Domain Receptors Proteins 0.000 description 1
- 244000035744 Hura crepitans Species 0.000 description 1
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical group [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 1
- 241000700605 Viruses Species 0.000 description 1
- 239000008186 active pharmaceutical agent Substances 0.000 description 1
- 230000002776 aggregation Effects 0.000 description 1
- 238000004220 aggregation Methods 0.000 description 1
- 239000003443 antiviral agent Substances 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 238000013475 authorization Methods 0.000 description 1
- 230000004888 barrier function Effects 0.000 description 1
- 230000007175 bidirectional communication Effects 0.000 description 1
- 239000000872 buffer Substances 0.000 description 1
- 239000003990 capacitor Substances 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 230000001010 compromised effect Effects 0.000 description 1
- 238000012790 confirmation Methods 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 235000014510 cooky Nutrition 0.000 description 1
- 230000006378 damage Effects 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 238000013079 data visualisation Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- ZXQYGBMAQZUVMI-GCMPRSNUSA-N gamma-cyhalothrin Chemical compound CC1(C)[C@@H](\C=C(/Cl)C(F)(F)F)[C@H]1C(=O)O[C@H](C#N)C1=CC=CC(OC=2C=CC=CC=2)=C1 ZXQYGBMAQZUVMI-GCMPRSNUSA-N 0.000 description 1
- 238000003306 harvesting Methods 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 230000002194 synthesizing effect Effects 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 230000003442 weekly effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0281—Proxies
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/57—Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/285—Clustering or classification
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1408—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic
- H04L63/1425—Traffic logging, e.g. anomaly detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/20—Network architectures or network communication protocols for network security for managing network security; network security policies in general
Definitions
- This application relates to the field of enterprise security, and more particularly to one-click reputation adjustment on a data exchange layer.
- An enterprise service bus is a software-based network architecture that provides a medium of data exchange over a service-oriented architecture.
- ESB is a special case of a client-server software architecture in which clients may route messages through the server.
- malware software, binaries, executables, advertising, web pages, documents, macros, executable objects, and other data provided to users (collectively “executable objects”) may include security flaws and privacy leaks that are subject to exploitation by malware.
- malicious software may include a virus, Trojan, zombie, rootkit, backdoor, worm, spyware, adware, ransomware, dialer, payload, malicious browser helper object, cookie, logger, or similar application or part of an application designed to take a potentially-unwanted action, including by way of non-limiting example data destruction, covert data collection, covert communication, browser hijacking, network proxy hijacking or redirection, covert tracking, data logging, keylogging, excessive or deliberate barriers to removal, contact harvesting, unwanted use of premium services, and unauthorized self-propagation.
- malware may also include legitimate software that includes inadvertent security flaws that cause or enable malware behavior.
- Malware behavior is defined as any behavior that qualifies an application as malware or grayware.
- executable objects In addition to executable objects, computing devices may encounter static objects, which are not intended to change the operating state of a computer. As a class, executable objects and static objects may be referred to simply as “objects.” An enterprise security concern is the classification of objects' malware status.
- FIG. 1 is a network diagram of a context-aware network with data exchange layer (DXL) capability according to one or more examples of the present specification.
- DXL data exchange layer
- FIG. 1A is an example where a domain controller is a joint threat intelligence (JTI) server according to one or more examples of the present specification.
- JTI joint threat intelligence
- FIG. 1B is a network diagram of select elements of a context-aware network according to one or more examples of the present specification.
- FIG. 2 is a network diagram disclosing a distributed architecture according to one or more examples of the present specification.
- FIG. 3 is a network diagram of an example DXL network operating across a traditional enterprise boundary according to one or more examples of the present specification.
- FIG. 4 is a network diagram of a context-aware network according to one or more examples of the present specification.
- FIG. 5 is a block diagram of a DXL broker according to one or more examples of the present specification.
- FIG. 6 is a block diagram of a common information model (CIM) server according to one or more examples of the present specification.
- CIM common information model
- FIG. 7 is a block diagram of a domain controller according to one or more examples of the present specification.
- FIG. 8 is a block diagram of a client according to one or more examples of the present specification.
- FIG. 9 is a flow diagram illustrating evaluation of an object in a hierarchical manner according to one or more examples of the present specification.
- FIG. 10 is a flow diagram of a method performed by a client according to one or more examples of the present specification.
- FIG. 10A is a flow diagram of a method performed by a JTI server in connection with the method of FIG. 10 according to one or more example embodiments of the present specification.
- FIG. 11 is a flow diagram of a method of a JTI server servicing a reputation request according to one or more examples of the present specification.
- FIG. 12 is a flow diagram of an enhancement to the method of FIG. 10A according to one or more examples of the present specification.
- FIG. 13 is a flowchart of a method performed by a DXL controller according to one or more examples of the present specification.
- FIG. 14 is a flowchart of a method performed by DXL endpoints responsive to receiving a published reputation update for an object according to one or more examples of the present specification.
- a security management console comprising: a hardware platform, comprising a processor, a memory, and a data exchange layer (DXL) interface, the DXL interface comprising a hardware network connection and a software layer, the software layer to provide a two-layer messaging bus, wherein a lower layer is an internet protocol (IP) network, and an upper layer is a publish-subscribe enterprise service bus (ESB); an interface to a reputation database, the reputation database including cached reputations for a plurality of network objects, the reputations representing the network objects' safety within an enterprise serviced by the DXL; and instructions encoded within the memory to instruct the processor to: provide a DXL security console graphical user interface (GUI), the GUI including instructions to provide a graphical representation of an object, including the object's default reputation retrieved from the reputation database; receive a user input to override the object's default reputation to a selected reputation; provide an instruction via the reputation database interface to update the object's default reputation in the database with the selected reputation
- GUI DXL security
- enterprises may face new and enhanced security challenges and malware threats. This creates a situation in which real-time exchange of threat intelligence between otherwise autonomous network elements is desirable. Increased sharing may improve security between devices that otherwise operate in their own security “silos.”
- the system and method of the present specification addresses such challenges by providing standardized data representations across data sources, and safeguarding the quality of data shared by disparate sources.
- Context-aware computing is a style of computing in which situational and environmental information about people, places and things is used to anticipate immediate needs and proactively offer enriched, situation-aware, and usable functions and experiences. Context-aware computing relies on capturing data about the world as it is at the moment the system is running.
- a “context-aware network” is an adaptive system, including for example a security system, of interconnected services that communicate and share information to make real-time, accurate decisions by individual products and/or as a collective.
- network, endpoint, database, application and other security solutions are no longer to operate as separate “silos” but as one synchronized, real-time, context-aware and adaptive, security system.
- DXL data exchange layer
- network elements include any type of client or server (e.g., a video server, a web server, etc.), routers, switches, gateways, bridges, load-balancers, firewalls, inline service nodes, proxies, network appliances, processors, modules, or any other suitable device, component, element, or object operable to exchange information in a network environment.
- DXL endpoints are network elements that interact over a DXL ESB. DXL endpoints may be distributed across a customer network and communicate in “real-time” in a trusted, secure, and reliable fashion. This may provide increased automation and improved security services.
- DXL endpoints are deployed at strategic locations within a network to intercept ongoing business activity, inspect and interpret it, and ultimately determine whether it is authorized, meaning for example that it is consistent with enterprise security policies.
- network elements make such decisions “in-band,” momentarily suspending the business activity, and in “machine-real-time,” at latencies low enough to avoid a significant user-perceptible delay in the business activity.
- network elements may have independent access to security data only by way of their own independent analysis and observation, and via scheduled definition updates, which may come, for example, on a weekly basis as updated malware definition.
- network elements are often heterogeneous and may be deployed, particularly in a modern network, in a temporary or ad hoc fashion, real-time intelligence becomes a challenge, particularly when “in-band” decisions are necessary.
- an enterprise may procure security solutions in a piecemeal fashion, so that one product cannot always assume the presence of another product.
- Representation and interpretation of data offer yet another challenge.
- Network elements may use disparate, proprietary data representations.
- an antivirus scanner may not be configured to share newly-discovered malware information with a network-based security device. Trustworthiness of information may be yet another challenge in other contexts. In other words, even if an antivirus scanner and network-based security device are configured to share security intelligence, each may not have a means of validating intelligence received from the other.
- DXL data exchange layer
- ESB messaging-based communications infrastructure
- DXL may be one element of a larger security-connected framework, which is an adaptive system, such as a security system, of interconnected services that communicate and share information to make real-time, accurate security decisions by individual security products and/or as a collective.
- network, endpoint, database, application and other security solutions need not operate as separate ‘silos’ but as one synchronized, real-time, context-aware and adaptive security system.
- a real-time, bi-directional communications fabric for enabling real-time security management.
- certain existing messaging infrastructures are based on one-to-many communications (publish-subscribe).
- the publish-subscribe capabilities may be significantly enhanced, so that communication can be one-to-one (for example, peer-to-peer), or bi-directional (for example, query-response).
- the framework can scale to millions of concurrent connected clients, so that any connected client can reach any other connected client in real-time or near real-time regardless of the physical location of the connected clients.
- the DXL abstraction layer is provided between different types of connected clients, and acts as an intermediary communications medium.
- a DXL domain controller may combine and reconcile the client properties received from a plurality of sources into a single record of truth according to a common information model (CIM), containing a single value or values. This may include determining that a first data source is more trusted than a second data source, and using the data from the first data source, or otherwise reconciling a plurality of data into a single record.
- CIM common information model
- the reconciled data may be stored in a domain database, and a domain controller may publish the client properties on the DXL.
- a DXL broker may then forward the published message to DXL endpoints, which receives a singular and most accurate reconciled value.
- a client may send a DXL request over the DXL, inquiring about the properties of a DXL client.
- the DXL broker receives this request and automatically routes it to a domain controller.
- the domain controller retrieves the client properties from its domain database and sends a DXL response message, which the DXL broker receives and forwards to the DXL client.
- Note that while the “publish-subscribe” transactions in this example are one-to-many, one-to-one “request-response” transactions are natively provided on the same fabric.
- new or better data sources may be incorporated, by integrating them with domain controller 160 . This may be completely transparent to clients 120 and other DXL endpoints.
- Additional features of a DXL broker may include, by way of non-limiting example: service and location registries to lookup registered endpoints, available services, and their locations; publish/subscribe (1:N), request/response (1:1), device-to-device (1:1), and push notification messaging interfaces; optimized message passing between brokers; destination-aware message routing; and broker-to-broker failover.
- domain controllers need not be concerned with how each DXL endpoint treats a published message. Rather, that can be a matter of enterprise security policy.
- FIG. 1 is a network diagram of a context-aware network 100 with DXL capability.
- a plurality of clients 120 are connected to a DXL enterprise service bus (ESB) 130 .
- DXL ESB 130 is an example of a DXL fabric, and may be provided on top of an existing network, such as a local area network (LAN).
- LAN local area network
- Client 120 may be any suitable computing device, including by way of non-limiting example a computer, a personal digital assistant (PDA), a laptop or electronic notebook, a cellular telephone, an internet protocol (IP) telephone, an iPhoneTM, an iPadTM, a Microsoft SurfaceTM, an AndroidTM phone, a Google NexusTM, or any other device, component, element, or object capable of initiating voice, audio, or data exchanges within a communication system, including a suitable interface to an end user, such as a microphone, a display, or a keyboard or other terminal equipment.
- client 120 - 1 is an embedded device, such as a network security sensor.
- Client 120 - 2 is a virtual machine.
- Client 120 - 3 is a laptop or notebook computer.
- Client 120 - 4 is a desktop computer.
- DXL ESB 130 may be any type of physical or virtual network connection over which appropriate data may pass. At present, there is no fixed or global standard for an ESB, and the term, as used herein, is intended broadly to encompass any network technology or topology suitable for message exchange.
- message queuing telemetry transport (MQTT) messages are exchanged on port 8883 .
- clients 120 , DXL broker 110 , domain controller 160 , database 162 , JTI server ( FIG. 1A ), proxy 170 ( FIG. 1A ), and threat intelligence service 180 ( FIG. 1A ), all by way of non-limiting example, may be referred to as “network elements.”
- DXL endpoints Network elements configured to operate on or with DXL ESB 130 may be referred to as “DXL endpoints.” These may include, in an example, clients 120 , DXL broker 110 , and domain controller 160 .
- DXL broker 110 may be configured to provide DXL messaging services over DXL ESB 130 , such as maintaining DXL routing tables and delivering messages.
- DXL broker 110 provides DXL services 190 , which in an example are network services operable to provide DXL ESB 130 to DXL endpoints.
- Domain controller 160 may be configured to communicatively couple to DXL broker 130 . Domain controller 160 may maintain domain data in a database such as database 162 .
- database 162 may reside on a disk drive local to the domain controller 160 , or may be separately or remotely hosted.
- Database 162 is disclosed by way of example, and may be any suitable data store, including a structured or relational database, distributed database, or flat file by way of non-limiting example.
- a client such as laptop 120 - 3 connects to the LAN and receives a new IP address.
- several properties of laptop 120 - 3 become knowable to other network elements, including by way of non-limiting example, its IP address, information about its operating system, and the logged-on user's username. For ease of reference, these are referred to as “client properties” throughout this example.
- Client properties are embodiments of security-intelligence data, and are of interest to virtual machine 120 - 2 , which has previously subscribed the security-intelligence data topic with domain controller 160 .
- Client properties may be reported to the DXL simultaneously by two distinct sources, namely by laptop 120 - 3 , and by network security sensor 120 - 1 .
- network security sensor 120 - 1 may fail to report a username value. It may also report an OS value different from that reported by the laptop 120 - 3 . This may be, for example, because network security sensor 120 - 1 is sensing data remotely, and may not be able to determine these values as reliably as laptop 120 - 3 itself.
- Domain controller 160 is responsible for the “client system” data domain, which includes client properties.
- client system data domain
- client properties When laptop 120 - 3 and client 120 - 1 publish a message containing the client properties, both messages are first routed to DXL broker 110 .
- DXL broker 110 may then forward the client properties to domain controller 160 .
- Domain controller 160 may combine and reconcile the client properties received from the two sources into a single record of truth, containing a single value for IP address, operating system, and username respectively. Specifically, it may determine via its own logic and perhaps prior configuration that laptop 120 - 3 is trusted more for OS value than network security sensor 120 - 1 . Therefore, domain controller 160 may ignore the “operating system” value received from network security sensor 120 - 1 when it conflicts with laptop 120 - 3 .
- the reconciled client properties are persistently stored in domain database 162 .
- Domain controller 160 may then publish the client properties on DXL ESB 130 .
- DXL broker 110 may then forward the published message to virtual machine 120 - 2 , which receives a singular and most accurate value for client properties.
- client 120 - 4 may send a DXL request over DXL ESB 130 , inquiring about the client properties for laptop 120 - 3 .
- DXL broker 110 receives this request and automatically routes it to domain controller 160 .
- Domain controller 160 retrieves the client properties from domain database 162 and sends a DXL response message, which DXL broker 110 receives and forwards to client 120 - 4 .
- DXL may be characterized by messaging that allows loose integration or coupling of multiple network elements. Loose coupling may reduce the assumptions each DXL endpoint must make about other DXL endpoints, such as the presence of certain capabilities, hardware, or software.
- DXL is a ‘Plug-and-Play’ application program interface (API), and may facilitate context-aware and adaptive security by enabling context to be shared between products.
- API application program interface
- DXL is an elastic architecture with multiple deployment options and is highly scalable. DXL may also be designed with openness in mind and enable third-party integration.
- DXL ESB 130 may be based on a two-layer protocol.
- the “bottom” layer is a secure, reliable, low-latency data transport fabric that connects diverse security elements as a mesh, or in a hub-and-spoke configuration.
- the “top” layer is an extensible data exchange framework that is configured to facilitate trustworthy data representation.
- DXL endpoints connect to DXL ESB 130 .
- Each DXL endpoint is assigned a distinct identity, and authenticates itself to DXL ESB 130 upon startup, for example via a certificate or other secure token.
- DXL endpoints may establish one-to-one communications via DXL ESB 130 , for example by sending a DXL message addressed to a DXL endpoint with a specific identity. This enables DXL endpoints to communicate with each other without having to establish a point-to-point network connection. In an example, this is analogous to a person-to-person phone call.
- DXL may provide a publish-subscribe framework in which certain DXL endpoints “subscribe” to messages of a certain type. When a DXL endpoint “publishes” a message of that type on DXL ESB 130 , all subscribers may process the message, while non-subscribers may safely ignore it. In an example, this is analogous to a podcast subscription service.
- DXL may provide a request-response framework. In this case, one DXL endpoint may publish a request over DXL ESB 130 . An appropriate DXL endpoint receiving the request may provide a response.
- the response may be used by more than just the DXL endpoint that originally published the request.
- JTI server 150 may respond by publishing the reputation.
- other clients 120 that find instances of the object may benefit from the response.
- clients 120 may maintain a comprehensive cache of reputations published on the network. If a client 120 then newly encounters an object that is known on the network, client 120 already has an up-to-date reputation for the object.
- DXL ESB 130 may be implemented using diverse software elements, patterns, and constructs suited to the specific infrastructure connecting the security elements. For instance, in a physical enterprise network, messaging middleware consisting of multiple interconnected message brokers may be deployed, where endpoints connect to the closest broker. In a virtual network infrastructure, the fabric may leverage hypervisor provided channels.
- DXL ESB 130 may be configured to provide real-time, trusted exchange of data among otherwise-autonomous, dynamically-assembled DXL endpoints.
- DXL ESB 130 's conceptual framework may comprise two virtual components:
- domain controller 160 may establish first-hand trust relationships with data-provider endpoints. This enables it to gauge the quality (including accuracy and reliability) of data (such as reputation data) it receives from any particular source. When duplicate, piecemeal data is received from multiple (independent) sources, such as different clients 120 , domain controller 160 may reconcile the data and resolve conflicts to derive a single best-known record of truth (such as, for example, a reputation) for each object. This ensures that clients 120 receive consistent data.
- Domain controller 160 may also transform data into a well-understood, standardized representation. This representation may be published on DXL ESB 130 , so that all clients 120 receive usable data.
- DXL endpoints do not need to know what device originated data, or make point-to-point connections to other DXL endpoints, even when one-to-one communication is necessary. Rather, DXL client software or DXL extensions enable a DXL endpoint to use its own local APIs for querying and receiving data.
- DXL endpoints may cache received data locally, which data may be trusted until it is superseded by an authorized DXL message.
- clients 120 may subscribe to published reputations for objects. When an object reputation is received, either in response to a request-response transaction, or in a publish-subscribe model, client 120 may store the reputation in a local database.
- the reputation may be trusted until superseded, because DXL controller 160 is configured to publish a reputation update whenever it receives an updated reputation.
- DXL controller 160 is configured to publish a reputation update whenever it receives an updated reputation.
- DXL broker 110 provides a discovery and location service that informs DXL endpoints of the specific domain controller 160 to which data query and subscription requests should be routed.
- the example DXL architecture described herein is flexible. For example, individual data sources may connect and disconnect from the network without affecting data consumers. Domain controller 160 may simply rely on whatever data sources are available. Furthermore, the framework makes no assumptions about the physical location or specifically how domain controller 160 or domain endpoints are deployed or configured. So long as each network element provides valid DXL messaging, traffic is routed correctly.
- DXL controller 160 is a logical singleton, but it should be noted that DXL controller 160 may be implemented, for example, as a set of distributed service components, where each component services either a subset of the domain, or provides a local data replica of a service running elsewhere. Such configurations may enhance scale, performance, and reliability. This may also allow services to be transparently relocated.
- DXL framework is extensible. For example, data about new entities and relationships may be provided simply by creating new data domains. New attributes and relationships for existing data domains may be provided simply by defining new message types for that domain.
- domain controller 160 has responsibility over the domain of malware data.
- a namespace may be defined for each.
- the reputation domain may use the “MALWARE” namespace
- the network status domain may use the “STATUS” namespace
- the device maintenance domain may use the “MAINT” namespace.
- both the reputation domain and a device maintenance domain may have use for a message such as DOWNLOAD_UPDATES.
- this message may be an instruction to retrieve updated definitions from JTI server 150 .
- this may be an instruction to download operating system updates from a vendor.
- Clients 120 may be configured to exchange data from several DXL domains and may subscribe to messages on both the reputation domain and the device maintenance domain.
- client 120 - 1 may parse and respond to a DXL message DOWNLOAD_UPDATES by requesting bulk reputation updates.
- the message requesting malware updates may itself be a DXL message.
- delivery of the updates may be completed outside of the DXL architecture to reserve a DXL for lightweight, high-speed messaging.
- Client 120 may also know that it should parse and respond to MAINT: DOWNLOAD_ UPDATES by contacting a vendor's servers and requesting updates.
- domain controller 160 In the case where domain controller 160 is configured as the controller for the reputation domain, it may know to ignore all DXL messages that are not in the MALWARE namespace. Note, however, that a single physical device may be configured to act as a domain controller for multiple domains, in which case traffic in different namespaces may be passed to different subroutines.
- DXL broker 110 may be configured to synthesize reports from a plurality of DXL network devices such as clients 120 that are given lesser privileges, such as “suggest” privileges on DXL ESB 130 .
- new or better data sources may be incorporated, by integrating them with domain controller 160 . This may be completely transparent to clients 120 and other DXL endpoints.
- Additional features of a DXL broker 110 may include, by way of non-limiting example: service and location registries to lookup registered endpoints, available services, and their locations; publish/subscribe (1:N), request/response (1:1), device-to-device (1:1), and push notification messaging interfaces; optimized message passing between brokers; destination-aware message routing; and broker-to-broker failover.
- domain controller 160 need not be concerned with how each DXL endpoint treats a published message. Rather, that can be a matter of enterprise security policy.
- Additional DXL features for clients 120 may include, by way of non-limiting example: local message bus integration for an API to discover brokers, authenticate to DXL, and send and receive catalogued messages.
- context-aware network 100 may include, by way of non-limiting example: DXL broker and client provisioning and management of domain controller 160 ; policy-based authorization of endpoints onto DXL ESB 130 ; secure sockets layer (SSL)-based communications; proxy support for off-premises communications; and domain controller appliances pre-configured with DXL broker functionality (thus joining domain controller 160 and DXL broker 110 into one device).
- DXL broker and client provisioning and management of domain controller 160 policy-based authorization of endpoints onto DXL ESB 130 ; secure sockets layer (SSL)-based communications; proxy support for off-premises communications; and domain controller appliances pre-configured with DXL broker functionality (thus joining domain controller 160 and DXL broker 110 into one device).
- SSL secure sockets layer
- FIG. 1A is an example where domain controller 160 is a joint threat intelligence (JTI) server 150 , providing for example, object reputation services on the “reputation” domain according to one or more examples of the present specification.
- JTI server 150 may communicatively couple to DXL broker 110 .
- JTI server 150 may be a middleware appliance configured to provide reputation services, maintain metadata about network objects (such as reputation, prevalence, and intelligence, by way of non-limiting example), call out to external scanners for an object's reputation classification, and provide telemetry data to threat intelligence service 180 .
- JTI server 150 may communicate with a global threat intelligence service 180 via a proxy 170 , which may include either communication over DXL ESB 130 , or over a more traditional IP network.
- JTI server 150 in connection with threat intelligence service 180 , may provide crowd-sourced object reputations.
- JTI server 150 may also provide administrator overrides. These may include aggregation of administrator override policies from several enterprises, for whether an object should be run on a network and whether a certificate is considered “clean.” These may also include client-side results, such as an aggregate of end-user decisions of whether to allow or block an object.
- JTI server 150 may track prevalence data, including the prevalence of an object on context-aware network 100 .
- JTI server 150 may serve as a telemetry aggregator/proxy to gather and send to threat intelligence service 180 telemetry from endpoints that do not directly interact with threat intelligence service 180 .
- JTI server 150 may also contribute file metadata to threat intelligence service 180 , such as hashes, digital signature data, and file attributes.
- JTI server 150 may receive several such messages from different clients 120 , and in some cases, the messages may conflict with one another.
- domain controller 160 may publish a warning that the other clients should give additional scrutiny to the object, such as deep scanning or requesting user verification before executing the object. In other embodiments, domain controller 160 may provide such information in response to a request for an object reputation from a client 120 .
- JTI server 150 may then publish a higher-level, such as command-level, message identifying the object as malware. If JTI server 150 receives multiple conflicting reports from different clients, a synthesis algorithm may provide an appropriate action. For example, if one or a few clients are found to be outliers, reporting a status different from a large majority of other clients, the outliers may be discarded. This synthesis algorithm may also account for specific clients' past reputations for accurate reporting, or for a reputation assigned based on installed hardware or software.
- domain controller 160 is a JTI server 150
- this example illustrates the value of designating a hierarchy or other schema for assigning DXL endpoint privileges.
- clients 120 may have “suggest” privileges. This may mean, for example, that clients 120 may identify an object that they believe to be malware, and may either direct a specific message to JTI server 150 , or may publish a general message identifying the object as malware. Because clients have only “suggest” privileges on DXL ESB 130 , other DXL endpoints that subscribe to reputation updates may treat the identification as less authoritative than an identification from a DXL network element with elevated privileges such as “assign” privileges. Privileges, and especially elevated privileges such as “assign” privileges, may be authenticated by a secure certificate provided as part of a DXL message.
- FIG. 1B is a network diagram of select elements in a context-aware network 100 according to one or more examples of the present specification.
- an additional DXL broker 110 - 2 may be added to service endpoints 120 - 3 and 120 - 4 .
- DXL broker 110 - 2 may communicate with a second domain controller 160 - 2 , which may share domain database 162 with domain controller 160 - 1 .
- FIG. 2 is a network diagram disclosing a distributed architecture according to one or more examples of the present specification.
- DXL broker 110 - 1 may be designated as the “hub,” while DXL brokers 110 - 2 , 110 - 3 , 110 - 4 , and 110 - 5 may be designated as “spokes.” in an example, all DXL traffic that passes through a spoke will be forwarded to the hub, which will distribute the traffic to other spokes.
- Designation of a DXL broker 110 as the hub may be accomplished via any suitable means, such as selecting the hub based on MAC ID, IP address, or network proximity to domain controller 160 .
- DXL broker 110 - 1 If DXL broker 110 - 1 goes offline, another hub may be at least temporarily needed. In that case, another hub may be elected. When DXL broker 110 - 1 comes back online, it may resume its duties as a hub, or may act as a spoke, depending on network topology and design considerations.
- spokes may form a temporary mesh network upon connecting effectively to DXL broker 110 - 1 .
- DXL brokers 110 may be configured to operate full time in a mesh configuration.
- Additional extensibility may be provided by bridging DXL ESB 130 across disparate networks, enabling data to be exchanged over larger networks, including the internet.
- FIG. 3 is a network diagram of an example DXL network operating across a traditional enterprise boundary according to one or more examples of the present specification.
- first enterprise 302 includes a DXL broker 110 - 2 which communicatively couples to a domain controller 160 and enterprise switch controller (ESM) 330 .
- domain controller 160 and ESM 330 may be coupled over a traditional (non-DXL) network interface 312 .
- Domain controller 160 may connect to an IP Network 310 .
- IP Network 310 may be any communicative platform operable to exchange data or information emanating from endpoints, including by way of non-limiting example, an internet architecture providing end users with the ability to electronically interact, a plain old telephone system (POTS), which end users could use to perform transactions in which they may be assisted by human operators or in which they may manually key data into a telephone or other suitable electronic equipment, any packet data network (PDN) offering a communications interface or exchange between any two nodes in a system, or any local area network (LAN), metropolitan area network (MAN), wide area network (WAN), wireless local area network (WLAN), virtual private network (VPN), intranet, or any other appropriate architecture or system that facilitates communications in a network or telephonic environment.
- POTS plain old telephone system
- PDN packet data network
- LAN local area network
- MAN metropolitan area network
- WAN wide area network
- WLAN wireless local area network
- VPN virtual private network
- intranet or any other appropriate architecture or system that facilitates communications in a network or telephonic environment.
- Second enterprise 304 also includes a DXL broker 110 - 1 .
- DXL brokers 110 may communicate with each other over DXL ESB 130 .
- DXL ESB 130 is physically provided by IP Network 310 , but DXL traffic may be distinguished from other types of internet traffic such as http and other user-centric network traffic, for example because it is provided on a different port or protocol.
- DXL broker 110 - 1 may also be coupled, for example, to a network service provider (NSP) 340 , antivirus agent 350 , enterprise firewall 360 , and advanced threat detection appliance (ATD) 370 .
- NSP network service provider
- ATD advanced threat detection appliance
- ATD 370 may be a dedicated appliance, or a general-purpose computing machine running advanced detection software. In one example, ATD 370 is configured to analyze objects without existing reputations and to assign those objects threat levels based on the analysis.
- DXL ESB 130 may be used to integrate heterogeneous or otherwise unrelated network architectures, even across different enterprises.
- second enterprise 304 may be a third-party JTI service provider delivering ATD services to first enterprise 302 .
- FIG. 4 is a network diagram of a context-aware network 400 according to one or more examples of the present specification.
- context-aware network 400 is substantially similar to context-aware network 100 .
- context-aware network 400 domain controller 160 is a common information model (CIM) server 410 .
- CIM common information model
- CIM is open and extensible logical database schema designed to host different types of situational and environmental information.
- CIM may provide robust representation of new objects, building blocks, and data types.
- Core entities of CIM include, by way of non-limiting example, assets, identities, applications, and locations.
- CIM may provide many-to-many relationships and building blocks that drive multiple use cases.
- CIM may also support advanced data visualization.
- CIM scales massively and is open and extensible, allowing different product groups and third parties to develop new data extensions.
- a “location” represents a collection of network elements forming a logical location mapped into a physical location or a place.
- the location context can be used to, by way of non-limiting example, gather complete understanding with regards to the true scope and size of an organization (i.e. in the form of a network topology map).
- CIM may also maintain the global authoritative state of situational and environmental information by synthesizing contextual information shared by multiple data sources over DXL ESB 130 .
- FIG. 5 is a block diagram of a DXL broker according to one or more examples of the present specification.
- DXL broker 110 may be provided in a single physical computing device.
- DXL services 190 may be provided in a single physical computing device.
- JTI server 150 may be provided in a single physical computing device.
- DXL broker 110 is controlled by a processor 510 .
- Processor 510 may connect to other system elements via system bus 570 .
- Those other elements may include, by way of non-limiting example, a memory 520 , network interface 540 , and storage 550 .
- Processor 510 is configured to control DXL broker 110 , for example via executable software or firmware instructions.
- a “processor” as used herein includes any combination of hardware, software, or firmware providing programmable logic, including by way of non-limiting example a microprocessor, digital signal processor, field-programmable gate array, programmable logic array, application-specific integrated circuit, or virtual machine processor.
- Memory 520 may be a relatively low-latency volatile memory in some embodiments, and may include main memory, cache, on-chip memory, L1 memory, L2 memory, or similar. Note that in this embodiment, processor 510 is depicted in a direct memory access arrangement with memory 520 , but in other embodiments, memory 520 may communicate with processor 510 via system bus 570 , via some other bus, or via some other means. Furthermore, although memory 520 and storage 550 are depicted in this example as physically or conceptually separate devices, it should be appreciated that in some embodiments, memory 520 and storage 550 may share a physical device, which may or may not be divided into separate memory areas. Thus, it should be appreciated that the arrangement disclosed here is an example only, and not limiting. Rather, it is expressly intended that even where a memory and storage are spoken of separately, they may be embodied in a single physical or logical device unless expressly stated otherwise.
- network interface 540 provides a physical and logical interface to DXL ESB 130 , and includes any communication medium, whether analog, digital, or mixed-signal, that is configured to communicatively couple client 120 to other computing devices.
- Network interface 540 may include, by way of non-limiting example, a WiFi, Ethernet, Firewire, fiber optic, USB, serial interface, infrared, cellular network, digital PCS network, 2G data network, 3G data network, 4G WiMAX, or 4G LTE data network.
- network interface 540 may also provide a physical and logical interface to IP Network 310 .
- Storage 550 is disclosed as an example of a non-volatile memory medium, which may be a species of memory 520 .
- memory 520 and storage 550 may be separate devices, with memory 520 being a relatively low-latency volatile memory device, and storage 550 being a relatively high-latency non-volatile memory device.
- Storage 550 may also be another device, such as a hard drive, solid-state drive, external storage, redundant array of independent disks (RAID), network-attached storage, optical storage, tape drive, backup system, or any combination of the foregoing.
- RAID redundant array of independent disks
- Many other configurations are also possible, and are intended to be encompassed within the broad scope of this specification.
- memory 520 includes DXL broker 522 and DXL services software 526 .
- DXL broker 522 provides DXL broker services as described herein.
- DXL services software 526 may provide DXL client services or DXL broker 110 .
- DXL broker 110 may subscribe to certain types of messages in a client capacity.
- FIG. 6 is a block diagram of a CIM server 410 according to one or more examples of the present specification.
- CIM server 410 is controlled by a processor 610 .
- Processor 610 may connect to other system elements via system bus 670 .
- Those other elements may include, by way of non-limiting example, a memory 620 , network interface 640 , and storage 650 .
- Reference is made to corresponding elements in FIG. 5 which contains additional details and definitions.
- Memory 620 may include CIM server software 622 .
- CIM server software 622 may be configured to provide CIM services as described herein.
- Storage 650 may include a local object database 652 .
- Object database 652 may contain stored information about objects on the network, including, for example, reputations and metadata.
- FIG. 7 is a block diagram of a domain controller 160 according to one or more examples of the present specification.
- domain controller 160 is controlled by a processor 710 .
- Processor 710 may connect to other system elements via system bus 770 .
- Those other elements may include, by way of non-limiting example, a memory 720 , network interface 740 , and storage 750 .
- Reference is made to corresponding elements in FIG. 5 which contains additional details and definitions.
- memory 720 includes domain controller software 722 and DXL extension 724 .
- Domain controller software 722 may be configured to provide domain controller services as described herein.
- DXL extensions 724 may provide server extensions that allow domain controller 160 to operate on DXL ESB 130 .
- DXL extension 724 may include instructions that permit domain controller 160 to act as a DXL client in some situations.
- FIG. 8 is a block diagram of a client 120 according to one or more examples of the present specification.
- Client 120 is controlled by a processor 810 , which is communicatively coupled to a memory element 820 .
- processor 810 is communicatively coupled to other system elements via bus 870 .
- Those elements may include, by way of non-limiting example, a network interface 840 , storage 850 , which in some cases may be a species of memory element 820 , and a user interface 860 . It is expressly intended that any of the above elements can be realized in hardware, software, firmware, or any combination thereof.
- a user interface 860 may be provided to aid a user in interacting with client 120 .
- a “user interface” includes any combination of hardware, software, and firmware configured to enable a user to interact with client 120 , whether or not in real-time.
- user interface 860 may include, by way of non-limiting example, a keyboard (not shown), mouse (not shown), display monitor 842 , speaker 846 , microphone 844 , touch-sensitive display, which may act as a combined input/output device, and which may be a species of display 842 , and a camera 848 .
- User interface 860 may include software services such as a graphical user interface, including real-time dialog boxes that solicit input or confirmation from a user.
- memory 820 has stored therein executable instructions operable to provide software services, which may be contained in several distinct modules.
- a DXL client 826 may provide software services for interacting with DXL ESB 130 , and may include, for example, certificates authenticating client 120 on DXL ESB 130 , subroutines for publishing messages, and subroutines for parsing subscribed incoming messages.
- CIM client 822 may provide CIM services as described with more particularity in relation to FIG. 4 .
- CIM client 822 may also maintain a comprehensive catalog of objects 852 , including for example a comprehensive catalog of installed applications.
- JTI client 824 may provide JTI client services, such as local reputation management and interactions with JTI server 150 .
- Client 120 may also have a separate antimalware agent 828 , which may provide antivirus and other antimalware services. In some cases, antimalware agent 828 is integrated with JTI client 824 .
- FIG. 9 is a flow diagram illustrating evaluation of an object in a hierarchical manner according to one or more examples of the present specification.
- policies on the left are designated as “block,” and deterministically block an object, while policies on the right are designated as “allow,” and deterministically allow an object.
- policies on the right are designated as “allow,” and deterministically allow an object.
- the policies of FIG. 9 are disclosed as a fixed hierarchy. However, this is not intended to be limiting. For example, in other embodiments, policies may be weighted, or serviced in a round-robin fashion. Furthermore, in embodiments where a hierarchy is used, this particular hierarchy is not required.
- an administrator which may be either or both of a human operator or a device with administrative credentials, may assign a “block” override to the object, which may be identified by a hash.
- the administrator may provide an “allow” override to an object identified by a hash.
- an administrator may assign a block to override to an object identified by a certificate.
- an administrator may assign an allow overwrite to an object identified by a certificate.
- threat intelligence service 180 may assign a block status based on a certificate.
- threat intelligence service 180 may assign an object allow status based on a certificate.
- threat intelligence service 180 may assign an object block status base on a hash.
- threat intelligence service 180 may assign an object allow status based on a hash.
- malware definitions may identify an object as block, while in block 952 , malware definitions may identify the object as allow.
- JTI rules may assume that the object is dirty. In block 962 , JTI rules may assume that the object is clean.
- JTI client 824 may prompt an end user, via user interface 860 , to confirm executing or opening an object. If the user declines, then in block 970 the object is blocked. If the user confirms, then in block 972 the object is allowed.
- a decision to either block or allow the object depends on JTI policies and algorithms. This may include requesting a reputation for the object.
- FIG. 10 is a flow diagram of a method performed by a client 120 according to one or more examples of the present specification.
- client 120 opens a new object. This may be, for example, because a user interacts with the object, or because an automated process interacts with the object.
- client 120 checks to see if the object has a cached reputation in its local reputation database. If the object has an existing reputation, then in block 1030 , client 120 may make a decision to either block or allow the object. In some examples, client 120 may publish the block or allowed decision over DXL ESB 130 . This allows other DXL network objects that have subscribed to such updates to receive and integrate the decision.
- client 120 may request a reputation from JTI server 150 .
- client 120 may receive reputation data from JTI server 150 , whereupon control passes to block 130 . As shown by the looping arrow back to 1010 , this process may be repeated for each new object.
- FIG. 10A is a flow diagram of a method performed by JTI server 150 in connection with the method of FIG. 10 according to one or more example embodiments of the present specification.
- JTI server 150 receives a reputation request from client 120 .
- JTI server 150 may query its local database to find whether the object is already known. If the object is known, then in block 1070 , JTI server 150 may update its local threat intelligence database. This may include, for example, noting the circumstances of the request from client 120 .
- JTI server 150 may return the reputation data to client 120 .
- the method is complete.
- JTI server 150 may request information from the threat intelligence service 180 .
- JTI server 150 receives threat intelligence data from threat intelligence service 180 , and in block 1070 updates its local JTI database with the received intelligence.
- the intelligence is returned to client 120 , and in block 1090 the process is done.
- Block 1034 represents an alternate entry point into the method.
- a JTI server 150 receives a published decision block, for example, a decision to be published by client 120 according to the method of FIG. 10 .
- JTI server 150 may subscribe to published block/allow decisions, and in block 1070 may use a publish decision to update its local database. In this case, control passes directly from block 1080 to block 1090 .
- FIG. 11 is a flow diagram of a method of a JTI server 150 servicing a reputation request according to one or more examples of the present specification.
- the method of FIG. 11 may be performed in connection with block 1080 of FIG. 10A .
- an administrator may enter allow or block overrides, for example as disclosed in connection with FIG. 9 .
- Block 1040 corresponds to block 1040 of FIG. 10A , in which the JTI server 150 receives a reputation request from client 120 .
- JTI server 150 checks to see whether the administrator has entered an override, such as an enterprise-wide override. In particular, an override may remove the decision of whether to allow or block the object.
- an override such as an enterprise-wide override. In particular, an override may remove the decision of whether to allow or block the object.
- JTI server 150 returns the override to client 120 .
- JTI server 150 returns the reputation for client 120 to act on.
- FIG. 12 is a flow diagram of an enhancement to the method of FIG. 10A according to one or more examples of the present specification. Blocks in FIG. 12 with numbering identical to the corresponding blocks in FIG. 10A may be identical in function to the blocks disclosed in FIG. 10A .
- New block 1210 queries whether threat intelligence is available from threat intelligence service 180 . If threat intelligence is available, then in block 1052 , JTI server 150 receives the threat intelligence as illustrated in FIG. 10A . In block 1220 , if no threat intelligence is available, then JTI server 150 may send the object to ATD 370 for analysis. Rather than respond directly to the request, ATD 370 may publish reputation data for the object once it has completed its analysis. In block 1230 , JTI server 150 may subscribe to published reputation data messages, and thus may receive the DXL message published by ATD 370 . The remainder of the method may be unchanged.
- the DXL of the present specification may be used to provide monolithic reputation updates in a distributed environment.
- providing reputation updates to a plurality of endpoints may be complicated because some endpoints may have different data requirements from other endpoints.
- updating the reputation for a single object may include formatting data about the object into a plurality of formats, and distributing the data over a plurality of protocols.
- FIG. 13 is a flowchart of a method performed by DXL controller 160 according to one or more examples of the present specification.
- an administrator, service, or other authority may define reputation classifiers for context aware network 100 . This may include, for example, defining one or more classes of objects. Objects may include, by way of non-limiting example, files, certificates, URLs, identities, computer systems, servers, mobile devices, and other objects that may compromise or be compromised by an attacker.
- Reputation classes may define an object as trusted, malware, grayware, or in general, completely allow, completely block, or anything in between. Reputation classes may also carry information about actions to be taken in response to classifiers.
- endpoints may be required to take a responsive action, such as quarantine, block, delete, sandbox, deny permissions (e.g., if the object is identified as grayware), remedy, prompt, or custom action.
- a responsive action such as quarantine, block, delete, sandbox, deny permissions (e.g., if the object is identified as grayware), remedy, prompt, or custom action.
- network policies may provide a unitary specification for handling objects of given reputation classes, the specific implementation of the specification may vary between devices.
- DXL controller 160 may receive registrations or subscriptions from a plurality of endpoints subject to the unitary specification or object classification scheme. These may be, for example, in the form of endpoints subscribing to a topic designated for handling object reputation updates.
- DXL controller 160 may receive an updated reputation for an object. This may come, for example, from JTI server 150 , from analysis of the object, from ATD 370 , or from any other suitable reputation source.
- DXL controller 160 may publish on DXL ESB 130 a reputation update for the object. This updated reputation may be received by all endpoints that subscribe to the topic.
- the method is done, meaning that from the perspective of domain controller 160 , all relevant objects have been successfully updated absent notice to the contrary.
- FIG. 14 is a flowchart of a method performed by DXL endpoints responsive to receiving a published reputation update for an object according to one or more examples of the present specification.
- FIG. 14 refers to a client 120 , although it should be noted that any suitable endpoint may perform this method, and in particular, any endpoint acting as a reputation consumer.
- client 120 registers or subscribes to the reputation update topic.
- client 120 receives the published object reputation update, and recognizes it as a valid message.
- client 120 may process the updated reputation according to local protocols for client 120 .
- the unitary specification may require endpoints to restrict access to certain system services such as short messaging service (SMS). That policy may not be relevant for certain desktop computer systems that do not implement SMS, while it may be highly relevant for smartphones that provide SMS services. Thus, while the policy specification is unitary and global, individual implementations may vary according to endpoint needs.
- SMS short messaging service
- designating an object or set of objects, such as a set of files and or certificates, as good or bad can be achieved via a single click within a security management console by leveraging persistent client-initiated connections to DXL ESB 130 to enable real time communication of the reputation updates across the customer's environment, including systems potentially unreachable by DXL controller 160 , such as those behind a firewall or NAT.
- SOC system on chip
- CPU central processing unit
- An SOC represents an integrated circuit (IC) that integrates components of a computer or other electronic system into a single chip. It may contain digital, analog, mixed-signal, and radio frequency functions: all of which may be provided on a single chip substrate.
- Other embodiments may include a multi-chip-module (MCM), with a plurality of chips located within a single electronic package and configured to interact closely with each other through the electronic package.
- MCM multi-chip-module
- the digital signal processing functionalities may be implemented in one or more silicon cores in Application Specific Integrated Circuits (ASICs), Field Programmable Gate Arrays (FPGAs), and other semiconductor chips.
- ASICs Application Specific Integrated Circuits
- FPGAs Field Programmable Gate Arrays
- processing activities outlined herein may also be implemented in software.
- one or more of these features may be implemented in hardware provided external to the elements of the disclosed FIGUREs, or consolidated in any appropriate manner to achieve the intended functionality.
- the various components may include software (or reciprocating software) that can coordinate in order to achieve the operations as outlined herein.
- these elements may include any suitable algorithms, hardware, software, components, modules, interfaces, or objects that facilitate the operations thereof.
- Any suitably-configured processor component can execute any type of instructions associated with the data to achieve the operations detailed herein.
- Any processor disclosed herein could transform an element or an article (for example, data) from one state or thing to another state or thing.
- some activities outlined herein may be implemented with fixed logic or programmable logic (for example, software and/or computer instructions executed by a processor) and the elements identified herein could be some type of a programmable processor, programmable digital logic (for example, a field programmable gate array (FPGA), an erasable programmable read only memory (EPROM), an electrically erasable programmable read only memory (EEPROM)), an ASIC that includes digital logic, software, code, electronic instructions, flash memory, optical disks, CD-ROMs, DVD ROMs, magnetic or optical cards, other types of machine-readable mediums suitable for storing electronic instructions, or any suitable combination thereof.
- FPGA field programmable gate array
- EPROM erasable programmable read only memory
- EEPROM electrically
- processors may store information in any suitable type of non-transitory storage medium (for example, random access memory (RAM), read only memory (ROM), field programmable gate array (FPGA), erasable programmable read only memory (EPROM), electrically erasable programmable ROM (EEPROM), etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs.
- RAM random access memory
- ROM read only memory
- FPGA field programmable gate array
- EPROM erasable programmable read only memory
- EEPROM electrically erasable programmable ROM
- any of the memory items discussed herein should be construed as being encompassed within the broad term ‘memory.’
- any of the potential processing elements, modules, and machines described herein should be construed as being encompassed within the broad term ‘microprocessor’ or ‘processor.’
- Computer program logic implementing all or part of the functionality described herein is embodied in various forms, including, but in no way limited to, a source code form, a computer executable form, and various intermediate forms (for example, forms generated by an assembler, compiler, linker, or locator).
- source code includes a series of computer program instructions implemented in various programming languages, such as an object code, an assembly language, or a high-level language such as OpenCL, Fortran, C, C++, JAVA, or HTML for use with various operating systems or operating environments.
- the source code may define and use various data structures and communication messages.
- the source code may be in a computer executable form (e.g., via an interpreter), or the source code may be converted (e.g., via a translator, assembler, or compiler) into a computer executable form.
- the capacitors, buffers, graphics elements, interconnect boards, clocks, DDRs, camera sensors, dividers, inductors, resistors, amplifiers, switches, digital core, transistors, and/or other components can readily be replaced, substituted, or otherwise modified in order to accommodate particular circuitry needs.
- the use of complementary electronic devices, hardware, non-transitory software, etc. offer an equally viable option for implementing the teachings of the present disclosure.
- any number of electrical circuits of the FIGURES may be implemented on a board of an associated electronic device.
- the board can be a general circuit board that can hold various components of the internal electronic system of the electronic device and, further, provide connectors for other peripherals. More specifically, the board can provide the electrical connections by which the other components of the system can communicate electrically.
- Any suitable processors (inclusive of digital signal processors, microprocessors, supporting chipsets, etc.), memory elements, etc. can be suitably coupled to the board based on particular configuration needs, processing demands, computer designs, etc.
- Other components such as external storage, additional sensors, controllers for audio/video display, and peripheral devices may be attached to the board as plug-in cards, via cables, or integrated into the board itself.
- the electrical circuits of the FIGURES may be implemented as stand-alone modules (e.g., a device with associated components and circuitry configured to perform a specific application or function) or implemented as plug-in modules into application specific hardware of electronic devices.
- a security management console comprising: a hardware platform, comprising a processor, a memory, and a data exchange layer (DXL) interface, the DXL interface comprising a hardware network connection and a software layer, the software layer to provide a two-layer messaging bus, wherein a lower layer is an internet protocol (IP) network, and an upper layer is a publish-subscribe enterprise service bus (ESB); an interface to a reputation database, the reputation database including cached reputations for a plurality of network objects, the reputations representing the network objects' safety within an enterprise serviced by the DXL; and instructions encoded within the memory to instruct the processor to: provide a DXL security console graphical user interface (GUI), the GUI including instructions to provide a graphical representation of an object, including the object's default reputation retrieved from the reputation database; receive a user input to override the object's default reputation to a selected reputation; provide an instruction via the reputation database interface to update the object's default reputation in the database with the selected reputation;
- GUI DXL
- publishing the DXL message comprises sending the message to a DXL broker with a DXL header including the DXL topic.
- DXL data exchange layer
- ESD publish-subscribe enterprise service bus
- IP internet protocol
- API application programming interface
- publishing the override reputation comprises sending the message to a DXL broker with a DXL header including a DXL topic.
- a computer-implemented method of providing a one-click reputation update of an object via a data exchange layer comprising: establishing a logical connection with the DXL, comprising overlaying a publish-subscribe enterprise service bus (ESB) onto an internet protocol (IP) network; receiving an identifier for a DXL object; receiving a default reputation for the DXL object; receiving via a software interface an override reputation for the object; and publishing a DXL message comprising the override reputation for the object.
- DXL data exchange layer
- receiving the default reputation comprises receiving the default reputation from a database.
- receiving the default reputation from the database comprises receiving the default reputation via a DXL message.
- the software interface is an application programming interface (API) for providing DXL administration functions.
- API application programming interface
- publishing the override reputation comprises sending the message to a DXL broker with a DXL header including a DXL topic.
- the means for performing the method comprise a processor and a memory.
- the memory comprises machine-readable instructions that, when executed, cause the apparatus to perform the method of a number of the above examples.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- Databases & Information Systems (AREA)
- Computing Systems (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Mining & Analysis (AREA)
- Computer And Data Communications (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
Description
- This application claims priority to U.S. patent application Ser. No. 14/913,394, entitled “One-Click Reputation Adjustment,” filed 22 Feb. 2016, which application claims priority to PCT International Application Serial No. PCT/US2013/076908, filed on 20 Dec. 2013 and entitled “One-Click Reputation Adjustment”, which application claims priority to U.S. Provisional Application 61/884,090, also entitled “One-Click Reputation Adjustment,” filed 29 Sep. 2013. Both are incorporated herein by reference.
- This application relates to the field of enterprise security, and more particularly to one-click reputation adjustment on a data exchange layer.
- An enterprise service bus (ESB) is a software-based network architecture that provides a medium of data exchange over a service-oriented architecture. In some embodiments, ESB is a special case of a client-server software architecture in which clients may route messages through the server.
- Software, binaries, executables, advertising, web pages, documents, macros, executable objects, and other data provided to users (collectively “executable objects”) may include security flaws and privacy leaks that are subject to exploitation by malware. As used throughout this specification, malicious software (“malware”) may include a virus, Trojan, zombie, rootkit, backdoor, worm, spyware, adware, ransomware, dialer, payload, malicious browser helper object, cookie, logger, or similar application or part of an application designed to take a potentially-unwanted action, including by way of non-limiting example data destruction, covert data collection, covert communication, browser hijacking, network proxy hijacking or redirection, covert tracking, data logging, keylogging, excessive or deliberate barriers to removal, contact harvesting, unwanted use of premium services, and unauthorized self-propagation. In some cases, malware may also include legitimate software that includes inadvertent security flaws that cause or enable malware behavior. “Malware behavior” is defined as any behavior that qualifies an application as malware or grayware. Some prior art systems are configured to identify and block malware, for example by maintaining databases of known malware.
- In addition to executable objects, computing devices may encounter static objects, which are not intended to change the operating state of a computer. As a class, executable objects and static objects may be referred to simply as “objects.” An enterprise security concern is the classification of objects' malware status.
- The present disclosure is best understood from the following detailed description when read with the accompanying FIGURES. It is emphasized that, in accordance with the standard practice in the industry, various features are not drawn to scale and are used for illustration purposes only. In fact, the dimensions of the various features may be arbitrarily increased or reduced for clarity of discussion.
-
FIG. 1 is a network diagram of a context-aware network with data exchange layer (DXL) capability according to one or more examples of the present specification. -
FIG. 1A is an example where a domain controller is a joint threat intelligence (JTI) server according to one or more examples of the present specification. -
FIG. 1B is a network diagram of select elements of a context-aware network according to one or more examples of the present specification. -
FIG. 2 is a network diagram disclosing a distributed architecture according to one or more examples of the present specification. -
FIG. 3 is a network diagram of an example DXL network operating across a traditional enterprise boundary according to one or more examples of the present specification. -
FIG. 4 is a network diagram of a context-aware network according to one or more examples of the present specification. -
FIG. 5 is a block diagram of a DXL broker according to one or more examples of the present specification. -
FIG. 6 is a block diagram of a common information model (CIM) server according to one or more examples of the present specification. -
FIG. 7 is a block diagram of a domain controller according to one or more examples of the present specification. -
FIG. 8 is a block diagram of a client according to one or more examples of the present specification. -
FIG. 9 is a flow diagram illustrating evaluation of an object in a hierarchical manner according to one or more examples of the present specification. -
FIG. 10 is a flow diagram of a method performed by a client according to one or more examples of the present specification. -
FIG. 10A is a flow diagram of a method performed by a JTI server in connection with the method ofFIG. 10 according to one or more example embodiments of the present specification. -
FIG. 11 is a flow diagram of a method of a JTI server servicing a reputation request according to one or more examples of the present specification. -
FIG. 12 is a flow diagram of an enhancement to the method ofFIG. 10A according to one or more examples of the present specification. -
FIG. 13 is a flowchart of a method performed by a DXL controller according to one or more examples of the present specification. -
FIG. 14 is a flowchart of a method performed by DXL endpoints responsive to receiving a published reputation update for an object according to one or more examples of the present specification. - In an example, there is disclosed a security management console, comprising: a hardware platform, comprising a processor, a memory, and a data exchange layer (DXL) interface, the DXL interface comprising a hardware network connection and a software layer, the software layer to provide a two-layer messaging bus, wherein a lower layer is an internet protocol (IP) network, and an upper layer is a publish-subscribe enterprise service bus (ESB); an interface to a reputation database, the reputation database including cached reputations for a plurality of network objects, the reputations representing the network objects' safety within an enterprise serviced by the DXL; and instructions encoded within the memory to instruct the processor to: provide a DXL security console graphical user interface (GUI), the GUI including instructions to provide a graphical representation of an object, including the object's default reputation retrieved from the reputation database; receive a user input to override the object's default reputation to a selected reputation; provide an instruction via the reputation database interface to update the object's default reputation in the database with the selected reputation; and publish a DXL message to a DXL topic associated with the object, the DXL message including the selected reputation.
- The following disclosure provides many different embodiments, or examples, for implementing different features of the present disclosure. Specific examples of components and arrangements are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to be limiting. Further, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed.
- Different embodiments many have different advantages, and no particular advantage is necessarily required of any embodiment.
- In an increasingly heterogeneous software ecosystem, enterprises may face new and enhanced security challenges and malware threats. This creates a situation in which real-time exchange of threat intelligence between otherwise autonomous network elements is desirable. Increased sharing may improve security between devices that otherwise operate in their own security “silos.”
- The system and method of the present specification addresses such challenges by providing standardized data representations across data sources, and safeguarding the quality of data shared by disparate sources.
- Context-aware computing (CAC) is a style of computing in which situational and environmental information about people, places and things is used to anticipate immediate needs and proactively offer enriched, situation-aware, and usable functions and experiences. Context-aware computing relies on capturing data about the world as it is at the moment the system is running.
- According to one or more examples of the present specification, a “context-aware network” is an adaptive system, including for example a security system, of interconnected services that communicate and share information to make real-time, accurate decisions by individual products and/or as a collective. According to an example, network, endpoint, database, application and other security solutions are no longer to operate as separate “silos” but as one synchronized, real-time, context-aware and adaptive, security system.
- In an example, multiple network elements are connected to one another via a data exchange layer (DXL), which is a type of ESB that is suitable for exchange of security-related messages among other things. As used herein, “network elements” include any type of client or server (e.g., a video server, a web server, etc.), routers, switches, gateways, bridges, load-balancers, firewalls, inline service nodes, proxies, network appliances, processors, modules, or any other suitable device, component, element, or object operable to exchange information in a network environment. More specifically, DXL endpoints are network elements that interact over a DXL ESB. DXL endpoints may be distributed across a customer network and communicate in “real-time” in a trusted, secure, and reliable fashion. This may provide increased automation and improved security services.
- In an example, DXL endpoints are deployed at strategic locations within a network to intercept ongoing business activity, inspect and interpret it, and ultimately determine whether it is authorized, meaning for example that it is consistent with enterprise security policies. In some cases, network elements make such decisions “in-band,” momentarily suspending the business activity, and in “machine-real-time,” at latencies low enough to avoid a significant user-perceptible delay in the business activity.
- In some cases, network elements may have independent access to security data only by way of their own independent analysis and observation, and via scheduled definition updates, which may come, for example, on a weekly basis as updated malware definition.
- Because network elements are often heterogeneous and may be deployed, particularly in a modern network, in a temporary or ad hoc fashion, real-time intelligence becomes a challenge, particularly when “in-band” decisions are necessary. Furthermore, an enterprise may procure security solutions in a piecemeal fashion, so that one product cannot always assume the presence of another product. For example, there may not be a single, pre-defined repository of threat intelligence for network elements to consult, and regular malware definition updates may not include lately discovered threats. Representation and interpretation of data offer yet another challenge. Network elements may use disparate, proprietary data representations. Thus, for example, even an antivirus scanner may not be configured to share newly-discovered malware information with a network-based security device. Trustworthiness of information may be yet another challenge in other contexts. In other words, even if an antivirus scanner and network-based security device are configured to share security intelligence, each may not have a means of validating intelligence received from the other.
- In an example, the present specification provides a data exchange layer (DXL), which may operate on a lightweight messaging-based communications infrastructure such as ESB and be configured to allow endpoints to share contextual data. DXL may be one element of a larger security-connected framework, which is an adaptive system, such as a security system, of interconnected services that communicate and share information to make real-time, accurate security decisions by individual security products and/or as a collective. According to an example, network, endpoint, database, application and other security solutions need not operate as separate ‘silos’ but as one synchronized, real-time, context-aware and adaptive security system.
- In an example of a security-connected framework, a real-time, bi-directional communications fabric is provided for enabling real-time security management. Specifically, certain existing messaging infrastructures are based on one-to-many communications (publish-subscribe). The publish-subscribe capabilities may be significantly enhanced, so that communication can be one-to-one (for example, peer-to-peer), or bi-directional (for example, query-response). Advantageously, the framework can scale to millions of concurrent connected clients, so that any connected client can reach any other connected client in real-time or near real-time regardless of the physical location of the connected clients. To this end, the DXL abstraction layer is provided between different types of connected clients, and acts as an intermediary communications medium.
- A DXL domain controller may combine and reconcile the client properties received from a plurality of sources into a single record of truth according to a common information model (CIM), containing a single value or values. This may include determining that a first data source is more trusted than a second data source, and using the data from the first data source, or otherwise reconciling a plurality of data into a single record.
- The reconciled data may be stored in a domain database, and a domain controller may publish the client properties on the DXL. A DXL broker may then forward the published message to DXL endpoints, which receives a singular and most accurate reconciled value. Subsequently, a client may send a DXL request over the DXL, inquiring about the properties of a DXL client. The DXL broker receives this request and automatically routes it to a domain controller. The domain controller retrieves the client properties from its domain database and sends a DXL response message, which the DXL broker receives and forwards to the DXL client. Note that while the “publish-subscribe” transactions in this example are one-to-many, one-to-one “request-response” transactions are natively provided on the same fabric.
- Further adding to extensibility, new or better data sources may be incorporated, by integrating them with
domain controller 160. This may be completely transparent to clients 120 and other DXL endpoints. - Additional features of a DXL broker may include, by way of non-limiting example: service and location registries to lookup registered endpoints, available services, and their locations; publish/subscribe (1:N), request/response (1:1), device-to-device (1:1), and push notification messaging interfaces; optimized message passing between brokers; destination-aware message routing; and broker-to-broker failover.
- Advantageously, domain controllers need not be concerned with how each DXL endpoint treats a published message. Rather, that can be a matter of enterprise security policy.
-
FIG. 1 is a network diagram of a context-aware network 100 with DXL capability. According to this example, a plurality of clients 120 are connected to a DXL enterprise service bus (ESB) 130.DXL ESB 130 is an example of a DXL fabric, and may be provided on top of an existing network, such as a local area network (LAN). Client 120 may be any suitable computing device, including by way of non-limiting example a computer, a personal digital assistant (PDA), a laptop or electronic notebook, a cellular telephone, an internet protocol (IP) telephone, an iPhone™, an iPad™, a Microsoft Surface™, an Android™ phone, a Google Nexus™, or any other device, component, element, or object capable of initiating voice, audio, or data exchanges within a communication system, including a suitable interface to an end user, such as a microphone, a display, or a keyboard or other terminal equipment. In the example ofFIG. 1 , client 120-1 is an embedded device, such as a network security sensor. Client 120-2 is a virtual machine. Client 120-3 is a laptop or notebook computer. Client 120-4 is a desktop computer. -
DXL ESB 130 may be any type of physical or virtual network connection over which appropriate data may pass. At present, there is no fixed or global standard for an ESB, and the term, as used herein, is intended broadly to encompass any network technology or topology suitable for message exchange. In one embodiment, message queuing telemetry transport (MQTT) messages are exchanged on port 8883. In some cases, clients 120,DXL broker 110,domain controller 160,database 162, JTI server (FIG. 1A ), proxy 170 (FIG. 1A ), and threat intelligence service 180 (FIG. 1A ), all by way of non-limiting example, may be referred to as “network elements.” - Network elements configured to operate on or with
DXL ESB 130 may be referred to as “DXL endpoints.” These may include, in an example, clients 120,DXL broker 110, anddomain controller 160. -
DXL broker 110 may be configured to provide DXL messaging services overDXL ESB 130, such as maintaining DXL routing tables and delivering messages. -
DXL broker 110 provides DXL services 190, which in an example are network services operable to provideDXL ESB 130 to DXL endpoints. -
Domain controller 160 may be configured to communicatively couple toDXL broker 130.Domain controller 160 may maintain domain data in a database such asdatabase 162. In this example,domain controller 160 anddatabase 162 are shown as two distinct entities, but it should be noted that many configurations are possible. For example,database 162 may reside on a disk drive local to thedomain controller 160, or may be separately or remotely hosted.Database 162 is disclosed by way of example, and may be any suitable data store, including a structured or relational database, distributed database, or flat file by way of non-limiting example. - By way of operative example, a client such as laptop 120-3 connects to the LAN and receives a new IP address. At this point, several properties of laptop 120-3 become knowable to other network elements, including by way of non-limiting example, its IP address, information about its operating system, and the logged-on user's username. For ease of reference, these are referred to as “client properties” throughout this example. Client properties are embodiments of security-intelligence data, and are of interest to virtual machine 120-2, which has previously subscribed the security-intelligence data topic with
domain controller 160. - Client properties may be reported to the DXL simultaneously by two distinct sources, namely by laptop 120-3, and by network security sensor 120-1. However, network security sensor 120-1 may fail to report a username value. It may also report an OS value different from that reported by the laptop 120-3. This may be, for example, because network security sensor 120-1 is sensing data remotely, and may not be able to determine these values as reliably as laptop 120-3 itself.
-
Domain controller 160 is responsible for the “client system” data domain, which includes client properties. When laptop 120-3 and client 120-1 publish a message containing the client properties, both messages are first routed toDXL broker 110.DXL broker 110 may then forward the client properties todomain controller 160. -
Domain controller 160 may combine and reconcile the client properties received from the two sources into a single record of truth, containing a single value for IP address, operating system, and username respectively. Specifically, it may determine via its own logic and perhaps prior configuration that laptop 120-3 is trusted more for OS value than network security sensor 120-1. Therefore,domain controller 160 may ignore the “operating system” value received from network security sensor 120-1 when it conflicts with laptop 120-3. - The reconciled client properties are persistently stored in
domain database 162.Domain controller 160 may then publish the client properties onDXL ESB 130.DXL broker 110 may then forward the published message to virtual machine 120-2, which receives a singular and most accurate value for client properties. - Subsequently, client 120-4 may send a DXL request over
DXL ESB 130, inquiring about the client properties for laptop 120-3.DXL broker 110 receives this request and automatically routes it todomain controller 160.Domain controller 160 retrieves the client properties fromdomain database 162 and sends a DXL response message, whichDXL broker 110 receives and forwards to client 120-4. Note that while the “publish-subscribe” transactions in this example are one-to-many, the “request-response” transactions are one-to-one. - In some embodiments, DXL may be characterized by messaging that allows loose integration or coupling of multiple network elements. Loose coupling may reduce the assumptions each DXL endpoint must make about other DXL endpoints, such as the presence of certain capabilities, hardware, or software. According to one or more examples of the present specification, DXL is a ‘Plug-and-Play’ application program interface (API), and may facilitate context-aware and adaptive security by enabling context to be shared between products.
- Further according to one or more examples of the present specification, DXL is an elastic architecture with multiple deployment options and is highly scalable. DXL may also be designed with openness in mind and enable third-party integration.
-
DXL ESB 130 may be based on a two-layer protocol. The “bottom” layer is a secure, reliable, low-latency data transport fabric that connects diverse security elements as a mesh, or in a hub-and-spoke configuration. The “top” layer is an extensible data exchange framework that is configured to facilitate trustworthy data representation. - In an example, DXL endpoints connect to
DXL ESB 130. Each DXL endpoint is assigned a distinct identity, and authenticates itself toDXL ESB 130 upon startup, for example via a certificate or other secure token. DXL endpoints may establish one-to-one communications viaDXL ESB 130, for example by sending a DXL message addressed to a DXL endpoint with a specific identity. This enables DXL endpoints to communicate with each other without having to establish a point-to-point network connection. In an example, this is analogous to a person-to-person phone call. - In another example, DXL may provide a publish-subscribe framework in which certain DXL endpoints “subscribe” to messages of a certain type. When a DXL endpoint “publishes” a message of that type on
DXL ESB 130, all subscribers may process the message, while non-subscribers may safely ignore it. In an example, this is analogous to a podcast subscription service. In yet another example, DXL may provide a request-response framework. In this case, one DXL endpoint may publish a request overDXL ESB 130. An appropriate DXL endpoint receiving the request may provide a response. Advantageously, the response may be used by more than just the DXL endpoint that originally published the request. For example, if a client 120 publishes a request for an object's reputation,JTI server 150 may respond by publishing the reputation. Thus, other clients 120 that find instances of the object may benefit from the response. For example, clients 120 may maintain a comprehensive cache of reputations published on the network. If a client 120 then newly encounters an object that is known on the network, client 120 already has an up-to-date reputation for the object. -
DXL ESB 130 may be implemented using diverse software elements, patterns, and constructs suited to the specific infrastructure connecting the security elements. For instance, in a physical enterprise network, messaging middleware consisting of multiple interconnected message brokers may be deployed, where endpoints connect to the closest broker. In a virtual network infrastructure, the fabric may leverage hypervisor provided channels. - As noted above,
DXL ESB 130 may be configured to provide real-time, trusted exchange of data among otherwise-autonomous, dynamically-assembled DXL endpoints. Thus, in anexample DXL ESB 130's conceptual framework may comprise two virtual components: -
- a. Broad collections of security-relevant data are categorized into “data domains.” Each data domain is a closely related sub-collection of entities, attributes, and inter-relationships.
- b.
Domain controller 160 is a data provider assigned ownership of data for each domain.Domain controller 160 acts as an intermediate trusted data broker between first-hand sources of raw “intelligence” data, and data consumer endpoints such as clients 120. Intelligence data may flow from data producer endpoints to theappropriate domain controller 160, and then be relayed to data consumer endpoints such as clients 120. Note that in this example, the concepts of “data producer” and “data consumer” are contextual roles, and not necessarily physical devices. A client 120 may be a data producer in one context and a data consumer in another context.
- In an example,
domain controller 160 may establish first-hand trust relationships with data-provider endpoints. This enables it to gauge the quality (including accuracy and reliability) of data (such as reputation data) it receives from any particular source. When duplicate, piecemeal data is received from multiple (independent) sources, such as different clients 120,domain controller 160 may reconcile the data and resolve conflicts to derive a single best-known record of truth (such as, for example, a reputation) for each object. This ensures that clients 120 receive consistent data. -
Domain controller 160 may also transform data into a well-understood, standardized representation. This representation may be published onDXL ESB 130, so that all clients 120 receive usable data. - Advantageously, DXL endpoints do not need to know what device originated data, or make point-to-point connections to other DXL endpoints, even when one-to-one communication is necessary. Rather, DXL client software or DXL extensions enable a DXL endpoint to use its own local APIs for querying and receiving data. To increase network efficiency, DXL endpoints may cache received data locally, which data may be trusted until it is superseded by an authorized DXL message. For example, clients 120 may subscribe to published reputations for objects. When an object reputation is received, either in response to a request-response transaction, or in a publish-subscribe model, client 120 may store the reputation in a local database. The reputation may be trusted until superseded, because
DXL controller 160 is configured to publish a reputation update whenever it receives an updated reputation. Thus, frequent individual data requests from clients 120 become bulk data subscriptions, as published reputations are available to all clients 120 that subscribe to reputations. Advantageously, this may reduce the latency of data exchanges. - In yet another example,
DXL broker 110 provides a discovery and location service that informs DXL endpoints of thespecific domain controller 160 to which data query and subscription requests should be routed. - Advantageously, the example DXL architecture described herein is flexible. For example, individual data sources may connect and disconnect from the network without affecting data consumers.
Domain controller 160 may simply rely on whatever data sources are available. Furthermore, the framework makes no assumptions about the physical location or specifically howdomain controller 160 or domain endpoints are deployed or configured. So long as each network element provides valid DXL messaging, traffic is routed correctly. - In the example above,
DXL controller 160 is a logical singleton, but it should be noted thatDXL controller 160 may be implemented, for example, as a set of distributed service components, where each component services either a subset of the domain, or provides a local data replica of a service running elsewhere. Such configurations may enhance scale, performance, and reliability. This may also allow services to be transparently relocated. - Further advantageously, the DXL framework provided herein is extensible. For example, data about new entities and relationships may be provided simply by creating new data domains. New attributes and relationships for existing data domains may be provided simply by defining new message types for that domain.
- In an example,
domain controller 160 has responsibility over the domain of malware data. To distinguish messages from the “malware” domain, such as network status and device maintenance, a namespace may be defined for each. For example, the reputation domain may use the “MALWARE” namespace, the network status domain may use the “STATUS” namespace, and the device maintenance domain may use the “MAINT” namespace. Thus, ifdomain controller 160 is the controller for the reputation domain, it knows to process messages within the malware namespace, and to ignore all others. This allows a designer for each domain to assign a set of messages without having to consult existing domains to avoid name collisions for messages. - For example, both the reputation domain and a device maintenance domain may have use for a message such as DOWNLOAD_UPDATES. In the case of the reputation domain, this message may be an instruction to retrieve updated definitions from
JTI server 150. In the device maintenance domain, this may be an instruction to download operating system updates from a vendor. - Clients 120 may be configured to exchange data from several DXL domains and may subscribe to messages on both the reputation domain and the device maintenance domain. Thus, client 120-1 for example, may parse and respond to a DXL message DOWNLOAD_UPDATES by requesting bulk reputation updates. In one embodiment, the message requesting malware updates may itself be a DXL message. In some cases, for example where the updates are large and are not needed in real-time, delivery of the updates may be completed outside of the DXL architecture to reserve a DXL for lightweight, high-speed messaging.
- Client 120 may also know that it should parse and respond to MAINT: DOWNLOAD_ UPDATES by contacting a vendor's servers and requesting updates.
- In the case where
domain controller 160 is configured as the controller for the reputation domain, it may know to ignore all DXL messages that are not in the MALWARE namespace. Note, however, that a single physical device may be configured to act as a domain controller for multiple domains, in which case traffic in different namespaces may be passed to different subroutines. In some embodiments,DXL broker 110 may be configured to synthesize reports from a plurality of DXL network devices such as clients 120 that are given lesser privileges, such as “suggest” privileges onDXL ESB 130. - Further adding to extensibility, new or better data sources may be incorporated, by integrating them with
domain controller 160. This may be completely transparent to clients 120 and other DXL endpoints. - Additional features of a
DXL broker 110 may include, by way of non-limiting example: service and location registries to lookup registered endpoints, available services, and their locations; publish/subscribe (1:N), request/response (1:1), device-to-device (1:1), and push notification messaging interfaces; optimized message passing between brokers; destination-aware message routing; and broker-to-broker failover. - Advantageously,
domain controller 160 need not be concerned with how each DXL endpoint treats a published message. Rather, that can be a matter of enterprise security policy. - Additional DXL features for clients 120 may include, by way of non-limiting example: local message bus integration for an API to discover brokers, authenticate to DXL, and send and receive catalogued messages.
- Additional general features of context-
aware network 100 may include, by way of non-limiting example: DXL broker and client provisioning and management ofdomain controller 160; policy-based authorization of endpoints ontoDXL ESB 130; secure sockets layer (SSL)-based communications; proxy support for off-premises communications; and domain controller appliances pre-configured with DXL broker functionality (thus joiningdomain controller 160 andDXL broker 110 into one device). -
FIG. 1A is an example wheredomain controller 160 is a joint threat intelligence (JTI)server 150, providing for example, object reputation services on the “reputation” domain according to one or more examples of the present specification.JTI server 150 may communicatively couple toDXL broker 110.JTI server 150 may be a middleware appliance configured to provide reputation services, maintain metadata about network objects (such as reputation, prevalence, and intelligence, by way of non-limiting example), call out to external scanners for an object's reputation classification, and provide telemetry data to threat intelligence service 180.JTI server 150 may communicate with a global threat intelligence service 180 via aproxy 170, which may include either communication overDXL ESB 130, or over a more traditional IP network. - Advantageously,
JTI server 150, in connection with threat intelligence service 180, may provide crowd-sourced object reputations.JTI server 150 may also provide administrator overrides. These may include aggregation of administrator override policies from several enterprises, for whether an object should be run on a network and whether a certificate is considered “clean.” These may also include client-side results, such as an aggregate of end-user decisions of whether to allow or block an object. - In another example,
JTI server 150 may track prevalence data, including the prevalence of an object on context-aware network 100. - In yet another example,
JTI server 150 may serve as a telemetry aggregator/proxy to gather and send to threat intelligence service 180 telemetry from endpoints that do not directly interact with threat intelligence service 180.JTI server 150 may also contribute file metadata to threat intelligence service 180, such as hashes, digital signature data, and file attributes. -
JTI server 150 may receive several such messages from different clients 120, and in some cases, the messages may conflict with one another. Upon receiving an initial report from a client 120 identifying an object as malware,domain controller 160 may publish a warning that the other clients should give additional scrutiny to the object, such as deep scanning or requesting user verification before executing the object. In other embodiments,domain controller 160 may provide such information in response to a request for an object reputation from a client 120. - If additional clients 120 identify the object as malware, then a confidence indicator may pass a threshold.
JTI server 150 may then publish a higher-level, such as command-level, message identifying the object as malware. IfJTI server 150 receives multiple conflicting reports from different clients, a synthesis algorithm may provide an appropriate action. For example, if one or a few clients are found to be outliers, reporting a status different from a large majority of other clients, the outliers may be discarded. This synthesis algorithm may also account for specific clients' past reputations for accurate reporting, or for a reputation assigned based on installed hardware or software. - In an embodiment where
domain controller 160 is aJTI server 150, this example illustrates the value of designating a hierarchy or other schema for assigning DXL endpoint privileges. For example, with respect to designating an object as malware, clients 120 may have “suggest” privileges. This may mean, for example, that clients 120 may identify an object that they believe to be malware, and may either direct a specific message toJTI server 150, or may publish a general message identifying the object as malware. Because clients have only “suggest” privileges onDXL ESB 130, other DXL endpoints that subscribe to reputation updates may treat the identification as less authoritative than an identification from a DXL network element with elevated privileges such as “assign” privileges. Privileges, and especially elevated privileges such as “assign” privileges, may be authenticated by a secure certificate provided as part of a DXL message. -
FIG. 1B is a network diagram of select elements in a context-aware network 100 according to one or more examples of the present specification. As seen inFIG. 1B , an additional DXL broker 110-2 may be added to service endpoints 120-3 and 120-4. DXL broker 110-2 may communicate with a second domain controller 160-2, which may sharedomain database 162 with domain controller 160-1. -
FIG. 2 is a network diagram disclosing a distributed architecture according to one or more examples of the present specification. In this example, DXL broker 110-1 may be designated as the “hub,” while DXL brokers 110-2, 110-3, 110-4, and 110-5 may be designated as “spokes.” in an example, all DXL traffic that passes through a spoke will be forwarded to the hub, which will distribute the traffic to other spokes. Designation of aDXL broker 110 as the hub may be accomplished via any suitable means, such as selecting the hub based on MAC ID, IP address, or network proximity todomain controller 160. - If DXL broker 110-1 goes offline, another hub may be at least temporarily needed. In that case, another hub may be elected. When DXL broker 110-1 comes back online, it may resume its duties as a hub, or may act as a spoke, depending on network topology and design considerations.
- In another example, spokes may form a temporary mesh network upon connecting effectively to DXL broker 110-1. In yet other embodiments,
DXL brokers 110 may be configured to operate full time in a mesh configuration. - Additional extensibility may be provided by bridging
DXL ESB 130 across disparate networks, enabling data to be exchanged over larger networks, including the internet. -
FIG. 3 is a network diagram of an example DXL network operating across a traditional enterprise boundary according to one or more examples of the present specification. In this example,first enterprise 302 includes a DXL broker 110-2 which communicatively couples to adomain controller 160 and enterprise switch controller (ESM) 330. In one embodiment,domain controller 160 andESM 330 may be coupled over a traditional (non-DXL)network interface 312.Domain controller 160 may connect to anIP Network 310.IP Network 310 may be any communicative platform operable to exchange data or information emanating from endpoints, including by way of non-limiting example, an internet architecture providing end users with the ability to electronically interact, a plain old telephone system (POTS), which end users could use to perform transactions in which they may be assisted by human operators or in which they may manually key data into a telephone or other suitable electronic equipment, any packet data network (PDN) offering a communications interface or exchange between any two nodes in a system, or any local area network (LAN), metropolitan area network (MAN), wide area network (WAN), wireless local area network (WLAN), virtual private network (VPN), intranet, or any other appropriate architecture or system that facilitates communications in a network or telephonic environment. - Second enterprise 304 also includes a DXL broker 110-1.
DXL brokers 110 may communicate with each other overDXL ESB 130. In this example,DXL ESB 130 is physically provided byIP Network 310, but DXL traffic may be distinguished from other types of internet traffic such as http and other user-centric network traffic, for example because it is provided on a different port or protocol. - DXL broker 110-1 may also be coupled, for example, to a network service provider (NSP) 340, antivirus agent 350,
enterprise firewall 360, and advanced threat detection appliance (ATD) 370. -
ATD 370 may be a dedicated appliance, or a general-purpose computing machine running advanced detection software. In one example,ATD 370 is configured to analyze objects without existing reputations and to assign those objects threat levels based on the analysis. - As this figure demonstrates,
DXL ESB 130 may be used to integrate heterogeneous or otherwise unrelated network architectures, even across different enterprises. In an example, second enterprise 304 may be a third-party JTI service provider delivering ATD services tofirst enterprise 302. -
FIG. 4 is a network diagram of a context-aware network 400 according to one or more examples of the present specification. In an example, context-aware network 400 is substantially similar to context-aware network 100. However, inFIG. 4 , context-aware network 400domain controller 160 is a common information model (CIM)server 410. - According to one or more examples of the present specification, CIM is open and extensible logical database schema designed to host different types of situational and environmental information. CIM may provide robust representation of new objects, building blocks, and data types. Core entities of CIM include, by way of non-limiting example, assets, identities, applications, and locations.
- CIM may provide many-to-many relationships and building blocks that drive multiple use cases. CIM may also support advanced data visualization. Advantageously, according to one or more examples of the present specification, CIM scales massively and is open and extensible, allowing different product groups and third parties to develop new data extensions.
- In an example of a CIM use case, a “location” represents a collection of network elements forming a logical location mapped into a physical location or a place. The location context can be used to, by way of non-limiting example, gather complete understanding with regards to the true scope and size of an organization (i.e. in the form of a network topology map).
- CIM may also maintain the global authoritative state of situational and environmental information by synthesizing contextual information shared by multiple data sources over
DXL ESB 130. -
FIG. 5 is a block diagram of a DXL broker according to one or more examples of the present specification. In some embodiments,DXL broker 110, DXL services 190, andJTI server 150 may be provided in a single physical computing device. - In an example,
DXL broker 110 is controlled by aprocessor 510.Processor 510 may connect to other system elements via system bus 570. Those other elements may include, by way of non-limiting example, amemory 520,network interface 540, andstorage 550. -
Processor 510 is configured to controlDXL broker 110, for example via executable software or firmware instructions. A “processor” as used herein includes any combination of hardware, software, or firmware providing programmable logic, including by way of non-limiting example a microprocessor, digital signal processor, field-programmable gate array, programmable logic array, application-specific integrated circuit, or virtual machine processor. -
Memory 520 may be a relatively low-latency volatile memory in some embodiments, and may include main memory, cache, on-chip memory, L1 memory, L2 memory, or similar. Note that in this embodiment,processor 510 is depicted in a direct memory access arrangement withmemory 520, but in other embodiments,memory 520 may communicate withprocessor 510 via system bus 570, via some other bus, or via some other means. Furthermore, althoughmemory 520 andstorage 550 are depicted in this example as physically or conceptually separate devices, it should be appreciated that in some embodiments,memory 520 andstorage 550 may share a physical device, which may or may not be divided into separate memory areas. Thus, it should be appreciated that the arrangement disclosed here is an example only, and not limiting. Rather, it is expressly intended that even where a memory and storage are spoken of separately, they may be embodied in a single physical or logical device unless expressly stated otherwise. - In this example,
network interface 540 provides a physical and logical interface toDXL ESB 130, and includes any communication medium, whether analog, digital, or mixed-signal, that is configured to communicatively couple client 120 to other computing devices.Network interface 540 may include, by way of non-limiting example, a WiFi, Ethernet, Firewire, fiber optic, USB, serial interface, infrared, cellular network, digital PCS network, 2G data network, 3G data network, 4G WiMAX, or 4G LTE data network. In some embodiments,network interface 540 may also provide a physical and logical interface toIP Network 310. -
Storage 550 is disclosed as an example of a non-volatile memory medium, which may be a species ofmemory 520. In some embodiments,memory 520 andstorage 550 may be separate devices, withmemory 520 being a relatively low-latency volatile memory device, andstorage 550 being a relatively high-latency non-volatile memory device.Storage 550 may also be another device, such as a hard drive, solid-state drive, external storage, redundant array of independent disks (RAID), network-attached storage, optical storage, tape drive, backup system, or any combination of the foregoing. Many other configurations are also possible, and are intended to be encompassed within the broad scope of this specification. - In an example,
memory 520 includesDXL broker 522 andDXL services software 526.DXL broker 522 provides DXL broker services as described herein.DXL services software 526 may provide DXL client services orDXL broker 110. For example,DXL broker 110 may subscribe to certain types of messages in a client capacity. -
FIG. 6 is a block diagram of aCIM server 410 according to one or more examples of the present specification. In an example,CIM server 410 is controlled by aprocessor 610.Processor 610 may connect to other system elements viasystem bus 670. Those other elements may include, by way of non-limiting example, amemory 620,network interface 640, andstorage 650. Reference is made to corresponding elements inFIG. 5 , which contains additional details and definitions. -
Memory 620 may includeCIM server software 622.CIM server software 622 may be configured to provide CIM services as described herein. -
Storage 650 may include alocal object database 652.Object database 652 may contain stored information about objects on the network, including, for example, reputations and metadata. -
FIG. 7 is a block diagram of adomain controller 160 according to one or more examples of the present specification. In an example,domain controller 160 is controlled by aprocessor 710.Processor 710 may connect to other system elements viasystem bus 770. Those other elements may include, by way of non-limiting example, amemory 720,network interface 740, andstorage 750. Reference is made to corresponding elements inFIG. 5 , which contains additional details and definitions. - In an example,
memory 720 includesdomain controller software 722 andDXL extension 724.Domain controller software 722 may be configured to provide domain controller services as described herein.DXL extensions 724 may provide server extensions that allowdomain controller 160 to operate onDXL ESB 130. In some embodiments,DXL extension 724 may include instructions that permitdomain controller 160 to act as a DXL client in some situations. -
FIG. 8 is a block diagram of a client 120 according to one or more examples of the present specification. Client 120 is controlled by aprocessor 810, which is communicatively coupled to amemory element 820. In an example,processor 810 is communicatively coupled to other system elements via bus 870. Those elements may include, by way of non-limiting example, a network interface 840,storage 850, which in some cases may be a species ofmemory element 820, and a user interface 860. It is expressly intended that any of the above elements can be realized in hardware, software, firmware, or any combination thereof. - In some embodiments, a user interface 860 may be provided to aid a user in interacting with client 120. A “user interface” includes any combination of hardware, software, and firmware configured to enable a user to interact with client 120, whether or not in real-time. In an example, user interface 860 may include, by way of non-limiting example, a keyboard (not shown), mouse (not shown),
display monitor 842, speaker 846,microphone 844, touch-sensitive display, which may act as a combined input/output device, and which may be a species ofdisplay 842, and acamera 848. User interface 860 may include software services such as a graphical user interface, including real-time dialog boxes that solicit input or confirmation from a user. - In an example,
memory 820 has stored therein executable instructions operable to provide software services, which may be contained in several distinct modules. ADXL client 826 may provide software services for interacting withDXL ESB 130, and may include, for example, certificates authenticating client 120 onDXL ESB 130, subroutines for publishing messages, and subroutines for parsing subscribed incoming messages. CIM client 822 may provide CIM services as described with more particularity in relation toFIG. 4 . CIM client 822 may also maintain a comprehensive catalog ofobjects 852, including for example a comprehensive catalog of installed applications. JTI client 824 may provide JTI client services, such as local reputation management and interactions withJTI server 150. Client 120 may also have aseparate antimalware agent 828, which may provide antivirus and other antimalware services. In some cases,antimalware agent 828 is integrated with JTI client 824. -
FIG. 9 is a flow diagram illustrating evaluation of an object in a hierarchical manner according to one or more examples of the present specification. - In this example, policies on the left are designated as “block,” and deterministically block an object, while policies on the right are designated as “allow,” and deterministically allow an object. By way of non-limiting example, the policies of
FIG. 9 are disclosed as a fixed hierarchy. However, this is not intended to be limiting. For example, in other embodiments, policies may be weighted, or serviced in a round-robin fashion. Furthermore, in embodiments where a hierarchy is used, this particular hierarchy is not required. - In
block 910, an administrator, which may be either or both of a human operator or a device with administrative credentials, may assign a “block” override to the object, which may be identified by a hash. Inblock 912, the administrator may provide an “allow” override to an object identified by a hash. - In
block 920, an administrator may assign a block to override to an object identified by a certificate. Inblock 922, an administrator may assign an allow overwrite to an object identified by a certificate. - In
block 930, threat intelligence service 180 may assign a block status based on a certificate. Inblock 932, threat intelligence service 180 may assign an object allow status based on a certificate. - In block 940, threat intelligence service 180 may assign an object block status base on a hash. In block 942, threat intelligence service 180 may assign an object allow status based on a hash.
- In block 950, malware definitions may identify an object as block, while in
block 952, malware definitions may identify the object as allow. - In
block 960, JTI rules may assume that the object is dirty. In block 962, JTI rules may assume that the object is clean. - JTI client 824 may prompt an end user, via user interface 860, to confirm executing or opening an object. If the user declines, then in
block 970 the object is blocked. If the user confirms, then inblock 972 the object is allowed. - In block 980, if the object has passed all the preceding filters, a decision to either block or allow the object depends on JTI policies and algorithms. This may include requesting a reputation for the object.
-
FIG. 10 is a flow diagram of a method performed by a client 120 according to one or more examples of the present specification. Inblock 1010, client 120 opens a new object. This may be, for example, because a user interacts with the object, or because an automated process interacts with the object. Inblock 1020, client 120 checks to see if the object has a cached reputation in its local reputation database. If the object has an existing reputation, then inblock 1030, client 120 may make a decision to either block or allow the object. In some examples, client 120 may publish the block or allowed decision overDXL ESB 130. This allows other DXL network objects that have subscribed to such updates to receive and integrate the decision. Inblock 1022, if there is no cached reputation, then client 120 may request a reputation fromJTI server 150. Inblock 1024, client 120 may receive reputation data fromJTI server 150, whereupon control passes to block 130. As shown by the looping arrow back to 1010, this process may be repeated for each new object. -
FIG. 10A is a flow diagram of a method performed byJTI server 150 in connection with the method ofFIG. 10 according to one or more example embodiments of the present specification. Inblock 1040,JTI server 150 receives a reputation request from client 120. Inblock 1060,JTI server 150 may query its local database to find whether the object is already known. If the object is known, then inblock 1070,JTI server 150 may update its local threat intelligence database. This may include, for example, noting the circumstances of the request from client 120. Inblock 1080,JTI server 150 may return the reputation data to client 120. Inblock 1090, the method is complete. - Returning to block 1060, if the object is not known, then in
block 1050JTI server 150 may request information from the threat intelligence service 180. Inblock 1052,JTI server 150 receives threat intelligence data from threat intelligence service 180, and inblock 1070 updates its local JTI database with the received intelligence. Again inblock 1080, the intelligence is returned to client 120, and inblock 1090 the process is done. -
Block 1034 represents an alternate entry point into the method. Atblock 1034, aJTI server 150 receives a published decision block, for example, a decision to be published by client 120 according to the method ofFIG. 10 . Depending on the network configuration,JTI server 150 may subscribe to published block/allow decisions, and inblock 1070 may use a publish decision to update its local database. In this case, control passes directly fromblock 1080 to block 1090. -
FIG. 11 is a flow diagram of a method of aJTI server 150 servicing a reputation request according to one or more examples of the present specification. In some embodiments, the method ofFIG. 11 may be performed in connection withblock 1080 ofFIG. 10A . Inblock 1110, an administrator may enter allow or block overrides, for example as disclosed in connection withFIG. 9 .Block 1040 corresponds to block 1040 ofFIG. 10A , in which theJTI server 150 receives a reputation request from client 120. Inblock 1130,JTI server 150 checks to see whether the administrator has entered an override, such as an enterprise-wide override. In particular, an override may remove the decision of whether to allow or block the object. Instead, the override may deterministically allow or block the object. Thus, inblock 1140,JTI server 150 returns the override to client 120. Inblock 1130, if there is no enterprise override, then inblock 1150,JTI server 150 returns the reputation for client 120 to act on. -
FIG. 12 is a flow diagram of an enhancement to the method ofFIG. 10A according to one or more examples of the present specification. Blocks inFIG. 12 with numbering identical to the corresponding blocks inFIG. 10A may be identical in function to the blocks disclosed inFIG. 10A . -
New block 1210 queries whether threat intelligence is available from threat intelligence service 180. If threat intelligence is available, then inblock 1052,JTI server 150 receives the threat intelligence as illustrated inFIG. 10A . Inblock 1220, if no threat intelligence is available, thenJTI server 150 may send the object toATD 370 for analysis. Rather than respond directly to the request,ATD 370 may publish reputation data for the object once it has completed its analysis. Inblock 1230,JTI server 150 may subscribe to published reputation data messages, and thus may receive the DXL message published byATD 370. The remainder of the method may be unchanged. - In an example, the DXL of the present specification may be used to provide monolithic reputation updates in a distributed environment. In some prior art systems, providing reputation updates to a plurality of endpoints may be complicated because some endpoints may have different data requirements from other endpoints. Thus, in some prior art embodiments, updating the reputation for a single object may include formatting data about the object into a plurality of formats, and distributing the data over a plurality of protocols.
- In an example, reputations may be updated monolithically.
FIG. 13 is a flowchart of a method performed byDXL controller 160 according to one or more examples of the present specification. Inblock 1310, an administrator, service, or other authority may define reputation classifiers for contextaware network 100. This may include, for example, defining one or more classes of objects. Objects may include, by way of non-limiting example, files, certificates, URLs, identities, computer systems, servers, mobile devices, and other objects that may compromise or be compromised by an attacker. Reputation classes may define an object as trusted, malware, grayware, or in general, completely allow, completely block, or anything in between. Reputation classes may also carry information about actions to be taken in response to classifiers. For example, if an object is identified as malware, endpoints may be required to take a responsive action, such as quarantine, block, delete, sandbox, deny permissions (e.g., if the object is identified as grayware), remedy, prompt, or custom action. Although network policies may provide a unitary specification for handling objects of given reputation classes, the specific implementation of the specification may vary between devices. - In
block 1320,DXL controller 160 may receive registrations or subscriptions from a plurality of endpoints subject to the unitary specification or object classification scheme. These may be, for example, in the form of endpoints subscribing to a topic designated for handling object reputation updates. Inblock 1330,DXL controller 160 may receive an updated reputation for an object. This may come, for example, fromJTI server 150, from analysis of the object, fromATD 370, or from any other suitable reputation source. Inblock 1340,DXL controller 160 may publish on DXL ESB 130 a reputation update for the object. This updated reputation may be received by all endpoints that subscribe to the topic. Inblock 1390, the method is done, meaning that from the perspective ofdomain controller 160, all relevant objects have been successfully updated absent notice to the contrary. -
FIG. 14 is a flowchart of a method performed by DXL endpoints responsive to receiving a published reputation update for an object according to one or more examples of the present specification. By way of non-limiting example,FIG. 14 refers to a client 120, although it should be noted that any suitable endpoint may perform this method, and in particular, any endpoint acting as a reputation consumer. Inblock 1410, client 120 registers or subscribes to the reputation update topic. Inblock 1420, client 120 receives the published object reputation update, and recognizes it as a valid message. Inblock 1430, client 120 may process the updated reputation according to local protocols for client 120. For example, if an object is identified as grayware, the unitary specification may require endpoints to restrict access to certain system services such as short messaging service (SMS). That policy may not be relevant for certain desktop computer systems that do not implement SMS, while it may be highly relevant for smartphones that provide SMS services. Thus, while the policy specification is unitary and global, individual implementations may vary according to endpoint needs. Inblock 1490, the method is done. - Advantageously, designating an object or set of objects, such as a set of files and or certificates, as good or bad can be achieved via a single click within a security management console by leveraging persistent client-initiated connections to
DXL ESB 130 to enable real time communication of the reputation updates across the customer's environment, including systems potentially unreachable byDXL controller 160, such as those behind a firewall or NAT. - The foregoing outlines features of several embodiments so that those skilled in the art may better understand the aspects of the present disclosure. Those skilled in the art should appreciate that they may readily use the present disclosure as a basis for designing or modifying other processes and structures for carrying out the same purposes and/or achieving the same advantages of the embodiments introduced herein. Those skilled in the art should also realize that such equivalent constructions do not depart from the spirit and scope of the present disclosure, and that they may make various changes, substitutions, and alterations herein without departing from the spirit and scope of the present disclosure.
- The particular embodiments of the present disclosure may readily include a system on chip (SOC) central processing unit (CPU) package. An SOC represents an integrated circuit (IC) that integrates components of a computer or other electronic system into a single chip. It may contain digital, analog, mixed-signal, and radio frequency functions: all of which may be provided on a single chip substrate. Other embodiments may include a multi-chip-module (MCM), with a plurality of chips located within a single electronic package and configured to interact closely with each other through the electronic package. In various other embodiments, the digital signal processing functionalities may be implemented in one or more silicon cores in Application Specific Integrated Circuits (ASICs), Field Programmable Gate Arrays (FPGAs), and other semiconductor chips.
- In example implementations, at least some portions of the processing activities outlined herein may also be implemented in software. In some embodiments, one or more of these features may be implemented in hardware provided external to the elements of the disclosed FIGUREs, or consolidated in any appropriate manner to achieve the intended functionality. The various components may include software (or reciprocating software) that can coordinate in order to achieve the operations as outlined herein. In still other embodiments, these elements may include any suitable algorithms, hardware, software, components, modules, interfaces, or objects that facilitate the operations thereof.
- Additionally, some of the components associated with described microprocessors may be removed, or otherwise consolidated. In a general sense, the arrangements depicted in the FIGURES may be more logical in their representations, whereas a physical architecture may include various permutations, combinations, and/or hybrids of these elements. It is imperative to note that countless possible design configurations can be used to achieve the operational objectives outlined herein. Accordingly, the associated infrastructure has a myriad of substitute arrangements, design choices, device possibilities, hardware configurations, software implementations, equipment options, etc.
- Any suitably-configured processor component can execute any type of instructions associated with the data to achieve the operations detailed herein. Any processor disclosed herein could transform an element or an article (for example, data) from one state or thing to another state or thing. In another example, some activities outlined herein may be implemented with fixed logic or programmable logic (for example, software and/or computer instructions executed by a processor) and the elements identified herein could be some type of a programmable processor, programmable digital logic (for example, a field programmable gate array (FPGA), an erasable programmable read only memory (EPROM), an electrically erasable programmable read only memory (EEPROM)), an ASIC that includes digital logic, software, code, electronic instructions, flash memory, optical disks, CD-ROMs, DVD ROMs, magnetic or optical cards, other types of machine-readable mediums suitable for storing electronic instructions, or any suitable combination thereof. In operation, processors may store information in any suitable type of non-transitory storage medium (for example, random access memory (RAM), read only memory (ROM), field programmable gate array (FPGA), erasable programmable read only memory (EPROM), electrically erasable programmable ROM (EEPROM), etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs. Further, the information being tracked, sent, received, or stored in a processor could be provided in any database, register, table, cache, queue, control list, or storage structure, based on particular needs and implementations, all of which could be referenced in any suitable timeframe. Any of the memory items discussed herein should be construed as being encompassed within the broad term ‘memory.’ Similarly, any of the potential processing elements, modules, and machines described herein should be construed as being encompassed within the broad term ‘microprocessor’ or ‘processor.’
- Computer program logic implementing all or part of the functionality described herein is embodied in various forms, including, but in no way limited to, a source code form, a computer executable form, and various intermediate forms (for example, forms generated by an assembler, compiler, linker, or locator). In an example, source code includes a series of computer program instructions implemented in various programming languages, such as an object code, an assembly language, or a high-level language such as OpenCL, Fortran, C, C++, JAVA, or HTML for use with various operating systems or operating environments. The source code may define and use various data structures and communication messages. The source code may be in a computer executable form (e.g., via an interpreter), or the source code may be converted (e.g., via a translator, assembler, or compiler) into a computer executable form.
- In the discussions of the embodiments above, the capacitors, buffers, graphics elements, interconnect boards, clocks, DDRs, camera sensors, dividers, inductors, resistors, amplifiers, switches, digital core, transistors, and/or other components can readily be replaced, substituted, or otherwise modified in order to accommodate particular circuitry needs. Moreover, it should be noted that the use of complementary electronic devices, hardware, non-transitory software, etc. offer an equally viable option for implementing the teachings of the present disclosure.
- In one example, any number of electrical circuits of the FIGURES may be implemented on a board of an associated electronic device. The board can be a general circuit board that can hold various components of the internal electronic system of the electronic device and, further, provide connectors for other peripherals. More specifically, the board can provide the electrical connections by which the other components of the system can communicate electrically. Any suitable processors (inclusive of digital signal processors, microprocessors, supporting chipsets, etc.), memory elements, etc. can be suitably coupled to the board based on particular configuration needs, processing demands, computer designs, etc. Other components such as external storage, additional sensors, controllers for audio/video display, and peripheral devices may be attached to the board as plug-in cards, via cables, or integrated into the board itself. In another example, the electrical circuits of the FIGURES may be implemented as stand-alone modules (e.g., a device with associated components and circuitry configured to perform a specific application or function) or implemented as plug-in modules into application specific hardware of electronic devices.
- Note that with the numerous examples provided herein, interaction may be described in terms of two, three, four, or more electrical components. However, this has been done for purposes of clarity and example only. It should be appreciated that the system can be consolidated in any suitable manner. Along similar design alternatives, any of the illustrated components, modules, and elements of the FIGURES may be combined in various possible configurations, all of which are clearly within the broad scope of this Specification. In certain cases, it may be easier to describe one or more of the functionalities of a given set of flows by only referencing a limited number of electrical elements. It should be appreciated that the electrical circuits of the FIGURES and its teachings are readily scalable and can accommodate a large number of components, as well as more complicated/sophisticated arrangements and configurations. Accordingly, the examples provided should not limit the scope or inhibit the broad teachings of the electrical circuits as potentially applied to a myriad of other architectures.
- Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims. In order to assist the United States Patent and Trademark Office (USPTO) and, additionally, any readers of any patent issued on this application in interpreting the claims appended hereto, Applicant wishes to note that the Applicant: (a) does not intend any of the appended claims to invoke paragraph six (6) of 35 U.S.C. section 112 as it exists on the date of the filing hereof unless the words “means for” or “steps for” are specifically used in the particular claims; and (b) does not intend, by any statement in the specification, to limit this disclosure in any way that is not otherwise reflected in the appended claims.
- There is disclosed in one example a security management console, comprising: a hardware platform, comprising a processor, a memory, and a data exchange layer (DXL) interface, the DXL interface comprising a hardware network connection and a software layer, the software layer to provide a two-layer messaging bus, wherein a lower layer is an internet protocol (IP) network, and an upper layer is a publish-subscribe enterprise service bus (ESB); an interface to a reputation database, the reputation database including cached reputations for a plurality of network objects, the reputations representing the network objects' safety within an enterprise serviced by the DXL; and instructions encoded within the memory to instruct the processor to: provide a DXL security console graphical user interface (GUI), the GUI including instructions to provide a graphical representation of an object, including the object's default reputation retrieved from the reputation database; receive a user input to override the object's default reputation to a selected reputation; provide an instruction via the reputation database interface to update the object's default reputation in the database with the selected reputation; and publish a DXL message to a DXL topic associated with the object, the DXL message including the selected reputation.
- There is further disclosed an example security management console, wherein the object is a device.
- There is further disclosed an example security management console, wherein the object is a certificate.
- There is further disclosed an example security management console, wherein the object is a file.
- There is further disclosed an example security management console, wherein the object is a URL.
- There is further disclosed an example security management console, wherein publishing the DXL message comprises sending the message to a DXL broker with a DXL header including the DXL topic.
- There is further disclosed an example security management console, wherein the instructions include a guest platform.
- There is further disclosed an example security management console, wherein the guest platform includes a virtualization layer.
- There is further disclosed an example security management console, wherein the guest platform includes a containerization infrastructure.
- There is also disclosed an example of one or more tangible, non-transitory computer-readable storage media having stored thereon executable instructions to: provide a data exchange layer (DXL) bus, including an publish-subscribe enterprise service bus (ESB) layer on top of a traditional internet protocol (IP) network; receive an identifier for a DXL object; query an object reputation database for a default reputation for the DXL object; receive via an interface an override reputation for the object; and publish the override reputation to the DXL via a DXL message.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the instructions are further to cause a database update to update the DXL object with the override reputation.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the interface is a graphical user interface.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the interface is a DXL administrator graphical user interface.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the interface is an application programming interface (API) for providing DXL administration functions.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the DXL object is a device.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the DXL object is a certificate.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the DXL object is a file.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein the DXL object is a URL.
- There is further disclosed an example of one or more tangible, non-transitory computer-readable storage media, wherein publishing the override reputation comprises sending the message to a DXL broker with a DXL header including a DXL topic.
- There is also disclosed a computer-implemented method of providing a one-click reputation update of an object via a data exchange layer (DXL), comprising: establishing a logical connection with the DXL, comprising overlaying a publish-subscribe enterprise service bus (ESB) onto an internet protocol (IP) network; receiving an identifier for a DXL object; receiving a default reputation for the DXL object; receiving via a software interface an override reputation for the object; and publishing a DXL message comprising the override reputation for the object.
- There is further disclosed an example method, wherein receiving the default reputation comprises receiving the default reputation from a database.
- There is further disclosed an example method, wherein receiving the default reputation from the database comprises receiving the default reputation via a DXL message.
- There is further disclosed an example method, wherein the software interface is a graphical user interface.
- There is further disclosed an example method, wherein the software interface is a DXL administrator graphical user interface.
- There is further disclosed an example method, wherein the software interface is an application programming interface (API) for providing DXL administration functions.
- There is further disclosed an example method, wherein the object is a device.
- There is further disclosed an example method, wherein the object is a certificate.
- There is further disclosed an example method, wherein the object is a file.
- There is further disclosed an example method, wherein the object is a URL.
- There is further disclosed an example method, wherein publishing the override reputation comprises sending the message to a DXL broker with a DXL header including a DXL topic.
- There is further disclosed an example apparatus comprising means for performing the method of a number of the above examples.
- There is further disclosed an example apparatus, wherein the means for performing the method comprise a processor and a memory.
- There is further disclosed an example apparatus, wherein the memory comprises machine-readable instructions that, when executed, cause the apparatus to perform the method of a number of the above examples.
- There is further disclosed an example apparatus, wherein the apparatus is a computing system.
- There is further disclosed an example of at least one computer readable medium comprising instructions that, when executed, implement a method or realize an apparatus as illustrated in a number of the above examples.
Claims (20)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/993,660 US20200403977A1 (en) | 2013-09-29 | 2020-08-14 | One-click reputation adjustment |
US18/732,312 US20240323167A1 (en) | 2013-09-29 | 2024-06-03 | One-click reputation adjustment |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201361884090P | 2013-09-29 | 2013-09-29 | |
PCT/US2013/076908 WO2015047440A1 (en) | 2013-09-29 | 2013-12-20 | One-click reputation adjustment |
US201614913394A | 2016-02-22 | 2016-02-22 | |
US16/993,660 US20200403977A1 (en) | 2013-09-29 | 2020-08-14 | One-click reputation adjustment |
Related Parent Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2013/076908 Continuation WO2015047440A1 (en) | 2013-09-29 | 2013-12-20 | One-click reputation adjustment |
US14/913,394 Continuation US10749843B2 (en) | 2013-09-29 | 2013-12-20 | One-click reputation adjustment |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US18/732,312 Continuation US20240323167A1 (en) | 2013-09-29 | 2024-06-03 | One-click reputation adjustment |
Publications (1)
Publication Number | Publication Date |
---|---|
US20200403977A1 true US20200403977A1 (en) | 2020-12-24 |
Family
ID=52744304
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/913,394 Active US10749843B2 (en) | 2013-09-29 | 2013-12-20 | One-click reputation adjustment |
US16/993,660 Abandoned US20200403977A1 (en) | 2013-09-29 | 2020-08-14 | One-click reputation adjustment |
US18/732,312 Pending US20240323167A1 (en) | 2013-09-29 | 2024-06-03 | One-click reputation adjustment |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/913,394 Active US10749843B2 (en) | 2013-09-29 | 2013-12-20 | One-click reputation adjustment |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US18/732,312 Pending US20240323167A1 (en) | 2013-09-29 | 2024-06-03 | One-click reputation adjustment |
Country Status (2)
Country | Link |
---|---|
US (3) | US10749843B2 (en) |
WO (1) | WO2015047440A1 (en) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2015047440A1 (en) | 2013-09-29 | 2015-04-02 | Mcafee, Inc. | One-click reputation adjustment |
US10621613B2 (en) * | 2015-05-05 | 2020-04-14 | The Nielsen Company (Us), Llc | Systems and methods for monitoring malicious software engaging in online advertising fraud or other form of deceit |
US11062052B2 (en) * | 2018-07-13 | 2021-07-13 | Bank Of America Corporation | System for provisioning validated sanitized data for application development |
CN109714737B (en) * | 2019-02-21 | 2021-08-20 | 江苏大学 | D2D covert communication system with full-duplex base station cellular network and communication method thereof |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080256622A1 (en) * | 2007-04-16 | 2008-10-16 | Microsoft Corporation | Reduction of false positive reputations through collection of overrides from customer deployments |
US20110252483A1 (en) * | 2006-12-08 | 2011-10-13 | Microsoft Corporation | Reputation-Based Authorization Decisions |
US20170237754A1 (en) * | 2016-02-17 | 2017-08-17 | Sophos Limited | Evaluating installers and installer payloads |
US20180357086A1 (en) * | 2017-06-13 | 2018-12-13 | Intel Corporation | Container virtual switching |
Family Cites Families (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6073142A (en) | 1997-06-23 | 2000-06-06 | Park City Group | Automated post office based rule analysis of e-mail messages and other data objects for controlled distribution in network environments |
US5987610A (en) | 1998-02-12 | 1999-11-16 | Ameritech Corporation | Computer virus screening methods and systems |
US6606706B1 (en) * | 1999-02-08 | 2003-08-12 | Nortel Networks Limited | Hierarchical multicast traffic security system in an internetwork |
US6460050B1 (en) | 1999-12-22 | 2002-10-01 | Mark Raymond Pace | Distributed content identification system |
US6901519B1 (en) | 2000-06-22 | 2005-05-31 | Infobahn, Inc. | E-mail virus protection system and method |
US7302634B2 (en) * | 2001-03-14 | 2007-11-27 | Microsoft Corporation | Schema-based services for identity-based data access |
US20030061365A1 (en) * | 2001-03-14 | 2003-03-27 | Microsoft Corporation | Service-to-service communication for network services |
US8561167B2 (en) | 2002-03-08 | 2013-10-15 | Mcafee, Inc. | Web reputation scoring |
US6886741B1 (en) * | 2004-03-08 | 2005-05-03 | Melvin E. Salveson | Electronic transaction system |
US7953814B1 (en) * | 2005-02-28 | 2011-05-31 | Mcafee, Inc. | Stopping and remediating outbound messaging abuse |
US20060200487A1 (en) * | 2004-10-29 | 2006-09-07 | The Go Daddy Group, Inc. | Domain name related reputation and secure certificates |
US20080022013A1 (en) * | 2004-10-29 | 2008-01-24 | The Go Daddy Group, Inc. | Publishing domain name related reputation in whois records |
US20060248182A1 (en) * | 2005-05-02 | 2006-11-02 | Polycentric Networks Corporation | Formatted and/or tunable QoS data publication, subscription, and/or distribution including dynamic network formation |
US7562304B2 (en) * | 2005-05-03 | 2009-07-14 | Mcafee, Inc. | Indicating website reputations during website manipulation of user information |
US7647623B2 (en) * | 2005-10-17 | 2010-01-12 | Alcatel Lucent | Application layer ingress filtering |
US8103727B2 (en) * | 2007-08-30 | 2012-01-24 | Fortinet, Inc. | Use of global intelligence to make local information classification decisions |
US8200587B2 (en) | 2008-04-07 | 2012-06-12 | Microsoft Corporation | Techniques to filter media content based on entity reputation |
US8832777B2 (en) * | 2009-03-02 | 2014-09-09 | Headwater Partners I Llc | Adapting network policies based on device service processor configuration |
US8380797B2 (en) | 2009-11-09 | 2013-02-19 | General Electric Company | Business data exchange layer |
US9535769B2 (en) | 2010-02-05 | 2017-01-03 | Oracle International Corporation | Orchestrated data exchange and synchronization between data repositories |
US8863291B2 (en) | 2011-01-20 | 2014-10-14 | Microsoft Corporation | Reputation checking of executable programs |
CN107104939B (en) * | 2011-11-01 | 2021-01-12 | 谷歌有限责任公司 | System, method for managing secure elements |
WO2015047440A1 (en) | 2013-09-29 | 2015-04-02 | Mcafee, Inc. | One-click reputation adjustment |
-
2013
- 2013-12-20 WO PCT/US2013/076908 patent/WO2015047440A1/en active Application Filing
- 2013-12-20 US US14/913,394 patent/US10749843B2/en active Active
-
2020
- 2020-08-14 US US16/993,660 patent/US20200403977A1/en not_active Abandoned
-
2024
- 2024-06-03 US US18/732,312 patent/US20240323167A1/en active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110252483A1 (en) * | 2006-12-08 | 2011-10-13 | Microsoft Corporation | Reputation-Based Authorization Decisions |
US20080256622A1 (en) * | 2007-04-16 | 2008-10-16 | Microsoft Corporation | Reduction of false positive reputations through collection of overrides from customer deployments |
US20170237754A1 (en) * | 2016-02-17 | 2017-08-17 | Sophos Limited | Evaluating installers and installer payloads |
US20180357086A1 (en) * | 2017-06-13 | 2018-12-13 | Intel Corporation | Container virtual switching |
Non-Patent Citations (3)
Title |
---|
Denchy, Mark "The Publish/Subscribe Model: You gave the message to whom?", EXTOL Technology Blog, August 17th, 2009 (Year: 2009) * |
NPL Search Terms (Year: 2023) * |
Tarkoma, Sasu. Publish/subscribe systems: design and principles. John Wiley & Sons, 2012 (Year: 2012) * |
Also Published As
Publication number | Publication date |
---|---|
WO2015047440A1 (en) | 2015-04-02 |
US10749843B2 (en) | 2020-08-18 |
US20240323167A1 (en) | 2024-09-26 |
US20160205073A1 (en) | 2016-07-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11902388B2 (en) | Service-oriented architecture | |
US10715556B2 (en) | Real-time policy distribution | |
US10447714B2 (en) | Context-aware network on a data exchange layer | |
US11418605B2 (en) | Efficient request-response routing over a data exchange layer | |
US10142373B2 (en) | Security-connected framework | |
EP3210146B1 (en) | Security orchestration framework | |
US10205798B2 (en) | Merging multiple system trees over a data exchange layer | |
US10904269B2 (en) | Threat intelligence on a data exchange layer | |
US20240323167A1 (en) | One-click reputation adjustment | |
US10237303B2 (en) | Prevalence-based reputations |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
AS | Assignment |
Owner name: UBS AG, STAMFORD BRANCH, AS COLLATERAL AGENT, CONNECTICUT Free format text: FIRST LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:MUSARUBRA US LLC;SKYHIGH NETWORKS, LLC;REEL/FRAME:057453/0053 Effective date: 20210727 Owner name: UBS AG, STAMFORD BRANCH, AS COLLATERAL AGENT, CONNECTICUT Free format text: SECOND LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:MUSARUBRA US LLC;SKYHIGH NETWORKS, LLC;REEL/FRAME:056990/0960 Effective date: 20210727 |
|
AS | Assignment |
Owner name: MUSARUBRA US LLC, CALIFORNIA Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE PROPERTY NUMBERS PREVIOUSLY RECORDED AT REEL: 057315 FRAME: 0001. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT;ASSIGNOR:MCAFEE, LLC;REEL/FRAME:060878/0126 Effective date: 20210726 |
|
AS | Assignment |
Owner name: MUSARUBRA US LLC, TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MCAFEE, LLC;REEL/FRAME:059855/0807 Effective date: 20210726 |
|
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: RESPONSE AFTER FINAL ACTION FORWARDED TO EXAMINER |
|
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: FINAL REJECTION MAILED |
|
AS | Assignment |
Owner name: STG PARTNERS, LLC, CALIFORNIA Free format text: SECURITY INTEREST;ASSIGNORS:MUSARUBRA US LLC;SKYHIGH SECURITY LLC;REEL/FRAME:068324/0731 Effective date: 20240730 |
|
AS | Assignment |
Owner name: MAGENTA SECURITY HOLDINGS LLC, TEXAS Free format text: INTELLECTUAL PROPERTY ASSIGNMENT AGREEMENT;ASSIGNOR:MAGENTA SECURITY INTERMEDIATE HOLDINGS LLC;REEL/FRAME:068656/0920 Effective date: 20240814 Owner name: MAGENTA SECURITY HOLDINGS LLC, TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MAGENTA SECURITY INTERMEDIATE HOLDINGS LLC;REEL/FRAME:068657/0843 Effective date: 20240814 Owner name: MAGENTA SECURITY INTERMEDIATE HOLDINGS LLC, TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MUSARUBRA US LLC;REEL/FRAME:068657/0764 Effective date: 20240814 Owner name: UBS AG, STAMFORD BRANCH, AS COLLATERAL AGENT, CONNECTICUT Free format text: FIRST LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:MAGENTA SECURITY HOLDINGS LLC;SKYHIGH SECURITY LLC;REEL/FRAME:068657/0666 Effective date: 20240814 Owner name: MAGENTA SECURITY INTERMEDIATE HOLDINGS LLC, TEXAS Free format text: INTELLECTUAL PROPERTY ASSIGNMENT AGREEMENT;ASSIGNOR:MUSARUBRA US LLC;REEL/FRAME:068656/0098 Effective date: 20240814 Owner name: MUSARUBRA US LLC, TEXAS Free format text: TERMINATION AND RELEASE OF SECOND LIEN SECURITY INTEREST IN CERTAIN PATENTS RECORDED AT REEL 056990, FRAME 0960;ASSIGNOR:UBS AG, STAMFORD BRANCH, AS COLLATERAL AGENT;REEL/FRAME:068655/0430 Effective date: 20240814 Owner name: MUSARUBRA US LLC, TEXAS Free format text: TERMINATION AND RELEASE OF FIRST LIEN SECURITY INTEREST IN CERTAIN PATENTS RECORDED AT REEL 057453, FRAME 0053;ASSIGNOR:UBS AG, STAMFORD BRANCH, AS COLLATERAL AGENT;REEL/FRAME:068655/0413 Effective date: 20240814 |
|
AS | Assignment |
Owner name: SKYHIGH SECURITY LLC, TEXAS Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:STG PARTNERS, LLC;REEL/FRAME:068671/0435 Effective date: 20240814 Owner name: MUSARUBRA US LLC, TEXAS Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:STG PARTNERS, LLC;REEL/FRAME:068671/0435 Effective date: 20240814 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |