Compare commits

..

No commits in common. "e0b3d03fdfcf653bba35d72c9dc620c3c0ba2465" and "b54223680527984ee5fa1a333a2b90652a617229" have entirely different histories.

9 changed files with 11 additions and 121 deletions

View file

@ -5,6 +5,8 @@
#include "Block.h" #include "Block.h"
size_t Block::max_height = 0;
void Block::calculateHash() { void Block::calculateHash() {
memset(hash, 0, SHA256_DIGEST_LENGTH); memset(hash, 0, SHA256_DIGEST_LENGTH);
SHA256_CTX sha; SHA256_CTX sha;
@ -29,27 +31,10 @@ Block::Block(Transaction tr[], size_t count, const char *prev_hash) {
memset(this->prev_hash, 0, SHA256_CBLOCK+1); memset(this->prev_hash, 0, SHA256_CBLOCK+1);
else else
strcpy(this->prev_hash, prev_hash); strcpy(this->prev_hash, prev_hash);
height = ++max_height;
calculateHash(); calculateHash();
} }
void Block::mine(size_t diff) {
difficulty = diff;
std::string str;
for (int i = 0; i < diff; ++i) {
str += '0';
}
while(strncmp(hash,str.c_str(),diff) != 0){
nonce++;
calculateHash();
std::cout << nonce << std::endl;
}
}
size_t Block::getDifficulty() const {
return difficulty;
}
Transaction &Transaction::operator=(Transaction &tr) { Transaction &Transaction::operator=(Transaction &tr) {
if(this != &tr){ if(this != &tr){
strcpy(sender,tr.getSender()); strcpy(sender,tr.getSender());

View file

@ -49,14 +49,14 @@ class Block {
char hash[SHA256_CBLOCK+1]; char hash[SHA256_CBLOCK+1];
char prev_hash[SHA256_CBLOCK+1]; char prev_hash[SHA256_CBLOCK+1];
Transaction transactions[MAX_BLOCK_TRANSACTION]; Transaction transactions[MAX_BLOCK_TRANSACTION];
size_t difficulty; size_t height;
int nonce = 0; static size_t max_height;
public: public:
size_t getHeight() { return height; }
static size_t getMaxHeight() { return max_height; }
char* getHash() const { return (char*)hash;} char* getHash() const { return (char*)hash;}
char* getPerviousHash() const { return (char*)prev_hash;} char* getPerviousHash() const { return (char*)prev_hash;}
size_t getDifficulty() const;
Block(Transaction tr[],size_t count, const char *prev_hash = ""); Block(Transaction tr[],size_t count, const char *prev_hash = "");
void mine(size_t diff);
private: private:
void calculateHash(); void calculateHash();
}; };

View file

@ -34,30 +34,3 @@ bool Blockchain::addBlock(Block &b) {
blockList.push_back(b); blockList.push_back(b);
return verifyBlocks(); return verifyBlocks();
} }
Block Blockchain::operator[](size_t id) {
if(id >= blockList.size())
throw std::out_of_range("Out of range");
return blockList[id];
}
bool Blockchain::operator<(Blockchain &b) {
return blockList.size() < b.blockList.size();
}
size_t Blockchain::getHeight() const {
return blockList.size();
}
bool Blockchain::operator>(Blockchain &b) {
return blockList.size() > b.getHeight();
}
Blockchain::Blockchain() {
}
Blockchain::Blockchain(const Blockchain &b) {
for(Block bl : b.blockList)
blockList.push_back(bl);
}

View file

@ -15,17 +15,11 @@ class Blockchain {
static int blockReward; static int blockReward;
std::vector<Block> blockList; std::vector<Block> blockList;
public: public:
Blockchain();
Blockchain(const Blockchain &b);
const std::vector<Block> &getBlockList() const; const std::vector<Block> &getBlockList() const;
static int getDifficulty(); static int getDifficulty();
static int getBlockReward(); static int getBlockReward();
bool verifyBlocks() const; bool verifyBlocks() const;
size_t getHeight() const;
bool addBlock(Block& b); bool addBlock(Block& b);
Block operator[](size_t id);
bool operator<(Blockchain& b);
bool operator>(Blockchain& b);
}; };

View file

@ -3,8 +3,8 @@ project(blockchain)
set(CMAKE_CXX_STANDARD 14) set(CMAKE_CXX_STANDARD 14)
find_package(OpenSSL REQUIRED) find_package(OpenSSL REQUIRED)
add_executable(blockchain main.cpp Block.cpp Block.h config.h Blockchain.cpp Blockchain.h base58.cpp base58.h) add_executable(blockchain main.cpp Block.cpp Block.h config.h Blockchain.cpp Blockchain.h)
add_executable(test test/main.cpp Block.cpp Block.h base58.h base58.cpp) add_executable(test test/main.cpp Block.cpp Block.h)
include_directories(${OPENSSL_INCLUDE_DIR}) include_directories(${OPENSSL_INCLUDE_DIR})
target_link_libraries(test ${OPENSSL_LIBRARIES}) target_link_libraries(test ${OPENSSL_LIBRARIES})
target_link_libraries(blockchain ${OPENSSL_LIBRARIES}) target_link_libraries(blockchain ${OPENSSL_LIBRARIES})

View file

@ -1,43 +0,0 @@
//
// Készítette: Toldi Balázs Ádám
// Dátum: 2020. 03. 27.
//
#include "base58.h"
static const char* Base58arr = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";
std::string base58::encode(const char *data, int len) {
int zero = 0;
int clen = 0;
for (int i = 0; i < len && data[i] == 0; ++i)
zero++;
int size = len*138/100+1;
std::vector<unsigned char> b58(size);
for (int j = 0; j < len; ++j) {
int carry = data[j];
int i = 0;
for (auto it = b58.rbegin(); (carry != 0 || i < clen) && (it != b58.rend()); it++, i++) {
carry += 256* (*it);
*it = carry % 58;
carry /= 58;
}
assert(carry == 0);
clen = i;
}
auto it = b58.begin() + (size - clen);
while (it != b58.end() && *it == 0)
it++;
// Translate the result into a string.
std::string str;
str.reserve(zero + (b58.end() - it));
str.assign(zero, '1');
while (it != b58.end())
str += Base58arr[*(it++)];
return str;
}
std::string base58::encode(const std::string &data) {
return encode(data.c_str(),data.length());
}

View file

@ -1,17 +0,0 @@
//
// Készítette: Toldi Balázs Ádám
// Dátum: 2020. 03. 27.
//
#ifndef BLOCKCHAIN_BASE58_H
#define BLOCKCHAIN_BASE58_H
#include <string>
#include <cstring>
#include <vector>
#include <cassert>
namespace base58 {
std::string encode(const char * data, int len);
std::string encode(const std::string& data);
}
#endif //BLOCKCHAIN_BASE58_H

View file

@ -4,10 +4,9 @@
int main() { int main() {
std::cout << "Hello, World!" << std::endl; std::cout << "Hello, World!" << std::endl;
Transaction tr("","Balazs1",100); Transaction tr("","Balazs",100);
Transaction trs[] = {tr}; Transaction trs[] = {tr};
Block b(trs,1); Block b(trs,1);
b.mine(3);
std::cout << b.getHash() << std::endl; std::cout << b.getHash() << std::endl;
Block b2(nullptr,0,b.getHash()); Block b2(nullptr,0,b.getHash());
std::cout << b.getHash() << std::endl; std::cout << b.getHash() << std::endl;

View file

@ -1,7 +1,7 @@
#include <iostream> #include <iostream>
#include <cstring>
#include <sstream> #include <sstream>
#include <openssl/sha.h> #include <openssl/sha.h>
#include "../base58.h"
class Entity{ class Entity{
float x,y; float x,y;
@ -26,6 +26,5 @@ int main(){
for(int i = 0; i < SHA256_DIGEST_LENGTH; i++) for(int i = 0; i < SHA256_DIGEST_LENGTH; i++)
ss << std::hex << (int)md[i]; ss << std::hex << (int)md[i];
std::cout << ss.str() << std::endl; std::cout << ss.str() << std::endl;
std::cout << base58::encode("cat") << std::endl;
return 0; return 0;
} }