summaryrefslogtreecommitdiff
path: root/protocols/Tox/src/tox_address.h
blob: 265ed2f94ee3bd4d97306ef0393045a2b2bb27c4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#ifndef _TOX_ADDRESS_H_
#define _TOX_ADDRESS_H_

class ToxHexAddress;
class ToxBinAddress;

class ToxHexAddress
{
private:
	std::string hexData;
public:
	ToxHexAddress(const ToxHexAddress &address) : hexData(address.hexData) { }
	ToxHexAddress(const char *hex, size_t size = TOX_ADDRESS_SIZE * 2) : hexData(hex, hex + size) { }
	ToxHexAddress(const std::string &hex)
	{
		this->ToxHexAddress::ToxHexAddress(hex.c_str(), hex.size());
	}
	ToxHexAddress(const uint8_t *bin, size_t size = TOX_ADDRESS_SIZE)
	{
		char *hex = (char*)mir_alloc(size * 2 + 1);
		hexData = bin2hex(bin, size, hex);
		std::transform(hexData.begin(), hexData.end(), hexData.begin(), ::toupper);
		mir_free(hex);
	}
	ToxHexAddress(const std::vector<uint8_t> &bin)
	{
		this->ToxHexAddress::ToxHexAddress(bin.data(), bin.size());
	}
	const size_t GetLength() const
	{
		return hexData.length();
	}
	const bool IsEmpty() const
	{
		return hexData.empty();
	}
	const ToxHexAddress GetPubKey() const
	{
		ToxHexAddress pubKey = hexData.substr(0, TOX_PUBLIC_KEY_SIZE * 2).c_str();
		return pubKey;
	}
	operator const char*() const
	{
		return hexData.c_str();
	}
	static ToxHexAddress Empty()
	{
		return ToxHexAddress("", 0);
	}
	ToxBinAddress ToBin() const;
};

class ToxBinAddress
{
private:
	std::vector<uint8_t> binData;
public:
	ToxBinAddress(const ToxBinAddress &address) : binData(address.binData) { }
	ToxBinAddress(const uint8_t *bin, size_t size = TOX_ADDRESS_SIZE) : binData(bin, bin + size) { }
	ToxBinAddress(const std::vector<uint8_t> &bin, size_t size = TOX_ADDRESS_SIZE) : binData(bin.begin(), bin.begin() + size) { }
	ToxBinAddress(const char *hex, size_t size = TOX_ADDRESS_SIZE * 2)
	{
		char *endptr;
		const char *pos = hex;
		for (size_t i = 0; i < size / 2; i++)
		{
			char buf[5] = { '0', 'x', pos[0], pos[1], 0 };
			binData.push_back((uint8_t)strtol(buf, &endptr, 0));
			pos += 2;
		}
	}
	ToxBinAddress(const std::string &hex)
	{
		this->ToxBinAddress::ToxBinAddress(hex.c_str(), hex.size());
	}
	const ToxBinAddress GetPubKey() const
	{
		ToxBinAddress pubKey(binData.data(), TOX_PUBLIC_KEY_SIZE);
		return pubKey;
	}
	operator const uint8_t*() const
	{
		return binData.data();
	}
	ToxHexAddress ToHex() const
	{
		ToxHexAddress hex(binData.data(), binData.size());
		return hex;
	}
};

ToxBinAddress ToxHexAddress::ToBin() const
{
	ToxBinAddress bin(hexData.c_str());
	return bin;
}

#endif //_TOX_ADDRESS_H_