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. 2 mesi fa
..
AES.cpp 9aff094b6f node/ -> MPL 2 mesi fa
AES.hpp 9aff094b6f node/ -> MPL 2 mesi fa
AES_aesni.cpp 9aff094b6f node/ -> MPL 2 mesi fa
AES_armcrypto.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Address.hpp 9aff094b6f node/ -> MPL 2 mesi fa
AtomicCounter.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Bond.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Bond.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Buffer.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Capability.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Capability.hpp 9aff094b6f node/ -> MPL 2 mesi fa
CertificateOfMembership.cpp 9aff094b6f node/ -> MPL 2 mesi fa
CertificateOfMembership.hpp 9aff094b6f node/ -> MPL 2 mesi fa
CertificateOfOwnership.cpp 9aff094b6f node/ -> MPL 2 mesi fa
CertificateOfOwnership.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Constants.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Credential.hpp 9aff094b6f node/ -> MPL 2 mesi fa
DNS.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Dictionary.hpp 9aff094b6f node/ -> MPL 2 mesi fa
ECC.cpp 342fa9d33f clang-format this branch 3 mesi fa
ECC.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Hashtable.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Identity.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Identity.hpp 9aff094b6f node/ -> MPL 2 mesi fa
IncomingPacket.cpp 9aff094b6f node/ -> MPL 2 mesi fa
IncomingPacket.hpp 9aff094b6f node/ -> MPL 2 mesi fa
InetAddress.cpp 9aff094b6f node/ -> MPL 2 mesi fa
InetAddress.hpp 9aff094b6f node/ -> MPL 2 mesi fa
MAC.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Membership.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Membership.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Metrics.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Metrics.hpp 9aff094b6f node/ -> MPL 2 mesi fa
MulticastGroup.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Multicaster.cpp 6e6fc9a704 Add conditional compilation of controller. 2 mesi fa
Multicaster.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Mutex.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Network.cpp 1e62d69762 Do not compress frames -- also unrelated to bug. 2 mesi fa
Network.hpp 9aff094b6f node/ -> MPL 2 mesi fa
NetworkConfig.cpp 9aff094b6f node/ -> MPL 2 mesi fa
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. 2 mesi fa
NetworkController.hpp 9aff094b6f node/ -> MPL 2 mesi fa
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. 2 mesi fa
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. 2 mesi fa
OutboundMulticast.cpp 9aff094b6f node/ -> MPL 2 mesi fa
OutboundMulticast.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Packet.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Packet.hpp 9aff094b6f node/ -> MPL 2 mesi fa
PacketMultiplexer.cpp 9aff094b6f node/ -> MPL 2 mesi fa
PacketMultiplexer.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Path.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Path.hpp 9aff094b6f node/ -> MPL 2 mesi fa
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. 2 mesi fa
Peer.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Poly1305.cpp ba2a4a605c clang-format 3 mesi fa
Poly1305.hpp 9aff094b6f node/ -> MPL 2 mesi fa
README.md 8a2ff0b31e Actual documentation. 8 anni fa
Revocation.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Revocation.hpp 9aff094b6f node/ -> MPL 2 mesi fa
RingBuffer.hpp 9aff094b6f node/ -> MPL 2 mesi fa
RuntimeEnvironment.hpp 9aff094b6f node/ -> MPL 2 mesi fa
SHA512.cpp ba2a4a605c clang-format 3 mesi fa
SHA512.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Salsa20.cpp ba2a4a605c clang-format 3 mesi fa
Salsa20.hpp ba2a4a605c clang-format 3 mesi fa
SelfAwareness.cpp 9aff094b6f node/ -> MPL 2 mesi fa
SelfAwareness.hpp 9aff094b6f node/ -> MPL 2 mesi fa
SharedPtr.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Switch.cpp bed6557a6d Re-enable relaying checks, also not bug related but put back after we decided to punt removing moons. 2 mesi fa
Switch.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Tag.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Tag.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Topology.cpp 1e62d69762 Do not compress frames -- also unrelated to bug. 2 mesi fa
Topology.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Trace.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Trace.hpp 9aff094b6f node/ -> MPL 2 mesi fa
Utils.cpp 9aff094b6f node/ -> MPL 2 mesi fa
Utils.hpp 9aff094b6f node/ -> MPL 2 mesi fa
World.hpp 9aff094b6f node/ -> MPL 2 mesi fa

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.