cdk-lambda-subminute 2.0.354 → 2.0.355

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/.jsii +3 -3
  2. package/lib/cdk-lambda-subminute.js +3 -3
  3. package/node_modules/aws-sdk/README.md +1 -1
  4. package/node_modules/aws-sdk/apis/keyspaces-2022-02-10.min.json +159 -16
  5. package/node_modules/aws-sdk/apis/metadata.json +0 -8
  6. package/node_modules/aws-sdk/clients/all.d.ts +0 -2
  7. package/node_modules/aws-sdk/clients/all.js +0 -2
  8. package/node_modules/aws-sdk/clients/dynamodb.d.ts +1 -1
  9. package/node_modules/aws-sdk/clients/keyspaces.d.ts +165 -4
  10. package/node_modules/aws-sdk/dist/aws-sdk-core-react-native.js +2 -2
  11. package/node_modules/aws-sdk/dist/aws-sdk-react-native.js +109 -211
  12. package/node_modules/aws-sdk/dist/aws-sdk.js +3 -11
  13. package/node_modules/aws-sdk/dist/aws-sdk.min.js +38 -38
  14. package/node_modules/aws-sdk/dist-tools/service-collector.js +1 -1
  15. package/node_modules/aws-sdk/lib/config_service_placeholders.d.ts +0 -4
  16. package/node_modules/aws-sdk/lib/core.js +1 -1
  17. package/node_modules/aws-sdk/lib/dynamodb/document_client.d.ts +1 -1
  18. package/node_modules/aws-sdk/package.json +1 -1
  19. package/node_modules/aws-sdk/scripts/console +3 -3
  20. package/package.json +3 -3
  21. package/node_modules/aws-sdk/apis/cloudfront-keyvaluestore-2022-07-26.examples.json +0 -5
  22. package/node_modules/aws-sdk/apis/cloudfront-keyvaluestore-2022-07-26.min.json +0 -359
  23. package/node_modules/aws-sdk/apis/cloudfront-keyvaluestore-2022-07-26.paginators.json +0 -10
  24. package/node_modules/aws-sdk/apis/neptune-graph-2023-11-29.examples.json +0 -5
  25. package/node_modules/aws-sdk/apis/neptune-graph-2023-11-29.min.json +0 -1286
  26. package/node_modules/aws-sdk/apis/neptune-graph-2023-11-29.paginators.json +0 -28
  27. package/node_modules/aws-sdk/apis/neptune-graph-2023-11-29.waiters2.json +0 -168
  28. package/node_modules/aws-sdk/clients/cloudfrontkeyvaluestore.d.ts +0 -294
  29. package/node_modules/aws-sdk/clients/cloudfrontkeyvaluestore.js +0 -18
  30. package/node_modules/aws-sdk/clients/neptunegraph.d.ts +0 -1459
  31. package/node_modules/aws-sdk/clients/neptunegraph.js +0 -20
  32. package/node_modules/aws-sdk/lib/services/neptunegraph.js +0 -14
package/.jsii CHANGED
@@ -7,7 +7,7 @@
7
7
  "url": "https://fantasticsie.medium.com/"
8
8
  },
9
9
  "bundled": {
10
- "aws-sdk": "^2.1537.0"
10
+ "aws-sdk": "^2.1538.0"
11
11
  },
12
12
  "dependencies": {
13
13
  "aws-cdk-lib": "^2.94.0",
@@ -4135,6 +4135,6 @@
4135
4135
  "symbolId": "src/cdk-lambda-subminute:SubminuteStateMachineProps"
4136
4136
  }
4137
4137
  },
4138
- "version": "2.0.354",
4139
- "fingerprint": "hmvd89/FCp7WaE5jlq8etnqpU+6S0xeCq1V/Lcc+Ykk="
4138
+ "version": "2.0.355",
4139
+ "fingerprint": "vljWtpW8Q/BVz/w8TWlTYw7uf5/Fy0Gq/kLCtDPmhDQ="
4140
4140
  }
@@ -45,7 +45,7 @@ class LambdaSubminute extends constructs_1.Construct {
45
45
  }
46
46
  exports.LambdaSubminute = LambdaSubminute;
47
47
  _a = JSII_RTTI_SYMBOL_1;
