• REST
Overview¶
Stargate is a data gateway (Proxy) on top of Apache Cassandra which exposes new interfaces to simplify integration in your applications. It is a way to create stateless components and ease the integration through one of four different HTTP Apis (rest, doc, graphQL, gRPC). In this chapter we will cover integration with REST Apis
also called DATA
in the swagger specifications.
To know more regarding this interface specially you can have a look to dedicated section of the wiki or reference Stargate Rest Api Quick Start Guide.
⚠️ We recommend using version
V2
(with V2 in the URL) as it covers more features and V1 will be deprecated eventually.
Design¶
Prerequisites¶
- You should have an Astra account
- You should Create an Astra Database
- You should Have an Astra Token
Operations¶
- List keyspaces
private static void listKeyspaces(CloseableHttpClient httpClient, String apiRestEndpoint)
throws Exception {
// Build Request
HttpGet listKeyspacesReq = new HttpGet(apiRestEndpoint + "/v2/schemas/keyspaces");
listKeyspacesReq.addHeader("X-Cassandra-Token", ASTRA_TOKEN);
// Execute Request
try(CloseableHttpResponse res = httpClient.execute(listKeyspacesReq)) {
if (200 == res.getCode()) {
logger.info("[OK] Keyspaces list retrieved");
logger.info("Returned message: {}", EntityUtils.toString(res.getEntity()));
}
}
}
- Create a Table
Query used is
createTableJson
here:
{
"name": "users",
"columnDefinitions": [
{
"name": "firstname",
"typeDefinition": "text"
},
{
"name": "lastname",
"typeDefinition": "text"
},
{
"name": "email",
"typeDefinition": "text"
},
{
"name": "color",
"typeDefinition": "text"
}
],
"primaryKey": {
"partitionKey": ["firstname"],
"clusteringKey": ["lastname"]
},
"tableOptions": {
"defaultTimeToLive": 0,
"clusteringExpression": [{ "column": "lastname", "order": "ASC" }]
}
}
Create Table code
private static void createTable(CloseableHttpClient httpClient, String apiRestEndpoint)
throws Exception {
HttpPost createTableReq = new HttpPost(apiRestEndpoint
+ "/v2/schemas/keyspaces/" + ASTRA_DB_KEYSPACE + "/tables");
createTableReq.addHeader("X-Cassandra-Token", ASTRA_TOKEN);
String createTableJson = "{...JSON.....}";
createTableReq.setEntity(new StringEntity(createTableJson, ContentType.APPLICATION_JSON));
// Execute Request
try(CloseableHttpResponse res = httpClient.execute(createTableReq)) {
if (201 == res.getCode()) {
logger.info("[OK] Table Created (if needed)");
logger.info("Returned message: {}", EntityUtils.toString(res.getEntity()));
}
}
}
- Insert a Row
private static void insertRow(CloseableHttpClient httpClient, String apiRestEndpoint)
throws Exception {
HttpPost insertCedrick = new HttpPost(apiRestEndpoint + "/v2/keyspaces/"
+ ASTRA_DB_KEYSPACE + "/users" );
insertCedrick.addHeader("X-Cassandra-Token", ASTRA_TOKEN);
insertCedrick.setEntity(new StringEntity("{"
+ " \"firstname\": \"Cedrick\","
+ " \"lastname\" : \"Lunven\","
+ " \"email\" : \"c.lunven@gmail.com\","
+ " \"color\" : \"blue\" }", ContentType.APPLICATION_JSON));
// Execute Request
try(CloseableHttpResponse res = httpClient.execute(insertCedrick)) {
if (201 == res.getCode()) {
logger.info("[OK] Row inserted");
logger.info("Returned message: {}", EntityUtils.toString(res.getEntity()));
}
}
}
- Retrieve a row
private static void retrieveRow(CloseableHttpClient httpClient, String apiRestEndpoint)
throws Exception {
// Build Request
HttpGet rowReq = new HttpGet(apiRestEndpoint + "/v2/keyspaces/"
+ ASTRA_DB_KEYSPACE + "/users/Cedrick/Lunven" );
rowReq.addHeader("X-Cassandra-Token", ASTRA_TOKEN);
// Execute Request
try(CloseableHttpResponse res = httpClient.execute(rowReq)) {
if (200 == res.getCode()) {
String payload = EntityUtils.toString(res.getEntity());
logger.info("[OK] Row retrieved");
logger.info("Row retrieved : {}", payload);
}
}
}
Using Postman with REST¶
Postman is a widely-used collaboration platform for API development and testing. Using this third-party tool, you can easily test APIs with environments generated for your test platforms and imported testing collections of API queries.
A Postman collection is available for Astra using the REST API.