Adam Ierymenko af4e79735c Fix "orbit" semantics. Federation works. il y a 8 ans
..
Address.hpp 31db768e4d A bit of code cleanup. il y a 9 ans
Array.hpp 4e4fd51117 boring doc stuff il y a 10 ans
AtomicCounter.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. il y a 9 ans
Buffer.hpp 8f2a42d1ad allow user to specify arbitrary allowed IP networks in allowManaged il y a 9 ans
C25519.cpp 38433e85bf More little stuff in crypto code. il y a 11 ans
C25519.hpp 4e4fd51117 boring doc stuff il y a 10 ans
Capability.cpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. il y a 9 ans
Capability.hpp 672f17c6e9 Add a mask and value range to the IP tos rule field. This allows TOS to be matched more usefully. This will break anyone using tos in the beta, but nobody seems to be and its pre-release so now is the time. il y a 9 ans
CertificateOfMembership.cpp 56febbf2ba . il y a 9 ans
CertificateOfMembership.hpp 32fa061700 Compute credential TTL et al. il y a 9 ans
CertificateOfRepresentation.hpp 3587aa1ea7 Add and send certificates of representation to tell people what our valid upstreams are. These are not used yet but will be needed for future privacy modes, etc. Also some cleanup. il y a 9 ans
Cluster.cpp dcb1233b0d Slight refactor to RENEDEZVOUS sending code for federation. il y a 9 ans
Cluster.hpp 29ec7bf3a2 Add more specific check in source==self case instead of dumping it. il y a 9 ans
Constants.hpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
Dictionary.hpp 15c07c58b6 Refactored network config chunking to sign every chunk to prevent stupid DOS attack potential, and implement network config fast propagate (though we probably will not use this for a bit). il y a 9 ans
Hashtable.hpp 8a2e8bd585 Rework how paths are set as remote cluster preferred. The code is now clearer and cluster preference indications are now very sticky as they should be. il y a 9 ans
Identity.cpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
Identity.hpp 7036831203 Sign Dictionary in doNETWORK_CONFIG_REQUEST. il y a 9 ans
IncomingPacket.cpp af4e79735c Fix "orbit" semantics. Federation works. il y a 8 ans
IncomingPacket.hpp d5528e4e9a Wire up VERB_USER_MESSAGE in core. il y a 9 ans
InetAddress.cpp 6a50291aa2 Fix the case for InetAddress::containsAddress for IPv6 route of :: il y a 9 ans
InetAddress.hpp 25f9c294dc Small bug fix and warning removal. il y a 9 ans
MAC.hpp 4e4fd51117 boring doc stuff il y a 10 ans
Membership.cpp cdc289fa9c Tags work. il y a 9 ans
Membership.hpp 78d548458b Capabilities basically work but need to refactor a bit for performance reasons. il y a 9 ans
MulticastGroup.hpp dbf3e6c3c9 Dead code removal. il y a 9 ans
Multicaster.cpp 1615ef1114 Rename getBestRoot() etc. il y a 9 ans
Multicaster.hpp 1346e31a8e Windows build fixes, Software update fix, warning removal. il y a 9 ans
Mutex.hpp 4e4fd51117 boring doc stuff il y a 10 ans
Network.cpp cdc289fa9c Tags work. il y a 9 ans
Network.hpp ed31cb76d6 Fix to cluster network configs. il y a 9 ans
NetworkConfig.cpp 31db768e4d A bit of code cleanup. il y a 9 ans
NetworkConfig.hpp 0b3b994241 Relay policy can now be computed. il y a 9 ans
NetworkController.hpp 226123ca08 Refactor controller to permit sending of pushes as well as just replies to config requests. il y a 9 ans
Node.cpp 4b11566505 Integrate moon concept into http config bus, and clean up that code quite a bit. il y a 8 ans
Node.hpp 4b11566505 Integrate moon concept into http config bus, and clean up that code quite a bit. il y a 8 ans
NonCopyable.hpp 4e4fd51117 boring doc stuff il y a 10 ans
OutboundMulticast.cpp cc4bacc199 Cleanup, and implement compression disable flag for networks. il y a 9 ans
OutboundMulticast.hpp cc4bacc199 Cleanup, and implement compression disable flag for networks. il y a 9 ans
Packet.cpp e0d63c50db One more tweak after thinking about related keys and key stream reuse. Just a precaution. il y a 9 ans
Packet.hpp 803f74634a Tweak how we do crypto of the masked portions of HELLO just to be more "boring" in the DJB sense. il y a 9 ans
Path.cpp a3bdae9735 Work in progress: Path canonicalization refactor. il y a 9 ans
Path.hpp 5b6d27e659 Implement relay policy, and setting multicast limit to 0 now disables multicast on the network as would be expected. il y a 9 ans
Peer.cpp e4b6611201 Only accept world updates from upstreams. il y a 8 ans
Peer.hpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
Poly1305.cpp c952fbbd8d Only enable 128-bit Poly1305 on X86_64 right now. Has compilation issues on ARM, but the 64-bit version should be fine. il y a 10 ans
Poly1305.hpp 4e4fd51117 boring doc stuff il y a 10 ans
README.md 8a2ff0b31e Actual documentation. il y a 9 ans
Revocation.cpp 1f74dd4589 Revocation work in progress, add WATCH which is TEE with implicit rate sync (thanks JG@DCVC!), and clean up some cruft in Network. il y a 9 ans
Revocation.hpp 3587aa1ea7 Add and send certificates of representation to tell people what our valid upstreams are. These are not used yet but will be needed for future privacy modes, etc. Also some cleanup. il y a 9 ans
RuntimeEnvironment.hpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. il y a 9 ans
SHA512.cpp 4e4fd51117 boring doc stuff il y a 10 ans
SHA512.hpp 4e4fd51117 boring doc stuff il y a 10 ans
Salsa20.cpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
Salsa20.hpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
SelfAwareness.cpp d3524f3609 Refactor COM stuff a bit, and respond to COM requests a bit more readily for rapid setup. Will need to revisit later. il y a 9 ans
SelfAwareness.hpp b5c86b6ba4 Bunch more path refactoring. Peers no longer forget paths, but do not normally use expired paths. Expired paths might still be tried if nothing else is reachable. il y a 9 ans
SharedPtr.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. il y a 9 ans
Switch.cpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. il y a 9 ans
Switch.hpp d9e4ba1280 Eliminate a little copypasta. il y a 9 ans
Tag.cpp 1f74dd4589 Revocation work in progress, add WATCH which is TEE with implicit rate sync (thanks JG@DCVC!), and clean up some cruft in Network. il y a 9 ans
Tag.hpp 3587aa1ea7 Add and send certificates of representation to tell people what our valid upstreams are. These are not used yet but will be needed for future privacy modes, etc. Also some cleanup. il y a 9 ans
Topology.cpp af4e79735c Fix "orbit" semantics. Federation works. il y a 8 ans
Topology.hpp af4e79735c Fix "orbit" semantics. Federation works. il y a 8 ans
Utils.cpp 42f28bce52 Cleanup and make moons (federated roots) a little easier to deal with. il y a 8 ans
Utils.hpp 42f28bce52 Cleanup and make moons (federated roots) a little easier to deal with. il y a 8 ans
World.hpp 4b11566505 Integrate moon concept into http config bus, and clean up that code quite a bit. il y a 8 ans

README.md

ZeroTier Network Hypervisor Core

This directory contains the real ZeroTier: a completely OS-independent global virtual Ethernet switch engine. This is where the magic happens.

Give it wire packets and it gives you Ethernet packets, and vice versa. The core contains absolutely no actual I/O, port configuration, or other OS-specific code (except Utils::getSecureRandom()). It provides a simple C API via /include/ZeroTierOne.h. It's designed to be small and maximally portable for future use on small embedded and special purpose systems.

Code in here follows these guidelines:

  • Keep it minimal, especially in terms of code footprint and memory use.
  • There should be no OS-dependent code here unless absolutely necessary (e.g. getSecureRandom).
  • If it's not part of the core virtual Ethernet switch it does not belong here.
  • No C++11 or C++14 since older and embedded compilers don't support it yet and this should be maximally portable.
  • Minimize the use of complex C++ features since at some point we might end up "minus-minus'ing" this code if doing so proves necessary to port to tiny embedded systems.