Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain...

90
What’s Holding Blockchain Back from Mass Adoption? Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 William Favre Slater, III M.S., MBA, PMP, CISSP, CISA, SSCP, Security+, ITILv3 What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III February 27, 2019 1

Transcript of Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain...

Page 1: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

What’s Holding Blockchain Back from

Mass Adoption?

Quick Introduction to

Blockchain Security &

Blockchain Auditing

February 27, 2019

William Favre Slater, IIIM.S., MBA, PMP, CISSP, CISA, SSCP, Security+, ITILv3

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 1

Page 2: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Presentation Location

http://billslater.com/writing

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 2

Page 3: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

For a Cynical & Humorous View of Blockchain

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 3

Page 4: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

ISIS Loves Bitcoin (or They Did Love It)

Their Public Key

Comment: This actually didn’t end well for ISIS and their Donors.

Enough said.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 4

Page 5: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

New Free Blockchain Daily Newspaper:

More information: https://paper.li/billslater/1530793250#/

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 5

Page 6: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Introduction and

Where Are We Right Now?

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 6

Page 7: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

AbstractSince Blockchain became well-known as the foundational set of

technologies that enabled the creation and operation of Bitcoin, it

has captured the attention and imagination of developers, industry

leaders, and investors. This is because as a set of technologies that

use consensus and peer-to-peer, decentralized systems, it creates

immutable data records and enables trust and disintermediation at

scale. So what is preventing Blockchain from changing the world?

This presentation will present some of the challenges that are

preventing mass adoption of Blockchain, and some practical

solutions to those challenges.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 7

Page 8: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Agenda

What’s Holding Back Blockchain from Mass Adoption?

Topic 1: Why Blockchain?Topic 2: Blockchain LawTopic 3: Distributed Systems and Blockchain Security ConceptsTopic 4: Blockchain Limits and ChallengesTopic 5: How to Secure Blockchain Infrastructure and ApplicationsTopic 6: How to perform Secure Software Development for Blockchain applications by design, coding practices, testing and verificationTopic 7: Blockchain and AuditingTopic 8: How to Design and Implement a Blockchain Solution Project – an Organized High-Level Step-by-Step Approach Topic 9: How to Help your Organization Rapidly Ramp Up Skills and Readiness for Blockchain Application DevelopmentConclusionSpecial ThanksReferences

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 8

Page 9: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 1: WHY BLOCKCHAIN?

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 9

Page 10: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

February 27, 2019 What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III 10

Page 11: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 11

Page 12: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: To Blockchain or not to Blockchain? https://medium.com/causys/to-blockchain-or-not-to-blockchain-aed05bf08150 Hats off to the author, Thomas Ferry of Causys

February 27, 2019 What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III 12

Page 13: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain Use Evolution

February 27, 2019 What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III 13

Page 14: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Why Is Blockchain Important?

• Accessible

• Open source

• Easily provides three challenging elements of the Parkerian Hexad model for

security:

• Authenticity

• Control

• Utility

• It WORKS!

• Business enabler

• Reduces risk of computer fraud

• It is being widely adopted for trusted computing

• Blockchain developers and architects are in great demand:

for every Blockchain professional there are 14 open positionsDonn B. Parker

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 14

Page 15: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Parkerian Hexad

Donn B. Parker

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 15

Page 16: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 2: BLOCKCHAIN LAW

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 16

Page 17: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain & The Law

• Blockchain establishes ownership, confirmed transactions, control,

and transfer of ownership.

• Blockchain will force lawyers to understand technology better

• Blockchain could also make room for “smart contracts,” where assets

would be transferred automatically once certain conditions are met.

• Blockchain could resolve disputes very directly and efficiently,

saving lawyers and their clients a great deal of work. This also could

mean the end of escrow accounts where the law firm holds onto

money and distributes funds once conditions have been met.

• Contracts and transactions could be a logical first-step in the

blockchain adoption journey.

• Blockchain could very well improve the effectiveness of the criminal

justice system;

• If corporations and websites agree to give law firms access to records

automatically collected through blockchain, those records could

cause new, reliable evidence to surface more quickly.

• Expect that those with evidence on their side will embrace this

concept, and others will prefer to drag their adversary through a

drawn-out process.

• As more companies adopt Blockchain technologies and require their

third-party suppliers to adopt Blockchain technologies, expect this

requirement to be written into legally binding business contracts.

