Adam Ierymenko 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. před 5 roky
..
AES.cpp 9d66d876f4 Likely fix for some alignment issues on ARM. před 5 roky
AES.hpp 70f37962cf Backport AES fixes for compiler, arch, and splitting into separate files. před 5 roky
AES_aesni.cpp dd65680150 Windows build fixes, version bump in AIP. před 5 roky
AES_armcrypto.cpp a624dfd776 Fixing regression in AES for ARM targets před 5 roky
Address.hpp 06730c7d1d BSL date bump před 5 roky
AtomicCounter.hpp 06730c7d1d BSL date bump před 5 roky
Bond.cpp ecfac0601a Add new bond control commands to CLI před 5 roky
Bond.hpp ecfac0601a Add new bond control commands to CLI před 5 roky
BondController.cpp ecfac0601a Add new bond control commands to CLI před 5 roky
BondController.hpp ecfac0601a Add new bond control commands to CLI před 5 roky
Buffer.hpp 06730c7d1d BSL date bump před 5 roky
C25519.cpp 2ac49d99dd AES integrated on send side. před 5 roky
C25519.hpp 06730c7d1d BSL date bump před 5 roky
Capability.cpp 06730c7d1d BSL date bump před 5 roky
Capability.hpp 06730c7d1d BSL date bump před 5 roky
CertificateOfMembership.cpp 06730c7d1d BSL date bump před 5 roky
CertificateOfMembership.hpp 06730c7d1d BSL date bump před 5 roky
CertificateOfOwnership.cpp 06730c7d1d BSL date bump před 5 roky
CertificateOfOwnership.hpp 06730c7d1d BSL date bump před 5 roky
Constants.hpp 9d66d876f4 Likely fix for some alignment issues on ARM. před 5 roky
Credential.hpp 06730c7d1d BSL date bump před 5 roky
DNS.hpp 06730c7d1d BSL date bump před 5 roky
Dictionary.hpp 06730c7d1d BSL date bump před 5 roky
Flow.hpp 06730c7d1d BSL date bump před 5 roky
Hashtable.hpp 06730c7d1d BSL date bump před 5 roky
Identity.cpp 2ac49d99dd AES integrated on send side. před 5 roky
Identity.hpp 7219ca0c0f AES works! Only with this or newer nodes. Uses salsa with older ones as usual. před 5 roky
IncomingPacket.cpp 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. před 5 roky
IncomingPacket.hpp 06730c7d1d BSL date bump před 5 roky
InetAddress.cpp de308f05e0 missing break in InetAddress::ipScope() před 5 roky
InetAddress.hpp 90f18f7ee7 Fix for ZTO-33 (Jira), only assign routes if there is a viable source IP. před 5 roky
MAC.hpp 06730c7d1d BSL date bump před 5 roky
Membership.cpp 06730c7d1d BSL date bump před 5 roky
Membership.hpp 06730c7d1d BSL date bump před 5 roky
MulticastGroup.hpp 06730c7d1d BSL date bump před 5 roky
Multicaster.cpp 44af828aa4 Tweak multicast settings to prevent failures due to TX queue overflow. před 5 roky
Multicaster.hpp 9480ff1f37 Fix some timestamp signedness mismatches. před 5 roky
Mutex.hpp 06730c7d1d BSL date bump před 5 roky
Network.cpp dc806dd718 Try pipelining tap reads on Linux for a little more speed. před 5 roky
Network.hpp 06730c7d1d BSL date bump před 5 roky
NetworkConfig.cpp 06730c7d1d BSL date bump před 5 roky
NetworkConfig.hpp 06730c7d1d BSL date bump před 5 roky
NetworkController.hpp 06730c7d1d BSL date bump před 5 roky
Node.cpp 06730c7d1d BSL date bump před 5 roky
Node.hpp 06730c7d1d BSL date bump před 5 roky
OutboundMulticast.cpp 06730c7d1d BSL date bump před 5 roky
OutboundMulticast.hpp 06730c7d1d BSL date bump před 5 roky
Packet.cpp 31d8758ad9 Apple "fat binaries" are back! před 5 roky
Packet.hpp e6b5f8aabd AES work... but disabled in this commit. před 5 roky
Path.cpp 06730c7d1d BSL date bump před 5 roky
Path.hpp ecfac0601a Add new bond control commands to CLI před 5 roky
Peer.cpp ac808d51d6 Crash fix před 5 roky
Peer.hpp 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. před 5 roky
Poly1305.cpp d530356055 RingBuffer<> is now templated with size, buffer is now static. před 7 roky
Poly1305.hpp 06730c7d1d BSL date bump před 5 roky
README.md 8a2ff0b31e Actual documentation. před 9 roky
Revocation.cpp 06730c7d1d BSL date bump před 5 roky
Revocation.hpp 06730c7d1d BSL date bump před 5 roky
RingBuffer.hpp 06730c7d1d BSL date bump před 5 roky
RuntimeEnvironment.hpp 06730c7d1d BSL date bump před 5 roky
SHA512.cpp 1ad555a071 More selective push of AES modifications and refactoring stuff. před 5 roky
SHA512.hpp 2ac49d99dd AES integrated on send side. před 5 roky
Salsa20.cpp 9681fedbb4 Spellcheck sweep across codebase před 7 roky
Salsa20.hpp 41c187ba12 Another very small crypto optimization. před 8 roky
SelfAwareness.cpp 06730c7d1d BSL date bump před 5 roky
SelfAwareness.hpp 06730c7d1d BSL date bump před 5 roky
SharedPtr.hpp 06730c7d1d BSL date bump před 5 roky
Switch.cpp 26a0cbcd73 Revert "Push credentials in multicast." před 5 roky
Switch.hpp 06730c7d1d BSL date bump před 5 roky
Tag.cpp 06730c7d1d BSL date bump před 5 roky
Tag.hpp 06730c7d1d BSL date bump před 5 roky
Topology.cpp d64c5a92c6 Merge pull request #1233 from dosuperuser/improvement/optimizations před 5 roky
Topology.hpp 06730c7d1d BSL date bump před 5 roky
Trace.cpp 06730c7d1d BSL date bump před 5 roky
Trace.hpp 06730c7d1d BSL date bump před 5 roky
Utils.cpp 31d8758ad9 Apple "fat binaries" are back! před 5 roky
Utils.hpp 90f18f7ee7 Fix for ZTO-33 (Jira), only assign routes if there is a viable source IP. před 5 roky
World.hpp 06730c7d1d BSL date bump před 5 roky

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.