Instantiate and use the client with the following:
The SDK exports all request and response types as TypeScript interfaces. Simply import them with the following namespace:
When the API returns a non-success status code (4xx or 5xx response), a subclass of the following error will be thrown.
If you would like to send additional headers as part of the request, use the headers request option.
The SDK is instrumented with automatic retries with exponential backoff. A request will be retried as long as the request is deemed retriable and the number of retry attempts has not grown larger than the configured retry limit (default: 2).
A request is deemed retriable when any of the following HTTP status codes is returned:
Use the maxRetries request option to configure this behavior.
The SDK defaults to a 60 second timeout. Use the timeoutInSeconds option to configure this behavior.
The SDK allows users to abort requests at any point by passing in an abort signal.
The SDK defaults to node-fetch but will use the global fetch client if present. The SDK works in the following runtimes:
The SDK provides a way for you to customize the underlying HTTP client / Fetch function. If you’re running in an unsupported environment, this provides a way for you to break glass and ensure the SDK works.
Here’s a practical example of integrating the Chrt SDK in a Next.js application with authentication:
Create a utility function to handle client instantiation with dynamic authentication:
For client-side usage, you can also set up a React context provider:
This pattern allows you to seamlessly use the Chrt SDK across your application with proper authentication handling.
Add the dependency to your pom.xml:
Or with Gradle:
Pin Java to the same PR-based version as the other SDKs (1.{PR_NUMBER}.{PATCH}), then update deliberately when you are ready for new generated API changes. The Java SDK is generated alongside the TypeScript and Swift SDKs and provides the same API coverage. See the API Reference for full endpoint documentation with Java snippets.
The Swift SDK is available via Swift Package Manager. Add the following to your Package.swift:
Pin Swift to the same PR-based version as the other SDKs (1.{PR_NUMBER}.{PATCH}). Prefer upToNextMinor if you want patch updates for the same server PR, or an exact version if you want fully locked generated API shapes. The Swift SDK is ideal for building native iOS applications that integrate with CHRT — for example, driver apps that send location updates and complete task artifacts.
While we value open-source contributions to these SDKs, the libraries are generated programmatically. Additions made directly would have to be moved over to our generation code, otherwise they would be overwritten upon the next generated release. Feel free to open a PR as a proof of concept, but know that we will not be able to merge it as-is. We suggest opening an issue first to discuss with us!
On the other hand, contributions to the READMEs are always very welcome!
For more information about our APIs and integrations, check out our API Reference or contact our Support team.