A tunneling client to Newt sites https://docs.fossorial.io
Find a file
2026-04-27 20:13:48 -07:00
.github Add CODEOWNERS 2026-04-07 11:34:38 -04:00
api Add api endpoints to jit 2026-03-04 17:01:17 -08:00
device set mtu to 0 on darwin 2026-01-01 17:38:01 -05:00
dns Merge pull request #100 from LaurenceJJones/fix/issue-38-stale-dns-cleanup 2026-04-07 21:26:38 -04:00
olm Get peer manager 2026-03-20 17:28:39 -07:00
peers Basic route selector working 2026-04-13 18:24:11 -07:00
websocket Remove redundant info 2026-03-16 13:50:21 -07:00
.dockerignore Fix docker ignore 2025-12-08 14:05:48 -05:00
.gitignore Package? 2025-11-01 18:34:00 -07:00
.go-version Update .go-version 2025-08-28 17:26:43 +02:00
API.md Merge branch 'main' into dev 2026-01-23 10:22:21 -08:00
config.go Default override dns to true 2026-02-02 10:03:22 -08:00
CONTRIBUTING.md Update domains 2025-10-19 15:12:37 -07:00
create_test_creds.py Create test creds python script 2025-11-25 21:05:41 -05:00
docker-compose.yml added docker version of olm 2025-08-31 07:22:32 +00:00
Dockerfile Update dockerfile for new version 2026-03-17 11:27:44 -07:00
entrypoint.sh Rename to olm 2025-02-21 12:31:25 -05:00
get-olm.sh Update get olm script to work with sudo 2025-09-28 11:41:07 -07:00
go.mod Update newt 2026-04-27 20:13:20 -07:00
go.sum Update newt 2026-04-27 20:13:20 -07:00
LICENSE Add license 2025-01-04 21:22:32 -05:00
main.go Update cicd 2026-03-16 17:52:40 -07:00
Makefile Update cicd 2026-03-16 17:52:40 -07:00
namespace.sh Add namespace test script 2025-11-18 10:34:49 -05:00
olm.iss Update iss 2026-02-25 14:57:56 -08:00
README.md Mention the cli 2026-04-19 15:49:08 -07:00
SECURITY.md Update domains 2025-10-19 15:12:37 -07:00
service_unix.go Add update checks, log rotation, and message timeouts (#42) 2025-10-08 17:48:50 -07:00
service_windows.go Adapt args to work on windows 2025-12-07 17:44:10 -05:00

Olm

Olm is being phased out in favor of the Pangolin CLI and is only meant for advanced use cases.

Olm is a WireGuard tunnel client designed to securely connect your computer to Newt sites running on remote networks.

Installation and Documentation

Olm is used with Pangolin and Newt as part of the larger system. See documentation below:

Key Functions

Registers with Pangolin

Using the Olm ID and a secret, the olm will make HTTP requests to Pangolin to receive a session token. Using that token, it will connect to a websocket and maintain that connection. Control messages will be sent over the websocket.

Receives WireGuard Control Messages

When Olm receives WireGuard control messages, it will use the information encoded (endpoint, public key) to bring up a WireGuard tunnel on your computer to a remote Newt. It will ping over the tunnel to ensure the peer is brought up.

Hole Punching

In the default mode, olm uses both relaying through Gerbil and NAT hole punching to connect to Newt. Hole punching attempts to orchestrate a NAT traversal between the two sites so that traffic flows directly, which can save data costs and improve speed. If hole punching fails, traffic will fall back to relaying through Gerbil.

Build

Binary

Make sure to have Go 1.25 installed.

make

Licensing

Olm is dual licensed under the AGPLv3 and the Fossorial Commercial license. For inquiries about commercial licensing, please contact us.

Contributions

Please see CONTRIBUTIONS in the repository for guidelines and best practices.