48
- LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.354" };
48
+ LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.355" };
49
49
  class IteratorLambda extends constructs_1.Construct {
50
50
  constructor(scope, name, props) {
51
51
  super(scope, name);
@@ -85,7 +85,7 @@ class IteratorLambda extends constructs_1.Construct {
85
85
  }
86
86
  exports.IteratorLambda = IteratorLambda;
87
87
  _b = JSII_RTTI_SYMBOL_1;
88
- IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.354" };
88
+ IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.355" };
89
89
  class SubminuteStateMachine extends constructs_1.Construct {
90
90
  constructor(scope, id, props) {
91
91
  super(scope, id);
@@ -160,5 +160,5 @@ class SubminuteStateMachine extends constructs_1.Construct {
160
160
  }
161
161
  exports.SubminuteStateMachine = SubminuteStateMachine;
162
162
  _c = JSII_RTTI_SYMBOL_1;
163
- SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.354" };
163
+ SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.355" };
164
164
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-lambda-subminute.js","sourceRoot":"","sources":["../src/cdk-lambda-subminute.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport events = require('aws-cdk-lib/aws-events');\nimport targets = require('aws-cdk-lib/aws-events-targets');\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\nimport { IFunction, Runtime, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { NodejsFunction } from 'aws-cdk-lib/aws-lambda-nodejs';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\nimport { Construct } from 'constructs';\n\nexport interface LambdaSubminuteProps {\n  /**\n   * The Lambda function that is going to be executed per time unit less than one minute.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * A pattern you want this statemachine to be executed.\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * @default cron(50/1 15-17 ? * * *) UTC+0 being run every minute starting from 15:00 PM to 17:00 PM.\n   */\n  readonly cronjobExpression?: string;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency?: number;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime?: number;\n}\n\nexport class LambdaSubminute extends Construct {\n  /**\n   * The Lambda function that plays the role of the iterator.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * The ARN of the state machine that executes the target Lambda function per time unit less than one minute.\n   */\n  readonly stateMachineArn: string;\n  constructor(parent: Construct, name: string, props: LambdaSubminuteProps) {\n    super(parent, name);\n    const iterator = new IteratorLambda(this, 'IteratorLambda', { targetFunction: props.targetFunction });\n    this.iteratorFunction = iterator.function;\n    const subminuteStateMachine = new SubminuteStateMachine(this, 'SubminuteStateMachine', {\n      stateMachineName: 'lambda-subminute-statemachine',\n      targetFunction: props.targetFunction,\n      iteratorFunction: this.iteratorFunction,\n      intervalTime: props.intervalTime ?? 10,\n      frequency: props.frequency ?? 6,\n    });\n    this.stateMachineArn = subminuteStateMachine.stateMachine.stateMachineArn;\n\n    const startRule = new events.Rule(this, 'StartSubminuteStateMachine', {\n      schedule: events.Schedule.expression(props.cronjobExpression ?? 'cron(50/1 15-17 ? * * *)'),\n      ruleName: 'subminute-statemachine-lambda-rule',\n      description: `A rule to run the subminute state machine, i.e. ${subminuteStateMachine.stateMachine.stateMachineName}`,\n    });\n    startRule.addTarget(new targets.SfnStateMachine(\n      subminuteStateMachine.stateMachine, {\n        input: events.RuleTargetInput.fromObject({\n          iterator: {\n            index: 0,\n            count: 6,\n          },\n        }),\n      }));\n  }\n}\n\nexport interface IteratorLambdaProps {\n  /**\n     * The Lambda function that is going to be executed per time unit less than one minute.\n     */\n  readonly targetFunction: IFunction;\n}\n\nexport class IteratorLambda extends Construct {\n  /**\n     * A Lambda function that plays the role of the iterator.\n     */\n  readonly function: IFunction;\n  constructor(scope: Construct, name: string, props: IteratorLambdaProps) {\n    super(scope, name);\n    const iteratorLambdaRole = new iam.Role(this, 'IteratorLambdaRole', {\n      assumedBy: new iam.CompositePrincipal(\n        new iam.ServicePrincipal('lambda.amazonaws.com'),\n      ),\n      description: 'An execution role for a Lambda function to invoke a target Lambda Function per time unit less than one minute',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXRayDaemonWriteAccess'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole'),\n      ],\n      roleName: 'Lambda-Iterator-Role',\n    });\n    cdk.DockerVolumeConsistency.CONSISTENT;\n\n\n    iteratorLambdaRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'TargetLambdaPermission',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [props.targetFunction.functionArn],\n    }));\n\n    this.function = new NodejsFunction(this, 'Iterator', {\n      functionName: 'lambda-subminute-iterator',\n      description: 'A function for breaking the limit of 1 minute with the CloudWatch Rules.',\n      logRetention: RetentionDays.THREE_MONTHS,\n      runtime: Runtime.NODEJS_18_X,\n      entry: fs.existsSync(path.join(__dirname, 'resources/iterator/iterator_agent.ts')) ? path.join(__dirname, 'resources/iterator/iterator_agent.ts') : path.join(__dirname, 'resources/iterator/iterator_agent.js'),\n      handler: 'lambdaHandler',\n      environment: {\n        TARGET_FN_NAME: props.targetFunction.functionName,\n      },\n      memorySize: 128,\n      role: iteratorLambdaRole,\n      timeout: cdk.Duration.seconds(58), // 1 min\n      tracing: Tracing.ACTIVE,\n    });\n  }\n}\n\nexport interface SubminuteStateMachineProps {\n  /**\n   * the name of the state machine.\n   */\n  readonly stateMachineName: string;\n  /**\n   * the Lambda function that executes your intention.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * the iterator Lambda function for the target Lambda function.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime: number;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency: number;\n}\n\nexport class SubminuteStateMachine extends Construct {\n  readonly stateMachine: sfn.StateMachine;\n  constructor(scope: Construct, id: string, props: SubminuteStateMachineProps) {\n    super(scope, id);\n    const stateMachineRole = this._createWorkFlowRole(\n      props.targetFunction.functionArn, props.iteratorFunction.functionArn);\n    const jobDefinition = this.createJobDefinition(props.iteratorFunction, props.intervalTime, props.frequency);\n    const stateMachine = new sfn.StateMachine(this, 'StateMachine', {\n      stateMachineName: props.stateMachineName,\n      definition: jobDefinition,\n      role: stateMachineRole,\n    });\n    this.stateMachine = stateMachine;\n  }\n\n  /**\n   * Creates a state machine for breaking the limit of 1 minute with the CloudWatch Rules.\n   *\n   * @param iteratorFunction The iterator Lambda function for the target Labmda funciton.\n   * @param intervalTime Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   * @param frequency How many times you intent to execute in a minute.\n   * @returns THe job definition for the state machine.\n   */\n  private createJobDefinition = (\n    iteratorFunction: IFunction, intervalTime: number, frequency: number): sfn.Chain => {\n    const configureCount = new sfn.Pass(this, 'ConfigureCount', {\n      result: sfn.Result.fromObject({\n        index: 0,\n        count: frequency,\n      }),\n      resultPath: '$.iterator',\n    });\n    const iterator = new tasks.LambdaInvoke(this, 'Iterator', {\n      lambdaFunction: iteratorFunction,\n      resultPath: '$.iterator',\n      resultSelector: {\n        'index.$': '$.Payload.index',\n        'count.$': '$.Payload.count',\n        'continue.$': '$.Payload.continue',\n      },\n    });\n    const wait = new sfn.Wait(this, 'Wait for the target Lambda function finished', {\n      time: sfn.WaitTime.duration(cdk.Duration.seconds(intervalTime)),\n    });\n    wait.next(iterator);\n    const done = new sfn.Pass(this, 'Done');\n\n    const isCountReached = new sfn.Choice(this, 'IsCountReached');\n    isCountReached.when(sfn.Condition.booleanEquals('$.iterator.continue', true), wait);\n    isCountReached.otherwise(done);\n    const jobDefinition = configureCount.next(iterator).next(isCountReached);\n    return jobDefinition;\n  };\n\n  /**\n   * Creates a role and corresponding policies for the subminute state machine.\n   *\n   * @param targetFunctionArn the ARN of the Lambda function that executes your intention.\n   * @param iteratorFunctionArn the ARN of the iterator Lambda function for the target Lambda function.\n   * @returns the role as the documentation indicates.\n   */\n  private _createWorkFlowRole = (targetFunctionArn: string, iteratorFunctionArn: string) => {\n    const workFlowExecutionRole = new iam.Role(this, 'StepFunctionExecutionRole', {\n      assumedBy: new iam.ServicePrincipal('states.amazonaws.com'),\n      description: 'Execute a workflow related to executing a Lambda function per time unit less than 1 minute.',\n    });\n    workFlowExecutionRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'LambdaInvokePermissions',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [\n        targetFunctionArn,\n        iteratorFunctionArn,\n      ],\n    }));\n    return workFlowExecutionRole;\n  };\n}"]}
@@ -69,7 +69,7 @@ require('aws-sdk/lib/maintenance_mode_message').suppress = true;
69
69
  To use the SDK in the browser, simply add the following script tag to your
70
70
  HTML pages:
71
71
 
72
- <script src="https://sdk.amazonaws.com/js/aws-sdk-2.1537.0.min.js"></script>
72
+ <script src="https://sdk.amazonaws.com/js/aws-sdk-2.1538.0.min.js"></script>
73
73
 
74
74
  You can also build a custom browser SDK with your specified set of AWS services.
75
75
  This can allow you to reduce the SDK's size, specify different API versions of
@@ -85,6 +85,12 @@
85
85
  },
86
86
  "clientSideTimestamps": {
87
87
  "shape": "S13"
88
+ },
89
+ "autoScalingSpecification": {
90
+ "shape": "S15"
91
+ },
92
+ "replicaSpecifications": {
93
+ "shape": "S1c"
88
94
  }
89
95
  }
90
96
  },
@@ -188,22 +194,7 @@
188
194
  "shape": "Sf"
189
195
  },
