Basic concept of blockchain
This commit is contained in:
@@ -8,6 +8,8 @@
|
|||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
B5E66EBD2407FDE000E89D17 /* main.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E66EBC2407FDE000E89D17 /* main.swift */; };
|
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 */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXCopyFilesBuildPhase section */
|
/* Begin PBXCopyFilesBuildPhase section */
|
||||||
@@ -25,6 +27,8 @@
|
|||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
B5E66EB92407FDE000E89D17 /* Blockchain */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = Blockchain; sourceTree = BUILT_PRODUCTS_DIR; };
|
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>"; };
|
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 */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
@@ -57,11 +61,21 @@
|
|||||||
B5E66EBB2407FDE000E89D17 /* Blockchain */ = {
|
B5E66EBB2407FDE000E89D17 /* Blockchain */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
B5E66EC32407FDEC00E89D17 /* Models */,
|
||||||
B5E66EBC2407FDE000E89D17 /* main.swift */,
|
B5E66EBC2407FDE000E89D17 /* main.swift */,
|
||||||
);
|
);
|
||||||
path = Blockchain;
|
path = Blockchain;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
B5E66EC32407FDEC00E89D17 /* Models */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B5E66EC42407FE0900E89D17 /* Block.swift */,
|
||||||
|
B5E66EC62407FEC800E89D17 /* Blockchain.swift */,
|
||||||
|
);
|
||||||
|
path = Models;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
@@ -121,6 +135,8 @@
|
|||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
B5E66EBD2407FDE000E89D17 /* main.swift in Sources */,
|
B5E66EBD2407FDE000E89D17 /* main.swift in Sources */,
|
||||||
|
B5E66EC52407FE0900E89D17 /* Block.swift in Sources */,
|
||||||
|
B5E66EC72407FEC800E89D17 /* Blockchain.swift in Sources */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<Bucket
|
||||||
|
uuid = "1409866F-116F-4CB0-A121-C7CA467135B7"
|
||||||
|
type = "1"
|
||||||
|
version = "2.0">
|
||||||
|
</Bucket>
|
||||||
25
Blockchain/Models/Block.swift
Normal file
25
Blockchain/Models/Block.swift
Normal 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: "")
|
||||||
|
}
|
||||||
|
}
|
||||||
34
Blockchain/Models/Blockchain.swift
Normal file
34
Blockchain/Models/Blockchain.swift
Normal 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 ?? "")")
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,5 +8,25 @@
|
|||||||
|
|
||||||
import Foundation
|
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"
|
||||||
|
|||||||
Reference in New Issue
Block a user