Usage
Short link: aka.ms/azsdk/tsp-client
tsp-client
is a simple command line tool to facilitate generating client libraries from TypeSpec.
Installation
npm install -g @azure-tools/typespec-client-generator-cli
Prerequisites
Users working with a repository that already accepts this tool can continue to the Usage section.
Repo owners should follow the steps in the tsp-client repo setup doc.
Usage
tsp-client < command > [options]
Commands
Use one of the supported commands to get started generating clients from a TypeSpec project.
This tool will default to using your current working directory to generate clients in and will
use it to look for relevant configuration files. To specify a different output directory, use
the -o
or --output-dir
option.
To see supported commands, run:
tsp-client --help
To see supported parameters and options for a specific command, run:
tsp-client < command > --help
Example using the init
command:
tsp-client init --help
init
Initialize the client library directory using a tspconfig.yaml. When running this command pass in a path to a local or the URL of a remote tspconfig.yaml with the -c
or --tsp-config
flag. If remote, the tspconfig.yaml must include the specific commit in the path. (See example below)
The init
command generates a directory structure following the standard pattern used across Azure SDK language repositories, creates a tsp-location.yaml file to control generation, and performs an initial generation of the client library. If you want to skip client library generation, then pass the --skip-sync-and-generate
flag.
Example:
tsp-client init -c https://github.com/Azure/azure-rest-api-specs/blob/dee71463cbde1d416c47cf544e34f7966a94ddcb/specification/contosowidgetmanager/Contoso.WidgetManager/tspconfig.yaml
update
The update
command will look for a tsp-location.yaml file in your current directory to sync a TypeSpec project and generate a client library. The update flow calls the sync
and generate
commands internally, so if you need to separate these steps, use the sync
and generate
commands separately instead.
Example:
tsp-client update
sync
Sync a TypeSpec project with the parameters specified in tsp-location.yaml.
By default the sync
command will look for a tsp-location.yaml to get the project details and sync them to a temporary directory called TempTypeSpecFiles
. Alternately, you can pass in the --local-spec-repo
flag with the path to your local TypeSpec project to pull those files into your temporary directory.
Example:
tsp-client sync
generate
Generate a client library from a TypeSpec project. The generate
command should be run after the sync
command. generate
relies on the existence of the TempTypeSpecFiles
directory created by the sync
command and on an emitter-package.json
file checked into your repository at the following path: <repo root>/eng/emitter-package.json
. The emitter-package.json
file is used to install project dependencies and get the appropriate emitter package.
Example:
tsp-client generate
convert
Convert an existing swagger specification to a TypeSpec project. This command should only be run once to get started working on a TypeSpec project. TypeSpec projects will need to be optimized manually and fully reviewed after conversion. When using this command a path or url to a swagger README file is required through the --swagger-readme
flag. By default, the converted TypeSpec project will leverage TypeSpec built-in libraries with standard patterns and templates (highly recommended), which will cause discrepancies between the generated TypeSpec and original swagger. If you really don’t want this intended discrepancy, add --fully-compatible
flag to generate a TypeSpec project that is fully compatible with the swagger.
Example:
tsp-client convert -o ./Contoso.WidgetManager --swagger-readme < path-to > /readme.md
compare
Compares two Swagger definitions to identify the relevant differences between them. This command is useful when comparing an existing Swagger definition with a TypeSpec generated one. The compare
command requires two parameters: --lhs
which will typically be the original hand-authored Swagger and --rhs
which will usually be the folder containing your TypeSpec. The command will generate the Swagger and compare the two definitions. The command will ignore differences in the Swagger that don’t
correspond to differences in the service, allowing you to focus only on differences that are relevant.
sort-swagger
Sort an existing swagger specification to be the same content order with TypeSpec generated swagger. This will allow you to easily compare and identify differences between the existing swagger and TypeSpec generated one. You should run this command on existing swagger files and check them in prior to creating converted TypeSpec PRs.
generate-config-files
This command generates the default configuration files used by tsp-client. Run this command to generate the emitter-package.json
and emitter-package-lock.json
under the eng/ directory of your current repository.
Required: Use the --package-json
flag to specify the path to the package.json file of the emitter you will use to generate client libraries.
Example:
tsp-client generate-config-files --package-json < path-to-emitter-repo-clone > /package.json
Example using the azure-sdk-for-js
and the @azure-tools/typespec-ts
emitter:
The --package-json
flag should be the relative or absolute path to repo clone of the @azure-tools/typespec-ts package.
azure-sdk-for-js > tsp-client generate-config-files --package-json < path-to-emitter-repo-clone > /package.json
To be explicit about specifying dependencies you’d like pinned, add a new field in the package.json file of your emitter called "azure-sdk/emitter-package-json-pinning"
with a list of the dependencies you want to be forwarded to the emitter-package.json. These dependencies must be specified in your package.json’s devDependencies in order for the tool to assign the correct version.
If the azure-sdk/emitter-package-json-pinning
field is missing from the package.json file, the tool will default to pinning the packages listed under peerDependencies
.
Example package.json using "azure-sdk/emitter-package-json-pinning"
:
{ "name": "@azure-tools/typespec-foo", "version": "0.4.0-alpha.20250110.1", ... "dependencies": { "@azure-tools/generator-foo": "0.3.0", "@typespec/http-client-foo": "1.2.0" }, "devDependencies": { "@typespec/compiler": "0.64.0", "rimraf": "^6.0", }, "azure-sdk/emitter-package-json-pinning": [ "@typespec/compiler" ]}
Example emitter-package.json
generated from the package.json shown above:
{ "main": "dist/src/index.js", "dependencies": { "@azure-tools/typespec-foo": "0.4.0-alpha.20250110.1" }, "devDependencies": { "@typespec/compiler": "0.64.0" }}
If you need to override dependencies for your emitter-package.json you can create a json file to explicitly list the package and corresponding version you want to override. This will add an overrides
section in your emitter-package.json that will be used during npm install
or npm ci
. See npm overrides doc.
Example json file with package overrides:
{ "@azure-tools/typespec-foo": "https://<dev-feed-url>/typespec-foo-0.4.0-alpha.20250110.1.tgz", "@azure-tools/generator-foo": "https://<dev-feed-url>/generator-foo-1.3.0-alpha.20250110.1.tgz"}
Example command specifying overrides:
tsp-client generate-config-files --overrides my_overrides.json --package-json < path-to-emitter-repo-clone > /package.json
Example emitter-package.json
generated using overrides:
{ "main": "dist/src/index.js", "dependencies": { "@azure-tools/typespec-foo": "https://<dev-feed-url>/typespec-foo-0.4.0-alpha.20250110.1.tgz" }, "devDependencies": { "@typespec/compiler": "~0.64.0" }, "overrides": { "@azure-tools/generator-foo": "https://<dev-feed-url>/generator-foo-1.3.0-alpha.20250110.1.tgz" }}
generate-lock-file
Generate an emitter-package-lock.json under the eng/ directory based on existing <repo-root>/eng/emitter-package.json
.
Example:
tsp-client generate-lock-file
Important concepts
Per project setup
Each project will need to have a configuration file called tsp-location.yaml that will tell the tool where to find the TypeSpec project.
tsp-location.yaml
This file is created through the tsp-client init
command or you can manually create it under the project directory to run other commands supported by this tool.
This file should live under the project directory for each service.
The file has the following properties:
Example:
directory: specification/contosowidgetmanager/Contoso.WidgetManagercommit: 431eb865a581da2cd7b9e953ae52cb146f31c2a6repo: Azure/azure-rest-api-specsadditionalDirectories: - specification/contosowidgetmanager/Contoso.WidgetManager.Shared/