You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
341 lines
13 KiB
341 lines
13 KiB
9 years ago
|
|
||
|
|
||
|
/******************************************************************************
|
||
|
* *
|
||
|
* *
|
||
|
* Using Brute force techinque program will randomly pick the block and *
|
||
|
* would compare is header hash. The expected header hashes for the blocks *
|
||
|
* are accurate and caculated using local bitcoind *
|
||
|
* *
|
||
|
* All api calls are made on Iguana Core *
|
||
|
* *
|
||
|
******************************************************************************/
|
||
|
|
||
|
#include<stdlib.h>
|
||
|
#include<string.h>
|
||
|
#include<assert.h>
|
||
|
#include<curl/curl.h>
|
||
|
#include<unistd.h>
|
||
|
#include<stdlib.h>
|
||
|
#define MAX_HEADER 45
|
||
|
#define STR_LEN 64
|
||
|
struct MemoryStruct
|
||
|
{
|
||
|
char *memory;
|
||
|
size_t size;
|
||
|
};
|
||
|
|
||
|
static size_t
|
||
|
WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp)
|
||
|
{
|
||
|
size_t realsize = size * nmemb;
|
||
|
struct MemoryStruct *mem = (struct MemoryStruct *)userp;
|
||
|
|
||
|
mem->memory = realloc(mem->memory, mem->size + realsize + 1);
|
||
|
if(mem->memory == NULL) {
|
||
|
/* out of memory! */
|
||
|
printf("not enough memory (realloc returned NULL)\n");
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
memcpy(&(mem->memory[mem->size]), contents, realsize);
|
||
|
mem->size += realsize;
|
||
|
mem->memory[mem->size] = 0;
|
||
|
|
||
|
return realsize;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
void fetchBlockHeader(const char * jsonrpc);
|
||
|
void bruteforceHashComparer();
|
||
|
int hash_index = 0;
|
||
|
int in=0;
|
||
|
int ind=0;
|
||
|
//char ActualHash[STR_LEN];
|
||
|
//char ExpectedHash[STR_LEN];
|
||
|
char *ActualHash;
|
||
|
char *ExpectedHash;
|
||
|
|
||
|
const char *hashes[MAX_HEADER] =
|
||
|
{"00000000839a8e6886ab5951d76f411475428afc90947ee320161bbf18eb6048",
|
||
|
"0000000026f34d197f653c5e80cb805e40612eadb0f45d00d7ea4164a20faa33",
|
||
|
"000000007bc154e0fa7ea32218a72fe2c1bb9f86cf8c9ebf9a715ed27fdb229a",
|
||
|
"000000009ca75733b4cf527fe193b919201a2ed38c9e147a5665fdfade551f4d",
|
||
|
"000000008f1a7008320c16b8402b7f11e82951f44ca2663caf6860ab2eeef320",
|
||
|
"000000004e833644bc7fb021abd3da831c64ec82bae73042cfa63923d47d3303",
|
||
|
"0000000062b69e4a2c3312a5782d7798b0711e9ebac065cd5d19f946439f8609",
|
||
|
"00000000e286ad94972e44b0532f2823bcda3977661a5136ff4d9d7db107d944",
|
||
|
"000000002dd9919f0a67590bb7c945cb57270a060ce39e85d8d37536a71928c3",
|
||
|
"00000000e474895c09bcdaf9261845960b35ea54ed3ecaf60d8a392940f1f3f9",
|
||
|
"000000004ff664bfa7d217f6df64c1627089061429408e1da5ef903b8f3c77db",
|
||
|
"00000000314ff43c77573a3b8094951ce4b0f86aceee65e226914eb737ada575",
|
||
|
"00000000c7f956a913bbef9c94f517c318805821b59ea6227175f3841792ea88",
|
||
|
"00000000d3ebca0f1cf140987959ba9231e9da43f3f76aed02d0cfe9d88b71d7",
|
||
|
"0000000084d973c18381c87a63a2430ad2eff1d84934ec34e3bfd78ffd3cd9c1",
|
||
|
"00000000ad8174a71c1b2c01fd6076143c2cf57d768bf80d7c11b6721d3a2525",
|
||
|
"00000000def8545899ea7274e5c59bda5982f8f960052774df45b7d5c64f9c5d",
|
||
|
"00000000923a992877f070d2c8fa5ae67e66f6edcd828b321caa75885136386b",
|
||
|
"00000000e684309e67fabdf765bea193cdf8532111079b7f53a0839746d19240",
|
||
|
"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09",
|
||
|
"000000009cd3f93cd2d843202155561eb773b2a7b7c97561ddef31e707f4eb4b",
|
||
|
"00000000f0b6da96d1e3272e87e181a7057c3d79bf984b420d4f6fd6d7a49fc7",
|
||
|
"0000000047a712b762d9c91aa1cc2e33fb48ea64276a7086c3c10aa252a934ab",
|
||
|
"00000000c9c28d2bb760225beaddbc212a01720869b624f088e9311df5b5d8f2",
|
||
|
"000000007d07681a955b7bb9d96c473e847395b592b6e9e5a73b15b594bd4013",
|
||
|
"00000000f6b38fee667afb9cb2eedc5a9988d345e7b61ce220d34005d2d5b8bf",
|
||
|
"000000009bf03aa138b1bb31491261221f8d4562941c1022a798acda7e3158d4",
|
||
|
"00000000046d4e2de13c9a31dec05fafcae393ae7de773242abd4db47e9e747f",
|
||
|
"00000000e67f39a80dbba80e5bf130294ef460b89022c7a56c3df76ab2df2e71",
|
||
|
"00000000dfd5d65c9d8561b4b8f60a63018fe3933ecb131fb37f905f87da951a",
|
||
|
"00000000d5092034c3a92473d42f28e3fd279f0652e2d5b0049c7d40fcbc990b",
|
||
|
"0000000070118b55e0436a721d4533fc3d09a0238f72a5380e8a694c9dbf948e",
|
||
|
"0000000091a5fdf4b5f5fe07ed869bf82049b3d61a403f2771b5cbd1937dad09",
|
||
|
"00000000081038eb250216ebb27f94d8896d2984dc962020c53e6a2852b92967",
|
||
|
"00000000d84724559f1691d916b2ed63a44884d495d155197647ce7667116b16",
|
||
|
"0000000091a7488531bb1050f24c0f8f90d4da873673eb4dec62bbce56a32910",
|
||
|
"000000001731f7bb532ebd8ff11c253f128a9e3108eaf038d8155fedeba5bc0c",
|
||
|
"00000000d10250150162aefbf7d64ab10f3b4706ffe4d04ae59ca410f672e97b",
|
||
|
"00000000a4342e04aa766386cdb4da70137efd47ac271f1a4e18429af3020a7c",
|
||
|
"000000004a81b9aa469b11649996ecb0a452c16d1181e72f9f980850a1c5ecce",
|
||
|
"00000000bccaab487030fe7c0d8d66a80fefc157bd75f0de40b6b8d61ea1d287",
|
||
|
"00000000b6641cc18693437c5208bf362730c533fd3ea4cca364793603bba957",
|
||
|
"00000000bfa35a68d94bf878a712c538484d8bc272c6ddd70de4e636d55f45de",
|
||
|
"00000000b590a5ff44afeb50e51444d8b6ccd08f6232951316f33e19b5ca5ff2",
|
||
|
"00000000922e2aa9e84a474350a3555f49f06061fd49df50a9352f156692a842"
|
||
|
};
|
||
|
|
||
|
const char *jsonRPC[MAX_HEADER] =
|
||
|
{ "{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1] }",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [50] }",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [100]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [150]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [200]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [250]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [300]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [350]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [400]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [450]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [500]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [550]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [600]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [650]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [700]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [750]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [800]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [850]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [900]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1000]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1100]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1200]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1300]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1400]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1500]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1600]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1700]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1800]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [1900]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2000]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2100]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2200]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2300]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2400]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2500]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2600]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2700]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2800]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [2900]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [3000]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [3200]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [3400]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [3600]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [3800]}",
|
||
|
"{\"id\":\"jl777\", \"method\": \"getblockhash\", \"params\": [4000]}"};
|
||
|
|
||
|
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
int api;
|
||
|
CURL *curl;
|
||
|
CURLcode res;
|
||
|
|
||
|
// struct MemoryStruct chunk;
|
||
|
|
||
|
// chunk.memory = malloc(1); /* will be grown as needed by the realloc above */
|
||
|
// chunk.size = 0; /* no data at this point */
|
||
|
|
||
|
// curl_global_init(CURL_GLOBAL_ALL);
|
||
|
// initialize all sub modules and return an easy handle for upcoming easy transfer
|
||
|
// curl = curl_easy_init();
|
||
|
|
||
|
// raise an assertion if handle is NULL
|
||
|
|
||
|
for(api=0; api<(MAX_HEADER-1); api++)
|
||
|
{
|
||
|
// printf("api == %d\n",api);
|
||
|
fetchBlockHeader(jsonRPC[api]);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
void fetchBlockHeader(const char* jsonrpc)
|
||
|
{
|
||
|
|
||
|
CURL *curl;
|
||
|
CURLcode res;
|
||
|
struct MemoryStruct chunk;
|
||
|
|
||
|
chunk.memory = malloc(1); /* will be grown as needed by the realloc above */
|
||
|
chunk.size = 0; /* no data at this point */
|
||
|
|
||
|
curl_global_init(CURL_GLOBAL_ALL);
|
||
|
// initialize all sub modules and return an easy handle for upcoming easy transfer
|
||
|
curl = curl_easy_init();
|
||
|
|
||
|
if(curl == NULL)
|
||
|
{
|
||
|
assert(curl);
|
||
|
}
|
||
|
|
||
|
ActualHash = (char*)calloc(64,sizeof(char));
|
||
|
ExpectedHash = (char*)calloc(64,sizeof(char));
|
||
|
if(ActualHash == NULL)
|
||
|
{
|
||
|
printf("ERROR: memory allocation failed for ActualHash\n");
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
if(ExpectedHash == NULL)
|
||
|
{
|
||
|
printf("ERROR: memory allocation failed for ExpectedHash\n");
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
printf("\n");
|
||
|
printf("RPC:%s\n\n",jsonrpc);
|
||
|
// set the properties and options for curl
|
||
|
// printf("1\n");
|
||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://127.0.0.1:7778");
|
||
|
|
||
|
/* send all data to this function */
|
||
|
// printf("2\n");
|
||
|
|
||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||
|
|
||
|
/* we pass our 'chunk' struct to the callback function */
|
||
|
// printf("3\n");
|
||
|
|
||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||
|
|
||
|
// calculate the length of data that will be passed using POST method to server
|
||
|
// printf("4\n");
|
||
|
|
||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (long) strlen(jsonrpc));
|
||
|
|
||
|
// the data parameter should be a pointer to character
|
||
|
// printf("5\n");
|
||
|
|
||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, jsonrpc);
|
||
|
|
||
|
// request using SSL for the transfer, otherwise normal transfer
|
||
|
// printf("6\n");
|
||
|
|
||
|
curl_easy_setopt(curl, CURLOPT_USE_SSL, CURLUSESSL_TRY);
|
||
|
// printf("7\n");
|
||
|
|
||
|
res =curl_easy_perform(curl);
|
||
|
// printf("8\n");
|
||
|
|
||
|
/* check for errors */
|
||
|
if(res != CURLE_OK) {
|
||
|
fprintf(stderr, "curl_easy_perform() failed: %s\n",
|
||
|
curl_easy_strerror(res));
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
// printf("9\n");
|
||
|
|
||
|
strcpy(ActualHash,chunk.memory);
|
||
|
//remove space from string
|
||
|
/*
|
||
|
while(ActualHash[in] !='\0')
|
||
|
{
|
||
|
if((ActualHash[in] != ' ') (ActualHash[in+1] != ' '))
|
||
|
{
|
||
|
|
||
|
iguanaResp[ind] = ActualHash[in];
|
||
|
ind++;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
printf("Got whitespace\n");
|
||
|
}
|
||
|
in++;
|
||
|
}
|
||
|
iguanaResp[ind] = '\0';
|
||
|
*/
|
||
|
// printf("10\n");
|
||
|
|
||
|
bruteforceHashComparer(curl);
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
sleep(2);
|
||
|
|
||
|
free(ActualHash);
|
||
|
// printf("11\n");
|
||
|
|
||
|
free(ExpectedHash);
|
||
|
// printf("12\n");
|
||
|
free(chunk.memory);
|
||
|
// printf("13\n");
|
||
|
|
||
|
in=0;
|
||
|
ind=0;
|
||
|
curl_easy_cleanup(curl);
|
||
|
//printf("14\n");
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
void bruteforceHashComparer()
|
||
|
{
|
||
|
|
||
|
int ret;
|
||
|
strcpy(ExpectedHash,hashes[hash_index]);
|
||
|
printf("Expect Hash: %s\n",ExpectedHash);
|
||
|
printf("Acutal Hash: %s\n",ActualHash);
|
||
|
|
||
|
ret = strncmp(ExpectedHash,ActualHash,64);
|
||
|
if(ret == 0)
|
||
|
{
|
||
|
printf("\t****************** PASSED ****************\n");
|
||
|
}
|
||
|
|
||
|
else
|
||
|
{
|
||
|
printf("\t****************** FAILED ****************\n");
|
||
|
|
||
|
}
|
||
|
|
||
|
hash_index++;
|
||
|
|
||
|
if(hash_index == MAX_HEADER)
|
||
|
{
|
||
|
hash_index = 0;
|
||
|
// curl_easy_cleanup(curl);
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|