*** title: SDK variables headline: SDK variables (OpenAPI) description: Use `x-fern-sdk-variables` to set common path parameters across all requests ----------------------------------------------------------------------------------------- The `x-fern-sdk-variables` extension allows you to define variables that are set once during SDK client initialization and automatically used in path parameters across all endpoint calls. This is useful for common parameters like tenant IDs, organization IDs, or environment identifiers that appear in many endpoint paths. SDK variables are supported in TypeScript (v2.6.3+), Python (v4.24.0+), and Java (v3.6.3+). Only string types are supported. ## Configuration Define variables at the document level using `x-fern-sdk-variables`, then mark path parameters as variables using `x-fern-sdk-variable`: ```yaml {1-7,17,23} title="openapi.yml" x-fern-sdk-variables: gardenId: type: string description: The unique identifier for your garden zoneId: type: string description: The zone within the garden paths: /gardens/{gardenId}/zones/{zoneId}/plants: get: operationId: list_plants_in_zone parameters: - name: gardenId in: path required: true x-fern-sdk-variable: gardenId schema: type: string - name: zoneId in: path required: true x-fern-sdk-variable: zoneId schema: type: string ``` ## SDK usage Variables become required constructor parameters instead of being passed to individual method calls: ```typescript {2-3} const client = new PlantClient({ gardenId: "garden_123", zoneId: "zone_456", apiKey: "your-api-key" }); const plants = await client.listPlantsInZone(); ``` ```python {2-3} client = PlantClient( garden_id="garden_123", zone_id="zone_456", api_key="your-api-key" ) plants = client.list_plants_in_zone() ``` ```java {2-3} PlantClient client = PlantClient.builder() .gardenId("garden_123") .zoneId("zone_456") .apiKey("your-api-key") .build(); List plants = client.listPlantsInZone(); ```