Source: https://www.forbes.com/sites/ianaltman/2018/06/29/blockchain-changes-business-law/#698d3605cb9f

For more informationGet Blockchain & the LawBy Primavera De FilippiAnd Aaron Wright, 2018

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 17

Page 18: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

When Blockchains Crash,

Who Can We Sue?

Source: https://www.forbes.com/sites/andreatinianow/2019/02/07/when-blockchains-crash-whom-can-you-sue/#760e20707775

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

Published February 7, 2019 atForbes.com

February 27, 2019 18

Page 19: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain & The Law

Nelson RosarioChicagohttps://www.linkedin.com/in/nelsonrosario/

Ms. Puneet BhasinMumbai, Indiahttps://www.linkedin.com/in/advpuneetbhasincyberlawyer/

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 19

Page 20: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 3: DISTRIBUTED SYSTEMS AND BLOCKCHAIN SECURITY CONCEPTS

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 20

Page 21: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CAP Theorem

Source: https://en.wikipedia.org/wiki/CAP_theorem

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 21

Page 22: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CAP Theorem

Source: https://en.wikipedia.org/wiki/CAP_theorem

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 22

Page 23: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CAP Theorem

Source: Edureka.in

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 23

Page 24: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CAP Theorem

Source: https://en.wikipedia.org/wiki/CAP_theorem

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 24

Page 25: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CAP Theorem

Source: https://en.wikipedia.org/wiki/CAP_theorem

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 25

Page 26: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain Security Threats and Vulnerabilities

& Remediations (A Short List – Part 1)Threat or Vulnerability

Description Remediation Comment(s)

Threat 51% Attack Securely design, implement, monitor, maintain, test & upgrade.

Happened to Bitcoin in June 2014.http://tinyurl.com/y5malrxc

Threat Sybil Attack Securely design, implement, monitor, maintain, test & upgrade.

Need better education and experience.

Vulnerability Bad Private Key Management Understand & Securely manage private keys.

Need better education and tools.

Vulnerability Centralization Understand the CAP Theorem and Decentralization. Design and implement accordingly.

Need better education.

Vulnerability Scalability Securely design, implement, monitor, maintain, test & upgrade.

Need better education and experience.

Vulnerability Network Security Securely design, implement, monitor, maintain, test & upgrade.

Need better education.

Vulnerability Smart Contracts – Coding errors Securely design, implement, monitor, maintain, test & upgrade.

Need better education and experience.

Vulnerability Smart Contracts – Configuration Errors

Securely design, implement, monitor, maintain, test & upgrade.

Need better education and experience.

Vulnerability Blockchain & Smart Contracts -Inexperience

Use Secure Development practices, and experienced developers and testers.

Need better education and experience.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 26

Page 27: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain Security Threats and Vulnerabilities

& Remediations (A Short List – Part 2)Threat or Vulnerability

Description Remediation Comment(s)

Vulnerability Reentrancy Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Unexpected Ether Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability DELEGATECALL Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Default Visibilities Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Entropy Illusion Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability External Contract Referencing Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Short Address / Parameter Attack Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Unchecked CALL Return Value Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Race Conditions / Front Running Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 27

Page 28: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Blockchain Security Threats and Vulnerabilities

& Remediations (A Short List - Part 3)Threat or Vulnerability

Description Remediation Comment(s)

Vulnerability Denial of Service Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Block Timestamp Manipulation Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Constructions with Care Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Uninitialized Storage Pointers Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Floating Point and Precision Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Transaction Origin Authentication Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Vulnerability Contract Libraries Securely design, implement, monitor, maintain, test & upgrade. Code reviews & Audits.

See Mastering Ethereum, Chapter 9.

Threat Shor’s Algorithm (Using Quantum Computing)

Stronger, better encryption, perhaps Quantum Cryptography.

Closer than you think

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 28

Page 29: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

51% Attack

on Ethereum

Classic –

January 2019

February 27, 2019 What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III 29

Source: MIT Review, Mike Orcutt, February 19, 2019 https://www.technologyreview.com/s/612974/once-hailed-as-unhackable-blockchains-are-now-getting-hacked/

Page 30: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Top Web Application & Software Vulnerabilities

The Story in 2019

Source: https://www.veracode.com/sites/default/files/pdf/resources/ipapers/state-of-software-security-volume-9/index.html

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 30

Page 31: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 4: BLOCKCHAIN LIMITS AND CHALLENGES

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 31

Page 32: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Technical Limitations

