summaryrefslogtreecommitdiff
path: root/node/NetworkConfigRequestMetaData.hpp
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2016-05-06 13:29:10 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2016-05-06 13:29:10 -0700
commit529515d1d173e6850c86230106cbfc36e1b9bf97 (patch)
tree53f0eca20d9ce1ff4e02287813677e0401346387 /node/NetworkConfigRequestMetaData.hpp
parent69d0562e2c2ff4e5ddbc6f33ba43ddba913a25a9 (diff)
downloadinfinitytier-529515d1d173e6850c86230106cbfc36e1b9bf97.tar.gz
infinitytier-529515d1d173e6850c86230106cbfc36e1b9bf97.zip
Changes to how new-style binary network configs are detected, and a new-style binary serialized meta-data representation.
Diffstat (limited to 'node/NetworkConfigRequestMetaData.hpp')
-rw-r--r--node/NetworkConfigRequestMetaData.hpp128
1 files changed, 113 insertions, 15 deletions
diff --git a/node/NetworkConfigRequestMetaData.hpp b/node/NetworkConfigRequestMetaData.hpp
index 5bf8bac4..3756d0d8 100644
--- a/node/NetworkConfigRequestMetaData.hpp
+++ b/node/NetworkConfigRequestMetaData.hpp
@@ -25,6 +25,9 @@
#include "Constants.hpp"
#include "NetworkConfig.hpp"
+#include "Buffer.hpp"
+
+#include "../version.h"
#ifdef ZT_SUPPORT_OLD_STYLE_NETCONF
#include <string>
@@ -33,27 +36,122 @@
namespace ZeroTier {
+/**
+ * Network configuration request meta data
+ */
class NetworkConfigRequestMetaData
{
public:
- NetworkConfigRequestMetaData() :
- _vendor(0),
- _majorVersion(0),
- _minorVersion(0),
- _revision(0),
- _buildNo(0),
- _flags(0)
+ NetworkConfigRequestMetaData()
{
+ memset(this,0,sizeof(NetworkConfigRequestMetaData));
+ }
+
+ template<unsigned int C>
+ inline void serialize(Buffer<C> &b) const
+ {
+ // Unlike network config we always send the old fields. Newer network
+ // controllers will detect the presence of the new serialized data by
+ // detecting extra data after the terminating NULL. But always sending
+ // these maintains backward compatibility with old controllers.
+ b.appendCString("majv="ZEROTIER_ONE_VERSION_MAJOR_S"\nminv="ZEROTIER_ONE_VERSION_MINOR_S"\nrevv="ZEROTIER_ONE_VERSION_REVISION_S"\n");
+
+ b.append((uint16_t)1); // version
+
+ b.append((uint64_t)buildId);
+ b.append((uint64_t)flags);
+ b.append((uint16_t)vendor);
+ b.append((uint16_t)platform);
+ b.append((uint16_t)architecture);
+ b.append((uint16_t)majorVersion);
+ b.append((uint16_t)minorVersion);
+ b.append((uint16_t)revision);
+
+ unsigned int tl = (unsigned int)strlen(_auth);
+ if (tl > 255) tl = 255; // sanity check
+ b.append((uint8_t)tl);
+ b.append((const void *)auth,tl);
+
+ b.append((uint16_t)0); // extended bytes, currently 0 since unused
}
-protected:
- unsigned int _vendor;
- unsigned int _majorVersion;
- unsigned int _minorVersion;
- unsigned int _revision;
- unsigned int _buildNo;
- unsigned int _flags;
- char _passcode[ZT_MAX_NETWORK_SHORT_NAME_LENGTH + 1];
+ template<unsigned int C>
+ inline unsigned int deserialize(const Buffer<C> &b,unsigned int startAt = 0)
+ {
+ memset(this,0,sizeof(NetworkConfigRequestMetaData));
+
+ unsigned int p = startAt;
+
+ // Seek past old style meta-data
+ while (b[p]) ++p;
+
+ if (b.template at<uint16_t>(p) != 1)
+ throw std::invalid_argument("unrecognized version");
+ p += 2;
+
+ buildId = b.template at<uint64_t>(p); p += 8;
+ flags = b.template at<uint64_t>(p); p += 8;
+ vendor = (ZT_Vendor)b.template at<uint16_t>(p); p += 2;
+ platform = (ZT_Platform)b.template at<uint16_t>(p); p += 2;
+ architecture = (ZT_Architecture)b.template at<uint16_t>(p); p += 2;
+ majorVersion = b.template at<uint16_t>(p); p += 2;
+ minorVersion = b.template at<uint16_t>(p); p += 2;
+ revision = b.template at<uint16_t>(p); p += 2;
+
+ unsigned int tl = (unsigned int)b[p++];
+ memcpy(auth,b.field(p,tl),std::max(tl,(unsigned int)ZT_MAX_NETWORK_SHORT_NAME_LENGTH));
+ // auth[] is ZT_MAX_NETWORK_SHORT_NAME_LENGTH + 1 and so will always end up null-terminated since we zeroed the structure
+ p += tl;
+
+ p += b.template at<uint16_t>(p) + 2;
+
+ return (p - startAt);
+ }
+
+ /**
+ * Build ID (currently unused, must be 0)
+ */
+ uint64_t buildId;
+
+ /**
+ * Flags (currently unused, must be 0)
+ */
+ uint64_t flags;
+
+ /**
+ * ZeroTier vendor or 0 for unspecified
+ */
+ ZT_Vendor vendor;
+
+ /**
+ * ZeroTier platform or 0 for unspecified
+ */
+ ZT_Platform platform;
+
+ /**
+ * ZeroTier architecture or 0 for unspecified
+ */
+ ZT_Architecture architecture;
+
+ /**
+ * ZeroTier software major version
+ */
+ unsigned int majorVersion;
+
+ /**
+ * ZeroTier software minor version
+ */
+ unsigned int minorVersion;
+
+ /**
+ * ZeroTier software revision
+ */
+ unsigned int revision;
+
+ /**
+ * Authentication data (e.g. bearer=<token>)
+ */
+ char auth[ZT_MAX_NETWORK_SHORT_NAME_LENGTH + 1];
};
} // namespace ZeroTier