190
196
  "capacitySpecification": {
191
- "type": "structure",
192
- "required": [
193
- "throughputMode"
194
- ],
195
- "members": {
196
- "throughputMode": {},
197
- "readCapacityUnits": {
198
- "type": "long"
199
- },
200
- "writeCapacityUnits": {
201
- "type": "long"
202
- },
203
- "lastUpdateToPayPerRequestTimestamp": {
204
- "type": "timestamp"
205
- }
206
- }
197
+ "shape": "S1p"
207
198
  },
208
199
  "encryptionSpecification": {
209
200
  "shape": "Sv"
@@ -231,6 +222,60 @@
231
222
  },
232
223
  "clientSideTimestamps": {
233
224
  "shape": "S13"
225
+ },
226
+ "replicaSpecifications": {
227
+ "type": "list",
228
+ "member": {
229
+ "type": "structure",
230
+ "members": {
231
+ "region": {},
232
+ "status": {},
233
+ "capacitySpecification": {
234
+ "shape": "S1p"
235
+ }
236
+ }
237
+ }
238
+ }
239
+ }
240
+ }
241
+ },
242
+ "GetTableAutoScalingSettings": {
243
+ "input": {
244
+ "type": "structure",
245
+ "required": [
246
+ "keyspaceName",
247
+ "tableName"
248
+ ],
249
+ "members": {
250
+ "keyspaceName": {},
251
+ "tableName": {}
252
+ }
253
+ },
254
+ "output": {
255
+ "type": "structure",
256
+ "required": [
257
+ "keyspaceName",
258
+ "tableName",
259
+ "resourceArn"
260
+ ],
261
+ "members": {
262
+ "keyspaceName": {},
263
+ "tableName": {},
264
+ "resourceArn": {},
265
+ "autoScalingSpecification": {
266
+ "shape": "S15"
267
+ },
268
+ "replicaSpecifications": {
269
+ "type": "list",
270
+ "member": {
271
+ "type": "structure",
272
+ "members": {
273
+ "region": {},
274
+ "autoScalingSpecification": {
275
+ "shape": "S15"
276
+ }
277
+ }
278
+ }
234
279
  }
235
280
  }
236
281
  }
@@ -363,6 +408,12 @@
363
408
  },