Source: Drescher, D. (2017). Blockchain Basics. Frankfort am Main, Germany: Apress.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 32

Page 33: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Technical Limitations

Source: Drescher, D. (2017). Blockchain Basics. Frankfort am Main, Germany: Apress.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 33

Page 34: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Limits and Challenges

• Scalability

• Performance (Bitcoin – 600 seconds / block; Ethereum, 14 to 17 seconds / block)

• Security, especially with user wallets

• Weaknesses in the technologies, i.e. deployment of bad contracts, can cause very

expensive blunders and loss of confidence and reputation

• Finding the right people to develop DApps and manage the technologies

• Resistance to change

• Anti-trust issues (Norton Rose Fulbright):

– Does blockchain allow for improper information sharing and facilitate collusion among

competitors?

– Do blockchain standards and rules create or enhance market power by favoring one or

several industry participant(s) over others?

– Does a permissioned blockchain amount to a concerted refusal to deal?

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 34

Page 35: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 5: HOW TO SECURE BLOCKCHAIN INFRASTRUCTURE AND APPLICATIONS

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 35

Page 36: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Topic 5: How to Secure Blockchain

Infrastructure and Applications

• Build and lead Teams of experienced, dedicated workers

• Design securely

• Implement securely

• Document everything

• Test security

– Routinely test vulnerabilities (at least quarterly)

• https://tinyurl.com/y292y3yf

– Penetration test semi-annually

• https://tinyurl.com/yya4vtac

– Test and document performance

• https://tinyurl.com/yxpwszj7

• Do Threat Management

• Continuously review for upgrading

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 36

Page 37: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 6: HOW TO PERFORM SECURE SOFTWARE DEVELOPMENT FOR BLOCKCHAIN APPLICATIONS BY DESIGN, CODING PRACTICES, TESTING AND VERIFICATION

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 37

Page 38: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Topic 6: How to Perform Secure Software

Development for Blockchain applications by

Design, Coding practices, Testing and

Verification

• Experienced DApp developers

• Test-driven Development

• Code reviews, by multiple experienced developers

• Understand and remediate the weakest security points,

especially protection of private keys and sensitive data.

• Implement the tests on test net and understand exactly how the

code will behave prior to moving to main net

• Automate Smart Contract testing when possible

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 38

Page 39: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CASE STUDIES

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 39

Page 40: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Case Study 1

• Timeframe: November 2017

• Location: User devops199 somewhere on the

Ethereum Blockchain

• Topic: Placement in Production of flawed Smart

Contract

• Results: Loss of over $150 million

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 40

Page 41: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

$150,000,000 bug

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 41

Page 42: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 7: BLOCKCHAIN AND AUDITING

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 42

Page 43: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Topic 7: Blockchain and Auditing

• Blockchain Integrity and Security

• DApps

• Infrastructure

• Physical Security

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 43

Page 44: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Concepts of Auditing the Data and

Transactions in Blockchain Data Structures

• Data should be validated and verified prior to

committing as a Blockchain transaction because once

written to the Blockchain it is immutable.

• Sample transactions should be verified from the

DApp, to as successfully written to the Blockchain.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 44

Page 45: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Automating the Auditing of Blockchains

and Blockchain Applications• In February 2018, Maian, an open source tool to monitor Smart Contracts

for being Greedy, Prodigal, or Suicidal was announced.

• As of April 2018, EY has Blockchain Auditing tools and technology.

– https://www.ey.com/en_gl/news/2018/04/ey-announces-blockchain-audit-

technology

• As of October 2018, How Big Four Auditors Delve Into Blockchain: PwC,

Deloitte, EY and KPMG Approaches Compared

– https://cointelegraph.com/news/how-big-four-auditors-delve-into-blockchain-

pwc-deloitte-ey-and-kpmg-approaches-compared

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 45

Page 46: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Auditing Smart Contracts at Scale

Source: https://www.reddit.com/r/Bitcoin/comments/7ys5nq/pdf_finding_the_greedy_prodigal_and_suicidal/

February 2018 Technical paper about flaws in How Ethereum and EVM handleSmart Contracts. Worth your time.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 46

Prodigal - Leak them carelessly to arbitrary users

Suicidal - Can be killed by anyone

Greedy - Lock funds Indefinitely

Page 47: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Auditing Smart Contracts at Scale

Sources: https://www.reddit.com/r/Bitcoin/comments/7ys5nq/pdf_finding_the_greedy_prodigal_and_suicidal/and https://bitsonline.com/singapore-research-ethereum/

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 47

