· Joseph · Web3  · 3 min read

Blockchain fullstack structure - Part 1 - Introduction

Recently, I ogranized a template of my blockchain fullstack project, including a Hardhat Solidity, Golang backend, and React js frontend. Does it need golang backend? Actually, I'm not sure. But there is a post said:

Server: 
Even though you have your smart contracts as backend, often times a Dapp will still have an additional traditional server running. Not always, but probably more often than you think.

So, I combined Harhat, Golang gin, and Next.js to my dApp-structure github repo, added some basic, simple interaction from Next.js to Blockchain, and from Golang to Blockchain.

Recently, I ogranized a template of my blockchain fullstack project, including a Hardhat Solidity, Golang backend, and React js frontend. Does it need golang backend? Actually, I’m not sure. But there is a post said:

Server: Even though you have your smart contracts as backend, often times a Dapp will still have an additional traditional server running. Not always, but probably more often than you think.

So, I combined Harhat, Golang gin, and Next.js to my dApp-structure github repo, added some basic, simple interaction from Next.js to Blockchain, and from Golang to Blockchain.

Prerequisite

  • Docker / Docker compose: Each project is dockerized, so you have to install docker first.
  • Gnu parallel: At the root project, I run docker in each project parallelly by parallel

Project structure

Now, let’s look at my project structure first. project structure

Here I have:

  • Makefile: to make frontend, backend, and hardhat docker-compose run.
  • backend: to put Golang gin project, and I use go clean architecture.
  • frontend: to put Next.js react project.
  • hardhat: to put Hardhat solidity project.
  • run_abigen.sh: to generate Golang file from Hardhat to backend.

As you see, there’s nothing special at the root. Because my host is MacOS, I can use http://docker.for.mac.localhost to connect each docker container. I just need to think how to run each project’s dockerfile at the root, thus I create Makefile and call parellel to run docker-compose for each child folders.

SUBDIRS = hardhat backend frontend
CURRENT_DIR := $(shell pwd)

define FOREACH
    for DIR in $(SUBDIRS); do \
        echo "=============  $(1) > $(CURRENT_DIR)/$$DIR"; \
        cd $(CURRENT_DIR)/$$DIR && $(1); \
    done
endef

all: build up
clean: down stop-rm-volume prune

up:
  parallel -j3 --lb 'cd ${PWD}/{} ; docker-compose --ansi always up' ::: $(SUBDIRS)

build:
  $(call FOREACH, docker-compose build)

down:
  $(call FOREACH, docker-compose down)

stop-rm:
  $(call FOREACH, docker-compose rm -sf)

stop-rm-volume:
  $(call FOREACH, docker-compose rm -sfv)

prune:
  docker system prune -af

make up run docker-compose parallelly, so that each subproject can run at the same time. make build, make down, make stop-rm, and make stop-rm-volume run docker-compose for each subproject in succession in order to generate an beautiful output.

output Let’s see the outpue of make up, and it shows each docker-compose result simultaneously.

Then, I introduce the run_abigen.sh file.

#!/bin/bash

read -p 'Input solidity json filename in your hardhat/data/abi folder (e.g.: Greeter): ' FILENAME

docker run -v $(pwd)/hardhat:/sources -v $(pwd)/backend:/targets ethereum/client-go:alltools-stable abigen \
  --abi=sources/data/abi/$FILENAME.json \
  --type $FILENAME \
  --pkg contracts \
  --out=targets/contracts/$FILENAME.go

It’s not too hard. I use hardhat-abi-exporter in hardhat to get ABI json, so I can use abigen docker to transfer ABI json to Go module. That’s all this file does.

Next time I will introduce each project’s setting. If you have any advice or question, please feel free to let me know.

References

Back to Blog

Related Posts

View All Posts »
Blockchain fullstack structure - Part 4 - React.js and Next.js

Blockchain fullstack structure - Part 4 - React.js and Next.js

Alright, the series of articles goes to frontend part. I post an article related to Blockchain with React.js and Next.js. If you haven't seen my previous posts Part 1 Introduction, Part 2 Hardhat, and Part 3 Golang Gin, please read them first. In this article, I demonstrate how to use React.js (Next.js) to interact with smart contract by Golang Gin API and hardhat RPC URL, and implement a simple Sign-in with Ethereum (SIWE) authentication and setGreeting to Solidity. Okay, let's start it. TOC

Blockchain fullstack structure - Part 3 - Golang Gin

Blockchain fullstack structure - Part 3 - Golang Gin

It's time to Blockchain with Golang. If you haven't seen my previous post Part 1 Introduction and Part 2 Hardhat, please read them first. Again, does Dapp need a Backend? reddit - You can pretty much make a dapp without backend, but there are some things that can't be done with a smart contract. - You need a backend among other reasons for off-chain or metadata that won’t be stored in the smart contracts. Have you ever thought about how Moralis works? Off-chain: Backend infrastructure that collects data from the blockchain, offers an API to clients like web apps and mobile apps, indexes the blockchain, provides real-time alerts, coordinates events that are happening on different chains, handles the user life-cycle and so much more. Moralis Dapp is used in order to speed up the implementation of the off-chain infrastructure. Moralis Dapp is a bundled solution of all the features most Dapps need in order to get going as soon as possible.

Blockchain fullstack structure - Part 2 - Hardhat

Blockchain fullstack structure - Part 2 - Hardhat

This is a series articles of Blockchain fullstack structure, please read Part 1 Introduction first. In this part, I will show how to set docker to Hardhat, but this is simpler than my previous article Hardhat Solidity NFT tutorial.

Hardhat - Solidity and NFT - Part 2 - Deploy contract and Mint NFT

Hardhat - Solidity and NFT - Part 2 - Deploy contract and Mint NFT

我們上一篇已經設定好docker及hardhat專案,這一篇就從NFT開始。 Generate NFT metadata 先建立一個images資料夾後,把你想要的圖片放進去,並存成1, 2, 3....之類的檔名,然後用ipfs-car指令打包在一起。 找不到圖可以先用opensea doc裡的圖當練習 ipfs-car 接著到NFT Storage上傳images.car檔案就可以了。 image-car-upload