Skip to content

@abstract-money/cli

One command to rule them all!

The Abstract CLI is a command-line tool for generating JavaScript bindings to contracts that use Abstract.

Installation

npm
npm i @abstract-money/cli

Usage

abstract <command> [options]

Init

Once you have installed the CLI, you need to define the CLI config in abstract.config.ts. You can generate a default configuration using the command:

abstract init

This will generate an abstract.config.ts in your project root. You can then configure it according to your needs.

Configuration

Here's an example of how to configure abstract.config.ts:

import { defineConfig } from '@abstract-money/cli'
import { react, registry, vanilla } from '@abstract-money/cli/plugins'
 
export default defineConfig({
  // Target directory for generated files.
  out: './src/generated',
 
  // Define contracts for which to generate bindings
  // Use this for contracts not registered in the Abstract schemas repository
  contracts: [
    {
      name: "exampleAdapter",
      path: "../schema/your-namespace/exampleAdapter/0.1.0/schema/",
      namespace: "your-namespace",
      version: "0.1.0",
      moduleType: "adapter", // Specify this if it's an adapter module
    },
    // You can add more contracts here as needed
  ],
 
  // List of plugins to use.
  plugins: [
    // Generate React hooks.
    react(),
    // Pull contract schemas from the registry at https://github.com/AbstractSDK/schemas
    registry({
      contracts: [
        {
          name: 'app-name', // Your App Name.
          namespace: 'abstract', // To claim a namespace on mainnet, please get in touch with Abstract Team.
          version: '0.1.0',
        },
      ],
    }),
 
    // Generate vanilla JavaScript bindings. Only include this if not using `react`.
    vanilla({
      // Enable Abstract App features for specific contracts
      enableAbstractAppFor: ['exampleAdapter']
    }),
  ],
})

Generating for Contracts Not Registered in Schemas Repository

Example:

contracts: [
  {
    name: "exampleAdapter",
    path: "../contracts/exampleAdapter/schema/",
    namespace: "your-namespace",
    version: "0.1.0",
    moduleType: "adapter",
  },
],

Generating for Contracts from the Abstract Registry

Example:

registry({
  contracts: [
    {
      name: 'payment-app',
      namespace: 'abstract',
      version: '0.0.1',
    },
  ],
}),

You can find the latest versions of these contracts in the Abstract schemas repository.

Enabling Abstract App Features

If you're working with an Abstract app, use the vanilla plugin with the enableAbstractAppFor option.

Example:

vanilla({
  enableAbstractAppFor: ['exampleAdapter']
}),

Generate

Once done, you're ready to generate the code:

abstract generate

You can use additional options as mentioned above. You should get an output like:

 abstract generate
 Validating plugins
 Resolving contracts
 Validating contracts
 Running plugins
 Writing to src/generated/index.ts

And you should be all set to use the types generated directly into your codebase.

Errors

Token 'X' does not exist

This is an issue with ts-codegen resolving too many files in the schema folder. You can fix this by removing all the files from the schema folder except for module-schema.json.

In our templates folder, we have an example of moving only the module-schema.json files to a schema folder here.

Double imports

There is currently a clash between the react and vanilla plugins that includes imports for contracts generated using each. If you encounter this, please reach out.