Skip to content

JIT for WireGuard. Open Source and MIT Licensed. Based on the explanation by Fly.io on their website.

Notifications You must be signed in to change notification settings

realrasengan/wg-jit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 

Repository files navigation

JIT (for WireGuard)

Inserts a BPF filter that filters for UDP packets to the WireGuard port. If detected, it sends the packet to userland. Then, it filters for the handshake Initiator packets and extracts the static public key after deriving the shared key.

"WireGuard" and the "WireGuard" logo are registered trademarks of Jason A. Donenfeld.

Purpose

I saw this article on HN about Wireguard JIT. I thought this would be really useful but I couldn't find the source code online.

Luckily, it was described in words so of course I turned it into code.

I actually saw this earlier, but I was giving a talk at the Handycon conference so I was nervous and dealing with that.

Sorry if anyone was trying to figure this out!

Notes

I got all the Noise code from wireguard-go and copy pasted it at the bottom.

How to Use

  1. Get Go

  2. Install the modules listed in the import

  3. Then you can just run it

go run wg.go -privatekey KEY -port PORT -iface INTERFACE

PORT is optional, but KEY and INTERFACE must be there. INTERFACE is like eth0 or enp2s50 and KEY is like "base64-encoded-wireguard-private-key"

Copyright

Copyright (c) 2024 Andrew Lee [email protected]

All Rights Reserved

MIT Licensed

About

JIT for WireGuard. Open Source and MIT Licensed. Based on the explanation by Fly.io on their website.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages