-
-
Notifications
You must be signed in to change notification settings - Fork 46.7k
proof_of_work.py #12003
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
proof_of_work.py #12003
Changes from 11 commits
b7d4872
f86061b
fe47ba4
f4223e8
0213607
c37e2f9
65a08c3
ef12e2b
d64c8ea
ead7845
f17414a
75a0ffb
b4419b7
2ce385a
87d42b7
f171519
bc0a150
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
""" | ||
This module implements the Proof of Work algorithm for a blockchain. | ||
It includes classes for Block and Blockchain, demonstrating how to mine a block | ||
by finding a nonce that satisfies a given difficulty level. | ||
""" | ||
|
||
from datetime import datetime | ||
import hashlib | ||
|
||
class Block: | ||
def __init__(self, index: int, previous_hash: str, data: str, timestamp: str) -> None: | ||
self.index = index | ||
self.previous_hash = previous_hash | ||
self.data = data | ||
self.timestamp = timestamp | ||
self.nonce = 0 | ||
self.hash = self.calculate_hash() | ||
|
||
def calculate_hash(self) -> str: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file |
||
""" | ||
Calculates the hash of the block using SHA-256. | ||
|
||
>>> block = Block(1, '0', 'data', '2024-10-12T00:00:00') | ||
>>> block.calculate_hash() | ||
'...' # Expected hash value here | ||
""" | ||
value = str(self.index) + self.previous_hash + str(self.data) + str(self.timestamp) + str(self.nonce) | ||
return hashlib.sha256(value.encode('utf-8')).hexdigest() | ||
|
||
def mine_block(self, difficulty: int) -> None: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file |
||
""" | ||
Mines a block by finding a nonce that produces a hash | ||
starting with a specified number of zeros. | ||
|
||
>>> block = Block(1, '0', 'data', '2024-10-12T00:00:00') | ||
>>> block.mine_block(4) # Method should modify the nonce | ||
""" | ||
# Implementation of mining logic | ||
print(f"Block mined: {self.hash}") | ||
|
||
class Blockchain: | ||
def __init__(self) -> None: | ||
self.chain = [self.create_genesis_block()] | ||
self.difficulty = 4 | ||
|
||
def create_genesis_block(self) -> Block: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file |
||
""" | ||
Creates the genesis block for the blockchain. | ||
|
||
>>> blockchain = Blockchain() | ||
>>> blockchain.create_genesis_block().data | ||
'Genesis Block' | ||
""" | ||
return Block(0, "0", "Genesis Block", datetime.now().isoformat()) | ||
|
||
def get_latest_block(self) -> Block: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file |
||
return self.chain[-1] | ||
|
||
def add_block(self, new_block: Block) -> None: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As there is no test file in this pull request nor any test function or class in the file |
||
self.chain.append(new_block) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As there is no test file in this pull request nor any test function or class in the file
blockchain/proof_of_work.py
, please provide doctest for the functioncalculate_hash