aws-cdk-lib
Version:
Version 2 of the AWS Cloud Development Kit library
97 lines (96 loc) • 3.79 kB
TypeScript
import { Construct } from 'constructs';
import { DynamoAttributeValue, DynamoConsumedCapacity, DynamoProjectionExpression } from './shared-types';
import * as ddb from '../../../aws-dynamodb';
import * as iam from '../../../aws-iam';
import * as sfn from '../../../aws-stepfunctions';
interface DynamoGetItemOptions {
/**
* The name of the table containing the requested item.
*/
readonly table: ddb.ITable;
/**
* Primary key of the item to retrieve.
*
* For the primary key, you must provide all of the attributes.
* For example, with a simple primary key, you only need to provide a value for the partition key.
* For a composite primary key, you must provide values for both the partition key and the sort key.
*
* @see https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_GetItem.html#DDB-GetItem-request-Key
*/
readonly key: {
[key: string]: DynamoAttributeValue;
};
/**
* Determines the read consistency model:
* If set to true, then the operation uses strongly consistent reads;
* otherwise, the operation uses eventually consistent reads.
*
* @default false
*/
readonly consistentRead?: boolean;
/**
* One or more substitution tokens for attribute names in an expression
*
* @see https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_GetItem.html#DDB-GetItem-request-ExpressionAttributeNames
*
* @default - No expression attributes
*/
readonly expressionAttributeNames?: {
[key: string]: string;
};
/**
* An array of DynamoProjectionExpression that identifies one or more attributes to retrieve from the table.
* These attributes can include scalars, sets, or elements of a JSON document.
*
* @see https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_GetItem.html#DDB-GetItem-request-ProjectionExpression
*
* @default - No projection expression
*/
readonly projectionExpression?: DynamoProjectionExpression[];
/**
* Determines the level of detail about provisioned throughput consumption that is returned in the response
*
* @see https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_GetItem.html#DDB-GetItem-request-ReturnConsumedCapacity
*
* @default DynamoConsumedCapacity.NONE
*/
readonly returnConsumedCapacity?: DynamoConsumedCapacity;
}
/**
* Properties for DynamoGetItem Task using JSONPath
*/
export interface DynamoGetItemJsonPathProps extends sfn.TaskStateJsonPathBaseProps, DynamoGetItemOptions {
}
/**
* Properties for DynamoGetItem Task using JSONata
*/
export interface DynamoGetItemJsonataProps extends sfn.TaskStateJsonataBaseProps, DynamoGetItemOptions {
}
/**
* Properties for DynamoGetItem Task
*/
export interface DynamoGetItemProps extends sfn.TaskStateBaseProps, DynamoGetItemOptions {
}
/**
* A StepFunctions task to call DynamoGetItem
*/
export declare class DynamoGetItem extends sfn.TaskStateBase {
private readonly props;
/**
* A StepFunctions task using JSONPath to call DynamoGetItem
*/
static jsonPath(scope: Construct, id: string, props: DynamoGetItemJsonPathProps): DynamoGetItem;
/**
* A StepFunctions task using JSONata to call DynamoGetItem
*/
static jsonata(scope: Construct, id: string, props: DynamoGetItemJsonataProps): DynamoGetItem;
protected readonly taskMetrics?: sfn.TaskMetricsConfig;
protected readonly taskPolicies?: iam.PolicyStatement[];
constructor(scope: Construct, id: string, props: DynamoGetItemProps);
/**
* @internal
*/
protected _renderTask(topLevelQueryLanguage?: sfn.QueryLanguage): any;
private configureProjectionExpression;
}
export {};