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

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.