Instantiate a client object
All Data API interactions through a client start with a DataAPIClient object.
Once you have a DataAPIClient object, you can connect to a database and the perform CRUD operations on your data.
Creating a client object is an essential component of Data API client scripts. For more information, see Get started with the Data API.
For more information about the Data API client hierarchy, see Python client usage, TypeScript client usage, and Java client usage.
Result
- 
Python 
- 
TypeScript 
- 
Java 
Returns a DataAPIClient object that you can use to interact with the Data API.
Returns a DataAPIClient object that you can use to interact with the Data API.
Returns a DataAPIClient object that you can use to interact with the Data API.
Parameters
- 
Python 
- 
TypeScript 
- 
Java 
| Name | Type | Summary | 
|---|---|---|
| 
 | 
 | Optional. An application token, or an instance of  The username and password used to generate the token must be tied to a role that has sufficient permissions to perform the desired operations. 
 | 
| 
 | 
 | Optional. Specify the environment this client will work in. Must be one of the values in  Default:  | 
| 
 | 
 | Optional. Attaches special identifying entries to the User-Agent header for all HTTP requests issued to the Data API. The full type of this parameter is  | 
| 
 | 
 | Optional. A complete or partial specification of the APIOptions for the client. This allows you to customize the client interaction with the Data API. For example, you can use this parameter to change the timeout settings. | 
| Name | Type | Summary | 
|---|---|---|
| 
 | 
 | Optional. An application token, or an instance of  The username and password used to generate the token must be tied to a role that has sufficient permissions to perform the desired operations. 
 | 
| 
 | Optional.
The options to use for the client, including defaults.
See Properties of  | 
| Name | Type | Summary | 
|---|---|---|
| Optional. Specify the environment this client will work in. Can be one of:  For more information, see the astra-db-ts README. Default:  | ||
| Optional. Options related to the API requests made by the client. The  
 
 For more information on http clients, see the astra-db-ts README and the client reference. | ||
| Optional.
Specify default options for when spawning a  | ||
| Optional.
Specify default options for when spawning an  | 
| Name | Type | Summary | 
|---|---|---|
| 
 | 
 | Optional. An application token, or an instance of  The username and password used to generate the token must be tied to a role that has sufficient permissions to perform the desired operations. 
 | 
| 
 | A class wrapping the advanced configuration of the client, such as as  | 