Prodigal - Leak them carelessly to arbitrary users

Suicidal - Can be killed by anyone

Greedy - Lock funds Indefinitely

Bottom Line: three to four percent of the smart contracts on Ethereum’s blockchain still contain trace vulnerabilities, according to the researchers’ new analysis methodology.

Page 48: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Auditing Smart Contracts at Scale

Sources: https://www.reddit.com/r/Bitcoin/comments/7ys5nq/pdf_finding_the_greedy_prodigal_and_suicidal/and https://bitsonline.com/singapore-research-ethereum/

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 48

Bottom Line: three to four percent of the smart contracts on Ethereum’s blockchain still contain trace vulnerabilities, according to the researchers’ new analysis methodology.

Opacity Is Hampering Ethereum SecurityAnother interesting point raised in the paper is the unavailability of smart contract source code for Ethereum smart contracts, estimating the number at only one percent of the 970 thousand contracts they analyzed.

Fixing serious security vulnerabilities at scale requires peer review, and the culture of propriety on the Ethereum network forced the research team to directly analyze EVM bytecode instead of the sources to complete their research. Were the source code for these contracts more available and reviewed, Trace Vulnerabilities on Ethereum may not have proliferated in the first place.

-- O'Ham, T. (2018). Singapore Research Team Codifies 3 new Ethereum VM Vulnerabilities. An article published at Bitsonline.com on February 21, 2018. Retrieved from https://bitsonline.com/singapore-research-ethereum/ on February 27, 2019.

Page 49: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

MAIAN

Source https://github.com/MAIAN-tool/MAIAN

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 49

Page 50: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

MAIAN

Source https://github.com/MAIAN-tool/MAIAN

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 50

Page 51: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

MAIAN

Source https://github.com/MAIAN-tool/MAIAN

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 51

Page 52: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

MAIAN

Source https://github.com/MAIAN-tool/MAIAN

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 52

Page 53: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

MAIAN

Source https://github.com/MAIAN-tool/MAIAN

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 53

Page 54: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 8: HOW TO DESIGN AND IMPLEMENT A BLOCKCHAIN SOLUTION PROJECT – AN ORGANIZED HIGH-LEVEL STEP-BY-STEP APPROACH

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 54

Page 55: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Overview of Ethereum

Source: https://www.researchgate.net/publication/315619465_A_more_pragmatic_Web_30_Linked_Blockchain_Data

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 55

Page 56: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Ethereum DApp Architecture

Source: https://www.researchgate.net/publication/315619465_A_more_pragmatic_Web_30_Linked_Blockchain_Data

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 56

Page 57: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

High-Level

DApp

Architecture

Source: Ethereum Smart Contract Development by Mayukh Mukhopadhyay

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 57

Page 58: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Web3.js Tech Stack

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 58

Page 59: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Web Apps and DApps - Compared

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 59

Page 60: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

DApp Development Steps

1. Analysis

2. Design

3. Implementation

Identify the entities involved, their roles and types of interactions

between them (e.g. contract owner, users, devices)

Analysis

Design

Implementation

Model the entity attributes as state variables and interactions

between them as functions. Also capture the dependencies and

constraints

Implement the contracts (including state variables, functions,

modifier and events) in a higher-level languages such as Solidity

For Dapp, also implement the front-end (HTML and CSS) and

backend (Javascript).

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 60

Page 61: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

DApp Development Steps – Analysis - Example

· Creates campaign

· Checks Campaign status

Campaign Owner

Campaign backers

Crowdfunding

Campaign

· Fund campaign

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 61

Page 62: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

DApp Development Steps –Design - Example

· Creates campaign

· Checks Campaign status

Campaign Owner

Campaign backers

Crowdfunding

Campaign

· Fund campaign

· address public owner;

· struct Backer {address addr; uint amount;}

· mapping (uint => Backer) backers;

· uint public backers;

· uint public deadline;

· string public campaignStatus;

· bool ended;

· uint public goal;

· uint public amountRaised;

· Crowdfunding(uint_deadline, uint_goal)

· checkGoalReached ()

· fund()

}

}}

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 62

Page 63: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

DApp Development Steps –Implementation - Example

(Example Business Case:

Crowdfunding Application)

Transaction: Create

Contract

· uint deadline

· uint goal

Externally Owned

Account

Transaction:

checkGoalReached ()

Transaction: fund ()