364
409
  "tagsOverride": {
365
410
  "shape": "S3"
411
+ },
412
+ "autoScalingSpecification": {
413
+ "shape": "S15"
414
+ },
415
+ "replicaSpecifications": {
416
+ "shape": "S1c"
366
417
  }
367
418
  }
368
419
  },
@@ -444,6 +495,12 @@
444
495
  },
445
496
  "clientSideTimestamps": {
446
497
  "shape": "S13"
498
+ },
499
+ "autoScalingSpecification": {
500
+ "shape": "S15"
501
+ },
502
+ "replicaSpecifications": {
503
+ "shape": "S1c"
447
504
  }
448
505
  }
449
506
  },
@@ -601,6 +658,92 @@
601
658
  "members": {
602
659
  "status": {}
603
660
  }
661
+ },
662
+ "S15": {
663
+ "type": "structure",
664
+ "members": {
665
+ "writeCapacityAutoScaling": {
666
+ "shape": "S16"
667
+ },
668
+ "readCapacityAutoScaling": {
669
+ "shape": "S16"
670
+ }
671
+ }
672
+ },
673
+ "S16": {
674
+ "type": "structure",
675
+ "members": {
676
+ "autoScalingDisabled": {
677
+ "type": "boolean"
678
+ },
679
+ "minimumUnits": {
680
+ "type": "long"
681
+ },
682
+ "maximumUnits": {
683
+ "type": "long"
684
+ },
685
+ "scalingPolicy": {
686
+ "type": "structure",
687
+ "members": {
688
+ "targetTrackingScalingPolicyConfiguration": {
689
+ "type": "structure",
690
+ "required": [
691
+ "targetValue"
692
+ ],
693
+ "members": {
694
+ "disableScaleIn": {
695
+ "type": "boolean"
696
+ },
697
+ "scaleInCooldown": {
698
+ "type": "integer"
699
+ },
700
+ "scaleOutCooldown": {
701
+ "type": "integer"
702
+ },
703
+ "targetValue": {
704
+ "type": "double"
705
+ }
706
+ }
707
+ }
708
+ }
709
+ }
710
+ }
711
+ },
712
+ "S1c": {
713
+ "type": "list",
714
+ "member": {
715
+ "type": "structure",
716
+ "required": [
717
+ "region"
718
+ ],
719
+ "members": {
720
+ "region": {},
721
+ "readCapacityUnits": {
722
+ "type": "long"
723
+ },
724
+ "readCapacityAutoScaling": {
725
+ "shape": "S16"
726
+ }
727
+ }
728
+ }
729
+ },
730
+ "S1p": {
731
+ "type": "structure",
732
+ "required": [
733
+ "throughputMode"
734
+ ],
735
+ "members": {
736
+ "throughputMode": {},
737
+ "readCapacityUnits": {
738
+ "type": "long"
739
+ },
740
+ "writeCapacityUnits": {
741
+ "type": "long"
742
+ },
743
+ "lastUpdateToPayPerRequestTimestamp": {
744
+ "type": "timestamp"
745
+ }
746
+ }
604
747
  }
