AWS.Keyspaces — AWS SDK for JavaScript (original) (raw)
We recommend that you migrate to AWS SDK for JavaScript v3. For dates, additional details, and information on how to migrate, please refer to the linked announcement.
Class: AWS.Keyspaces
Overview
Constructs a service interface object. Each API operation is exposed as a function on service.
Service Description
Amazon Keyspaces (for Apache Cassandra) is a scalable, highly available, and managed Apache Cassandra-compatible database service. Amazon Keyspaces makes it easy to migrate, run, and scale Cassandra workloads in the Amazon Web Services Cloud. With just a few clicks on the Amazon Web Services Management Console or a few lines of code, you can create keyspaces and tables in Amazon Keyspaces, without deploying any infrastructure or installing software.
In addition to supporting Cassandra Query Language (CQL) requests via open-source Cassandra drivers, Amazon Keyspaces supports data definition language (DDL) operations to manage keyspaces and tables using the Amazon Web Services SDK and CLI, as well as infrastructure as code (IaC) services and tools such as CloudFormation and Terraform. This API reference describes the supported DDL operations in detail.
For the list of all supported CQL APIs, see Supported Cassandra APIs, operations, and data types in Amazon Keyspaces in the Amazon Keyspaces Developer Guide.
To learn how Amazon Keyspaces API actions are recorded with CloudTrail, see Amazon Keyspaces information in CloudTrail in the Amazon Keyspaces Developer Guide.
For more information about Amazon Web Services APIs, for example how to implement retry logic or how to sign Amazon Web Services API requests, see Amazon Web Services APIs in the General Reference.
Sending a Request Using Keyspaces
var keyspaces = new AWS.Keyspaces();
keyspaces.createKeyspace(params, function (err, data) {
if (err) console.log(err, err.stack); // an error occurred
else console.log(data); // successful response
});
Locking the API Version
In order to ensure that the Keyspaces object uses this specific API, you can construct the object by passing the apiVersion
option to the constructor:
var keyspaces = new AWS.Keyspaces({apiVersion: '2022-02-10'});
You can also set the API version globally in AWS.config.apiVersions
using the keyspaces service identifier:
AWS.config.apiVersions = {
keyspaces: '2022-02-10',
// other service API versions
};
var keyspaces = new AWS.Keyspaces();
Constructor Summarycollapse
- new AWS.Keyspaces(options = {}) ⇒ Object constructor
Constructs a service object.
Property Summarycollapse
- endpoint ⇒ AWS.Endpoint readwrite
An Endpoint object representing the endpoint URL for service requests.
Properties inherited from AWS.Service
Method Summarycollapse
- createKeyspace(params = {}, callback) ⇒ AWS.Request
TheCreateKeyspace
operation adds a new keyspace to your account. - createTable(params = {}, callback) ⇒ AWS.Request
TheCreateTable
operation adds a new table to the specified keyspace. - deleteKeyspace(params = {}, callback) ⇒ AWS.Request
TheDeleteKeyspace
operation deletes a keyspace and all of its tables. - deleteTable(params = {}, callback) ⇒ AWS.Request
TheDeleteTable
operation deletes a table and all of its data. - getKeyspace(params = {}, callback) ⇒ AWS.Request
Returns the name and the Amazon Resource Name (ARN) of the specified table.
. - getTable(params = {}, callback) ⇒ AWS.Request
Returns information about the table, including the table's name and current status, the keyspace name, configuration settings, and metadata.
To read table metadata usingGetTable
,Select
action permissions for the table and system tables are required to complete the operation.
. - getTableAutoScalingSettings(params = {}, callback) ⇒ AWS.Request
Returns auto scaling related settings of the specified table in JSON format. - listKeyspaces(params = {}, callback) ⇒ AWS.Request
Returns a list of keyspaces.
. - listTables(params = {}, callback) ⇒ AWS.Request
Returns a list of tables for a specified keyspace.
. - listTagsForResource(params = {}, callback) ⇒ AWS.Request
Returns a list of all tags associated with the specified Amazon Keyspaces resource.
. - restoreTable(params = {}, callback) ⇒ AWS.Request
Restores the table to the specified point in time within theearliest_restorable_timestamp
and the current time. - tagResource(params = {}, callback) ⇒ AWS.Request
Associates a set of tags with a Amazon Keyspaces resource. - untagResource(params = {}, callback) ⇒ AWS.Request
Removes the association of tags from a Amazon Keyspaces resource.
. - updateTable(params = {}, callback) ⇒ AWS.Request
Adds new columns to the table or updates one of the table's settings, for example capacity mode, auto scaling, encryption, point-in-time recovery, or ttl settings. - waitFor(state, params = {}, callback) ⇒ AWS.Request
Waits for a given Keyspaces resource.
Methods inherited from AWS.Service
makeRequest, makeUnauthenticatedRequest, setupRequestListeners, defineService
Constructor Details
new AWS.Keyspaces(options = {}) ⇒ Object
Constructs a service object. This object has one method for each API operation.
Property Details
endpoint ⇒ AWS.Endpoint
Returns an Endpoint object representing the endpoint URL for service requests.
Method Details
createKeyspace(params = {}, callback) ⇒ AWS.Request
The CreateKeyspace
operation adds a new keyspace to your account. In an Amazon Web Services account, keyspace names must be unique within each Region.
CreateKeyspace
is an asynchronous operation. You can monitor the creation status of the new keyspace by using the GetKeyspace
operation.
For more information, see Creating keyspaces in the Amazon Keyspaces Developer Guide.
createTable(params = {}, callback) ⇒ AWS.Request
The CreateTable
operation adds a new table to the specified keyspace. Within a keyspace, table names must be unique.
CreateTable
is an asynchronous operation. When the request is received, the status of the table is set to CREATING
. You can monitor the creation status of the new table by using the GetTable
operation, which returns the current status
of the table. You can start using a table when the status is ACTIVE
.
For more information, see Creating tables in the Amazon Keyspaces Developer Guide.
deleteKeyspace(params = {}, callback) ⇒ AWS.Request
The DeleteKeyspace
operation deletes a keyspace and all of its tables.
deleteTable(params = {}, callback) ⇒ AWS.Request
The DeleteTable
operation deletes a table and all of its data. After a DeleteTable
request is received, the specified table is in the DELETING
state until Amazon Keyspaces completes the deletion. If the table is in the ACTIVE
state, you can delete it. If a table is either in the CREATING
or UPDATING
states, then Amazon Keyspaces returns a ResourceInUseException
. If the specified table does not exist, Amazon Keyspaces returns a ResourceNotFoundException
. If the table is already in the DELETING
state, no error is returned.
getKeyspace(params = {}, callback) ⇒ AWS.Request
Returns the name and the Amazon Resource Name (ARN) of the specified table.
getTable(params = {}, callback) ⇒ AWS.Request
Returns information about the table, including the table's name and current status, the keyspace name, configuration settings, and metadata.
To read table metadata using GetTable
, Select
action permissions for the table and system tables are required to complete the operation.
getTableAutoScalingSettings(params = {}, callback) ⇒ AWS.Request
Returns auto scaling related settings of the specified table in JSON format. If the table is a multi-Region table, the Amazon Web Services Region specific auto scaling settings of the table are included.
Amazon Keyspaces auto scaling helps you provision throughput capacity for variable workloads efficiently by increasing and decreasing your table's read and write capacity automatically in response to application traffic. For more information, see Managing throughput capacity automatically with Amazon Keyspaces auto scaling in the Amazon Keyspaces Developer Guide.
GetTableAutoScalingSettings
can't be used as an action in an IAM policy.
To define permissions for GetTableAutoScalingSettings
, you must allow the following two actions in the IAM policy statement's Action
element:
application-autoscaling:DescribeScalableTargets
application-autoscaling:DescribeScalingPolicies
listKeyspaces(params = {}, callback) ⇒ AWS.Request
Returns a list of keyspaces.
listTables(params = {}, callback) ⇒ AWS.Request
Returns a list of tables for a specified keyspace.
listTagsForResource(params = {}, callback) ⇒ AWS.Request
Returns a list of all tags associated with the specified Amazon Keyspaces resource.
restoreTable(params = {}, callback) ⇒ AWS.Request
Restores the table to the specified point in time within the earliest_restorable_timestamp
and the current time. For more information about restore points, see Time window for PITR continuous backups in the Amazon Keyspaces Developer Guide.
Any number of users can execute up to 4 concurrent restores (any type of restore) in a given account.
When you restore using point in time recovery, Amazon Keyspaces restores your source table's schema and data to the state based on the selected timestamp (day:hour:minute:second)
to a new table. The Time to Live (TTL) settings are also restored to the state based on the selected timestamp.
In addition to the table's schema, data, and TTL settings, RestoreTable
restores the capacity mode, auto scaling settings, encryption settings, and point-in-time recovery settings from the source table. Unlike the table's schema data and TTL settings, which are restored based on the selected timestamp, these settings are always restored based on the table's settings as of the current time or when the table was deleted.
You can also overwrite these settings during restore:
- Read/write capacity mode
- Provisioned throughput capacity units
- Auto scaling settings
- Point-in-time (PITR) settings
- Tags
For more information, see PITR restore settings in the Amazon Keyspaces Developer Guide.
Note that the following settings are not restored, and you must configure them manually for the new table:
- Identity and Access Management (IAM) policies
- Amazon CloudWatch metrics and alarms
tagResource(params = {}, callback) ⇒ AWS.Request
Associates a set of tags with a Amazon Keyspaces resource. You can then activate these user-defined tags so that they appear on the Cost Management Console for cost allocation tracking. For more information, see Adding tags and labels to Amazon Keyspaces resources in the Amazon Keyspaces Developer Guide.
For IAM policy examples that show how to control access to Amazon Keyspaces resources based on tags, see Amazon Keyspaces resource access based on tags in the Amazon Keyspaces Developer Guide.
untagResource(params = {}, callback) ⇒ AWS.Request
Removes the association of tags from a Amazon Keyspaces resource.
updateTable(params = {}, callback) ⇒ AWS.Request
Adds new columns to the table or updates one of the table's settings, for example capacity mode, auto scaling, encryption, point-in-time recovery, or ttl settings. Note that you can only update one specific table setting per update operation.
waitFor(state, params = {}, callback) ⇒ AWS.Request
Waits for a given Keyspaces resource. The final callback or'complete' event will be fired only when the resource is either in its final state or the waiter has timed out and stopped polling for the final state.