· value

EOAs

Create

contract

Check if

crowd-

funding

goal is

reached

Creates

and

owns

Fund

campaign

EOAs

send

transactions

Contract Crowdfunding

State Variables

Functions

Modifiers

Events

· Crowdfunding(uint_deadline, uint_goal)

· checkGoalReached ()

· fund()

· destroy()

· struct Backer {address addr; uint amount;}

· address public owner;

· uint public backers;

· uint public deadline;

· string public campaignStatus;

· bool ended;

· uint public goal;

· uint public amountRaised;

· mapping (uint => Backer) backers;

· Deposit (address_from,uint_amount)

· Refund (address_to,uint_amount)

· onlyOwner()

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 63

Page 64: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

BLOCKCHAIN APPLICATION TEMPLATES

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 64

Page 65: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

Blockchain Application Templates

Contract owner

Users

EOAs

Calls and

TransactionsCreates

and

owns

Contract

State Variables

Functions

Modifiers

Events

Many-to-One

Calls and

Transactions

Externally Owned

Account (EOA)

Account Address

Account Keys

Ether Balance

Some Current Examples

· Crowdfunding

· Event Registration

· Voting

· Name Registration

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 65

Page 66: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

Contract owner

Users

EOAs

Calls and

Transactions

Contract

State Variables

Functions

Modifiers

Events

Externally Owned

Account (EOA)

Some Current Examples

· Solar charging stations

· Smart switch

Blockchain Application Templates

Many-to-One for IoT Applications

Calls and

Transactions

IoT Device

Calls and

Transactions

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 66

Page 67: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

Users

Some Current Examples

· Product sales

· Stock photos

· Document verification

Blockchain Application Templates

Many-to-One for Financial Applications

Calls and

Transactions

EOAs

Contract

State Variables

Functions

Modifiers

Events

Calls and

Transactions

EOAs

Roles

· Buyer

· Consumer

· Verifier

Contract owner

EOA

Calls and

Transactions

Roles

· Seller

· Producer

· Creator

Users

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 67

Page 68: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Applications: A Hands-on Approach by Arsheep Bahga and Vijay Madisetti

Party A

Some Current Examples

· Call option

· Interest rate swap

Blockchain Application Templates

Many-to-Many or Peer-to-Peer

A’s Trading

Account

Contract

State Variables

Functions

Modifiers

Events

5. Validate

contract

Party B

B’s Trading

Account

6. Authorize

account

7. Settlement

4. F

und

acco

unt

8. Settlement

2. Initiate

contract

1. Fund

account

3. Authorize

account

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 68

Page 69: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Enabled Applications: Understand the Blockchain Ecosystem and How to Make it Work for You by Vikram Dhillon, David Metcalf, Max Hooper

Simple Blockchain Application Model

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 69

Page 70: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Source: Blockchain Enabled Applications: Understand the Blockchain Ecosystem and How to Make it Work for You by Vikram Dhillon, David Metcalf, Max Hooper

Example of a Blockchain-based Application

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 70

Page 71: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

TOPIC 9: HOW TO HELP YOUR ORGANIZATION RAPIDLY RAMP UP SKILLS AND READINESS FOR BLOCKCHAIN APPLICATION DEVELOPMENT

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 71

Page 72: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

The Required Skills for a Blockchain Development Staff

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 72

Page 73: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Additional Required Skills for a Blockchain Development Staff• Web3.js

• DApp development

• UI and UX Design and Testing Skills

• Deep understanding of compiled code, Gas, and the Ethereum Virtual Machine (EVM)

• Secure coding

• Defensive coding

• Egoless Programming

• Stringent Code Reviews

• Networking

• Understanding of Protocols

• Planning

• Requirements

• Technical Specifications and Writing

• Design

• Architecture – Infrastructure, Data, and Security

• Testing – Testing – Testing

• Simulation

• Troubleshooting

And don’t forget PROJECT MANAGEMENT &PROGRAM MANAGEMENT!

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 73

Page 74: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

The Roadmap

Roadmap to "Blockchain" Your IT Organization: How to Help Your IT Staff Go from

Square One to Competence & Dominance in Blockchain TechnologiesP

rep

ara

tio

nC

raw

lW

alk

Ru

nO

rie

nta

tio

n

Start

Continue

Continuosly

Learn the

Terminology and

Concepts.

Perform a

Baseline Skills

Inventory and

Assessment

Blockchain

Introduction and

