A TypeScript code generator for creating type-safe clients for Windmill.
windmill-ts.mov
Under the hood, it uses the official windmill-client library to interact with Windmill, and exposes a similar interface.
The output is a single file that could be used from Windmill itself (by creating
a script from the output and importing it from other TypeScript files), and from
your own codebase (by setting up windmill-client
in it).
- Generates fully typed TypeScript client code for your Windmill workspace
- Type-safe access to scripts, flows and resources
- Automatic schema generation from Windmill's JSON schemas
- Integration with the Windmill CLI configuration
- A configured Windmill CLI environment
Refer to the Windmill docs for instructions on how to set up the Windmill CLI.
npm install windmill-ts
The simplest way to use windmill-ts is to run it with no arguments, which will use your active Windmill CLI workspace:
npx windmill-ts ./generated-client.ts
You can also specify a specific workspace:
npx windmill-ts -w my-workspace ./generated-client.ts
To output to stdout instead of a file, use -
as the output path:
npx windmill-ts -
windmill-ts can be configured using a YAML configuration file. The configuration file can be named either windmill-ts.yaml
or windmill-ts.yml
and should be placed in your project root directory.
The configuration file supports the following options:
# Resource configuration
resources:
# Map of resource type to default resource path
# By default, if there is only one resource of a given type,
# it will be set as the default implicitly.
# You can override this behavior by:
# 1. Setting a specific resource path as the default
# 2. Setting null to disable the implicit default behavior
defaults:
# Override the default for "postgresql" resources to always use this path
postgresql: "f/prod/postgresql"
# Disable implicit default for "s3" resources even if there's only one
s3: null
# Set a specific default for "mysql" resources
mysql: "f/dev/mysql"
# Script generation configuration
scripts:
# Whether to generate script-related code (default: true)
enabled: true
# Flow generation configuration
flows:
# Whether to generate flow-related code (default: true)
enabled: true
The configuration file is optional. If not provided, windmill-ts will use default values. For resources, this means that when there is exactly one resource of a given type, it will be set as the default implicitly. You can override this behavior in the configuration file by either specifying a different default path or setting it to null
to disable the implicit default behavior.
The generated client provides type-safe functions for running scripts and flows, and getting resources:
import {
runScript,
runScriptAsync,
runFlow,
runFlowAsync,
getResource,
} from "./generated-client";
// Run a script synchronously
const result = await runScript("my/script/path", {
// TypeScript will enforce the correct argument types here
arg1: "value",
arg2: 42,
});
// Run a script asynchronously
const jobId = await runScriptAsync("my/script/path", {
arg1: "value",
arg2: 42,
});
// Run a flow
const flowResult = await runFlow("my/flow/path", {
input1: "value",
input2: true,
});
// Get a resource with type validation
const resource = await getResource("my/resource/path");
// TypeScript will infer the correct type based on the resource type
The generator:
- Connects to your configured Windmill workspace
- Fetches all available scripts, flows and resource types
- Generates Zod schemas for validating inputs
- Creates type-safe wrapper functions for running scripts and flows
- Handles resource type references and validations
This project is licensed under the Unlicense - see the LICENSE file for details.
Contributions are welcome! Please feel free to submit a Pull Request.