direct connection to node (hole punching) #19

Closed
opened 2 years ago by x1ddos · 1 comments
x1ddos commented 2 years ago
Owner

at the moment, direct connection to the node is possible only via tech-savvy configuration of a home router and other tricks like ipv6. tor as an alternative is slow and unreliable.

a "zero conf" direct connection from a client app like zap or zeus has been one of the goals of the project from the start. however, hole punching doesn't always work, in which case an intermediary relay is required. a client and the node also need a handshake server. additional requirement is open source, at least the self-hosted bits.

i believe nebula is the best candidate to start with:

later could also implement some alternatives.

NOTE: tor is still available for those who wants it. UI-wise, probably a "route all traffic through tor" toggle would make sense. turning it "on" should then disable direct connections. #8 (setup wizard) and #10 (lnd tab; client pairing) are also related to this.

alternatives

innernet

similar in its goals to Slack's nebula or Tailscale, but takes a bit of a different approach. It aims to take advantage of existing networking concepts like CIDRs and the security properties of WireGuard to turn your computer's basic IP networking into more powerful ACL primitives.

one disadvantage is, would need to build own android and ios client apps. otherwise, a pretty good alternative to nebula.

zerotier

  • weird BSL (business) license; unclear what constitutes a business use
  • only JNI wrapper is open source, not the rest of mobile apps; found only a reverse-engineered android app
  • a more complicated self-hosted setup

tailscale

  • not everything is open source; specifically, the controller server is closed sourced
  • an alternative controller exists - headscale - but it is again a reverse-engineered from the original

i've considered quite a few others: they are either more complicated to setup, implement other things or not fully open source.

nostr

  • very much in flux
  • would probably require a somewhat more involved changes to client apps and the node using nip-04
  • nip-04, the direct messages, is considered suboptimal but no alternative nips exist atm

other resources

at the moment, direct connection to the node is possible only via tech-savvy configuration of a home router and other tricks like ipv6. tor as an alternative is slow and unreliable. a "zero conf" direct connection from a client app like zap or zeus has been one of the goals of the project from the start. however, hole punching doesn't always work, in which case an intermediary relay is required. a client and the node also need a handshake server. additional requirement is open source, at least the self-hosted bits. i believe [nebula](https://github.com/slackhq/nebula) is the best candidate to start with: - [simple architecture](https://nebula.defined.net/docs/#technical-details) for self-hosted - uses noise protocol and PKI for mutual auth - single binary - has an android and ios opensource apps at https://github.com/DefinedNet/mobile_nebula later could also implement some alternatives. **NOTE**: tor is still available for those who wants it. UI-wise, probably a "route all traffic through tor" toggle would make sense. turning it "on" should then disable direct connections. #8 (setup wizard) and #10 (lnd tab; client pairing) are also related to this. ## alternatives [innernet](https://github.com/tonarino/innernet/) > similar in its goals to Slack's nebula or Tailscale, but takes a bit of a different approach. It aims to take advantage of existing networking concepts like CIDRs and the security properties of WireGuard to turn your computer's basic IP networking into more powerful ACL primitives. one disadvantage is, would need to build own android and ios client apps. otherwise, a pretty good alternative to nebula. [zerotier](https://zerotier.com) - weird BSL (business) license; unclear what constitutes a business use - only JNI wrapper is open source, not the rest of mobile apps; found only a [reverse-engineered android app](https://github.com/kaaass/zerotierfix) - a more complicated [self-hosted](https://docs.zerotier.com/self-hosting/introduction) setup [tailscale](https://tailscale.com) - not everything is open source; specifically, the controller server is closed sourced - an alternative controller exists - [headscale](https://github.com/juanfont/headscale) - but it is again a reverse-engineered from the original i've considered quite a few others: they are either more complicated to setup, implement other things or not fully open source. [nostr](https://github.com/nostr-protocol/nostr) - very much in flux - would probably require a somewhat more involved changes to client apps and the node using [nip-04](https://github.com/nostr-protocol/nips/blob/master/04.md) - nip-04, the direct messages, is considered suboptimal but no alternative nips exist atm ## other resources - a good list of existing tunnelling solutions: https://github.com/anderspitman/awesome-tunneling - a nice write up on complexiting of "punching a hole": https://tailscale.com/blog/how-nat-traversal-works/ - small UPnP library: http://miniupnp.free.fr/
x1ddos added the
sys
label 2 years ago
x1ddos added a new dependency 2 years ago
x1ddos added a new dependency 2 years ago
x1ddos removed a dependency 2 years ago
x1ddos removed a dependency 2 years ago
Poster
Owner
moved to https://github.com/nakamochi/ndg/issues/4
x1ddos closed this issue 8 months ago
This repo is archived. You cannot comment on issues.
No Milestone
No project
No Assignees
1 Participants
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.

No due date set.

Dependencies

No dependencies set.

Reference: nakamochi/ndg#19
Loading…
There is no content yet.