Trace.cpp 22 KB

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