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

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.