605
748
  }
606
749
  }
@@ -1347,10 +1347,6 @@
1347
1347
  "trustedadvisor": {
1348
1348
  "name": "TrustedAdvisor"
1349
1349
  },
1350
- "cloudfrontkeyvaluestore": {
1351
- "prefix": "cloudfront-keyvaluestore",
1352
- "name": "CloudFrontKeyValueStore"
1353
- },
1354
1350
  "inspectorscan": {
1355
1351
  "prefix": "inspector-scan",
1356
1352
  "name": "InspectorScan"
@@ -1405,10 +1401,6 @@
1405
1401
  "prefix": "marketplace-deployment",
1406
1402
  "name": "MarketplaceDeployment"
1407
1403
  },
1408
- "neptunegraph": {
1409
- "prefix": "neptune-graph",
1410
- "name": "NeptuneGraph"
1411
- },
1412
1404
  "networkmonitor": {
1413
1405
  "name": "NetworkMonitor"
1414
1406
  },
@@ -357,7 +357,6 @@ export import BedrockRuntime = require('./bedrockruntime');
357
357
  export import DataZone = require('./datazone');
358
358
  export import LaunchWizard = require('./launchwizard');
359
359
  export import TrustedAdvisor = require('./trustedadvisor');
360
- export import CloudFrontKeyValueStore = require('./cloudfrontkeyvaluestore');
361
360
  export import InspectorScan = require('./inspectorscan');
362
361
  export import BCMDataExports = require('./bcmdataexports');
363
362
  export import CostOptimizationHub = require('./costoptimizationhub');
@@ -373,6 +372,5 @@ export import QConnect = require('./qconnect');
373
372
  export import CleanRoomsML = require('./cleanroomsml');
374
373
  export import MarketplaceAgreement = require('./marketplaceagreement');
375
374
  export import MarketplaceDeployment = require('./marketplacedeployment');
376
- export import NeptuneGraph = require('./neptunegraph');
377
375
  export import NetworkMonitor = require('./networkmonitor');
378
376
  export import SupplyChain = require('./supplychain');