Examples
The following examples demonstrate how to instantiate a client.
Instantiate a client
- 
Python 
- 
TypeScript 
- 
Java 
from astrapy import DataAPIClient
from astrapy.constants import Environment
client = DataAPIClient(environment=Environment.HCD)import { DataAPIClient } from "@datastax/astra-db-ts";
const client = new DataAPIClient({ environment: "hcd" });import com.datastax.astra.client.DataAPIClient;
import com.datastax.astra.client.DataAPIDestination;
import com.datastax.astra.client.core.auth.UsernamePasswordTokenProvider;
import com.datastax.astra.client.core.options.DataAPIClientOptions;
public class Example {
  public static void main(String[] args) {
    String token =
        new UsernamePasswordTokenProvider("USERNAME", "PASSWORD").getTokenAsString();
    DataAPIClientOptions clientOptions =
        new DataAPIClientOptions().destination(DataAPIDestination.HCD);
    DataAPIClient client = new DataAPIClient(token, clientOptions);
  }
}Instantiate a client and pass a token
- 
Python 
- 
TypeScript 
- 
Java 
from astrapy import DataAPIClient
from astrapy.authentication import UsernamePasswordTokenProvider
from astrapy.constants import Environment
client = DataAPIClient(
    token=UsernamePasswordTokenProvider("USERNAME", "PASSWORD"),
    environment=Environment.HCD,
)import {
  DataAPIClient,
  UsernamePasswordTokenProvider,
} from "@datastax/astra-db-ts";
const client = new DataAPIClient(
  new UsernamePasswordTokenProvider("USERNAME", "PASSWORD"),
  { environment: "hcd" },
);import com.datastax.astra.client.DataAPIClient;
import com.datastax.astra.client.DataAPIDestination;
import com.datastax.astra.client.core.auth.UsernamePasswordTokenProvider;
import com.datastax.astra.client.core.options.DataAPIClientOptions;
public class Example {
  public static void main(String[] args) {
    String token =
        new UsernamePasswordTokenProvider("USERNAME", "PASSWORD").getTokenAsString();
    DataAPIClientOptions clientOptions =
        new DataAPIClientOptions().destination(DataAPIDestination.HCD);
    DataAPIClient client = new DataAPIClient(token, clientOptions);
  }
}Instantiate a client and specify options
- 
Python 
- 
TypeScript 
- 
Java 
from astrapy import DataAPIClient
from astrapy.api_options import (
    APIOptions,
    SerdesOptions,
    TimeoutOptions,
)
from astrapy.authentication import AWSEmbeddingHeadersProvider
from astrapy.constants import Environment
client = DataAPIClient(
    environment=Environment.HCD,
    api_options=APIOptions(
        timeout_options=TimeoutOptions(
            request_timeout_ms=15000,
            general_method_timeout_ms=30000,
            table_admin_timeout_ms=120000,
        ),
        serdes_options=SerdesOptions(
            custom_datatypes_in_reading=False,
            use_decimals_in_collections=True,
        ),
    ),
)import { DataAPIClient } from "@datastax/astra-db-ts";
import * as fetchH2 from "fetch-h2";
const client = new DataAPIClient({
  environment: "hcd",
  logging: [
    { events: "commandStarted", emits: "stdout" },
    { events: "commandFailed", emits: "stderr" },
  ],
  httpOptions: { client: "fetch-h2", fetchH2: fetchH2 },
  timeoutDefaults: {
    requestTimeoutMs: 20000,
    generalMethodTimeoutMs: 40000,
  },
});import com.datastax.astra.client.DataAPIClient;
import com.datastax.astra.client.DataAPIDestination;
import com.datastax.astra.client.core.http.HttpClientOptions;
import com.datastax.astra.client.core.http.HttpProxy;
import com.datastax.astra.client.core.options.DataAPIClientOptions;
import com.datastax.astra.client.core.options.TimeoutOptions;
import com.datastax.astra.internal.command.CommandObserver;
import com.datastax.astra.internal.command.ExecutionInfos;
import java.net.http.HttpClient;
import java.time.Duration;
public class Example {
  public static void main(String[] args) {
    DataAPIClientOptions options = new DataAPIClientOptions();
    // Specify the environment
    options.destination(DataAPIDestination.HCD);
    // Specify the HTTP client
    HttpClientOptions httpClientOptions =
        new HttpClientOptions()
            .retryCount(3)
            .retryDelay(Duration.ofMillis(200))
            .httpRedirect(HttpClient.Redirect.NORMAL)
            .httpVersion(HttpClient.Version.HTTP_2)
            .httpProxy(new HttpProxy().hostname("localhost").port(8080));
    options.httpClientOptions(httpClientOptions);
    // Specify timeouts
    TimeoutOptions timeoutsOptions =
        new TimeoutOptions()
            .collectionAdminTimeoutMillis(5000)
            .collectionAdminTimeout(Duration.ofMillis(5000))
            .tableAdminTimeoutMillis(5000)
            .tableAdminTimeout(Duration.ofMillis(5000))
            .databaseAdminTimeoutMillis(15000)
            .databaseAdminTimeout(Duration.ofMillis(15000))
            .generalMethodTimeoutMillis(1000)
            .generalMethodTimeout(Duration.ofMillis(1000))
            .requestTimeoutMillis(200)
            .requestTimeout(Duration.ofMillis(200))
            .connectTimeoutMillis(100)
            .connectTimeout(Duration.ofMillis(100));
    options.timeoutOptions(timeoutsOptions);
    // Add your application in the chain of callers in the header
    options.addCaller("MySampleApplication", "1.0.0");
    // Add headers to calls for admin or database operations
    options.addAdminAdditionalHeader("X-My-Header", "MyValue");
    options.addDatabaseAdditionalHeader("X-My-Header", "MyValue");
    // Add loggers and observers
    options.addObserver(
        "my_dummy_logger",
        new CommandObserver() {
          @Override
          public void onCommand(ExecutionInfos executionInfo) {
            System.out.println("Command executed: " + executionInfo.getCommand().getName());
          }
        });
    // Get a sl4j logger at debug level
    options.logRequests();
    DataAPIClient client = new DataAPIClient(options);
  }
}Client reference
- 
Python 
- 
TypeScript 
- 
Java 
For more information, see the client reference.
For more information, see the client reference.
For more information, see the client reference.