Orientation

Review Real-

World Use Cases

and Applications

Read Papers & Join

Blockchain Meetup

Groups, and other

Blockchain-related

Organizations like

www.isoc-bsig.org

Remediate Skills

Gap with

Consultants,

Training, and/or

Mentoring

Perform Detailed

Requirements

Analysis

Baseline your

Capabilities

Create a

Blockchain

Solution Design

Based on the

Detailed Analysis

Perform Gap

Analysis of Needs

versus Capabilities

Analyze your initial

Blockchain Needs

and Requirements

Create a Blockchain

Solution Design

Based on the

Detailed Analysis and

the Appropriate DApp

Template

Identify the

Appropriate

Blockchain

Solutions

Template

Perform Detailed

Requirements

Analysis

Create an

Implementation

Diagram for the

Blockchain Dapp

Solution based on the

Design

Implement the

Blockchain DApp

Solution based on the

Implementation

Diagram

Test and Optimize

the DApp for Optimal

Performance, and

Validate against

Requirements

Select the Type of

Blockchain

Validate the

DApp Prototype

Add Additional

Features to the

DApp Prototype

Prepare and

Validate the

Blockchain DApp

Development

Environment

Test, Validate, and

Publish Results

Implement a

Prototype a Proof

of Concept DApp

solution

Perform Analysis, Design

Testing and

Implementation based on

Previous Experience and

Lessons Learned

Review Lessons

Learned from

Previous Tracks or

DApps

Incorporate the use of

Agile/Scrum and DevOps

in the Blockchain

Solution Development

Lifecycle

Test and Optimize

the DApp for Optimal

Performance, and

Validate against

Requirements &

Publish Results

Focus on Implementing

Techniques to Optimize

the Analysis, Design,

Testing and

Implementation

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 74

Page 75: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 75

Page 76: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

CONCLUSION

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 76

Page 77: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

ConclusionSo we covered:

• Why Blockchain?

• Blockchain Law

• Distributed Systems and Blockchain Security Concepts

• Blockchain Limits and Challenges

• How to Secure Blockchain Infrastructure and Applications

• How to perform Secure Software Development for Blockchain

applications by design, coding practices, testing and verification

• Blockchain and Auditing

• How to Design and Implement a Blockchain Solution Project –

an Organized High-Level Step-by-Step Approach

• How to Help your Organization Rapidly Ramp Up Skills and

Readiness for Blockchain Application Development

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 77

Page 78: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Conclusion

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

Source: Blockchain still vulnerable to hacks despite security hype, but here are some solutions by James Nguyen. Retrieved from https://e27.co/blockchain-still-vulnerable-to-hacks-despite-security-hype-but-here-are-some-solutions-20190212/ -

From James NguyenFebruary 12, 2019

February 27, 2019 78

Page 79: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

QUESTIONS

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 79

Page 80: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Questions?

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

General George S. PattonCrypto Rebels

Revealed

Wired Magazine,

February 1993

Book of Satoshi

Collected Writings

Of Satoshi Nakamoto

February 27, 2019 80

Page 81: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

SPECIAL THANKS

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, IIIFebruary 27, 2019 81

Page 82: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Dedication

• This work is dedicated with love,

admiration, gratitude, and great

respect to James P. Jarnagin

(January 25, 1935 – December 2,

2018), the man who was my

Mentor and Father-figure since

March 1985. He is one the

biggest reasons for my career

success and personal success.

What I owe him can never be

repaid.

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

June 2013

June 1994 October 2015

February 27, 2019 82

Page 83: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Special Thanks To Chicago’s Best Blockchain Buddies:

Joe HernandezCo-Founder of the Chicago Blockchain Project

Hannah RosenburgCo-Founder of the Chicago Bitcoin and Open Blockchain Meetup

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

February 27, 2019 83

Page 84: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

Special Thanks To:

What's Holding Blockchain Back? - Blockchain Security & Auditing - William Favre Slater, III

Vitalik ButerinInventor of Ethereum

@VitalikButerin on#Twitter

February 27, 2019 84

Page 85: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

William Favre Slater, II

William Favre Slater, III

➢ 312-758-0307

[email protected]

[email protected]

➢ http://billslater.com/interview

➢ 1515 W. Haddon Ave., Unit 309Chicago, IL 60642United States of America

What's Holding Blockchain Back? - Blockchain Security & Auditing -William Favre Slater, III

February 27, 2019 85

Page 86: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

