| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 | /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. * * (c) ZeroTier, Inc. * https://www.zerotier.com/ */#ifndef ZT_TRACE_HPP#define ZT_TRACE_HPP#include "../include/ZeroTierOne.h"#include "Constants.hpp"#include "Credential.hpp"#include "Dictionary.hpp"#include "Hashtable.hpp"#include "InetAddress.hpp"#include "Mutex.hpp"#include "Packet.hpp"#include "SharedPtr.hpp"#include <stdint.h>#include <stdio.h>#include <stdlib.h>#include <string.h>namespace ZeroTier {class RuntimeEnvironment;class Address;class Identity;class Peer;class Path;class Network;class NetworkConfig;class MAC;class CertificateOfMembership;class CertificateOfOwnership;class Revocation;class Tag;class Capability;/** * Remote tracing and trace logging handler */class Trace {  public:	/**	 * Trace verbosity level	 */	enum Level { LEVEL_NORMAL = 0, LEVEL_VERBOSE = 10, LEVEL_RULES = 15, LEVEL_DEBUG = 20, LEVEL_INSANE = 30 };	/**	 * Filter rule evaluation result log	 *	 * Each rule in a rule set gets a four-bit log entry. A log entry	 * of zero means not evaluated. Otherwise each four-bit log entry	 * contains two two-bit values of 01 for 'false' and 10 for 'true'.	 * As with four-bit rules an 00 value here means this was not	 * evaluated or was not relevant.	 */	class RuleResultLog {	  public:		RuleResultLog()		{		}		inline void log(const unsigned int rn, const uint8_t thisRuleMatches, const uint8_t thisSetMatches)		{			_l[rn >> 1] |= (((thisRuleMatches + 1) << 2) | (thisSetMatches + 1)) << ((rn & 1) << 2);		}		inline void logSkipped(const unsigned int rn, const uint8_t thisSetMatches)		{			_l[rn >> 1] |= (thisSetMatches + 1) << ((rn & 1) << 2);		}		inline void clear()		{			memset(_l, 0, sizeof(_l));		}		inline const uint8_t* data() const		{			return _l;		}		inline unsigned int sizeBytes() const		{			return (ZT_MAX_NETWORK_RULES / 2);		}	  private:		uint8_t _l[ZT_MAX_NETWORK_RULES / 2];	};	Trace(const RuntimeEnvironment* renv) : RR(renv), _byNet(8)	{	}	void resettingPathsInScope(void* const tPtr, const Address& reporter, const InetAddress& reporterPhysicalAddress, const InetAddress& myPhysicalAddress, const InetAddress::IpScope scope);	void peerConfirmingUnknownPath(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& path, const uint64_t packetId, const Packet::Verb verb);	void bondStateMessage(void* const tPtr, char* msg);	void peerLearnedNewPath(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& newPath, const uint64_t packetId);	void peerRedirected(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& newPath);	void incomingPacketMessageAuthenticationFailure(void* const tPtr, const SharedPtr<Path>& path, const uint64_t packetId, const Address& source, const unsigned int hops, const char* reason);	void incomingPacketInvalid(void* const tPtr, const SharedPtr<Path>& path, const uint64_t packetId, const Address& source, const unsigned int hops, const Packet::Verb verb, const char* reason);	void incomingPacketDroppedHELLO(void* const tPtr, const SharedPtr<Path>& path, const uint64_t packetId, const Address& source, const char* reason);	void outgoingNetworkFrameDropped(void* const tPtr, const SharedPtr<Network>& network, const MAC& sourceMac, const MAC& destMac, const unsigned int etherType, const unsigned int vlanId, const unsigned int frameLen, const char* reason);	void incomingNetworkAccessDenied(		void* const tPtr,		const SharedPtr<Network>& network,		const SharedPtr<Path>& path,		const uint64_t packetId,		const unsigned int packetLength,		const Address& source,		const Packet::Verb verb,		bool credentialsRequested);	void incomingNetworkFrameDropped(		void* const tPtr,		const SharedPtr<Network>& network,		const SharedPtr<Path>& path,		const uint64_t packetId,		const unsigned int packetLength,		const Address& source,		const Packet::Verb verb,		const MAC& sourceMac,		const MAC& destMac,		const char* reason);	void networkConfigRequestSent(void* const tPtr, const Network& network, const Address& controller);	void networkFilter(		void* const tPtr,		const Network& network,		const RuleResultLog& primaryRuleSetLog,		const RuleResultLog* const matchingCapabilityRuleSetLog,		const Capability* const matchingCapability,		const Address& ztSource,		const Address& ztDest,		const MAC& macSource,		const MAC& macDest,		const uint8_t* const frameData,		const unsigned int frameLen,		const unsigned int etherType,		const unsigned int vlanId,		const bool noTee,		const bool inbound,		const int accept);	void credentialRejected(void* const tPtr, const CertificateOfMembership& c, const char* reason);	void credentialRejected(void* const tPtr, const CertificateOfOwnership& c, const char* reason);	void credentialRejected(void* const tPtr, const Capability& c, const char* reason);	void credentialRejected(void* const tPtr, const Tag& c, const char* reason);	void credentialRejected(void* const tPtr, const Revocation& c, const char* reason);	void updateMemoizedSettings();  private:	const RuntimeEnvironment* const RR;	void _send(void* const tPtr, const Dictionary<ZT_MAX_REMOTE_TRACE_SIZE>& d, const Address& dest);	void _spamToAllNetworks(void* const tPtr, const Dictionary<ZT_MAX_REMOTE_TRACE_SIZE>& d, const Level level);	Address _globalTarget;	Trace::Level _globalLevel;	Hashtable<uint64_t, std::pair<Address, Trace::Level> > _byNet;	Mutex _byNet_m;};}	// namespace ZeroTier#endif
 |