diff --git a/fern/products/sdks/guides/configure-readme.mdx b/fern/products/sdks/guides/configure-readme.mdx index 14e5f9d69..9e652808b 100644 --- a/fern/products/sdks/guides/configure-readme.mdx +++ b/fern/products/sdks/guides/configure-readme.mdx @@ -3,7 +3,7 @@ title: Customize README description: Guide to configuring the README in your SDK --- -By default, the README for your SDKs is generated programmatically. You can customize the content and structure of these README files across all of your SDKs by configuring the `readme` section in `generators.yml`. +By default, the README for your SDKs is [generated programmatically](./sdk-user-features) and contains information about how your users can interact with your API. You can customize the content and structure of these README files across all of your SDKs by configuring the `readme` section in `generators.yml`. ## Configuration options diff --git a/fern/products/sdks/guides/generated-sdk.mdx b/fern/products/sdks/guides/generated-sdk.mdx new file mode 100644 index 000000000..0f94e96b2 --- /dev/null +++ b/fern/products/sdks/guides/generated-sdk.mdx @@ -0,0 +1,30 @@ +--- +title: SDK user features +description: How your customers can use your SDK +--- + +Fern-generated SDKs provide a consistent set of features across all languages to help developers interact with your API. Usage information is auto-generated in your SDK's README, [which you can customize](./readme). + +## Installation and basic usage + +Users install SDKs using standard package managers (npm for TypeScript, pip for Python, Maven/Gradle for Java, etc.) from language-specific registries. + +Users initialize the client with your API's base URL and any required authentication, then call methods on the client to interact with your API. Generated SDKs support modern runtimes across languages. + +## Error handling + +When the API returns a 4xx or 5xx status code, the SDK throws an error that includes the status code, error message, response body, and raw response object. + +## Customization options + +Your SDK users can configure individual requests using language-specific options: + +| Option | Description | Availability | +|--------|-------------|--------------| +| Timeouts | Configure request timeouts (default: 30 seconds for C# and PHP, 60 seconds for all other languages) | All languages | +| [Retries](/sdks/deep-dives/retries-with-backoff) | Configure maximum retries (default: 2 with exponential backoff for 408, 429, and 5xx responses) | All languages except Ruby and Swift | +| Custom HTTP client | Override the default HTTP client for unsupported environments or custom requirements | TypeScript, Python, Java, PHP, and Swift | +| Custom headers | Send additional headers with any request | TypeScript, Java, and Swift | +| Raw response data | Access response headers alongside parsed data | TypeScript, Python, and Go | +| Query parameters | Add extra query string parameters | TypeScript and Swift | +| Abort signals | Cancel in-flight requests | TypeScript only | \ No newline at end of file diff --git a/fern/products/sdks/sdks.yml b/fern/products/sdks/sdks.yml index a023942f4..4020423c7 100644 --- a/fern/products/sdks/sdks.yml +++ b/fern/products/sdks/sdks.yml @@ -208,6 +208,8 @@ navigation: slug: mcp-server - section: Deep dives contents: + - page: SDK user features + path: ./guides/generated-sdk.mdx - page: Customize method names path: ./guides/customize-method-names.mdx slug: customize-method-names