@@ -359,7 +359,6 @@ module.exports = {
359
359
  DataZone: require('./datazone'),
360
360
  LaunchWizard: require('./launchwizard'),
361
361
  TrustedAdvisor: require('./trustedadvisor'),
362
- CloudFrontKeyValueStore: require('./cloudfrontkeyvaluestore'),
363
362
  InspectorScan: require('./inspectorscan'),
364
363
  BCMDataExports: require('./bcmdataexports'),
365
364
  CostOptimizationHub: require('./costoptimizationhub'),
@@ -375,7 +374,6 @@ module.exports = {
375
374
  CleanRoomsML: require('./cleanroomsml'),
376
375
  MarketplaceAgreement: require('./marketplaceagreement'),
377
376
  MarketplaceDeployment: require('./marketplacedeployment'),
378
- NeptuneGraph: require('./neptunegraph'),
379
377
  NetworkMonitor: require('./networkmonitor'),
380
378
  SupplyChain: require('./supplychain')
381
379
  };
@@ -3849,7 +3849,7 @@ declare namespace DynamoDB {
3849
3849
  */
3850
3850
  GlobalSecondaryIndexUpdates?: GlobalSecondaryIndexUpdateList;
3851
3851
  /**
3852
- * Represents the DynamoDB Streams configuration for the table. You receive a ResourceInUseException if you try to enable a stream on a table that already has a stream, or if you try to disable a stream on a table that doesn't have a stream.
3852
+ * Represents the DynamoDB Streams configuration for the table. You receive a ValidationException if you try to enable a stream on a table that already has a stream, or if you try to disable a stream on a table that doesn't have a stream.
3853
3853
  */
3854
3854
  StreamSpecification?: StreamSpecification;
3855
3855
  /**
@@ -59,6 +59,14 @@ declare class Keyspaces extends Service {
59
59
  * 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.
60
60
  */
61
61
  getTable(callback?: (err: AWSError, data: Keyspaces.Types.GetTableResponse) => void): Request<Keyspaces.Types.GetTableResponse, AWSError>;
62
+ /**
63
+ * 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.
64
+ */
65
+ getTableAutoScalingSettings(params: Keyspaces.Types.GetTableAutoScalingSettingsRequest, callback?: (err: AWSError, data: Keyspaces.Types.GetTableAutoScalingSettingsResponse) => void): Request<Keyspaces.Types.GetTableAutoScalingSettingsResponse, AWSError>;
66
+ /**
67
+ * 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.
68
+ */
69
+ getTableAutoScalingSettings(callback?: (err: AWSError, data: Keyspaces.Types.GetTableAutoScalingSettingsResponse) => void): Request<Keyspaces.Types.GetTableAutoScalingSettingsResponse, AWSError>;
62
70
  /**
63
71
  * Returns a list of keyspaces.
64
72
  */
@@ -84,11 +92,11 @@ declare class Keyspaces extends Service {
84
92
  */
85
93
  listTagsForResource(callback?: (err: AWSError, data: Keyspaces.Types.ListTagsForResourceResponse) => void): Request<Keyspaces.Types.ListTagsForResourceResponse, AWSError>;
86
94
  /**
87
- * Restores the specified 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, encryption, 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 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: Automatic scaling policies (for tables that use provisioned capacity mode) Identity and Access Management (IAM) policies Amazon CloudWatch metrics and alarms
95
+ * 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
88
96
  */
89
97
  restoreTable(params: Keyspaces.Types.RestoreTableRequest, callback?: (err: AWSError, data: Keyspaces.Types.RestoreTableResponse) => void): Request<Keyspaces.Types.RestoreTableResponse, AWSError>;
90
98
  /**
91
- * Restores the specified 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, encryption, 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 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: Automatic scaling policies (for tables that use provisioned capacity mode) Identity and Access Management (IAM) policies Amazon CloudWatch metrics and alarms
99
+ * 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
92
100
  */
93
101
  restoreTable(callback?: (err: AWSError, data: Keyspaces.Types.RestoreTableResponse) => void): Request<Keyspaces.Types.RestoreTableResponse, AWSError>;
94
102
  /**
@@ -108,16 +116,51 @@ declare class Keyspaces extends Service {
108
116
  */
109
117
  untagResource(callback?: (err: AWSError, data: Keyspaces.Types.UntagResourceResponse) => void): Request<Keyspaces.Types.UntagResourceResponse, AWSError>;
110
118
  /**
111
- * Adds new columns to the table or updates one of the table's settings, for example capacity mode, encryption, point-in-time recovery, or ttl settings. Note that you can only update one specific table setting per update operation.
119
+ * 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.
112
120
  */
113
121
  updateTable(params: Keyspaces.Types.UpdateTableRequest, callback?: (err: AWSError, data: Keyspaces.Types.UpdateTableResponse) => void): Request<Keyspaces.Types.UpdateTableResponse, AWSError>;
114
122
  /**
115
- * Adds new columns to the table or updates one of the table's settings, for example capacity mode, encryption, point-in-time recovery, or ttl settings. Note that you can only update one specific table setting per update operation.
123
+ * 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.
116
124
  */
117
125
  updateTable(callback?: (err: AWSError, data: Keyspaces.Types.UpdateTableResponse) => void): Request<Keyspaces.Types.UpdateTableResponse, AWSError>;
118
126
  }
119
127
  declare namespace Keyspaces {
120
128
  export type ARN = string;
129
+ export interface AutoScalingPolicy {
130
+ /**
131
+ * Auto scaling scales up capacity automatically when traffic exceeds this target utilization rate, and then back down when it falls below the target. A double between 20 and 90.
132
+ */
133
+ targetTrackingScalingPolicyConfiguration?: TargetTrackingScalingPolicyConfiguration;
134
+ }
135
+ export interface AutoScalingSettings {
136
+ /**
137
+ * This optional parameter enables auto scaling for the table if set to false.
138
+ */
139
+ autoScalingDisabled?: BooleanObject;
140
+ /**
141
+ * The minimum level of throughput the table should always be ready to support. The value must be between 1 and the max throughput per second quota for your account (40,000 by default).
142
+ */
143
+ minimumUnits?: CapacityUnits;
144
+ /**
145
+ * Manage costs by specifying the maximum amount of throughput to provision. The value must be between 1 and the max throughput per second quota for your account (40,000 by default).
146
+ */
147
+ maximumUnits?: CapacityUnits;
148
+ /**
149
+ * Amazon Keyspaces supports the target tracking auto scaling policy. With this policy, Amazon Keyspaces auto scaling ensures that the table's ratio of consumed to provisioned capacity stays at or near the target value that you specify. You define the target value as a percentage between 20 and 90.
150
+ */
151
+ scalingPolicy?: AutoScalingPolicy;
152
+ }
153
+ export interface AutoScalingSpecification {
154
+ /**
155
+ * The auto scaling settings for the table's write capacity.
156
+ */
157
+ writeCapacityAutoScaling?: AutoScalingSettings;
158
+ /**
159
+ * The auto scaling settings for the table's read capacity.
160
+ */
161
+ readCapacityAutoScaling?: AutoScalingSettings;
162
+ }
163
+ export type BooleanObject = boolean;
121
164
  export interface CapacitySpecification {
122
165
  /**
123
166
  * The read/write throughput capacity mode for a table. The options are: throughputMode:PAY_PER_REQUEST and throughputMode:PROVISIONED - Provisioned capacity mode requires readCapacityUnits and writeCapacityUnits as input. The default is throughput_mode:PAY_PER_REQUEST. For more information, see Read/write capacity modes in the Amazon Keyspaces Developer Guide.
@@ -251,6 +294,14 @@ declare namespace Keyspaces {
251
294
  * Enables client-side timestamps for the table. By default, the setting is disabled. You can enable client-side timestamps with the following option: status: "enabled" Once client-side timestamps are enabled for a table, this setting cannot be disabled.
252
295
  */
253
296
  clientSideTimestamps?: ClientSideTimestamps;
297
+ /**
298
+ * The optional auto scaling settings for a table in provisioned capacity mode. Specifies if the service can manage throughput capacity automatically on your behalf. 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. By default, auto scaling is disabled for a table.
299
+ */
300
+ autoScalingSpecification?: AutoScalingSpecification;
301
+ /**
302
+ * The optional Amazon Web Services Region specific settings of a multi-Region table. These settings overwrite the general settings of the table for the specified Region. For a multi-Region table in provisioned capacity mode, you can configure the table's read capacity differently for each Region's replica. The write capacity, however, remains synchronized between all replicas to ensure that there's enough capacity to replicate writes across all Regions. To define the read capacity for a table replica in a specific Region, you can do so by configuring the following parameters. region: The Region where these settings are applied. (Required) readCapacityUnits: The provisioned read capacity units. (Optional) readCapacityAutoScaling: The read capacity auto scaling settings for the table. (Optional)
303
+ */
304
+ replicaSpecifications?: ReplicaSpecificationList;
254
305
  }
255
306
  export interface CreateTableResponse {
256
307
  /**
@@ -279,6 +330,7 @@ declare namespace Keyspaces {
279
330
  }
280
331
  export interface DeleteTableResponse {
281
332
  }
333
+ export type DoubleObject = number;
282
334
  export interface EncryptionSpecification {
283
335
  /**
284
336
  * The encryption option specified for the table. You can choose one of the following KMS keys (KMS keys): type:AWS_OWNED_KMS_KEY - This key is owned by Amazon Keyspaces. type:CUSTOMER_MANAGED_KMS_KEY - This key is stored in your account and is created, owned, and managed by you. This option requires the kms_key_identifier of the KMS key in Amazon Resource Name (ARN) format as input. The default is type:AWS_OWNED_KMS_KEY. For more information, see Encryption at rest in the Amazon Keyspaces Developer Guide.
@@ -315,6 +367,38 @@ declare namespace Keyspaces {
315
367
  */
316
368
  replicationRegions?: RegionList;
317
369
  }
370
+ export interface GetTableAutoScalingSettingsRequest {
371
+ /**
372
+ * The name of the keyspace.
373
+ */
374
+ keyspaceName: KeyspaceName;
375
+ /**
376
+ * The name of the table.
377
+ */
378
+ tableName: TableName;
379
+ }
380
+ export interface GetTableAutoScalingSettingsResponse {
381
+ /**
382
+ * The name of the keyspace.
383
+ */
384
+ keyspaceName: KeyspaceName;
385
+ /**
386
+ * The name of the table.
387
+ */
388
+ tableName: TableName;
389
+ /**
390
+ * The Amazon Resource Name (ARN) of the table.
391
+ */
392
+ resourceArn: ARN;
393
+ /**
394
+ * The auto scaling settings of the table.
395
+ */
396
+ autoScalingSpecification?: AutoScalingSpecification;
397
+ /**
398
+ * The Amazon Web Services Region specific settings of a multi-Region table. Returns the settings for all Regions the table is replicated in.
399
+ */
400
+ replicaSpecifications?: ReplicaAutoScalingSpecificationList;
401
+ }
318
402
  export interface GetTableRequest {
319
403
  /**
320
404
  * The name of the keyspace that the table is stored in.
@@ -378,7 +462,12 @@ declare namespace Keyspaces {
378
462
  * The client-side timestamps setting of the table.
379
463
  */
380
464
  clientSideTimestamps?: ClientSideTimestamps;
465
+ /**
466
+ * Returns the Amazon Web Services Region specific settings of all Regions a multi-Region table is replicated in.
467
+ */
468
+ replicaSpecifications?: ReplicaSpecificationSummaryList;
381
469
  }
470
+ export type IntegerObject = number;
382
471
  export type KeyspaceName = string;
383
472
  export interface KeyspaceSummary {
384
473
  /**
@@ -494,6 +583,44 @@ declare namespace Keyspaces {
494
583
  earliestRestorableTimestamp?: Timestamp;
495
584
  }
496
585
  export type RegionList = region[];
586
+ export interface ReplicaAutoScalingSpecification {
587
+ /**
588
+ * The Amazon Web Services Region.
589
+ */
590
+ region?: region;
591
+ /**
592
+ * The auto scaling settings for a multi-Region table in the specified Amazon Web Services Region.
593
+ */
594
+ autoScalingSpecification?: AutoScalingSpecification;
595
+ }
596
+ export type ReplicaAutoScalingSpecificationList = ReplicaAutoScalingSpecification[];
597
+ export interface ReplicaSpecification {
598
+ /**
599
+ * The Amazon Web Services Region.
600
+ */
601
+ region: region;
602
+ /**
603
+ * The provisioned read capacity units for the multi-Region table in the specified Amazon Web Services Region.
604
+ */
605
+ readCapacityUnits?: CapacityUnits;
606
+ /**
607
+ * The read capacity auto scaling settings for the multi-Region table in the specified Amazon Web Services Region.
608
+ */
609
+ readCapacityAutoScaling?: AutoScalingSettings;
610
+ }
611
+ export type ReplicaSpecificationList = ReplicaSpecification[];
612
+ export interface ReplicaSpecificationSummary {
613
+ /**
614
+ * The Amazon Web Services Region.
615
+ */
616
+ region?: region;
617
+ /**
618
+ * The status of the multi-Region table in the specified Amazon Web Services Region.
619
+ */
620
+ status?: TableStatus;
621
+ capacitySpecification?: CapacitySpecificationSummary;
622
+ }
623
+ export type ReplicaSpecificationSummaryList = ReplicaSpecificationSummary[];
497
624
  export interface ReplicationSpecification {
498
625
  /**
499
626
  * The replicationStrategy of a keyspace, the required value is SINGLE_REGION or MULTI_REGION.
@@ -541,6 +668,14 @@ declare namespace Keyspaces {
541
668
  * A list of key-value pair tags to be attached to the restored table. For more information, see Adding tags and labels to Amazon Keyspaces resources in the Amazon Keyspaces Developer Guide.
542
669
  */
543
670
  tagsOverride?: TagList;
671
+ /**
672
+ * The optional auto scaling settings for the restored table in provisioned capacity mode. Specifies if the service can manage throughput capacity of a provisioned table automatically on your behalf. 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.
673
+ */
674
+ autoScalingSpecification?: AutoScalingSpecification;
675
+ /**
676
+ * The optional Region specific settings of a multi-Regional table.
677
+ */
678
+ replicaSpecifications?: ReplicaSpecificationList;
544
679
  }
545
680
  export interface RestoreTableResponse {
546
681
  /**
@@ -617,6 +752,24 @@ declare namespace Keyspaces {
617
752
  export interface TagResourceResponse {
618
753
  }
619
754
  export type TagValue = string;
755
+ export interface TargetTrackingScalingPolicyConfiguration {
756
+ /**
757
+ * Specifies if scale-in is enabled. When auto scaling automatically decreases capacity for a table, the table scales in. When scaling policies are set, they can't scale in the table lower than its minimum capacity.
758
+ */
759
+ disableScaleIn?: BooleanObject;
760
+ /**
761
+ * Specifies a scale-in cool down period. A cooldown period in seconds between scaling activities that lets the table stabilize before another scaling activity starts.
762
+ */
763
+ scaleInCooldown?: IntegerObject;
764
+ /**
765
+ * Specifies a scale out cool down period. A cooldown period in seconds between scaling activities that lets the table stabilize before another scaling activity starts.
766
+ */
767
+ scaleOutCooldown?: IntegerObject;
768
+ /**
769
+ * Specifies the target value for the target tracking auto scaling policy. Amazon Keyspaces auto scaling scales up capacity automatically when traffic exceeds this target utilization rate, and then back down when it falls below the target. This ensures that the ratio of consumed capacity to provisioned capacity stays at or near this value. You define targetValue as a percentage. A double between 20 and 90.
770
+ */
771
+ targetValue: DoubleObject;
772
+ }
620
773
  export type ThroughputMode = "PAY_PER_REQUEST"|"PROVISIONED"|string;
621
774
  export interface TimeToLive {
622
775
  /**
@@ -675,6 +828,14 @@ declare namespace Keyspaces {
675
828
  * Enables client-side timestamps for the table. By default, the setting is disabled. You can enable client-side timestamps with the following option: status: "enabled" Once client-side timestamps are enabled for a table, this setting cannot be disabled.
676
829
  */
677
830
  clientSideTimestamps?: ClientSideTimestamps;
831
+ /**
832
+ * The optional auto scaling settings to update for a table in provisioned capacity mode. Specifies if the service can manage throughput capacity of a provisioned table automatically on your behalf. 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. If auto scaling is already enabled for the table, you can use UpdateTable to update the minimum and maximum values or the auto scaling policy settings independently. For more information, see Managing throughput capacity automatically with Amazon Keyspaces auto scaling in the Amazon Keyspaces Developer Guide.
833
+ */
834
+ autoScalingSpecification?: AutoScalingSpecification;
835
+ /**
836
+ * The Region specific settings of a multi-Regional table.
837
+ */
838
+ replicaSpecifications?: ReplicaSpecificationList;
678
839
  }
679
840
  export interface UpdateTableResponse {
680
841
  /**