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

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.