wireguard-go
docs
wireguard-go | docs | |
---|---|---|
14 | 12 | |
2,729 | 4,959 | |
2.5% | 0.6% | |
6.3 | 9.8 | |
about 1 month ago | 5 days ago | |
Go | Shell | |
MIT License | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
wireguard-go
-
Writing highly scalable backends in UDP
Would you accept https://github.com/WireGuard/wireguard-go/blob/master/tun/ne... as a solution? =)
-
WireGuard client that exposes itself as a HTTP/SOCKS5 proxy
Maybe https://github.com/cloudflare/boringtun or https://github.com/WireGuard/wireguard-go ?
-
The Tailscale Universal Docker Mod
It's likely just `tailscale serve https / `.
https://github.com/tailscale/tailscale/blob/main/ipn/serve.g...
And they also support direct embedding:
https://tailscale.dev/blog/embedded-funnel
I think this is built on the wireguard-go + gvisor mashup, that allows you to do this with just Wireguard:
https://github.com/WireGuard/wireguard-go/tree/master/tun/ne...
One of my favorite applications of this is this little tool that turns Wireguard VPNs into SOCKS5 proxies (which you can selectively enable in your browser)
https://pkg.go.dev/github.com/octeep/wireproxy
-
Speed tests for Tailscale, Wireguard and Zerotier
They added this pull-request to wireguard-go and i assume they have already included it in their new version.
-
Show HN: Wiretap – Transparent WireGuard proxy server without root
Vanilla WireGuard doesn't provide a way to run a peer in userspace that can proxy traffic between another peer and an endpoint such as a web server because you need to be privileged to do thinks like work with raw packets. However, https://github.com/WireGuard/wireguard-go is a userspace implementation of WireGuard and has recently incorporated Google's userspace networking stack. This project uses these two userspace tools to "fake" a privileged WireGuard peer that proxies TCP, UDP, and (a small subset of) ICMP. It was written as a pentesting/red team utility for my team but it can also serve as a general makeshift VPN when you don't have privileges on a box you want to proxy through.
-
How to program a vpn (for fun)
How "scratch" do you want to go from? Do you want to write your own virtual network driver, or do you want to use an existing driver like Wintun? Either way learning about Wintun would be a good start. Then there's the protocol, regardless of what language you learn, the wireguard-go implementation is a very good example of how to implement a secure protocol with modern language.
-
Wireguard not working on Xen virtualization
https://github.com/cloudflare/boringtun https://github.com/WireGuard/wireguard-go
-
Show HN: Onetun, a cross-platform WireGuard port-forwarder
wireguard-go (the official userspace impl in golang) can do this since several months back. It uses gVisor's netstack as a tcp/udp provider to forward connections to its peer.
Here's a demonstration of both a http-client and a http-server running over wireguard (a poor man's QUIC): https://github.com/WireGuard/wireguard-go/tree/master/tun/ne...
fly.io wrote about such setups not long ago too: https://news.ycombinator.com/item?id=26315695
And tailscale.com uses a similar setup (with netstack) on non-Linux/xBSD platforms: https://news.ycombinator.com/item?id=28261683
-
Userspace WireGuard for armv7-linux-gnueabi
I think you can try wireguard-go,
-
Netaddr.ip: a new IP address type for Go
> The story begins in April 2019 with 89476f8cb5 in which David Crawshaw, aware of all these problems, created an IP type like:
It's in a PR here: https://github.com/WireGuard/wireguard-go/pull/11/files
Which mentions:
> Typically throughout WireGuard, we've used [4]byte for v4 and [16]byte for v6, considering the Go standard library's choice of v6-mapped-v4 to be a mistake.
It actually looks useful, there's something similar in wgtypes, and I wanted to use it recently [0] but that package unfortunately doesn't expose a way to write it out to a string/buffer, so I ended up almost replicating it.
[0] https://github.com/OJFord/terraform-provider-wireguard/blob/...
(There's a lot of ways of presenting/parsing/constructing the same config options there! I'm sure if I were more fluent in Go there's some more succinct way.)
docs
- The Tailscale Universal Docker Mod
-
Modern Perl Catalyst: Docker Setup
I will recommend you review the documentation for the official Postgresql docker images which you can read here.
- Changing parameter during container "boot"
-
Using PostgreSQL Official Docker image on Windows 10 and Ubuntu 22.10 kinetic.
This is the full documentation for these images. Please note, this page has links to Docker official documents on volumes, etc., which are necessary to run images such as this.
-
Dockerizing a Node.js / Express app from the very first [Part 2]
We've just followed the official documentation to add a PostgreSQL database server. This will act as an application container, as our app will soon be depended on it. And in order to make sure that the database container is always started whenever we start our application container, we've added a new depends_on key to the app service and let it know which other service(s) it, well, depends on. This will make sure that the database server is up and running before the app. You may also have noticed that we've mounted volume to our database server's datapath a bit differently. This is known as "named volume". We'll discuss it a bit more in another part, it's not relevant to what we're learning here.
-
Best way to sync and share files between machines
Nextcloud isn't hard to setup, follow the official doc https://github.com/docker-library/docs/blob/master/nextcloud/README.md
-
Nextcloud setup
Looking at the setup for this (link here: https://github.com/docker-library/docs/blob/master/nextcloud/README.md), I am starting to understand a lot of the recent posts that we've seen & how much of a mess it still is :(
-
How to begin with Docker if I want the best security for my websites?
Coming back to nextcloud, the official readme of the nextcloud image has a few notes on how to set up both nextcloud versions.
-
How to hide authorisation credentials in nginx.conf?
Use the native command envstubst to replace the Auth Tokens in your Config File before starting NGINX. Example: https://github.com/docker-library/docs/tree/master/nginx#using-environment-variables-in-nginx-configuration-new-in-119
-
Stuck with docker-compose, Nextcloud and Nginx
It's not clear why you want to split the web server (nginx) and the app (nextcloud). However, if you do have a good reason, you're in luck, they have a compose file that does just that: https://github.com/docker-library/docs/blob/master/nextcloud/README.md#base-version---fpm (version 2, but it'll work)
What are some alternatives?
boringtun - Userspace WireGuard® Implementation in Rust
docker - ⛴ Docker image of Nextcloud
set - Package set is a small wrapper around the official reflect package that facilitates loose type conversion and assignment into native Go types.
docker-socket-proxy - Proxy over your Docker socket to restrict which requests it accepts
wireguard-install - WireGuard VPN installer for Linux servers
sqitch - Sensible database change management
goja - ECMAScript/JavaScript engine in pure Go
ContactsDemo - Example Catalyst Application
go - The Go programming language
maildev - :mailbox: SMTP Server + Web Interface for viewing and testing emails during development.
onetun - User space WireGuard port-forward in Rust
tinybastion - wireguard bastion with OIDC auth