cosmos-sdk/docs/core/app5.md

2.4 KiB

App5 - Basecoin

As we've seen, the SDK provides a flexible yet comprehensive framework for building state machines and defining their transitions, including authenticating transactions, executing messages, controlling access to stores, and updating the validator set.

Until now, we have focused on building only isolated ABCI applications to demonstrate and explain the various features and flexibilities of the SDK. Here, we'll connect our ABCI application to Tendermint so we can run a full blockchain node, and introduce command line and HTTP interfaces for interacting with it.

But first, let's talk about how source code should be laid out.

Directory Structure

TODO

Tendermint Node

Since the Cosmos-SDK is written in Go, Cosmos-SDK applications can be compiled with Tendermint into a single binary. Of course, like any ABCI application, they can also run as separate processes that communicate with Tendermint via socket.

For more details on what's involved in starting a Tendermint full node, see the NewNode function in github.com/tendermint/tendermint/node.

The server package in the Cosmos-SDK simplifies connecting an application with a Tendermint node. For instance, the following main.go file will give us a complete full node using the Basecoin application we built:

//TODO imports

func main() {
	cdc := app.MakeCodec()
	ctx := server.NewDefaultContext()

	rootCmd := &cobra.Command{
		Use:               "basecoind",
		Short:             "Basecoin Daemon (server)",
		PersistentPreRunE: server.PersistentPreRunEFn(ctx),
	}

	server.AddCommands(ctx, cdc, rootCmd, server.DefaultAppInit,
		server.ConstructAppCreator(newApp, "basecoin"))

	// prepare and add flags
	rootDir := os.ExpandEnv("$HOME/.basecoind")
	executor := cli.PrepareBaseCmd(rootCmd, "BC", rootDir)
	executor.Execute()
}

func newApp(logger log.Logger, db dbm.DB) abci.Application {
	return app.NewBasecoinApp(logger, db)
}

Note we utilize the popular cobra library for the CLI, in concert with the viper library for managing configuration. See our cli library for more details.

TODO: compile and run the binary

Options for running the basecoind binary are effectively the same as for tendermint. See Using Tendermint for more details.

Clients

TODO