An open-source reimplementation of the defined.net management protocol
Find a file
2023-05-30 21:51:57 -04:00
.idea yo es un dumbass 2023-04-03 13:28:12 -04:00
api tfclient enrollment successful 2023-03-28 12:16:00 -04:00
dnapi-rs code cleanup 2023-05-15 14:51:27 -04:00
tfclient hotfix! re-enable nebula thread on tfclient 2023-05-28 16:13:35 -04:00
tfweb work 2023-05-30 21:51:57 -04:00
trifid-api work 2023-05-30 21:51:57 -04:00
trifid-pki code cleanup 2023-05-15 14:51:27 -04:00
.env buildfiles pt5 2023-02-07 14:00:57 -05:00
.gitignore Merge remote-tracking branch 'origin/feat-new-api' 2023-05-11 17:19:03 -04:00
Cargo.lock [trifid-api] dnclient endpoint, client updates and trifid-api MVP 2023-05-15 13:39:15 -04:00
Cargo.toml redo trifid-api with actix+sea-orm 2023-04-02 13:06:16 -04:00
index.md typo 2023-04-08 09:39:41 -04:00
LICENSE.txt licensing 2023-02-27 20:50:31 -05:00
README.md project documentation 2023-03-30 12:45:18 -04:00

trifid

trifid is an open-souce reimplementation of the Defined Networking management protocol for Nebula networks.

It includes a reimplementation of the API Server, the Web UI, dnclient, nebula-cert and dnapi - all fully API-compatible with the original versions.

We also include a Rust library for interacting with keys and certificates in the Nebula PKI. Find it in trifid-pki/, or on crates.rs as trifid-pki.

Want to make your own Defined Networking client? Check out dnapi-rs! dnapi-rs is a Rust port of the official dnapi Go library, to allow for easy interactions with Defined Networking-compatible API servers. Find it in dnapi-rs/, or on crates.rs as dnapi-rs.

The API implementation is tested with the official dnclient implementaiton, and the dnclient implementation is tested with the official API server, to ensure complete feature parity between the two.

The original Web UI does not work with trifid-api quite yet, as we haven't finished reverse engineering that API. Feature table below:

Features

trifid-api feature table:

Feature trifid-api api.defined.net
Enroll in sites with dnclient Yes Yes
Automatic config update polling by dnclient Not yet Yes
Group-based firewalling Not yet Yes
SSO authentication Not yet Yes
Open-source server Yes No

tfclient feature table:

Feature tfclient dnclient
Enroll in trifid-api/api.defined.net sites Yes Yes
Automatic VPN profile setup Yes Yes
Poll the API server for config updates Yes Yes
Secure Ed25519 signing for API communication Yes Yes