Adam Ierymenko bfa4bd2584 Removing this, which was suggested by a linter, turns out to break things by breaking equality comparison. The NetworkConfig struct would have to be re-implemented in a more modern way to allow the compiler to properly generate comparison operators, which is not important right now. vor 2 Monaten
..
AES.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
AES.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
AES_aesni.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
AES_armcrypto.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Address.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
AtomicCounter.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Bond.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Bond.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Buffer.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Capability.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Capability.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
CertificateOfMembership.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
CertificateOfMembership.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
CertificateOfOwnership.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
CertificateOfOwnership.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Constants.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Credential.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
DNS.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Dictionary.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
ECC.cpp 342fa9d33f clang-format this branch vor 3 Monaten
ECC.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Hashtable.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Identity.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Identity.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
IncomingPacket.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
IncomingPacket.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
InetAddress.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
InetAddress.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
MAC.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Membership.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Membership.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Metrics.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Metrics.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
MulticastGroup.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Multicaster.cpp 6e6fc9a704 Add conditional compilation of controller. vor 2 Monaten
Multicaster.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Mutex.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Network.cpp 1e62d69762 Do not compress frames -- also unrelated to bug. vor 2 Monaten
Network.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
NetworkConfig.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
NetworkConfig.hpp bfa4bd2584 Removing this, which was suggested by a linter, turns out to break things by breaking equality comparison. The NetworkConfig struct would have to be re-implemented in a more modern way to allow the compiler to properly generate comparison operators, which is not important right now. vor 2 Monaten
NetworkController.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Node.cpp ab208bb8f9 Make encrypted HELLO a local.conf setting -- 99.999999% of users do not need it and it introduces scalability problems on large controllers. vor 2 Monaten
Node.hpp ab208bb8f9 Make encrypted HELLO a local.conf setting -- 99.999999% of users do not need it and it introduces scalability problems on large controllers. vor 2 Monaten
OutboundMulticast.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
OutboundMulticast.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Packet.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Packet.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
PacketMultiplexer.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
PacketMultiplexer.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Path.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Path.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Peer.cpp ab208bb8f9 Make encrypted HELLO a local.conf setting -- 99.999999% of users do not need it and it introduces scalability problems on large controllers. vor 2 Monaten
Peer.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Poly1305.cpp ba2a4a605c clang-format vor 3 Monaten
Poly1305.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
README.md 8a2ff0b31e Actual documentation. vor 8 Jahren
Revocation.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Revocation.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
RingBuffer.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
RuntimeEnvironment.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
SHA512.cpp ba2a4a605c clang-format vor 3 Monaten
SHA512.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Salsa20.cpp ba2a4a605c clang-format vor 3 Monaten
Salsa20.hpp ba2a4a605c clang-format vor 3 Monaten
SelfAwareness.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
SelfAwareness.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
SharedPtr.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Switch.cpp bed6557a6d Re-enable relaying checks, also not bug related but put back after we decided to punt removing moons. vor 2 Monaten
Switch.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Tag.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Tag.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Topology.cpp 1e62d69762 Do not compress frames -- also unrelated to bug. vor 2 Monaten
Topology.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Trace.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Trace.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
Utils.cpp 9aff094b6f node/ -> MPL vor 2 Monaten
Utils.hpp 9aff094b6f node/ -> MPL vor 2 Monaten
World.hpp 9aff094b6f node/ -> MPL vor 2 Monaten

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.