MerakInitiaSchemasSchemas Config

Schemas Config & schemagen Tool

The schemagen CLI tool generates libraries for Schemas. It makes it much less error-prone than using the Schemas low-level API, and comes with typed Move APIs when setting and retrieving records.

Using schemagen with the Dubhe framework

If you are using the Dubhe framework and have a dubhe.config.ts file in your project, you can edit your Schemas config directly in this file!

A Schemas config should be named dubhe.config.ts, and placed at the root of your project.

This is the minimal config:

import { DubheConfig } from "@0xobelisk/initia-common";
 
export const dubheConfig = {
  name: "example", // name of the Move project
  description: "example desc", // description of the Move project
  schemas: {}, // an empty config with no schemas,
} as DubheConfig;

Generating the schemas

To generate the schemas, run pnpm dubhe schemagen ./dubhe.config.ts in the same folder as the config file.

Schema Data

Currently, Schema supports all the basic types of Move, and will be added later according to the demand.

export const dubheConfig = {
  name: "example",
  description: "example desc",
  schemas: {
    student_management: {
      data: [
        {
          name: "Class",
          fields: {
            name: "string",
            teacher: "string",
          },
        },
        {
          name: "Student",
          fields: {
            name: "string",
            age: "u8",
            class: "Class",
          },
        },
      ],
    },
  },
} as DubheConfig;

Schema structure

Schema currently supports three storage structures, StorageValue, StorageMap, StorageDoubleMap.

export const dubheConfig = {
  name: "example",
  description: "example desc",
  schemas: {
    student_management: {
      data: [
        {
          name: "Class",
          fields: {
            name: "string",
            teacher: "string",
          },
        },
        {
          name: "Student",
          fields: {
            name: "string",
            age: "u8",
            class: "Class",
          },
        },
      ],
      structure: {
        next_student_id: "StorageValue<u32>",
        student_info: "StorageMap<u32, Student>",
      },
    },
  },
} as DubheConfig;

Schema events

export const dubheConfig = {
  name: "example",
  description: "example desc",
  schemas: {
    student_management: {
      data: [
        {
          name: "Class",
          fields: {
            name: "string",
            teacher: "string",
          },
        },
        {
          name: "Student",
          fields: {
            name: "string",
            age: "u8",
            class: "Class",
          },
        },
      ],
      structure: {
        next_student_id: "StorageValue<u32>",
        student_info: "StorageMap<u32, Student>",
      },
      events: [
        {
          name: "StudentAdded",
          fields: {
            student_id: "u32",
            student: "Student",
          },
        },
        {
          name: "StudentRemoved",
          fields: {
            student_id: "u32",
          },
        },
      ],
    },
  },
} as DubheConfig;