1
0
mirror of https://github.com/PurpleI2P/i2pd-tools synced 2025-01-26 22:34:13 +00:00
i2pd-tools/vanity.hpp

68 lines
1.7 KiB
C++
Raw Normal View History

2017-08-09 16:55:08 +07:00
#pragma once
#include <iostream>
#include <fstream>
#include <stdlib.h>
#include <openssl/rand.h>
#include "Crypto.h"
#include "Identity.h"
2017-08-17 10:50:44 +03:00
#include "I2PEndian.h"
2017-08-09 16:55:08 +07:00
#include "common/key.hpp"
#include <thread>
#include <unistd.h>
#include <vector>
2017-08-17 10:50:44 +03:00
2017-08-17 03:02:21 +07:00
#ifdef _WIN32
#include <windows.h>
#endif
2017-08-17 10:50:44 +03:00
2017-08-16 12:16:40 +07:00
// sha256
2017-08-17 10:50:44 +03:00
#define Ch(x, y, z) ((x & (y ^ z)) ^ z)
2017-08-16 12:16:40 +07:00
#define Maj(x, y, z) ((x & (y | z)) | (y & z))
2017-08-17 10:50:44 +03:00
#define SHR(x, n) (x >> n)
#define ROTR(x, n) ((x >> n) | (x << (32 - n)))
#define S0(x) (ROTR(x, 2) ^ ROTR(x, 13) ^ ROTR(x, 22))
#define S1(x) (ROTR(x, 6) ^ ROTR(x, 11) ^ ROTR(x, 25))
#define s0(x) (ROTR(x, 7) ^ ROTR(x, 18) ^ SHR(x, 3))
#define s1(x) (ROTR(x, 17) ^ ROTR(x, 19) ^ SHR(x, 10))
2017-08-16 12:16:40 +07:00
#define RND(a, b, c, d, e, f, g, h, k) \
t0 = h + S1(e) + Ch(e, f, g) + k; \
t1 = S0(a) + Maj(a, b, c); \
d += t0; \
h = t0 + t1;
#define RNDr(S, W, i, k) \
RND(S[(64 - i) % 8], S[(65 - i) % 8], \
S[(66 - i) % 8], S[(67 - i) % 8], \
S[(68 - i) % 8], S[(69 - i) % 8], \
S[(70 - i) % 8], S[(71 - i) % 8], \
W[i] + k)
2018-06-11 23:53:39 +07:00
//static i2p::data::SigningKeyType type;
2017-08-11 18:37:37 +07:00
//static i2p::data::PrivateKeys keys;
2017-08-15 01:29:32 +07:00
static bool found=false;
2017-08-11 18:37:37 +07:00
static size_t MutateByte;
2017-08-15 01:29:32 +07:00
static uint32_t FoundNonce=0;
2017-08-11 18:37:37 +07:00
2017-08-09 16:55:08 +07:00
static uint8_t * KeyBuf;
2017-08-11 18:37:37 +07:00
//static uint8_t * PaddingBuf;
static unsigned long long hashescounter;
2017-08-15 01:29:32 +07:00
unsigned int count_cpu;
2017-08-10 10:07:38 +07:00
2017-08-16 12:16:40 +07:00
const uint8_t lastBlock[64] =
{
0x05, 0x00, 0x04, 0x00, 0x07, 0x00, 0x00, 0x80, // 7 bytes EdDSA certificate
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0C, 0x38 // 3128 bits (391 bytes)
};
2017-08-16 12:16:40 +07:00