Adam Ierymenko c9ee8612e4 Credential TTL (tags/capabilities) should be credential time max delta, since we could get pushed one that is newer. 9 năm trước cách đây
..
Address.hpp b9dba97fdb Bunch more refactoring for an even more compact NetworkConfig representation, especially rules. 9 năm trước cách đây
Array.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
AtomicCounter.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. 9 năm trước cách đây
Buffer.hpp 529515d1d1 Changes to how new-style binary network configs are detected, and a new-style binary serialized meta-data representation. 9 năm trước cách đây
C25519.cpp 38433e85bf More little stuff in crypto code. 11 năm trước cách đây
C25519.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
Capability.cpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. 9 năm trước cách đây
Capability.hpp 74afef8eb1 Think through and refine a few things in rules, especially edge case TEE and REDIRECT behavior and semantics. 9 năm trước cách đây
CertificateOfMembership.cpp 56febbf2ba . 9 năm trước cách đây
CertificateOfMembership.hpp 32fa061700 Compute credential TTL et al. 9 năm trước cách đây
Cluster.cpp f2d2df2b11 Cluster build fix. 9 năm trước cách đây
Cluster.hpp a963810e02 Tweak a few cluster params for higher perf / lower initial setup latency. 9 năm trước cách đây
Constants.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 năm trước cách đây
Dictionary.hpp 7036831203 Sign Dictionary in doNETWORK_CONFIG_REQUEST. 9 năm trước cách đây
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 năm trước cách đây
Identity.cpp ecc1324bb0 Rules engine work: capability based security model with tags and capabilities, and some cleanup across other places. 9 năm trước cách đây
Identity.hpp 7036831203 Sign Dictionary in doNETWORK_CONFIG_REQUEST. 9 năm trước cách đây
IncomingPacket.cpp a7d988745b Use ECHO instead of HELLO where possible. 9 năm trước cách đây
IncomingPacket.hpp a3bdae9735 Work in progress: Path canonicalization refactor. 9 năm trước cách đây
InetAddress.cpp b08ca49580 More controller work -- it builds! 9 năm trước cách đây
InetAddress.hpp bd15262e54 Bunch of rule JSON stuff. 9 năm trước cách đây
MAC.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
Membership.cpp a3c7627acf Push more than one packet for credentials if we happen to have a whole lot. Should not happen often but might if a member has tons of tags. 9 năm trước cách đây
Membership.hpp c9ee8612e4 Credential TTL (tags/capabilities) should be credential time max delta, since we could get pushed one that is newer. 9 năm trước cách đây
MulticastGroup.hpp dbf3e6c3c9 Dead code removal. 9 năm trước cách đây
Multicaster.cpp 0dfc08b317 Tidy up a few minor protocol things, improve documentation in Packet.hpp. 9 năm trước cách đây
Multicaster.hpp 00fd9c3a15 It builds... almost ready to test some rules engine stuff. 9 năm trước cách đây
Mutex.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
Network.cpp eebcf08084 Tweaks to new Path code for dual-stack operation, and other fixes. 9 năm trước cách đây
Network.hpp 74afef8eb1 Think through and refine a few things in rules, especially edge case TEE and REDIRECT behavior and semantics. 9 năm trước cách đây
NetworkConfig.cpp c9ee8612e4 Credential TTL (tags/capabilities) should be credential time max delta, since we could get pushed one that is newer. 9 năm trước cách đây
NetworkConfig.hpp c9ee8612e4 Credential TTL (tags/capabilities) should be credential time max delta, since we could get pushed one that is newer. 9 năm trước cách đây
NetworkController.hpp 2ba9343607 Encode and decode of tags and capabilities in NetworkConfig. 9 năm trước cách đây
Node.cpp 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 năm trước cách đây
Node.hpp ccea3d04d6 Push NETWORK_CONFIG_REFRESH on POSTs to /member/... in controller. 9 năm trước cách đây
NonCopyable.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
OutboundMulticast.cpp 74afef8eb1 Think through and refine a few things in rules, especially edge case TEE and REDIRECT behavior and semantics. 9 năm trước cách đây
OutboundMulticast.hpp 37d139177d Integrate Filter into OutboundMulticast properly. 9 năm trước cách đây
Packet.cpp 0ee4d3554a Stub out USER_MESSAGE. 9 năm trước cách đây
Packet.hpp 74afef8eb1 Think through and refine a few things in rules, especially edge case TEE and REDIRECT behavior and semantics. 9 năm trước cách đây
Path.cpp a3bdae9735 Work in progress: Path canonicalization refactor. 9 năm trước cách đây
Path.hpp a7d988745b Use ECHO instead of HELLO where possible. 9 năm trước cách đây
Peer.cpp a7d988745b Use ECHO instead of HELLO where possible. 9 năm trước cách đây
Peer.hpp a7d988745b Use ECHO instead of HELLO where possible. 9 năm trước cách đây
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 năm trước cách đây
Poly1305.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
README.md 6d8de214eb Docs and controller API version 9 năm trước cách đây
RuntimeEnvironment.hpp 98152d974a More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. 9 năm trước cách đây
SHA512.cpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
SHA512.hpp 4e4fd51117 boring doc stuff 10 năm trước cách đây
Salsa20.cpp 0c498556d5 Unroll Salsa20 fully for a little more speed (non-SSE now almost as fast as SSE) 10 năm trước cách đây
Salsa20.hpp 719233617c Add uint16_t key to Hashtable, and make Salsa20 zero its keyspace on destruction. 10 năm trước cách đây
SelfAwareness.cpp 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 năm trước cách đây
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 năm trước cách đây
SharedPtr.hpp 4931e44998 Implement "weak pointer" behavior on Topology Path canonicalization hash table. 9 năm trước cách đây
Switch.cpp 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 năm trước cách đây
Switch.hpp e1310a764a More cleanup and removal of cruft due to obsolete network-specific relays (will be replaced with federation stuff). 9 năm trước cách đây
Tag.cpp 56febbf2ba . 9 năm trước cách đây
Tag.hpp 9a3c652a51 Get rid of expiration in Capability and Tag and move this to NetworkConfig so it can be set network-wide and reset if needed. Also add NetworkConfig field for this and centralize checking of credential time validity. 9 năm trước cách đây
Topology.cpp 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 năm trước cách đây
Topology.hpp a3bdae9735 Work in progress: Path canonicalization refactor. 9 năm trước cách đây
Utils.cpp d7f2287ce9 More tweaks to path behavior. 9 năm trước cách đây
Utils.hpp e09c1a1c11 Big refactor mostly builds. We now have a uniform backward compatible netconf. 9 năm trước cách đây
World.hpp ecc1324bb0 Rules engine work: capability based security model with tags and capabilities, and some cleanup across other places. 9 năm trước cách đây

README.md

ZeroTier Virtual Switch 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.