Trace.cpp 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646
  1. /* This Source Code Form is subject to the terms of the Mozilla Public
  2. * License, v. 2.0. If a copy of the MPL was not distributed with this
  3. * file, You can obtain one at https://mozilla.org/MPL/2.0/.
  4. *
  5. * (c) ZeroTier, Inc.
  6. * https://www.zerotier.com/
  7. */
  8. // #define ZT_TRACE
  9. #include "Trace.hpp"
  10. #include "../include/ZeroTierDebug.h"
  11. #include "Capability.hpp"
  12. #include "CertificateOfMembership.hpp"
  13. #include "CertificateOfOwnership.hpp"
  14. #include "Constants.hpp"
  15. #include "Dictionary.hpp"
  16. #include "Node.hpp"
  17. #include "Revocation.hpp"
  18. #include "RuntimeEnvironment.hpp"
  19. #include "Switch.hpp"
  20. #include "Tag.hpp"
  21. #include <stdarg.h>
  22. #include <stdio.h>
  23. namespace ZeroTier {
  24. #ifdef ZT_TRACE
  25. static void ZT_LOCAL_TRACE(void* const tPtr, const RuntimeEnvironment* const RR, const char* const fmt, ...)
  26. {
  27. char traceMsgBuf[1024];
  28. va_list ap;
  29. va_start(ap, fmt);
  30. vsnprintf(traceMsgBuf, sizeof(traceMsgBuf), fmt, ap);
  31. va_end(ap);
  32. traceMsgBuf[sizeof(traceMsgBuf) - 1] = (char)0;
  33. RR->node->postEvent(tPtr, ZT_EVENT_TRACE, traceMsgBuf);
  34. }
  35. #else
  36. #define ZT_LOCAL_TRACE(...)
  37. #endif
  38. void Trace::resettingPathsInScope(void* const tPtr, const Address& reporter, const InetAddress& reporterPhysicalAddress, const InetAddress& myPhysicalAddress, const InetAddress::IpScope scope)
  39. {
  40. char tmp[128];
  41. ZT_LOCAL_TRACE(tPtr, RR, "RESET and revalidate paths in scope %d; new phy address %s reported by trusted peer %.10llx", (int)scope, myPhysicalAddress.toIpString(tmp), reporter.toInt());
  42. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  43. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__RESETTING_PATHS_IN_SCOPE_S);
  44. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, reporter);
  45. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, reporterPhysicalAddress.toString(tmp));
  46. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_PHYADDR, myPhysicalAddress.toString(tmp));
  47. d.add(ZT_REMOTE_TRACE_FIELD__IP_SCOPE, (uint64_t)scope);
  48. if (_globalTarget) {
  49. _send(tPtr, d, _globalTarget);
  50. }
  51. _spamToAllNetworks(tPtr, d, Trace::LEVEL_NORMAL);
  52. }
  53. void Trace::peerConfirmingUnknownPath(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& path, const uint64_t packetId, const Packet::Verb verb)
  54. {
  55. char tmp[128];
  56. if (! path) {
  57. return; // sanity check
  58. }
  59. ZT_LOCAL_TRACE(tPtr, RR, "trying unknown path %s to %.10llx (packet %.16llx verb %d local socket %lld network %.16llx)", path->address().toString(tmp), peer.address().toInt(), packetId, verb, path->localSocket(), networkId);
  60. std::pair<Address, Trace::Level> byn;
  61. if (networkId) {
  62. Mutex::Lock l(_byNet_m);
  63. _byNet.get(networkId, byn);
  64. }
  65. if ((_globalTarget) || (byn.first)) {
  66. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  67. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PEER_CONFIRMING_UNKNOWN_PATH_S);
  68. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  69. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_VERB, (uint64_t)verb);
  70. if (networkId) {
  71. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, networkId);
  72. }
  73. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, peer.address());
  74. if (path) {
  75. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  76. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  77. }
  78. if (_globalTarget) {
  79. _send(tPtr, d, _globalTarget);
  80. }
  81. if (byn.first) {
  82. _send(tPtr, d, byn.first);
  83. }
  84. }
  85. }
  86. void Trace::bondStateMessage(void* const tPtr, char* msg)
  87. {
  88. ZT_LOCAL_TRACE(tPtr, RR, "%s", msg);
  89. }
  90. void Trace::peerLearnedNewPath(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& newPath, const uint64_t packetId)
  91. {
  92. char tmp[128];
  93. if (! newPath) {
  94. return; // sanity check
  95. }
  96. ZT_LOCAL_TRACE(tPtr, RR, "learned new path %s to %.10llx (packet %.16llx local socket %lld network %.16llx)", newPath->address().toString(tmp), peer.address().toInt(), packetId, newPath->localSocket(), networkId);
  97. std::pair<Address, Trace::Level> byn;
  98. if (networkId) {
  99. Mutex::Lock l(_byNet_m);
  100. _byNet.get(networkId, byn);
  101. }
  102. if ((_globalTarget) || (byn.first)) {
  103. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  104. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PEER_LEARNED_NEW_PATH_S);
  105. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  106. if (networkId) {
  107. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, networkId);
  108. }
  109. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, peer.address());
  110. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, newPath->address().toString(tmp));
  111. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, newPath->localSocket());
  112. if (_globalTarget) {
  113. _send(tPtr, d, _globalTarget);
  114. }
  115. if (byn.first) {
  116. _send(tPtr, d, byn.first);
  117. }
  118. }
  119. }
  120. void Trace::peerRedirected(void* const tPtr, const uint64_t networkId, Peer& peer, const SharedPtr<Path>& newPath)
  121. {
  122. char tmp[128];
  123. if (! newPath) {
  124. return; // sanity check
  125. }
  126. ZT_LOCAL_TRACE(tPtr, RR, "explicit redirect from %.10llx to path %s", peer.address().toInt(), newPath->address().toString(tmp));
  127. std::pair<Address, Trace::Level> byn;
  128. if (networkId) {
  129. Mutex::Lock l(_byNet_m);
  130. _byNet.get(networkId, byn);
  131. }
  132. if ((_globalTarget) || (byn.first)) {
  133. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  134. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PEER_REDIRECTED_S);
  135. if (networkId) {
  136. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, networkId);
  137. }
  138. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, peer.address());
  139. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, newPath->address().toString(tmp));
  140. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, newPath->localSocket());
  141. if (_globalTarget) {
  142. _send(tPtr, d, _globalTarget);
  143. }
  144. if (byn.first) {
  145. _send(tPtr, d, byn.first);
  146. }
  147. }
  148. }
  149. void Trace::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)
  150. {
  151. #ifdef ZT_TRACE
  152. char tmp[128], tmp2[128];
  153. #endif
  154. if (! network) {
  155. return; // sanity check
  156. }
  157. ZT_LOCAL_TRACE(tPtr, RR, "%.16llx DROP frame %s -> %s etherType %.4x size %u (%s)", network->id(), sourceMac.toString(tmp), destMac.toString(tmp2), etherType, frameLen, (reason) ? reason : "unknown reason");
  158. std::pair<Address, Trace::Level> byn;
  159. {
  160. Mutex::Lock l(_byNet_m);
  161. _byNet.get(network->id(), byn);
  162. }
  163. if (((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) || ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE))) {
  164. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  165. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__OUTGOING_NETWORK_FRAME_DROPPED_S);
  166. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, network->id());
  167. d.add(ZT_REMOTE_TRACE_FIELD__SOURCE_MAC, sourceMac.toInt());
  168. d.add(ZT_REMOTE_TRACE_FIELD__DEST_MAC, destMac.toInt());
  169. d.add(ZT_REMOTE_TRACE_FIELD__ETHERTYPE, (uint64_t)etherType);
  170. d.add(ZT_REMOTE_TRACE_FIELD__VLAN_ID, (uint64_t)vlanId);
  171. d.add(ZT_REMOTE_TRACE_FIELD__FRAME_LENGTH, (uint64_t)frameLen);
  172. if (reason) {
  173. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  174. }
  175. if ((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) {
  176. _send(tPtr, d, _globalTarget);
  177. }
  178. if ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE)) {
  179. _send(tPtr, d, byn.first);
  180. }
  181. }
  182. }
  183. void Trace::incomingNetworkAccessDenied(
  184. void* const tPtr,
  185. const SharedPtr<Network>& network,
  186. const SharedPtr<Path>& path,
  187. const uint64_t packetId,
  188. const unsigned int packetLength,
  189. const Address& source,
  190. const Packet::Verb verb,
  191. bool credentialsRequested)
  192. {
  193. char tmp[128];
  194. if (! network) {
  195. return; // sanity check
  196. }
  197. ZT_LOCAL_TRACE(
  198. tPtr,
  199. RR,
  200. "%.16llx DENIED packet from %.10llx(%s) verb %d size %u%s",
  201. network->id(),
  202. source.toInt(),
  203. (path) ? (path->address().toString(tmp)) : "???",
  204. (int)verb,
  205. packetLength,
  206. credentialsRequested ? " (credentials requested)" : " (credentials not requested)");
  207. std::pair<Address, Trace::Level> byn;
  208. {
  209. Mutex::Lock l(_byNet_m);
  210. _byNet.get(network->id(), byn);
  211. }
  212. if (((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) || ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE))) {
  213. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  214. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__INCOMING_NETWORK_ACCESS_DENIED_S);
  215. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  216. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_VERB, (uint64_t)verb);
  217. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, source);
  218. if (path) {
  219. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  220. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  221. }
  222. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, network->id());
  223. if ((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) {
  224. _send(tPtr, d, _globalTarget);
  225. }
  226. if ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE)) {
  227. _send(tPtr, d, byn.first);
  228. }
  229. }
  230. }
  231. void Trace::incomingNetworkFrameDropped(
  232. void* const tPtr,
  233. const SharedPtr<Network>& network,
  234. const SharedPtr<Path>& path,
  235. const uint64_t packetId,
  236. const unsigned int packetLength,
  237. const Address& source,
  238. const Packet::Verb verb,
  239. const MAC& sourceMac,
  240. const MAC& destMac,
  241. const char* reason)
  242. {
  243. char tmp[128];
  244. if (! network) {
  245. return; // sanity check
  246. }
  247. ZT_LOCAL_TRACE(tPtr, RR, "%.16llx DROPPED frame from %.10llx(%s) verb %d size %u", network->id(), source.toInt(), (path) ? (path->address().toString(tmp)) : "???", (int)verb, packetLength);
  248. std::pair<Address, Trace::Level> byn;
  249. {
  250. Mutex::Lock l(_byNet_m);
  251. _byNet.get(network->id(), byn);
  252. }
  253. if (((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) || ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE))) {
  254. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  255. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__INCOMING_NETWORK_FRAME_DROPPED_S);
  256. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  257. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_VERB, (uint64_t)verb);
  258. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, source);
  259. if (path) {
  260. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  261. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  262. }
  263. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, network->id());
  264. d.add(ZT_REMOTE_TRACE_FIELD__SOURCE_MAC, sourceMac.toInt());
  265. d.add(ZT_REMOTE_TRACE_FIELD__DEST_MAC, destMac.toInt());
  266. if (reason) {
  267. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  268. }
  269. if ((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_VERBOSE)) {
  270. _send(tPtr, d, _globalTarget);
  271. }
  272. if ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_VERBOSE)) {
  273. _send(tPtr, d, byn.first);
  274. }
  275. }
  276. }
  277. void Trace::incomingPacketMessageAuthenticationFailure(void* const tPtr, const SharedPtr<Path>& path, const uint64_t packetId, const Address& source, const unsigned int hops, const char* reason)
  278. {
  279. char tmp[128];
  280. ZT_LOCAL_TRACE(tPtr, RR, "MAC failed for packet %.16llx from %.10llx(%s)", packetId, source.toInt(), (path) ? path->address().toString(tmp) : "???");
  281. if ((_globalTarget) && ((int)_globalLevel >= Trace::LEVEL_DEBUG)) {
  282. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  283. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PACKET_MAC_FAILURE_S);
  284. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  285. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_HOPS, (uint64_t)hops);
  286. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, source);
  287. if (path) {
  288. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  289. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  290. }
  291. if (reason) {
  292. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  293. }
  294. _send(tPtr, d, _globalTarget);
  295. }
  296. }
  297. void Trace::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)
  298. {
  299. char tmp[128];
  300. ZT_LOCAL_TRACE(tPtr, RR, "INVALID packet %.16llx from %.10llx(%s) (%s)", packetId, source.toInt(), (path) ? path->address().toString(tmp) : "???", (reason) ? reason : "unknown reason");
  301. if ((_globalTarget) && ((int)_globalLevel >= Trace::LEVEL_DEBUG)) {
  302. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  303. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PACKET_INVALID_S);
  304. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  305. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_VERB, (uint64_t)verb);
  306. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, source);
  307. if (path) {
  308. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  309. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  310. }
  311. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_HOPS, (uint64_t)hops);
  312. if (reason) {
  313. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  314. }
  315. _send(tPtr, d, _globalTarget);
  316. }
  317. }
  318. void Trace::incomingPacketDroppedHELLO(void* const tPtr, const SharedPtr<Path>& path, const uint64_t packetId, const Address& source, const char* reason)
  319. {
  320. char tmp[128];
  321. ZT_LOCAL_TRACE(tPtr, RR, "DROPPED HELLO from %.10llx(%s) (%s)", source.toInt(), (path) ? path->address().toString(tmp) : "???", (reason) ? reason : "???");
  322. if ((_globalTarget) && ((int)_globalLevel >= Trace::LEVEL_DEBUG)) {
  323. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  324. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__PACKET_INVALID_S);
  325. d.add(ZT_REMOTE_TRACE_FIELD__PACKET_ID, packetId);
  326. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_ZTADDR, source);
  327. if (path) {
  328. d.add(ZT_REMOTE_TRACE_FIELD__REMOTE_PHYADDR, path->address().toString(tmp));
  329. d.add(ZT_REMOTE_TRACE_FIELD__LOCAL_SOCKET, path->localSocket());
  330. }
  331. if (reason) {
  332. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  333. }
  334. _send(tPtr, d, _globalTarget);
  335. }
  336. }
  337. void Trace::networkConfigRequestSent(void* const tPtr, const Network& network, const Address& controller)
  338. {
  339. ZT_LOCAL_TRACE(tPtr, RR, "requesting configuration for network %.16llx", network.id());
  340. if ((_globalTarget) && ((int)_globalLevel >= Trace::LEVEL_DEBUG)) {
  341. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  342. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__NETWORK_CONFIG_REQUEST_SENT_S);
  343. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, network.id());
  344. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_CONTROLLER_ID, controller);
  345. _send(tPtr, d, _globalTarget);
  346. }
  347. }
  348. void Trace::networkFilter(
  349. void* const tPtr,
  350. const Network& network,
  351. const RuleResultLog& primaryRuleSetLog,
  352. const RuleResultLog* const matchingCapabilityRuleSetLog,
  353. const Capability* const matchingCapability,
  354. const Address& ztSource,
  355. const Address& ztDest,
  356. const MAC& macSource,
  357. const MAC& macDest,
  358. const uint8_t* const frameData,
  359. const unsigned int frameLen,
  360. const unsigned int etherType,
  361. const unsigned int vlanId,
  362. const bool noTee,
  363. const bool inbound,
  364. const int accept)
  365. {
  366. std::pair<Address, Trace::Level> byn;
  367. {
  368. Mutex::Lock l(_byNet_m);
  369. _byNet.get(network.id(), byn);
  370. }
  371. if (((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_RULES)) || ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_RULES))) {
  372. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  373. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__NETWORK_FILTER_TRACE_S);
  374. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, network.id());
  375. d.add(ZT_REMOTE_TRACE_FIELD__SOURCE_ZTADDR, ztSource);
  376. d.add(ZT_REMOTE_TRACE_FIELD__DEST_ZTADDR, ztDest);
  377. d.add(ZT_REMOTE_TRACE_FIELD__SOURCE_MAC, macSource.toInt());
  378. d.add(ZT_REMOTE_TRACE_FIELD__DEST_MAC, macDest.toInt());
  379. d.add(ZT_REMOTE_TRACE_FIELD__ETHERTYPE, (uint64_t)etherType);
  380. d.add(ZT_REMOTE_TRACE_FIELD__VLAN_ID, (uint64_t)vlanId);
  381. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_FLAG_NOTEE, noTee ? "1" : "0");
  382. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_FLAG_INBOUND, inbound ? "1" : "0");
  383. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_RESULT, (int64_t)accept);
  384. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_BASE_RULE_LOG, (const char*)primaryRuleSetLog.data(), (int)primaryRuleSetLog.sizeBytes());
  385. if (matchingCapabilityRuleSetLog) {
  386. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_CAP_RULE_LOG, (const char*)matchingCapabilityRuleSetLog->data(), (int)matchingCapabilityRuleSetLog->sizeBytes());
  387. }
  388. if (matchingCapability) {
  389. d.add(ZT_REMOTE_TRACE_FIELD__FILTER_CAP_ID, (uint64_t)matchingCapability->id());
  390. }
  391. d.add(ZT_REMOTE_TRACE_FIELD__FRAME_LENGTH, (uint64_t)frameLen);
  392. if (frameLen > 0) {
  393. d.add(ZT_REMOTE_TRACE_FIELD__FRAME_DATA, (const char*)frameData, (frameLen > 256) ? (int)256 : (int)frameLen);
  394. }
  395. if ((_globalTarget) && ((int)_globalLevel >= (int)Trace::LEVEL_RULES)) {
  396. _send(tPtr, d, _globalTarget);
  397. }
  398. if ((byn.first) && ((int)byn.second >= (int)Trace::LEVEL_RULES)) {
  399. _send(tPtr, d, byn.first);
  400. }
  401. }
  402. }
  403. void Trace::credentialRejected(void* const tPtr, const CertificateOfMembership& c, const char* reason)
  404. {
  405. std::pair<Address, Trace::Level> byn;
  406. if (c.networkId()) {
  407. Mutex::Lock l(_byNet_m);
  408. _byNet.get(c.networkId(), byn);
  409. }
  410. if ((_globalTarget) || (byn.first)) {
  411. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  412. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__CREDENTIAL_REJECTED_S);
  413. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, c.networkId());
  414. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TYPE, (uint64_t)c.credentialType());
  415. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ID, (uint64_t)c.id());
  416. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TIMESTAMP, c.timestamp());
  417. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ISSUED_TO, c.issuedTo());
  418. if (reason) {
  419. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  420. }
  421. if (_globalTarget) {
  422. _send(tPtr, d, _globalTarget);
  423. }
  424. if (byn.first) {
  425. _send(tPtr, d, byn.first);
  426. }
  427. }
  428. }
  429. void Trace::credentialRejected(void* const tPtr, const CertificateOfOwnership& c, const char* reason)
  430. {
  431. std::pair<Address, Trace::Level> byn;
  432. if (c.networkId()) {
  433. Mutex::Lock l(_byNet_m);
  434. _byNet.get(c.networkId(), byn);
  435. }
  436. if ((_globalTarget) || (byn.first)) {
  437. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  438. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__CREDENTIAL_REJECTED_S);
  439. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, c.networkId());
  440. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TYPE, (uint64_t)c.credentialType());
  441. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ID, (uint64_t)c.id());
  442. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TIMESTAMP, c.timestamp());
  443. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ISSUED_TO, c.issuedTo());
  444. if (reason) {
  445. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  446. }
  447. if (_globalTarget) {
  448. _send(tPtr, d, _globalTarget);
  449. }
  450. if (byn.first) {
  451. _send(tPtr, d, byn.first);
  452. }
  453. }
  454. }
  455. void Trace::credentialRejected(void* const tPtr, const Capability& c, const char* reason)
  456. {
  457. std::pair<Address, Trace::Level> byn;
  458. if (c.networkId()) {
  459. Mutex::Lock l(_byNet_m);
  460. _byNet.get(c.networkId(), byn);
  461. }
  462. if ((_globalTarget) || (byn.first)) {
  463. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  464. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__CREDENTIAL_REJECTED_S);
  465. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, c.networkId());
  466. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TYPE, (uint64_t)c.credentialType());
  467. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ID, (uint64_t)c.id());
  468. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TIMESTAMP, c.timestamp());
  469. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ISSUED_TO, c.issuedTo());
  470. if (reason) {
  471. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  472. }
  473. if (_globalTarget) {
  474. _send(tPtr, d, _globalTarget);
  475. }
  476. if (byn.first) {
  477. _send(tPtr, d, byn.first);
  478. }
  479. }
  480. }
  481. void Trace::credentialRejected(void* const tPtr, const Tag& c, const char* reason)
  482. {
  483. std::pair<Address, Trace::Level> byn;
  484. if (c.networkId()) {
  485. Mutex::Lock l(_byNet_m);
  486. _byNet.get(c.networkId(), byn);
  487. }
  488. if ((_globalTarget) || (byn.first)) {
  489. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  490. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__CREDENTIAL_REJECTED_S);
  491. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, c.networkId());
  492. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TYPE, (uint64_t)c.credentialType());
  493. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ID, (uint64_t)c.id());
  494. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TIMESTAMP, c.timestamp());
  495. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ISSUED_TO, c.issuedTo());
  496. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_INFO, (uint64_t)c.value());
  497. if (reason) {
  498. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  499. }
  500. if (_globalTarget) {
  501. _send(tPtr, d, _globalTarget);
  502. }
  503. if (byn.first) {
  504. _send(tPtr, d, byn.first);
  505. }
  506. }
  507. }
  508. void Trace::credentialRejected(void* const tPtr, const Revocation& c, const char* reason)
  509. {
  510. std::pair<Address, Trace::Level> byn;
  511. if (c.networkId()) {
  512. Mutex::Lock l(_byNet_m);
  513. _byNet.get(c.networkId(), byn);
  514. }
  515. if ((_globalTarget) || (byn.first)) {
  516. Dictionary<ZT_MAX_REMOTE_TRACE_SIZE> d;
  517. d.add(ZT_REMOTE_TRACE_FIELD__EVENT, ZT_REMOTE_TRACE_EVENT__CREDENTIAL_REJECTED_S);
  518. d.add(ZT_REMOTE_TRACE_FIELD__NETWORK_ID, c.networkId());
  519. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_TYPE, (uint64_t)c.credentialType());
  520. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_ID, (uint64_t)c.id());
  521. d.add(ZT_REMOTE_TRACE_FIELD__CREDENTIAL_REVOCATION_TARGET, c.target());
  522. if (reason) {
  523. d.add(ZT_REMOTE_TRACE_FIELD__REASON, reason);
  524. }
  525. if (_globalTarget) {
  526. _send(tPtr, d, _globalTarget);
  527. }
  528. if (byn.first) {
  529. _send(tPtr, d, byn.first);
  530. }
  531. }
  532. }
  533. void Trace::updateMemoizedSettings()
  534. {
  535. _globalTarget = RR->node->remoteTraceTarget();
  536. _globalLevel = RR->node->remoteTraceLevel();
  537. const std::vector<SharedPtr<Network> > nws(RR->node->allNetworks());
  538. {
  539. Mutex::Lock l(_byNet_m);
  540. _byNet.clear();
  541. for (std::vector<SharedPtr<Network> >::const_iterator n(nws.begin()); n != nws.end(); ++n) {
  542. const Address dest((*n)->config().remoteTraceTarget);
  543. if (dest) {
  544. std::pair<Address, Trace::Level>& m = _byNet[(*n)->id()];
  545. m.first = dest;
  546. m.second = (*n)->config().remoteTraceLevel;
  547. }
  548. }
  549. }
  550. }
  551. void Trace::_send(void* const tPtr, const Dictionary<ZT_MAX_REMOTE_TRACE_SIZE>& d, const Address& dest)
  552. {
  553. Packet outp(dest, RR->identity.address(), Packet::VERB_REMOTE_TRACE);
  554. outp.appendCString(d.data());
  555. outp.compress();
  556. RR->sw->send(tPtr, outp, true, 0, ZT_QOS_NO_FLOW);
  557. }
  558. void Trace::_spamToAllNetworks(void* const tPtr, const Dictionary<ZT_MAX_REMOTE_TRACE_SIZE>& d, const Level level)
  559. {
  560. Mutex::Lock l(_byNet_m);
  561. Hashtable<uint64_t, std::pair<Address, Trace::Level> >::Iterator i(_byNet);
  562. uint64_t* k = (uint64_t*)0;
  563. std::pair<Address, Trace::Level>* v = (std::pair<Address, Trace::Level>*)0;
  564. while (i.next(k, v)) {
  565. if ((v) && (v->first) && ((int)v->second >= (int)level)) {
  566. _send(tPtr, d, v->first);
  567. }
  568. }
  569. }
  570. } // namespace ZeroTier