References• Antonopoulos, A. M. (2018). Mastering Bitcoin: Programming the Open Blockchain, second edition.

Sebastopol, CA: O’Reilly Media, Inc.

• Antonopoulos, A. M. and Wood, G. (2019). Mastering Ethereum: Building Smart Contract sand DApps. Sebastopol, CA: O’Reilly Media, Inc.

• Associated Press. (2014). Mt. Gox finds 200,000 missing bitcoins. Retrieved from http://money.msn.com/business-news/article.aspx?feed=AP&date=20140321&id=17454291 on March 21, 2014.

• Bahga, A. and Madisetti, V. (2017). Blockchain Applications: A Hands-On Approach. Published by Arshdeep Bahga and Vijay Madisetti. www.blockchain-book.com .

• Bambara, J. J. and Allen P. R. (2018). Blockchain: A Practical Guide to Developing Business, Law, and Technology Solutions. New York, NY: McGraw-Hill Education.

• Bashir, I. (2018). Mastering Blockchain, second edition. Birmingham, UK: Packt Publishing Ltd.

• BBC. (2014). Troubled MtGox Bitcoin boss emerges after shut down Retrieved from http://www.bbc.com/news/technology-26352442 on February 26, 2014.

• Bitcoin.org. (2014). Bitcoin.org FAQs.. Retrieved from https://bitcoin.org/en/faq on April 10, 2014.

• Bitcoin Scammers. (2014). Bit Coin Scammers. Retrieved from http://bitcoinscammers.com/ on April 9, 2014.

• Casey, M. J. and Vigna, P. (2018). The Truth Machine: The Blockchain Reference and the Future of Everything. New York, NY: St. Martin’s Press.

• Caughey, M. (2013). Bitcoin Step by Step, second edition. Amazon Digital Services.

February 27, 2019What's Holding Blockchain Back? - Blockchain Security & Auditing -

William Favre Slater, III86

Page 87: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

References• Champagne, P. (2014). The Book of Satoshi: The Collected Writings of Bitcoin Creator Satoshi Nakamoto.

Published by E53 Publishing, LLC.

• Dannen, C. (2017). Introducing Ethereum and Solidity: Foundations of Crytocurrency and Blockchain Programming for Beginners. New York, NY: Apress

• De Filippi, P. and Wright, A. (2018). Blockchain and the Law: the Rule of Code. Cambridge, MA: President and Fellows of Harvard College.

• De Havilland, P. (2018). Greedy, Prodigal, and Suicidal — Hosho to Save Smart Contracts From Three Deadly Sins. An article published at Bitsonline.com on September 3, 2018. Retrieved from https://bitsonline.com/greedy-prodigal-suicidal-hosho-smart-contracts/ on February 27, 2019.

• Dhillon, V., Metcalf, D., and Hooper, M. (2017). Blockchain Enabled Applications: Understand the Blockchain Ecosystem and How to Nake It Work for You. New York, NY: Apress.

• Drescher, D. (2017). Blockchain Basics. Frankfort am Main, Germany: Apress.

• Eddison, L. (2017). Ethereum: A Deep Dive into Ethereum. Published by Leonard Eddison.

• Etwaru, R. (2017). Blockchain Trust Companies. Indianapolis, IN: Dog Ear Publishing.

• Ferry, T. (2019). To Blockchain or not to Blockchain. An article publsihed at Medium.com on June 8, 2018. Retrieved on January 13, 2019 from https://medium.com/causys/to-blockchain-or-not-to-blockchain-aed05bf08150 .

• Gerard, D. (2107), Attack of the 50 Foot Blockchain: Bitcoin, Blockchain, Ethereum, and Smart Contracts. Published by David Gerard. www.davidgerard.co.uk/blockchain .

February 27, 2019What's Holding Blockchain Back? - Blockchain Security & Auditing -

William Favre Slater, III87

Page 88: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

References• Hornyak, T. (2014). 'Malleability' attacks not to blame for Mt. Gox's missing bitcoins, study says. Retrieved

from http://www.pcworld.com/article/2114200/malleability-attacks-not-to-blame-for-mt-goxs-missing-bitcoins-study-says.html on March 27, 2014.

• Incencio, R. (2014). Ransomware and Bitcoin Theft Combine in BitCrypt. Retrieved from http://blog.trendmicro.com/trendlabs-security-intelligence/ransomware-and-bitcoin-theft-combine-in-bitcrypt/ on March 27, 2014.

