Book Image

Mastering Blockchain Programming with Solidity

By : Jitendra Chittoda
Book Image

Mastering Blockchain Programming with Solidity

By: Jitendra Chittoda

Overview of this book

Solidity is among the most popular and contract-oriented programming languages used for writing decentralized applications (DApps) on Ethereum blockchain. If you’re looking to perfect your skills in writing professional-grade smart contracts using Solidity, this book can help. You will get started with a detailed introduction to blockchain, smart contracts, and Ethereum, while also gaining useful insights into the Solidity programming language. A dedicated section will then take you through the different Ethereum Request for Comments (ERC) standards, including ERC-20, ERC-223, and ERC-721, and demonstrate how you can choose among these standards while writing smart contracts. As you approach later chapters, you will cover the different smart contracts available for use in libraries such as OpenZeppelin. You’ll also learn to use different open source tools to test, review and improve the quality of your code and make it production-ready. Toward the end of this book, you’ll get to grips with techniques such as adding security to smart contracts, and gain insights into various security considerations. By the end of this book, you will have the skills you need to write secure, production-ready smart contracts in Solidity from scratch for decentralized applications on Ethereum blockchain.
Table of Contents (21 chapters)
Free Chapter
1
Section 1: Getting Started with Blockchain, Ethereum, and Solidity
5
Section 2: Deep Dive into Development Tools
9
Section 3: Mastering ERC Standards and Libraries
16
Section 4: Design Patterns and Best Practices

Features of our token

To create a new token or any ICO contract, the first thing is to list down all the features of the contract that you require. For example, the features of an ICO contract can be pre-minted, mintable on-demand, burnable, capped crowdsale, and time-based crowdsale. All these features have been discussed in Chapter 9, Deep Dive into the OpenZeppelin Library. You can refer to that chapter for more details on these contracts.

Ideally, when you create a new contract or token, you have the specification documentation of the features and conditions to implement in the code. However, as we are going to learn how to create our own token, we need to jot down our own specifications. Now, let's build the specification of our token that we will create in this chapter:

  • Token contract specification:
  • We want to build a token that should be fungible up to 18 decimal...