Skip to content

Migrate data-plane specs

The swagger converter will not be able to accurately represent every part of every API in TypeSpec. This document outlines some common changes you may need to make to a converted TypeSpec to make it conform to your existing service API and pass validation checks.

Initial pass through checklist

βœ… DO configure your tspconfig.yaml. See: example tspconfig.yaml

βœ… DO extend the @azure-tools/typespec-azure-rulesets/data-plane linter rule set in your tspconfig.yaml. Example:

tspconfig.yaml
linter:
extends:
- "@azure-tools/typespec-azure-rulesets/data-plane"

βœ… DO ensure your @service and @server definitions are correct in main.tsp

βœ… DO use the built-in url for endpoint specification. Example:

@server(
"{endpoint}/widget",
"Contoso Widget APIs",
{
/**
* Supported Widget Services endpoints (protocol and hostname, for example:
* https://westus.api.widget.contoso.com).
*/
endpoint: url,
}
)

βœ… DO ensure that you have a security definition (@useAuth) specified for your service. See: Security definitions in TypeSpec

βœ… DO ensure you have versioning (@versioned) enabled over your service definition. See: Versioning

βœ… DO ensure your versions enum is up to date. For an initial migration we recommend migrating your latest stable API version (and the latest preview API version the service may support after the stable API version)

βœ… DO review all enum definitions and add documentation over each value. See: Documentation in TypeSpec

❌ DON’T suppress documentation warnings

βœ… DO use the standard Typespec Azure operation templates and data-types wherever possible. Standard operation templates should be used as much as possible

βœ… DO review model definitions and add the @resource decorator over models that represent resources in your service and the @key decorator for the resource identifier property on the model. Example:

/** A widget. */
@resource("widgets")
model Widget {
/** The widget name. */
@key("widgetName")
@visibility("read")
name: string;
/** The widget color. */
color: WidgetColor;
/** The ID of the widget's manufacturer. */
manufacturerId: string;
}

βœ… DO use union instead of enum to define Azure enums. See: Defining enums for Azure services. Example:

/** The color of a widget. */
union WidgetColor {
string,
/** Red Widget Color */
Red: "Red",
/** Green Widget Color */
Green: "Green",
/** Blue Widget Color */
Blue: "Blue",
}

❌ DON’T import or use templates from the @azure-tools/typespec-azure-resource-manager library in a data-plane specification

βœ… DO make client customizations in a client.tsp file

❌ DON’T import or use @azure-tools/typespec-client-generator-core in other files aside from client.tsp.

βœ… DO run tsp compile . on your specification and address all warnings

Additional considerations

βœ… DO ensure you pull in the latest main from the Azure/azure-rest-api-specs repo to stay up to date with latest dependencies

βœ… DO run npm ci to get a clean install of the package.json dependencies

❌ DON’T modify the package.json or package-lock.json files at the root of the azure-rest-api-specs repo

❌ DON’T add your own package.json or package-lock.json files in your project directory

❌ DON’T add multiple tspconfig.yaml files for your service specification

βœ… DO consult ci-fix.md for fixes to common CI errors reported