Reference

module.toml Manifest Reference

module.toml manifest reference covering module metadata, dependencies, params, assets, inputs, and generators.

module.toml Manifest Reference

The module.toml file is the manifest at the root of every rescile module. It defines the module’s identity, declares the parameters it accepts, specifies the asset and input schemas it expects from the consuming project, and configures data generators that fetch or scaffold data automatically before the graph is built.

When a module is loaded via --module, rescile reads this file first to validate parameters, assets, and inputs before any graph processing begins. It also drives the bootstrap command and dependency resolution via rescile-ce mod.

[module]
name = "my-module"
version = "1.0.0"
description = "A custom module"
rescile_version = ">=0.1.85"

[dependencies.other_module]
url = "https://github.com/rescile/other.git"
resource_aliases = { "old_type" = "new_type" }

[params.env]
description = "Environment variable"
default = "dev"
required = false

[assets."app.csv"]
resource_type = "application"
name_template = "app-{{ name }}"
bootstrap = "name,owner\napp1,teamA"
[assets."app.csv".columns.name]
type = "string"
required = true

[input."config.json"]
format = "object_of_objects"

[generators.fetch_data]
target_input = "config.json"
command = ["script.sh"]
env = ["TOKEN={{ env.TOKEN }}"]
ttl = "1h"
condition = "on_missing"

[module] — Module Identity

Declares the module’s name, version, human-readable description, and the minimum rescile version it requires. These fields are displayed in the rescile dashboard and used during dependency resolution.

Key Required Description
name Yes A short identifier for the module (e.g., "standard-webapp").
version Yes Semantic version string (e.g., "1.0.0").
description No A human-readable summary shown in the module index.
url No Canonical URL of the module’s repository.
rescile_version No Minimum rescile version constraint (e.g., ">=0.1.85").

For detailed usage see Using Modules.


[dependencies] — Module Dependencies

Declares other modules this module depends on. Three declaration formats are supported: a simple Git URL string, a detailed { git = "...", tag = "..." } table, or a release archive { url = "...", version = "..." } table. An optional resource_aliases map transparently remaps resource type names from the imported module to avoid naming conflicts in the global graph.

Dependencies are resolved recursively. Use rescile-ce mod lock to pin them to exact commits for reproducible builds.

For the full reference including lockfile commands see Module Dependencies & Lockfiles.


[params] — Module Parameters

Declares the named parameters a module accepts at runtime via --module-params. Each parameter entry can specify a description, a default value, whether it is required, and an allowed_values list for validation. Declared parameters are made available as global Tera variables in all models/, compliance/, and output/ files of the module.

Key Description
description Human-readable explanation of the parameter’s purpose.
required Boolean. If true, rescile will error when the parameter is not supplied.
default Fallback value used when the parameter is not supplied and required is false.
allowed_values Array of permitted string values. rescile validates the supplied value against this list.

For usage examples see Using Modules — Providing Parameters.


[assets] — Asset Schema & Bootstrap

Declares the CSV asset files the module expects in the consuming project’s data/assets/ directory. Each entry can define column-level validation (type, required, allow_empty), an optional name_template to dynamically rewrite the primary key, an explicit resource_type override, and a bootstrap string that rescile-ce bootstrap writes as the initial file content.

For the full asset schema reference and automatic asset generation via generators see Asset Management — Module Asset Configurations.


[input] — Input Schema & Bootstrap

Declares the JSON input files the module expects in the consuming project’s data/input/ directory. Each entry defines the expected format (currently object_of_objects), optional fields validation, and a bootstrap string for rescile-ce bootstrap. rescile validates user-supplied input files against this schema before processing begins.

For the full input schema reference see Input Management.


[generators] — Data Generators

Configures commands that rescile executes automatically to fetch or scaffold asset and input data before the graph is built. Each generator entry specifies a target_input or target_asset, the command array to run, optional env variable mappings, from_stdout capture, a ttl cache duration, and a condition trigger (always, on_missing).

Scripts placed in the module’s generators/ directory are automatically added to PATH during execution. Generators in untrusted modules require explicit approval via --trust-modules in CI environments.

For the complete generator reference including security and validation behaviour see Data Generators.