Giter VIP home page Giter VIP logo

etw-bypass-rust's Introduction

Event Tracing for Windows ETW Bypass in Rust

I have written about this on my blog, check it here!

Event Tracing for Windows (ETW) is a logging framework provided by Microsoft for Windows. ETW allows software developers and system admins to obtain detailed, real-time diagnostic information about system and application behavior. It provides a unified and efficient mechanism for logging system events, tracking application performance, debugging, and monitoring security. ETW operates by defining trace providers, which emit events, and trace sessions, which collect and store these events for analysis.

Endpoint Detection and Response (EDR) solutions leverage ETW to monitor and analyse system events in real-time, enabling the detection and investigation of malicious activities and security threats on endpoints.

ETW can be bypassed in user mode by modifying the address of the NtTraceEvent function in ntdll.dll. This involves patching the syscall stub of NtTraceEvent to change its implementation to a ret (return) instruction. By doing so, any attempts to invoke ETW functionality from user mode are effectively thwarted because the function will immediately return without performing any logging actions.

ETW bypasses are one method of EDR bypassing and EDR evasion.

I use my crate export-resolver to perform resolve the function virtual addresses dynamically via the PEB.

Proof

Before patching:

image

etw-test-1

After patching:

image

etw-test-two

LEGAL DISCLAIMER

This project, including all associated source code and documentation, is developed and shared solely for educational, research, and defensive purposes in the field of cybersecurity. It is intended to be used exclusively by cybersecurity professionals, researchers, and educators to enhance understanding, develop defensive strategies, and improve security postures.

Under no circumstances shall this project be used for criminal, unethical, or any other unauthorized activities. This is meant to serve as a resource for learning and should not be employed for offensive operations or actions that infringe upon any individual's or organization's rights or privacy.

The author of this project disclaims any responsibility for misuse or illegal application of the material provided herein. By accessing, studying, or using this project, you acknowledge and agree to use the information contained within strictly for lawful purposes and in a manner that is consistent with ethical guidelines and applicable laws and regulations.

USE AT YOUR OWN RISK. If you decide to use this software CONDUCT A THOROUGH INDEPENDENT CODE REVIEW to ensure it meets your standards. No unofficial third party dependencies are included to minimise attack surface of a supply chain risk. I cannot be held responsible for any problems that arise as a result of executing this, the burden is on the user of the software to validate its safety & integrity. All care has been taken to write safe code.

It is the user's responsibility to comply with all relevant local, state, national, and international laws and regulations related to cybersecurity and the use of such tools and information. If you are unsure about the legal implications of using or studying the material provided in this project, please consult with a legal professional before proceeding. Remember, responsible and ethical behavior is paramount in cybersecurity research and practice. The knowledge and tools shared in this project are provided in good faith to contribute positively to the cybersecurity community, and I trust they will be used with the utmost integrity.

etw-bypass-rust's People

Contributors

0xflux avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.