mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2024-12-19 04:57:53 +00:00
5a36b315a3
* Exit if loading an invalid identity from disk Previously, if an invalid identity was loaded from disk, ZeroTier would generate a new identity & chug along and generate a brand new identity as if nothing happened. When running in containers, this introduces the possibility for key matter loss; especially when running in containers where the identity files are mounted in the container read only. In this case, ZT will continue chugging along with a brand new identity with no possibility of recovering the private key. ZeroTier should exit upon loading of invalid identity.public/identity.secret #2056 * add validation test for #2056 |
||
---|---|---|
.. | ||
Address.hpp | ||
AES_aesni.cpp | ||
AES_armcrypto.cpp | ||
AES.cpp | ||
AES.hpp | ||
AtomicCounter.hpp | ||
Bond.cpp | ||
Bond.hpp | ||
Buffer.hpp | ||
C25519.cpp | ||
C25519.hpp | ||
Capability.cpp | ||
Capability.hpp | ||
CertificateOfMembership.cpp | ||
CertificateOfMembership.hpp | ||
CertificateOfOwnership.cpp | ||
CertificateOfOwnership.hpp | ||
Constants.hpp | ||
Credential.hpp | ||
Dictionary.hpp | ||
DNS.hpp | ||
Hashtable.hpp | ||
Identity.cpp | ||
Identity.hpp | ||
IncomingPacket.cpp | ||
IncomingPacket.hpp | ||
InetAddress.cpp | ||
InetAddress.hpp | ||
MAC.hpp | ||
Membership.cpp | ||
Membership.hpp | ||
Metrics.cpp | ||
Metrics.hpp | ||
Multicaster.cpp | ||
Multicaster.hpp | ||
MulticastGroup.hpp | ||
Mutex.hpp | ||
Network.cpp | ||
Network.hpp | ||
NetworkConfig.cpp | ||
NetworkConfig.hpp | ||
NetworkController.hpp | ||
Node.cpp | ||
Node.hpp | ||
OutboundMulticast.cpp | ||
OutboundMulticast.hpp | ||
Packet.cpp | ||
Packet.hpp | ||
Path.cpp | ||
Path.hpp | ||
Peer.cpp | ||
Peer.hpp | ||
Poly1305.cpp | ||
Poly1305.hpp | ||
README.md | ||
Revocation.cpp | ||
Revocation.hpp | ||
RingBuffer.hpp | ||
RuntimeEnvironment.hpp | ||
Salsa20.cpp | ||
Salsa20.hpp | ||
SelfAwareness.cpp | ||
SelfAwareness.hpp | ||
SHA512.cpp | ||
SHA512.hpp | ||
SharedPtr.hpp | ||
Switch.cpp | ||
Switch.hpp | ||
Tag.cpp | ||
Tag.hpp | ||
Topology.cpp | ||
Topology.hpp | ||
Trace.cpp | ||
Trace.hpp | ||
Utils.cpp | ||
Utils.hpp | ||
World.hpp |
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.