npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@solarity/hardhat-gobind

v1.2.2

Published

Generation of smart contract bindings for Golang

Downloads

543

Readme

npm hardhat

Hardhat GoBind

Hardhat plugin to simplify generation of smart contract bindings for Golang.

What

This plugin helps you generate .go files with bindings to call smart contracts from Go code. To produce them, the plugin uses abigen in a wasm binary form that is built from go-ethereum/cmd/abigen Go module.

Installation

npm install --save-dev @solarity/hardhat-gobind

Add the following statement to your hardhat.config.js:

require("@solarity/hardhat-gobind")

Or, if you are using TypeScript, add this to your hardhat.config.ts:

import "@solarity/hardhat-gobind"

Tasks

The bindings generation can be run either with built-in compile or the provided gobind task.

To view the available options, run these help commands:

npx hardhat help compile
npx hardhat help gobind

Environment extensions

This plugin does not extend the environment.

Usage

The plugin works out of the box: npx hardhat gobind will compile and generate bindings for all the contracts used in the project into the default folder.

To generate the most recent bindings, clean old artifacts with npx hardhat clean beforehand.

Configuration

The default configuration looks as follows. You may customize all fields in your hardhat config file.

module.exports = {
  gobind: {
    outdir: "./generated-types/bindings",
    deployable: false,
    runOnCompile: false,
    verbose: false,
    onlyFiles: [],
    skipFiles: [],
  },
}
  • outdir : The directory where the generated bindings will be placed
  • deployable : Generates the bindings with the bytecode (makes them deployable within Go)
  • runOnCompile : Whether to run bindings generation on compilation
  • verbose: Detailed logging on generation (e.g. count of included and skipped contracts, source paths, names)
  • onlyFiles: If specified, bindings will be generated only for matching sources, other will be ignored
  • skipFiles: Bindings will not be generated for any matching sources, also if those match onlyFiles

Some of the parameters are only available in CLI and they override the ones defined in your hardhat config (e.g. --deployable will generate deploy method regardless of config.gobind.deployable value). Run npx hardhat help gobind to get available options.

Including/excluding files

  • Path stands for relative path from project root to either .sol file or directory.
  • If path is a directory, all its files and sub-directories are considered matching.
  • If source is a node module, node_modules must not be present in the path.

How it works

The plugin runs compile task (if --no-compile is not given), gets the artifacts from Hardhat Runtime Environment (HRE), filters them according to onlyFiles and skipFiles, and performs the following actions:

  1. Writes contract's ABI (and bytecode, if necessary) into a temporary file ContractName.abi (and ContractName.bin with bytecode).
  2. Derives destination folder from the original file location: if the file is in ./contracts, the folder will be ./your_outdir/contracts.
  3. Derives Go package name from the parent folder: for ./your_outdir/nested/My_Contracts it will be mycontracts.
  4. Calls abigen via WebAssembly: abigen --abi /path/to/file.abi --pkg packagename --type ContractName --lang go --out /path/to/your_project/your_outdir (and --bin /path/to/file.bin, if necessary).
  5. Removes temporary files.

Bindings are generated for contracts, not files. Having 3 contracts in a single file, you get 3 .go files named after contracts. If you skip the file, all 3 contracts are ignored.

Consider we have Hardhat project with the following structure (excluding some files for brevity):

.
├── contracts
│   ├── Example.sol
│   ├── Sample.sol
│   └── interfaces
│       ├── IExample.sol
│       └── ISample.sol
├── hardhat.config.ts
└── node_modules
    └── @openzeppelin
        └── contracts
            └── access
                ├── Ownable
                │   └── Ownable.sol
                └── Ownable2Step
                    └── Ownable2Step.sol

npx hardhat gobind with the default configuration will create the following directory structure. Note there are no node_modules parent directory for @openzeppelin dependency.

generated-types
└── bindings
    ├── @openzeppelin
    │   └── contracts
    │       └── access
    │           ├── ownable
    │           │   └── Ownable.go
    │           └── ownable2step
    │               └── Ownable2Step.go
    │          
    └── contracts
        ├── example
        │   └── Example.go
        ├── sample
        │   └── Sample.go
        └── interfaces
            ├── iexample
            │   └── IExample.go
            └── isample
                └── ISample.go

In most cases, you want bindings only for your contracts/ directory, excluding contracts/interfaces and all the dependencies from node_modules.

It is achieved by adding the following into your hardhat config:

onlyFiles: ["contracts"],
skipFiles: ["contracts/interfaces", "@openzeppelin", "@solarity"],

Known limitations

  • --verbose is not available in CLI because of names clash with Hardhat. Learn more.
  • node_modules must not be present in the path.
  • All environment variables are omitted when the abigen.wasm is called