Skip to main content

Create an Application With Monomer

In this tutorial, you will learn how to create a new Monomer L2 application. Before starting this tutorial, we recommend reading through the Overview and Learn sections in the documentation to familiarize yourself with the Monomer architecture and concepts.

Create a New Monomer Application

We'll use the monogen tool to bootstrap a new Monomer L2 application.

To generate a new Monomer application with the default configuration, navigate to the parent directory of where you want to store your application and run the following command:

rm -rf ~/.testapp \
&& rm -rf testapp \
&& go run github.com/polymerdao/monomer/cmd/[email protected] \
&& cd testapp \
&& ./setup-helper.sh

To modify the default configuration, you can pass the following flags to the go run github.com/polymerdao/monomer/cmd/monogen command:

--address-prefix string   address prefix (default "cosmos")
--app-dir-path string project directory (default "./testapp")
--gomod-path string go module path (default "github.com/testapp/testapp")

Build and Run

To build the application, run one of the following commands from the testapp directory:

If using a Go version <1.23.0, run:

go build -o testappd ./cmd/testappd

If using a Go version >=1.23.0, run:

go build -ldflags=-checklinkname=0 -o testappd ./cmd/testappd

Now that our application is configured, we can start the Monomer application in sequencer mode by running the following command.

./testappd monomer start --minimum-gas-prices 0.01wei --monomer.sequencer --monomer.dev-start --api.enable

To run the application in verifier mode, omit the --monomer.sequencer flag:

./testappd monomer start --minimum-gas-prices 0.01wei --monomer.dev-start --api.enable

Congratulations! You've successfully integrated Monomer into your Cosmos SDK application.