All Projects → microsoft → Krabsetw

microsoft / Krabsetw

Licence: other
KrabsETW provides a modern C++ wrapper and a .NET wrapper around the low-level ETW trace consumption functions.

Labels

Projects that are alternatives of or similar to Krabsetw

Android Pwa Wrapper
Android Wrapper to create native Android Apps from offline-capable Progressive Web Apps
Stars: ✭ 265 (-19.7%)
Mutual labels:  wrapper
Node Zendesk
a zendesk API client library for use with node.js
Stars: ✭ 288 (-12.73%)
Mutual labels:  wrapper
Physx Rs
🎳 Rust binding and wrapper over NVIDIA PhysX 🦀
Stars: ✭ 310 (-6.06%)
Mutual labels:  wrapper
Twitchio
TwitchIO - An Async Bot/API wrapper for Twitch made in Python.
Stars: ✭ 268 (-18.79%)
Mutual labels:  wrapper
Pypresence
A complete Discord IPC and Rich Presence wrapper library in Python!
Stars: ✭ 277 (-16.06%)
Mutual labels:  wrapper
Uikitplus
🏰 Declarative UIKit with LivePreview for iOS9+ (best alternative to SwiftUI)
Stars: ✭ 294 (-10.91%)
Mutual labels:  wrapper
Tinyengine
Tiny OpenGL Wrapper / 3D Engine in C++
Stars: ✭ 251 (-23.94%)
Mutual labels:  wrapper
Python Snap7
A Python wrapper for the snap7 PLC communication library
Stars: ✭ 317 (-3.94%)
Mutual labels:  wrapper
Node Watch
A wrapper and enhancements for fs.watch
Stars: ✭ 282 (-14.55%)
Mutual labels:  wrapper
Canvasapi
Python API wrapper for Instructure's Canvas LMS. Easily manage courses, users, gradebooks, and more.
Stars: ✭ 306 (-7.27%)
Mutual labels:  wrapper
Steamtinkerlaunch
Linux wrapper tool for use with the Steam client for custom launch options and 3rd party programs
Stars: ✭ 271 (-17.88%)
Mutual labels:  wrapper
Pyopenpose
Python bindings for the Openpose library
Stars: ✭ 277 (-16.06%)
Mutual labels:  wrapper
Meshpy
2D/3D simplicial mesh generator interface for Python (Triangle, TetGen, gmsh)
Stars: ✭ 297 (-10%)
Mutual labels:  wrapper
Ios Pwa Wrapper
An iOS Wrapper application to create a native iOS App from an offline-capable Progressive Web App.
Stars: ✭ 268 (-18.79%)
Mutual labels:  wrapper
Jni.hpp
A modern, type-safe, header-only, C++14 wrapper for JNI
Stars: ✭ 313 (-5.15%)
Mutual labels:  wrapper
Python Blosc
A Python wrapper for the extremely fast Blosc compression library
Stars: ✭ 264 (-20%)
Mutual labels:  wrapper
Opencvsharp
OpenCV wrapper for .NET
Stars: ✭ 3,598 (+990.3%)
Mutual labels:  wrapper
Dokan Dotnet
Dokan DotNet Wrapper
Stars: ✭ 322 (-2.42%)
Mutual labels:  wrapper
Pokedex Promise V2
An easy way to use pokeapi v2 with promises in node.js
Stars: ✭ 315 (-4.55%)
Mutual labels:  wrapper
Pyupdater
Pyinstaller auto-update library
Stars: ✭ 300 (-9.09%)
Mutual labels:  wrapper

Overview

krabsetw is a C++ library that simplifies interacting with ETW. It allows for any number of traces and providers to be enabled and for client code to register for event notifications from these traces.

krabsetw also provides code to simplify parsing generic event data into strongly typed data types.

Microsoft.O365.Security.Native.ETW is a C++ CLI (.NET) wrapper around krabsetw. It provides the same functionality as krabsetw to .NET applications and is used in production by the Office 365 Security team. It's affectionately referred to as Lobsters.

Examples & Documentation

Important Notes

  • krabsetw and Microsoft.O365.Security.Native.ETW only support x64. No effort has been made to support x86.
  • krabsetw and Microsoft.O365.Security.Native.ETW are only supported on Windows 7 or Windows 2008R2 machines and above.
  • Throwing exceptions in the event handler callback or krabsetw or Microsoft.O365.Security.Native.ETW will cause the trace to stop processing events.
  • The call to "start" on the trace object is blocking so thread management may be necessary.
  • The Visual Studio solution is krabs\krabs.sln.
  • When building a native code binary using the krabsetw package, please refer to the compilation readme for notes about the TYPEASSERT and NDEBUG compilation flags.

NuGet Packages

NuGet packages are available both for the krabsetw C++ headers and the Microsoft.O365.Security.Native.ETW .NET library:

For verifying the .NET binaries, you can use the following command: sn -T Microsoft.O365.Security.Native.ETW.dll

The expected output is:

Microsoft (R) .NET Framework Strong Name Utility  Version 4.0.30319.0
Copyright (c) Microsoft Corporation.  All rights reserved.

Public key token is 31bf3856ad364e35

Community & Contact

Please feel free to file issues through GitHub for bugs and feature requests and we'll respond to them as quickly as we're able.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].