• Laurence, T. (2017). Blockchain for Dummies. Hoboken, NJ: John Wiley & Sons, Inc.

• Lee, T. B. (2013). 12 questions about Bitcoin you were too embarrassed to ask. Retrieved from http://www.washingtonpost.com/blogs/the-switch/wp/2013/11/19/12-questions-you-were-too-embarrassed-to-ask-about-bitcoin/ on November 19, 2013.

• Ma, M. (2017). Blockchain Design Sprint: An Agile Innovation Workbook to Implement an Agile Design Sprint for your Blockchain Business. Published by Future Lab www.futurelabconsulting.com .

• Markowitz, E. (2014). Cryptocurrencies Are the New Spam Frontier. Retrieved from http://www.vocativ.com/tech/bitcoin/cryptocurrencies-new-spam-frontier/ on March 28, 2014.

• Nakamoto. S. (2008). Bitcoin: A Peer-to-Peer Electronic Cash System. Retrieved from https://bitcoin.org/bitcoin.pdf on November 1, 2013.

• Nguyen, J. (2019). Blockchain still vulnerable to hacks despite security hype, but here are some solutions. Retrieved from https://e27.co/blockchain-still-vulnerable-to-hacks-despite-security-hype-but-here-are-some-solutions-20190212/ on February 13, 2019.

February 27, 2019What's Holding Blockchain Back? - Blockchain Security & Auditing -

William Favre Slater, III88

Page 89: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

References• O'Ham, T. (2018). Singapore Research Team Codifies 3 new Ethereum VM Vulnerabilities. An article

published at Bitsonline.com on February 21, 2018. Retrieved from https://bitsonline.com/singapore-research-ethereum/ on February 27, 2019.

• Orcutt, M. (2019). Once Hailed as Unhackable, Blockchains Are now Getting Hacked. An article in MIT Review. Published February 19, 2019. Retrieved from https://www.technologyreview.com/s/612974/once-hailed-as-unhackable-blockchains-are-now-getting-hacked/ on February 24, 2019.

• Popper, N. (2013). Into the Bitcoin Mines, Retrieved from http://dealbook.nytimes.com/2013/12/21/into-the-bitcoin-mines/?hp&_r=0 on December 21, 2013.

• Prusty, N. (2017). Building Blockchain Projects: Building Decentralized Blockchain Applications with Ethereum and Solidity. Birmingham, UK: Pact Publishing.

• SCGNEWS. (2014). The IRS Just Declared War on Bitcoin - Retroactively. Retrieved from http://scgnews.com/the-irs-just-declared-war-on-bitcoin-retroactively on March 27, 2014.

• Sharkey, T. (2014. Inside Bitcoins NYC Day 1: Bitcoin 2.0 Takes Center Stage. Retrieved from http://www.coindesk.com/inside-bitcoins-nyc-day-1-bitcoin-2-0-takes-center-stage/ on April 8, 2014.

• Zenko, M. (2017). Bitcoins for Bombs – a Blog published at the Council on Foreign Relations on August 17, 2017. Retrieved from https://www.cfr.org/blog/bitcoin-bombs on February 13, 2019.

February 27, 2019What's Holding Blockchain Back? - Blockchain Security & Auditing -

William Favre Slater, III89

Page 90: Mass Adoption? Quick Introduction to Blockchain Security ... · Quick Introduction to Blockchain Security & Blockchain Auditing February 27, 2019 ... How to perform Secure Software

References:Best Blockchain Texts

• Mastering Ethereum– by Andreas M. Antonopoulos and Dr. Gavin Wood.

• Mastering Blockchain - Second Edition– by Imran Bashir

• Introducing Ethereum and Solidity: Foundations of Cryptocurrency and Blockchain Programming for Beginners– By Chris Dannen

• Blockchain Applications: A Hands-On Approach – by Arshdeep Bahga and Vijay Madisetti

• Ethereum, tokens & smart contracts: Notes on getting started– by Eugenio Noyola

• Blockchain Enabled Applications: Understand the Blockchain Ecosystem and How to Make it Work for You– by Vikram Dhillon, David Metcalf, Max Hooper

• Foundations of Blockchain• By Koshik Raj

• The Book of Satoshi: The Collected Writings od Bitcoin Creator Satoshi Nakamoto– By Phil Champagne

February 27, 2019What's Holding Blockchain Back? - Blockchain Security & Auditing -

William Favre Slater, III90