i2pd/LeaseSet.h

51 lines
1008 B
C
Raw Normal View History

2013-11-25 03:10:27 +04:00
#ifndef LEASE_SET_H__
#define LEASE_SET_H__
#include <inttypes.h>
2013-11-29 16:52:09 +04:00
#include <string.h>
2014-01-02 03:19:03 +04:00
#include <vector>
2013-12-20 07:05:45 +04:00
#include "Identity.h"
2013-11-25 03:10:27 +04:00
namespace i2p
{
namespace data
2013-11-29 16:52:09 +04:00
{
2013-11-25 03:10:27 +04:00
#pragma pack(1)
2013-11-25 03:10:27 +04:00
struct Lease
{
uint8_t tunnelGateway[32];
uint32_t tunnelID;
uint64_t endDate;
};
2013-11-25 03:10:27 +04:00
#pragma pack()
class LeaseSet: public RoutingDestination
{
public:
LeaseSet (const uint8_t * buf, int len);
2014-01-13 07:31:26 +04:00
LeaseSet (const LeaseSet& ) = default;
LeaseSet& operator=(const LeaseSet& ) = default;
2013-11-25 03:10:27 +04:00
// implements RoutingDestination
2013-12-20 07:05:45 +04:00
const Identity& GetIdentity () const { return m_Identity; };
2013-11-29 16:52:09 +04:00
const IdentHash& GetIdentHash () const { return m_IdentHash; };
2014-01-02 03:19:03 +04:00
const std::vector<Lease>& GetLeases () const { return m_Leases; };
2013-11-25 03:10:27 +04:00
const uint8_t * GetEncryptionPublicKey () const { return m_EncryptionKey; };
bool IsDestination () const { return true; };
2013-11-25 03:10:27 +04:00
private:
2014-01-02 03:19:03 +04:00
std::vector<Lease> m_Leases;
2013-12-20 07:05:45 +04:00
Identity m_Identity;
2013-11-29 16:52:09 +04:00
IdentHash m_IdentHash;
2013-11-25 03:10:27 +04:00
uint8_t m_EncryptionKey[256];
};
}
}
#endif