Adam Ierymenko 010d0a7d56 Docs and a bit of cleanup. In particular ALL makes no sense for revocations because they have IDs. In that case you would just revoke the COM. пре 9 година
..
Address.hpp 31db768e4d A bit of code cleanup. пре 9 година
Array.hpp 4e4fd51117 boring doc stuff пре 10 година
AtomicCounter.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. пре 9 година
Buffer.hpp 2bf9145ae6 Outgoing side of packet counter for link quality reporting. Also some cleanup and a cluster mode build fix. пре 9 година
C25519.cpp 38433e85bf More little stuff in crypto code. пре 11 година
C25519.hpp 4e4fd51117 boring doc stuff пре 10 година
Capability.cpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. пре 9 година
Capability.hpp 010d0a7d56 Docs and a bit of cleanup. In particular ALL makes no sense for revocations because they have IDs. In that case you would just revoke the COM. пре 9 година
CertificateOfMembership.cpp 56febbf2ba . пре 9 година
CertificateOfMembership.hpp 32fa061700 Compute credential TTL et al. пре 9 година
CertificateOfOwnership.cpp 72653e54f9 Finish wiring up ipauth and macauth to Network filter. пре 9 година
CertificateOfOwnership.hpp 72653e54f9 Finish wiring up ipauth and macauth to Network filter. пре 9 година
CertificateOfRepresentation.hpp 010d0a7d56 Docs and a bit of cleanup. In particular ALL makes no sense for revocations because they have IDs. In that case you would just revoke the COM. пре 9 година
Cluster.cpp 2bf9145ae6 Outgoing side of packet counter for link quality reporting. Also some cleanup and a cluster mode build fix. пре 9 година
Cluster.hpp 29ec7bf3a2 Add more specific check in source==self case instead of dumping it. пре 9 година
Constants.hpp 0f3148bda2 Roots need to respond to lots of WHOISes пре 9 година
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). пре 9 година
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. пре 9 година
Identity.cpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. пре 9 година
Identity.hpp 7036831203 Sign Dictionary in doNETWORK_CONFIG_REQUEST. пре 9 година
IncomingPacket.cpp 0f3148bda2 Roots need to respond to lots of WHOISes пре 9 година
IncomingPacket.hpp d5528e4e9a Wire up VERB_USER_MESSAGE in core. пре 9 година
InetAddress.cpp 6a50291aa2 Fix the case for InetAddress::containsAddress for IPv6 route of :: пре 9 година
InetAddress.hpp 25f9c294dc Small bug fix and warning removal. пре 9 година
MAC.hpp 4e4fd51117 boring doc stuff пре 10 година
Membership.cpp 010d0a7d56 Docs and a bit of cleanup. In particular ALL makes no sense for revocations because they have IDs. In that case you would just revoke the COM. пре 9 година
Membership.hpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
MulticastGroup.hpp dbf3e6c3c9 Dead code removal. пре 9 година
Multicaster.cpp 1615ef1114 Rename getBestRoot() etc. пре 9 година
Multicaster.hpp 1346e31a8e Windows build fixes, Software update fix, warning removal. пре 9 година
Mutex.hpp 4e4fd51117 boring doc stuff пре 10 година
Network.cpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
Network.hpp 10185e92fa Certificate of ownership -- used to secure against IP address spoofing, especially for IPv4 and regular IPv6. пре 9 година
NetworkConfig.cpp 10185e92fa Certificate of ownership -- used to secure against IP address spoofing, especially for IPv4 and regular IPv6. пре 9 година
NetworkConfig.hpp 10185e92fa Certificate of ownership -- used to secure against IP address spoofing, especially for IPv4 and regular IPv6. пре 9 година
NetworkController.hpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
Node.cpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
Node.hpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
NonCopyable.hpp 4e4fd51117 boring doc stuff пре 10 година
OutboundMulticast.cpp 4436824faf ipauth characteristic now works with ARP пре 9 година
OutboundMulticast.hpp cc4bacc199 Cleanup, and implement compression disable flag for networks. пре 9 година
Packet.cpp 47166c9614 Sigh. Another thinko. пре 9 година
Packet.hpp 5e6a4e5f5e Send revocations automatically on deauth for instant kill, also fix some issues with the RP. пре 9 година
Path.cpp a3bdae9735 Work in progress: Path canonicalization refactor. пре 9 година
Path.hpp a97918f812 Windows build fixes. пре 9 година
Peer.cpp a577b8d381 Update how controller handles circuit tests -- save results to filesystem. пре 9 година
Peer.hpp e3b1fc2ac0 Tweak WHOIS path for federation. пре 9 година
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. пре 10 година
Poly1305.hpp 4e4fd51117 boring doc stuff пре 10 година
README.md 8a2ff0b31e Actual documentation. пре 9 година
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. пре 9 година
Revocation.hpp 010d0a7d56 Docs and a bit of cleanup. In particular ALL makes no sense for revocations because they have IDs. In that case you would just revoke the COM. пре 9 година
RuntimeEnvironment.hpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. пре 9 година
SHA512.cpp 4e4fd51117 boring doc stuff пре 10 година
SHA512.hpp 4e4fd51117 boring doc stuff пре 10 година
Salsa20.cpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. пре 9 година
Salsa20.hpp 43182f8f57 Docs, code cleanup, and protect the extra new fields of HELLO with encryption as a precaution. пре 9 година
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. пре 9 година
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. пре 9 година
SharedPtr.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. пре 9 година
Switch.cpp e3b1fc2ac0 Tweak WHOIS path for federation. пре 9 година
Switch.hpp d9e4ba1280 Eliminate a little copypasta. пре 9 година
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. пре 9 година
Tag.hpp 10185e92fa Certificate of ownership -- used to secure against IP address spoofing, especially for IPv4 and regular IPv6. пре 9 година
Topology.cpp db87d95c1d getUpstreamPeer issue with interim federated roots пре 9 година
Topology.hpp af4e79735c Fix "orbit" semantics. Federation works. пре 9 година
Utils.cpp 42f28bce52 Cleanup and make moons (federated roots) a little easier to deal with. пре 9 година
Utils.hpp 1d39be61b2 ZeroTier now has link quality measurement. We are not using this yet but decided to put it in to prep for future QoS support and SD-WAN stuff. пре 9 година
World.hpp 4b11566505 Integrate moon concept into http config bus, and clean up that code quite a bit. пре 9 година

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.