2020-05-22 16:18:41 +03:00
|
|
|
/*
|
2023-02-13 21:45:06 +03:00
|
|
|
* Copyright (c) 2013-2023, The PurpleI2P Project
|
2020-05-22 16:18:41 +03:00
|
|
|
*
|
|
|
|
* This file is part of Purple i2pd project and licensed under BSD3
|
|
|
|
*
|
|
|
|
* See full license text in LICENSE file at top of project tree
|
|
|
|
*/
|
|
|
|
|
2016-10-11 00:19:34 +03:00
|
|
|
#ifndef TAG_H__
|
|
|
|
#define TAG_H__
|
|
|
|
|
|
|
|
#include <boost/static_assert.hpp>
|
|
|
|
#include <string.h>
|
2016-11-14 20:05:44 +03:00
|
|
|
#include <openssl/rand.h>
|
2016-06-28 03:00:00 +03:00
|
|
|
#include "Base.h"
|
|
|
|
|
|
|
|
namespace i2p {
|
|
|
|
namespace data {
|
2020-03-01 13:25:50 +03:00
|
|
|
template<size_t sz>
|
|
|
|
class Tag
|
2016-10-11 00:46:18 +03:00
|
|
|
{
|
2020-03-01 13:25:50 +03:00
|
|
|
BOOST_STATIC_ASSERT_MSG(sz % 8 == 0, "Tag size must be multiple of 8 bytes");
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
Tag () = default;
|
|
|
|
Tag (const uint8_t * buf) { memcpy (m_Buf, buf, sz); }
|
|
|
|
|
|
|
|
bool operator== (const Tag& other) const { return !memcmp (m_Buf, other.m_Buf, sz); }
|
|
|
|
bool operator!= (const Tag& other) const { return !(*this == other); }
|
|
|
|
bool operator< (const Tag& other) const { return memcmp (m_Buf, other.m_Buf, sz) < 0; }
|
|
|
|
|
|
|
|
uint8_t * operator()() { return m_Buf; }
|
|
|
|
const uint8_t * operator()() const { return m_Buf; }
|
|
|
|
|
|
|
|
operator uint8_t * () { return m_Buf; }
|
|
|
|
operator const uint8_t * () const { return m_Buf; }
|
|
|
|
|
|
|
|
const uint8_t * data() const { return m_Buf; }
|
|
|
|
const uint64_t * GetLL () const { return ll; }
|
|
|
|
|
|
|
|
bool IsZero () const
|
|
|
|
{
|
|
|
|
for (size_t i = 0; i < sz/8; ++i)
|
|
|
|
if (ll[i]) return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Fill(uint8_t c)
|
|
|
|
{
|
|
|
|
memset(m_Buf, c, sz);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Randomize()
|
|
|
|
{
|
|
|
|
RAND_bytes(m_Buf, sz);
|
|
|
|
}
|
|
|
|
|
2022-02-06 01:14:25 +03:00
|
|
|
std::string ToBase64 (size_t len = sz) const
|
2020-03-01 13:25:50 +03:00
|
|
|
{
|
|
|
|
char str[sz*2];
|
2022-02-06 01:14:25 +03:00
|
|
|
size_t l = i2p::data::ByteStreamToBase64 (m_Buf, len, str, sz*2);
|
2020-03-01 13:25:50 +03:00
|
|
|
return std::string (str, str + l);
|
|
|
|
}
|
|
|
|
|
2022-02-06 01:14:25 +03:00
|
|
|
std::string ToBase32 (size_t len = sz) const
|
2020-03-01 13:25:50 +03:00
|
|
|
{
|
|
|
|
char str[sz*2];
|
2022-02-06 01:14:25 +03:00
|
|
|
size_t l = i2p::data::ByteStreamToBase32 (m_Buf, len, str, sz*2);
|
2020-03-01 13:25:50 +03:00
|
|
|
return std::string (str, str + l);
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t FromBase32 (const std::string& s)
|
|
|
|
{
|
|
|
|
return i2p::data::Base32ToByteStream (s.c_str (), s.length (), m_Buf, sz);
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t FromBase64 (const std::string& s)
|
|
|
|
{
|
|
|
|
return i2p::data::Base64ToByteStream (s.c_str (), s.length (), m_Buf, sz);
|
|
|
|
}
|
|
|
|
|
2023-02-13 21:45:06 +03:00
|
|
|
uint8_t GetBit (int i) const
|
|
|
|
{
|
|
|
|
int pos = i >> 3; // /8
|
2023-02-15 03:49:29 +03:00
|
|
|
if (pos >= (int)sz) return 0;
|
|
|
|
return m_Buf[pos] & (0x80 >> (i & 0x07));
|
2023-02-13 21:45:06 +03:00
|
|
|
}
|
|
|
|
|
2020-03-01 13:25:50 +03:00
|
|
|
private:
|
|
|
|
|
|
|
|
union // 8 bytes aligned
|
|
|
|
{
|
|
|
|
uint8_t m_Buf[sz];
|
|
|
|
uint64_t ll[sz/8];
|
|
|
|
};
|
2016-06-28 03:00:00 +03:00
|
|
|
};
|
|
|
|
} // data
|
|
|
|
} // i2p
|
|
|
|
|
2020-01-28 18:03:51 +03:00
|
|
|
namespace std
|
|
|
|
{
|
2020-03-01 13:25:50 +03:00
|
|
|
// hash for std::unordered_map
|
|
|
|
template<size_t sz> struct hash<i2p::data::Tag<sz> >
|
|
|
|
{
|
|
|
|
size_t operator()(const i2p::data::Tag<sz>& s) const
|
|
|
|
{
|
|
|
|
return s.GetLL ()[0];
|
|
|
|
}
|
|
|
|
};
|
2020-01-28 18:03:51 +03:00
|
|
|
}
|
|
|
|
|
2016-06-28 03:00:00 +03:00
|
|
|
#endif /* TAG_H__ */
|