ZeroTierOne/node
2016-08-29 16:38:10 -07:00
..
Address.hpp Bunch more refactoring for an even more compact NetworkConfig representation, especially rules. 2016-04-26 17:11:25 -07:00
Array.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
AtomicCounter.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
Buffer.hpp Changes to how new-style binary network configs are detected, and a new-style binary serialized meta-data representation. 2016-05-06 13:29:10 -07:00
C25519.cpp More little stuff in crypto code. 2014-06-26 17:23:10 -07:00
C25519.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
Capability.cpp More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. 2016-08-04 11:40:38 -07:00
Capability.hpp fix frame size range bug 2016-08-26 13:26:26 -07:00
CertificateOfMembership.cpp . 2016-08-04 10:39:28 -07:00
CertificateOfMembership.hpp Compute credential TTL et al. 2016-08-23 13:02:59 -07:00
Cluster.cpp Cleanup in numerous places, reduce network chattiness around MULTICAST_LIKE, and fix a "how was that working" latent bug causing some control traffic to take the scenic route. 2016-04-19 12:09:35 -07:00
Cluster.hpp Tweak a few cluster params for higher perf / lower initial setup latency. 2016-02-08 09:57:46 -08:00
Constants.hpp Obsolete "test network" removal. 2016-08-23 09:39:38 -07:00
Dictionary.hpp Sign Dictionary in doNETWORK_CONFIG_REQUEST. 2016-08-23 11:57:56 -07:00
Hashtable.hpp . 2016-08-05 15:02:01 -07:00
Identity.cpp Rules engine work: capability based security model with tags and capabilities, and some cleanup across other places. 2016-08-02 13:36:17 -07:00
Identity.hpp Sign Dictionary in doNETWORK_CONFIG_REQUEST. 2016-08-23 11:57:56 -07:00
IncomingPacket.cpp EXT_FRAME messages should always be accepted if we are the destination for a matching TEE or REDIRECT rule. 2016-08-29 15:54:06 -07:00
IncomingPacket.hpp Put CONFIG_REFRESH back. 2016-08-09 13:52:08 -07:00
InetAddress.cpp More controller work -- it builds! 2016-08-16 14:05:17 -07:00
InetAddress.hpp Bunch of rule JSON stuff. 2016-08-15 18:49:50 -07:00
MAC.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
Membership.cpp 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. 2016-08-26 14:43:16 -07:00
Membership.hpp 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. 2016-08-26 14:43:16 -07:00
Multicaster.cpp Tidy up a few minor protocol things, improve documentation in Packet.hpp. 2016-08-23 11:29:02 -07:00
Multicaster.hpp It builds... almost ready to test some rules engine stuff. 2016-08-08 17:33:26 -07:00
MulticastGroup.hpp Dead code removal. 2016-08-09 15:01:46 -07:00
Mutex.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
Network.cpp Debug output fixes. 2016-08-29 16:38:10 -07:00
Network.hpp EXT_FRAME messages should always be accepted if we are the destination for a matching TEE or REDIRECT rule. 2016-08-29 15:54:06 -07:00
NetworkConfig.cpp Cleanup. 2016-08-23 11:52:10 -07:00
NetworkConfig.hpp Documentation updates, add rules engine revision to network config request meta-data. 2016-08-26 10:38:43 -07:00
NetworkController.hpp Encode and decode of tags and capabilities in NetworkConfig. 2016-08-09 08:32:42 -07:00
Node.cpp Push NETWORK_CONFIG_REFRESH on POSTs to /member/... in controller. 2016-08-24 14:28:16 -07:00
Node.hpp Push NETWORK_CONFIG_REFRESH on POSTs to /member/... in controller. 2016-08-24 14:28:16 -07:00
NonCopyable.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
OutboundMulticast.cpp It basically works... at least on current controllers. 2016-08-24 15:26:18 -07:00
OutboundMulticast.hpp Integrate Filter into OutboundMulticast properly. 2016-08-04 13:01:14 -07:00
Packet.cpp Stub out USER_MESSAGE. 2016-08-23 14:38:20 -07:00
Packet.hpp Add length limit to TEE and REDIRECT, and completely factor out old C json-parser to eliminate a dependency. 2016-08-24 13:37:57 -07:00
Path.cpp Kill some old debug code. 2016-04-19 12:55:48 -07:00
Path.hpp Dead code removal, and get rid of reliable() because we will no longer make that distinction. 2016-08-24 17:56:35 -07:00
Peer.cpp Dead code removal, and get rid of reliable() because we will no longer make that distinction. 2016-08-24 17:56:35 -07:00
Peer.hpp Harden PUSH_DIRECT_PATHS and simplify things by only doing it on receive when hops>0 and trust has been established. 2016-08-24 16:16:39 -07:00
Poly1305.cpp Only enable 128-bit Poly1305 on X86_64 right now. Has compilation issues on ARM, but the 64-bit version should be fine. 2015-10-07 10:40:59 -07:00
Poly1305.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
README.md Docs and controller API version 2016-07-08 13:10:02 -07:00
RuntimeEnvironment.hpp More cleanup and removal of DeferredPackets, will do the latter in a more elegant way. 2016-08-04 11:40:38 -07:00
Salsa20.cpp Unroll Salsa20 fully for a little more speed (non-SSE now almost as fast as SSE) 2015-10-09 09:39:27 -07:00
Salsa20.hpp Add uint16_t key to Hashtable, and make Salsa20 zero its keyspace on destruction. 2015-10-14 10:14:07 -07:00
SelfAwareness.cpp Refactor and redesign symmetric NAT predictor. This is cleaner. 2016-08-10 10:28:54 -07:00
SelfAwareness.hpp Minor bug fix and some instrumentation stuff for testing. 2016-08-09 17:00:01 -07:00
SHA512.cpp boring doc stuff 2016-01-12 14:04:55 -08:00
SHA512.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
SharedPtr.hpp boring doc stuff 2016-01-12 14:04:55 -08:00
Switch.cpp Harden PUSH_DIRECT_PATHS and simplify things by only doing it on receive when hops>0 and trust has been established. 2016-08-24 16:16:39 -07:00
Switch.hpp More cleanup and removal of cruft due to obsolete network-specific relays (will be replaced with federation stuff). 2016-08-09 15:45:26 -07:00
Tag.cpp . 2016-08-04 10:39:28 -07:00
Tag.hpp 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. 2016-08-22 18:06:46 -07:00
Topology.cpp It builds... almost ready to test some rules engine stuff. 2016-08-08 17:33:26 -07:00
Topology.hpp . 2016-08-04 10:18:33 -07:00
Utils.cpp Big refactor mostly builds. We now have a uniform backward compatible netconf. 2016-06-16 12:28:43 -07:00
Utils.hpp Big refactor mostly builds. We now have a uniform backward compatible netconf. 2016-06-16 12:28:43 -07:00
World.hpp Rules engine work: capability based security model with tags and capabilities, and some cleanup across other places. 2016-08-02 13:36:17 -07:00

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.