Basic concept of blockchain

This commit is contained in:
vbodinaud
2020-02-27 16:29:33 +01:00
parent 29eeea28fd
commit 963a9b074a
5 changed files with 102 additions and 1 deletions

View File

@@ -8,6 +8,8 @@
/* Begin PBXBuildFile section */
B5E66EBD2407FDE000E89D17 /* main.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E66EBC2407FDE000E89D17 /* main.swift */; };
B5E66EC52407FE0900E89D17 /* Block.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E66EC42407FE0900E89D17 /* Block.swift */; };
B5E66EC72407FEC800E89D17 /* Blockchain.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E66EC62407FEC800E89D17 /* Blockchain.swift */; };
/* End PBXBuildFile section */
/* Begin PBXCopyFilesBuildPhase section */
@@ -25,6 +27,8 @@
/* Begin PBXFileReference section */
B5E66EB92407FDE000E89D17 /* Blockchain */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = Blockchain; sourceTree = BUILT_PRODUCTS_DIR; };
B5E66EBC2407FDE000E89D17 /* main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = main.swift; sourceTree = "<group>"; };
B5E66EC42407FE0900E89D17 /* Block.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Block.swift; sourceTree = "<group>"; };
B5E66EC62407FEC800E89D17 /* Blockchain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Blockchain.swift; sourceTree = "<group>"; };
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
@@ -57,11 +61,21 @@
B5E66EBB2407FDE000E89D17 /* Blockchain */ = {
isa = PBXGroup;
children = (
B5E66EC32407FDEC00E89D17 /* Models */,
B5E66EBC2407FDE000E89D17 /* main.swift */,
);
path = Blockchain;
sourceTree = "<group>";
};
B5E66EC32407FDEC00E89D17 /* Models */ = {
isa = PBXGroup;
children = (
B5E66EC42407FE0900E89D17 /* Block.swift */,
B5E66EC62407FEC800E89D17 /* Blockchain.swift */,
);
path = Models;
sourceTree = "<group>";
};
/* End PBXGroup section */
/* Begin PBXNativeTarget section */
@@ -121,6 +135,8 @@
buildActionMask = 2147483647;
files = (
B5E66EBD2407FDE000E89D17 /* main.swift in Sources */,
B5E66EC52407FE0900E89D17 /* Block.swift in Sources */,
B5E66EC72407FEC800E89D17 /* Blockchain.swift in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};

View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<Bucket
uuid = "1409866F-116F-4CB0-A121-C7CA467135B7"
type = "1"
version = "2.0">
</Bucket>

View File

@@ -0,0 +1,25 @@
//
// Block.swift
// Blockchain
//
// Created by Victor BODINAUD on 27/02/2020.
// Copyright © 2020 Victor BODINAUD. All rights reserved.
//
import Foundation
import CryptoKit
class Block {
var hash: String!
var data: String!
var previousHash: String!
var index: Int!
func generateHash() -> String {
if let hashData = data.data(using: .utf8) {
_ = SHA256.hash(data: hashData)
}
return NSUUID().uuidString.replacingOccurrences(of: "-", with: "")
}
}

View File

@@ -0,0 +1,34 @@
//
// Blockchain.swift
// Blockchain
//
// Created by Victor BODINAUD on 27/02/2020.
// Copyright © 2020 Victor BODINAUD. All rights reserved.
//
import Foundation
class Blockchain {
var chain = [Block]()
func createGenesisBlock(data: String) {
let genesisBlock = Block()
genesisBlock.data = data
genesisBlock.previousHash = "0000"
genesisBlock.index = 0
genesisBlock.hash = genesisBlock.generateHash()
chain.append(genesisBlock)
print("Genesis block created -- hash: \(genesisBlock.hash ?? "")")
}
func createBlock(data: String) {
let newBlock = Block()
newBlock.data = data
newBlock.previousHash = chain[chain.count-1].hash
newBlock.index = chain.count
newBlock.hash = newBlock.generateHash()
chain.append(newBlock)
print("Block \(newBlock.index ?? 0) created -- hash: \(newBlock.hash ?? "") previous hash: \(newBlock.previousHash ?? "") data: \(newBlock.data ?? "")")
}
}

View File

@@ -8,5 +8,25 @@
import Foundation
print("Hello, World!")
let blockchain = Blockchain()
var command: String?
blockchain.createGenesisBlock(data: "")
repeat {
print("Enter command:")
command = readLine()
if command == "create" {
print("data for the new block:")
let data = readLine()
blockchain.createBlock(data: data ?? "")
}
if command == "spam" {
for _ in 1...1000000 {
blockchain.createBlock(data: "\((blockchain.chain.last?.index ?? 0)+1)")
}
}
} while command != "exit"