Generated TypeScript SDK for Scalar API. API for managing Scalar platform resources.
For TypeScript, we provide a SDK that makes using our API even easier.
npm add @scalar/sdkCreate an API key in your Scalar account:
- Dashboard: https://dashboard.scalar.com/account
- Store it in
.env, for example:
SCALAR_API_KEY=your_personal_tokenThe personal token is not an access token. Exchange it first with postv1AuthExchange.
If you use the personal token directly for authenticated API calls, the API returns 401 Invalid authentication token.
import { Scalar } from '@scalar/sdk'
const scalar = new Scalar()
const exchange = await scalar.auth.postv1AuthExchange({
personalToken: process.env.SCALAR_API_KEY!,
})
const accessToken = exchange.accessTokenConstruct a second client with bearer auth. Use this authenticated client for API calls.
import { Scalar } from '@scalar/sdk'
const scalar = new Scalar()
const exchange = await scalar.auth.postv1AuthExchange({
personalToken: process.env.SCALAR_API_KEY!,
})
const authedScalar = new Scalar({
bearerAuth: exchange.accessToken,
})- The exchange request itself can be made from a client constructed with no arguments (
new Scalar()). - The exchanged access token is valid for 12 hours.
- Timestamps are Unix seconds.
- Installation
- Usage
- API Reference
- Authentication
- Errors
- Client Options
- Request Options
- Retries and Timeouts
- Helpers
- Logging
- Requirements
npm install @scalar/sdkimport Scalar from "@scalar/sdk";
const client = new Scalar({
bearerAuth: process.env["BEARER_AUTH"], // defaults to the BEARER_AUTH env var
environment: "production",
});
const listAllAPIDocuments = await client.registry.listAllAPIDocuments();
console.log(listAllAPIDocuments);The examples in the following sections assume a client configured as shown above.
See the API reference for every available operation.
Pass credentials to the generated client constructor. Environment variables are read automatically when supported by the target runtime.
| Option | Type | Default | Description |
|---|---|---|---|
bearerAuth |
string | provider |
- | Credential for the BearerAuth scheme. Defaults to BEARER_AUTH. |
Declared schemes:
BearerAuthbearer token
Non-success responses throw generated API errors. Error objects expose status, headers, response body, and request metadata where the target runtime supports it.
import { APIError } from "@scalar/sdk";
try {
const listAllAPIDocuments = await client.registry.listAllAPIDocuments();
} catch (err) {
if (err instanceof APIError) {
console.log(err.status, err.name, err.headers);
}
throw err;
}Documented error statuses: 400, 401, 403, 404, 422, 500.
Configure the generated client by setting any of these options when you create it.
import Scalar from "@scalar/sdk";
const client = new Scalar({
timeout: 60000,
maxRetries: 2,
logLevel: "debug",
});| Option | Type | Default | Description |
|---|---|---|---|
bearerAuth |
string | AuthTokenProvider |
process.env["BEARER_AUTH"] |
Credential for the BearerAuth scheme. |
environment |
Environment |
- | Select one of the configured API environments. |
baseURL |
string | null |
process.env["SCALAR_BASE_URL"] |
Override the default API base URL. Pass null when selecting a configured environment. |
timeout |
number |
60000 |
Maximum time in milliseconds to wait for a response before aborting a request. |
maxRetries |
number |
2 |
Number of retries for temporary failures. |
defaultHeaders |
HeadersInit |
- | Headers sent with every request. |
defaultQuery |
Record<string, string | undefined> |
- | Query parameters sent with every request. |
fetchOptions |
RequestInit |
- | Additional fetch options sent with every request. |
fetch |
Fetch |
- | Custom fetch implementation. |
logLevel |
"off" | "error" | "warn" | "info" | "debug" | null |
process.env["SCALAR_LOG"] |
Controls request and retry debug logging. |
logger |
Logger | null |
console |
Custom logger implementation. |
| Option | Type | Default | Description |
|---|---|---|---|
headers |
HeadersInit |
- | Per-request headers. |
query |
Record<string, unknown> |
- | Per-request query parameters. |
body |
unknown |
- | Override the generated request body. |
timeout |
number |
- | Per-request timeout in milliseconds. |
maxRetries |
number |
- | Per-request retry count. |
signal |
AbortSignal |
- | Abort an in-flight request. |
fetchOptions |
RequestInit |
- | Per-request fetch options. |
idempotencyKey |
string |
- | Idempotency key for retry-safe operations. |
Generated clients support request timeouts and retry temporary failures such as network errors, 408, 409, 429, and 5xx responses. Retry delays honor Retry-After headers when present. Tune the retry and timeout client options shown above, or override them per request.
- Use
.withResponse()on any request to inspect both parsed data and the rawResponseobject. - Every operation returns an
APIPromise, so you canawaitit directly or chain.withResponse().
- Set
logLevel: "debug"to log request URLs, options, response status, response headers, and retry attempts. - Pass a custom
loggerto route logs into your own observability pipeline. - Set
logLevel: nullto disable environment-driven logging.
- Node.js 20+, a modern browser, or any runtime with
fetchsupport
Powered by Scalar.
This SDK is generated programmatically. Manual edits to generated files will be overwritten on the next build.