cdk-docker-image-deployment 0.0.115 → 0.0.117

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.
package/.jsii CHANGED
@@ -8,7 +8,7 @@
8
8
  },
9
9
  "bundled": {
10
10
  "@types/aws-lambda": "^8.10.109",
11
- "aws-sdk": "^2.1282.0"
11
+ "aws-sdk": "^2.1283.0"
12
12
  },
13
13
  "dependencies": {
14
14
  "aws-cdk-lib": "^2.24.0",
@@ -3549,6 +3549,6 @@
3549
3549
  "symbolId": "src/source:SourceContext"
3550
3550
  }
3551
3551
  },
3552
- "version": "0.0.115",
3553
- "fingerprint": "77oB+6/JzB4yVxbinWRq1D0QKR2SSKl8h8+7/v+qeuE="
3552
+ "version": "0.0.117",
3553
+ "fingerprint": "aCBAy93JKqUm6IcfLLf08U26uIU/DylrHKdYp2l5vvs="
3554
3554
  }
@@ -26,7 +26,7 @@ class Destination {
26
26
  }
27
27
  exports.Destination = Destination;
28
28
  _a = JSII_RTTI_SYMBOL_1;
29
- Destination[_a] = { fqn: "cdk-docker-image-deployment.Destination", version: "0.0.115" };
29
+ Destination[_a] = { fqn: "cdk-docker-image-deployment.Destination", version: "0.0.117" };
30
30
  /**
31
31
  * Class used when the destination of docker image deployment is an ECR repository in the same account as the stack
32
32
  */
@@ -114,5 +114,5 @@ class DockerImageDeployment extends constructs_1.Construct {
114
114
  }
115
115
  exports.DockerImageDeployment = DockerImageDeployment;
116
116
  _a = JSII_RTTI_SYMBOL_1;
117
- DockerImageDeployment[_a] = { fqn: "cdk-docker-image-deployment.DockerImageDeployment", version: "0.0.115" };
117
+ DockerImageDeployment[_a] = { fqn: "cdk-docker-image-deployment.DockerImageDeployment", version: "0.0.117" };
118
118
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docker-image-deployment.js","sourceRoot":"","sources":["../src/docker-image-deployment.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { CustomResource, Duration, CfnOutput, Token } from 'aws-cdk-lib';\nimport * as codebuild from 'aws-cdk-lib/aws-codebuild';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Runtime } from 'aws-cdk-lib/aws-lambda';\nimport * as lambda from 'aws-cdk-lib/aws-lambda-nodejs';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { Destination } from './destination';\nimport { Source } from './source';\n\nexport interface DockerImageDeploymentProps {\n  /**\n   * Source of the image to deploy.\n   */\n  readonly source: Source;\n\n  /**\n   * Destination repository to deploy the image to.\n   */\n  readonly destination: Destination;\n}\n\n/**\n * `DockerImageDeployment` pushes an image from a local or external source to a specified external destination\n */\nexport class DockerImageDeployment extends Construct {\n  private readonly cb: codebuild.Project;\n\n  constructor(scope: Construct, id: string, props: DockerImageDeploymentProps) {\n    super(scope, id);\n\n    const handlerRole = new iam.Role(this, 'DockerImageDeployRole', {\n      assumedBy: new iam.ServicePrincipal('codebuild.amazonaws.com'),\n    });\n\n    const sourceConfig = props.source.bind(this, { handlerRole });\n    const destinationConfig = props.destination.bind(handlerRole);\n\n    const sourceUri = sourceConfig.imageUri;\n\n    const destTag = destinationConfig.destinationTag ?? sourceConfig.imageTag;\n    this.validateTag(destTag);\n\n    const destUri = `${destinationConfig.destinationUri}:${destTag}`;\n\n    const commands = [\n      sourceConfig.loginConfig.loginCommand,\n      `docker pull ${sourceUri}`,\n      `docker tag ${sourceUri} ${destUri}`,\n    ];\n\n    if (sourceConfig.loginConfig.region !== destinationConfig.loginConfig.region || !sourceConfig.loginConfig.region) { // different regions or either undefined should logout and login\n      commands.push('docker logout');\n      commands.push(destinationConfig.loginConfig.loginCommand);\n    }\n\n    commands.push(`docker push ${destUri}`);\n    commands.push('docker logout');\n\n    this.cb = new codebuild.Project(this, 'DockerImageDeployProject', {\n      buildSpec: codebuild.BuildSpec.fromObject({\n        version: '0.2',\n        phases: {\n          build: {\n            commands: commands,\n          },\n        },\n      }),\n      environment: {\n        privileged: true,\n        buildImage: codebuild.LinuxBuildImage.STANDARD_5_0,\n      },\n      role: handlerRole,\n    });\n\n    const onEventHandler = new lambda.NodejsFunction(this, 'onEventHandler', {\n      entry: path.join(__dirname, 'codebuild-handler/index.js'),\n      handler: 'onEventhandler',\n      runtime: Runtime.NODEJS_16_X,\n    });\n\n    const isCompleteHandler = new lambda.NodejsFunction(this, 'isCompleteHandler', {\n      entry: path.join(__dirname, 'codebuild-handler/index.js'),\n      handler: 'isCompleteHandler',\n      runtime: Runtime.NODEJS_16_X,\n    });\n\n    // https://github.com/aws/aws-cdk/issues/21721 issue to add grant methods to codebuild\n    const grantOnEvent = iam.Grant.addToPrincipal({\n      grantee: onEventHandler,\n      actions: ['codebuild:StartBuild'],\n      resourceArns: [this.cb.projectArn],\n      scope: this,\n    });\n\n    const grantIsComplete = iam.Grant.addToPrincipal({\n      grantee: isCompleteHandler,\n      actions: [\n        'codebuild:ListBuildsForProject',\n        'codebuild:BatchGetBuilds',\n      ],\n      resourceArns: [this.cb.projectArn],\n      scope: this,\n    });\n\n    const crProvider = new cr.Provider(this, 'CRProvider', {\n      onEventHandler: onEventHandler,\n      isCompleteHandler: isCompleteHandler,\n      queryInterval: Duration.seconds(30),\n      totalTimeout: Duration.minutes(30),\n    });\n\n    const customResource = new CustomResource(this, `CustomResource${Date.now().toString()}`, {\n      serviceToken: crProvider.serviceToken,\n      properties: {\n        projectName: this.cb.projectName,\n      },\n    });\n\n    customResource.node.addDependency(grantOnEvent, grantIsComplete);\n\n    try {\n      new CfnOutput(this, 'CustomResourceReport', {\n        value: `${customResource.getAttString('Status')}, see the logs here: ${customResource.getAtt('LogsUrl')}`,\n      });\n    } catch (error) {\n      throw new Error('Error getting the report from the custom resource');\n    }\n  }\n\n  private validateTag(tag: string): void {\n    if (Token.isUnresolved(tag)) {\n      return; // if token tag is likely from source, so assume it is valid\n    }\n    if (tag.length > 128) {\n      throw new Error (`Invalid tag: tags may contain a maximum of 128 characters; your tag ${tag} has ${tag.length} characters`);\n    }\n    if (!/^[^-.][a-zA-Z0-9-_.]+$/.test(tag)) {\n      throw new Error(`Invalid tag: tags must contain alphanumeric characters and \\'-\\' \\'_\\' \\'.\\' only and must not begin with \\'.\\' or \\'-\\'; your tag was ${tag}`);\n    }\n  }\n}\n"]}
package/lib/source.js CHANGED
@@ -29,7 +29,7 @@ class Source {
29
29
  }
30
30
  exports.Source = Source;
31
31
  _a = JSII_RTTI_SYMBOL_1;
32
- Source[_a] = { fqn: "cdk-docker-image-deployment.Source", version: "0.0.115" };
32
+ Source[_a] = { fqn: "cdk-docker-image-deployment.Source", version: "0.0.117" };
33
33
  /**
34
34
  * Source of docker image deployment is a local image from a directory
35
35
  */
@@ -1,7 +1,11 @@
1
1
  # Changelog for AWS SDK for JavaScript
2
- <!--LATEST=2.1282.0-->
2
+ <!--LATEST=2.1283.0-->
3
3
  <!--ENTRYINSERT-->
4
4
 
5
+ ## 2.1283.0
6
+ * feature: MemoryDB: This release adds support for MemoryDB Reserved nodes which provides a significant discount compared to on-demand node pricing. Reserved nodes are not physical nodes, but rather a billing discount applied to the use of on-demand nodes in your account.
7
+ * feature: Transfer: Add additional operations to throw ThrottlingExceptions
8
+
5
9
  ## 2.1282.0
6
10
  * feature: Connect: Support for Routing Profile filter, SortCriteria, and grouping by Routing Profiles for GetCurrentMetricData API. Support for RoutingProfiles, UserHierarchyGroups, and Agents as filters, NextStatus and AgentStatusName for GetCurrentUserData. Adds ApproximateTotalCount to both APIs.
7
11
  * feature: ConnectParticipant: Amazon Connect Chat introduces the Message Receipts feature. This feature allows agents and customers to receive message delivered and read receipts after they send a chat message.
@@ -57,7 +57,7 @@ for further details.
57
57
  To use the SDK in the browser, simply add the following script tag to your
58
58
  HTML pages:
59
59
 
60
- <script src="https://sdk.amazonaws.com/js/aws-sdk-2.1282.0.min.js"></script>
60
+ <script src="https://sdk.amazonaws.com/js/aws-sdk-2.1283.0.min.js"></script>
61
61
 
62
62
  You can also build a custom browser SDK with your specified set of AWS services.
63
63
  This can allow you to reduce the SDK's size, specify different API versions of
@@ -568,6 +568,75 @@
568
568
  }
569
569
  }
570
570
  },
571
+ "DescribeReservedNodes": {
572
+ "input": {
573
+ "type": "structure",
574
+ "members": {
575
+ "ReservationId": {},
576
+ "ReservedNodesOfferingId": {},
577
+ "NodeType": {},
578
+ "Duration": {},
579
+ "OfferingType": {},
580
+ "MaxResults": {
581
+ "type": "integer"
582
+ },
583
+ "NextToken": {}
584
+ }
585
+ },
586
+ "output": {
587
+ "type": "structure",
588
+ "members": {
589
+ "NextToken": {},
590
+ "ReservedNodes": {
591
+ "type": "list",
592
+ "member": {
593
+ "shape": "S36"
594
+ }
595
+ }
596
+ }
597
+ }
598
+ },
599
+ "DescribeReservedNodesOfferings": {
600
+ "input": {
601
+ "type": "structure",
602
+ "members": {
603
+ "ReservedNodesOfferingId": {},
604
+ "NodeType": {},
605
+ "Duration": {},
606
+ "OfferingType": {},
607
+ "MaxResults": {
608
+ "type": "integer"
609
+ },
610
+ "NextToken": {}
611
+ }
612
+ },
613
+ "output": {
614
+ "type": "structure",
615
+ "members": {
616
+ "NextToken": {},
617
+ "ReservedNodesOfferings": {
618
+ "type": "list",
619
+ "member": {
620
+ "type": "structure",
621
+ "members": {
622
+ "ReservedNodesOfferingId": {},
623
+ "NodeType": {},
624
+ "Duration": {
625
+ "type": "integer"
626
+ },
627
+ "FixedPrice": {
628
+ "type": "double"
629
+ },
630
+ "OfferingType": {},
631
+ "RecurringCharges": {
632
+ "shape": "S37"
633
+ }
634
+ }
635
+ }
636
+ }
637
+ }
638
+ }
639
+ },
571
640
  "DescribeServiceUpdates": {
572
641
  "input": {
573
642
  "type": "structure",
@@ -742,10 +811,10 @@
742
811
  "type": "structure",
743
812
  "members": {
744
813
  "ScaleUpNodeTypes": {
745
- "shape": "S3r"
814
+ "shape": "S41"
746
815
  },
747
816
  "ScaleDownNodeTypes": {
748
- "shape": "S3r"
817
+ "shape": "S41"
749
818
  }
750
819
  }
751
820
  }
@@ -769,6 +838,32 @@
769
838
  }
770
839
  }
771
840
  },
841
+ "PurchaseReservedNodesOffering": {
842
+ "input": {
843
+ "type": "structure",
844
+ "required": [
845
+ "ReservedNodesOfferingId"
846
+ ],
847
+ "members": {
848
+ "ReservedNodesOfferingId": {},
849
+ "ReservationId": {},
850
+ "NodeCount": {
851
+ "type": "integer"
852
+ },
853
+ "Tags": {
854
+ "shape": "Sz"
855
+ }
856
+ }
857
+ },
858
+ "output": {
859
+ "type": "structure",
860
+ "members": {
861
+ "ReservedNode": {
862
+ "shape": "S36"
863
+ }
864
+ }
865
+ }
866
+ },
772
867
  "ResetParameterGroup": {
773
868
  "input": {
774
869
  "type": "structure",
@@ -1303,7 +1398,45 @@
1303
1398
  "ARN": {}
1304
1399
  }
1305
1400
  },
1306
- "S3r": {
1401
+ "S36": {
1402
+ "type": "structure",
1403
+ "members": {
1404
+ "ReservationId": {},
1405
+ "ReservedNodesOfferingId": {},
1406
+ "NodeType": {},
1407
+ "StartTime": {
1408
+ "type": "timestamp"
1409
+ },
1410
+ "Duration": {
1411
+ "type": "integer"
1412
+ },
1413
+ "FixedPrice": {
1414
+ "type": "double"
1415
+ },
1416
+ "NodeCount": {
1417
+ "type": "integer"
1418
+ },
1419
+ "OfferingType": {},
1420
+ "State": {},
1421
+ "RecurringCharges": {
1422
+ "shape": "S37"
1423
+ },
1424
+ "ARN": {}
1425
+ }
1426
+ },
1427
+ "S37": {
1428
+ "type": "list",
1429
+ "member": {
1430
+ "type": "structure",
1431
+ "members": {
1432
+ "RecurringChargeAmount": {
1433
+ "type": "double"
1434
+ },
1435
+ "RecurringChargeFrequency": {}
1436
+ }
1437
+ }
1438
+ },
1439
+ "S41": {
1307
1440
  "type": "list",
1308
1441
  "member": {}
1309
1442
  }
@@ -1,4 +1,76 @@
1
1
  {
2
2
  "pagination": {
3
+ "DescribeACLs": {
4
+ "input_token": "NextToken",
5
+ "limit_key": "MaxResults",
6
+ "output_token": "NextToken",
7
+ "result_key": "ACLs"
8
+ },
9
+ "DescribeClusters": {
10
+ "input_token": "NextToken",
11
+ "limit_key": "MaxResults",
12
+ "output_token": "NextToken",
13
+ "result_key": "Clusters"
14
+ },
15
+ "DescribeEngineVersions": {
16
+ "input_token": "NextToken",
17
+ "limit_key": "MaxResults",
18
+ "output_token": "NextToken",
19
+ "result_key": "EngineVersions"
20
+ },
21
+ "DescribeEvents": {
22
+ "input_token": "NextToken",
23
+ "limit_key": "MaxResults",
24
+ "output_token": "NextToken",
25
+ "result_key": "Events"
26
+ },
27
+ "DescribeParameterGroups": {
28
+ "input_token": "NextToken",
29
+ "limit_key": "MaxResults",
30
+ "output_token": "NextToken",
31
+ "result_key": "ParameterGroups"
32
+ },
33
+ "DescribeParameters": {
34
+ "input_token": "NextToken",
35
+ "limit_key": "MaxResults",
36
+ "output_token": "NextToken",
37
+ "result_key": "Parameters"
38
+ },
39
+ "DescribeReservedNodes": {
40
+ "input_token": "NextToken",
41
+ "limit_key": "MaxResults",
42
+ "output_token": "NextToken",
43
+ "result_key": "ReservedNodes"
44
+ },
45
+ "DescribeReservedNodesOfferings": {
46
+ "input_token": "NextToken",
47
+ "limit_key": "MaxResults",
48
+ "output_token": "NextToken",
49
+ "result_key": "ReservedNodesOfferings"
50
+ },
51
+ "DescribeServiceUpdates": {
52
+ "input_token": "NextToken",
53
+ "limit_key": "MaxResults",
54
+ "output_token": "NextToken",
55
+ "result_key": "ServiceUpdates"
56
+ },
57
+ "DescribeSnapshots": {
58
+ "input_token": "NextToken",
59
+ "limit_key": "MaxResults",
60
+ "output_token": "NextToken",
61
+ "result_key": "Snapshots"
62
+ },
63
+ "DescribeSubnetGroups": {
64
+ "input_token": "NextToken",
65
+ "limit_key": "MaxResults",
66
+ "output_token": "NextToken",
67
+ "result_key": "SubnetGroups"
68
+ },
69
+ "DescribeUsers": {
70
+ "input_token": "NextToken",
71
+ "limit_key": "MaxResults",
72
+ "output_token": "NextToken",
73
+ "result_key": "Users"
74
+ }
3
75
  }
4
- }
76
+ }
@@ -171,6 +171,22 @@ declare class MemoryDB extends Service {
171
171
  * Returns the detailed parameter list for a particular parameter group.
172
172
  */
173
173
  describeParameters(callback?: (err: AWSError, data: MemoryDB.Types.DescribeParametersResponse) => void): Request<MemoryDB.Types.DescribeParametersResponse, AWSError>;
174
+ /**
175
+ * Returns information about reserved nodes for this account, or about a specified reserved node.
176
+ */
177
+ describeReservedNodes(params: MemoryDB.Types.DescribeReservedNodesRequest, callback?: (err: AWSError, data: MemoryDB.Types.DescribeReservedNodesResponse) => void): Request<MemoryDB.Types.DescribeReservedNodesResponse, AWSError>;
178
+ /**
179
+ * Returns information about reserved nodes for this account, or about a specified reserved node.
180
+ */
181
+ describeReservedNodes(callback?: (err: AWSError, data: MemoryDB.Types.DescribeReservedNodesResponse) => void): Request<MemoryDB.Types.DescribeReservedNodesResponse, AWSError>;
182
+ /**
183
+ * Lists available reserved node offerings.
184
+ */
185
+ describeReservedNodesOfferings(params: MemoryDB.Types.DescribeReservedNodesOfferingsRequest, callback?: (err: AWSError, data: MemoryDB.Types.DescribeReservedNodesOfferingsResponse) => void): Request<MemoryDB.Types.DescribeReservedNodesOfferingsResponse, AWSError>;
186
+ /**
187
+ * Lists available reserved node offerings.
188
+ */
189
+ describeReservedNodesOfferings(callback?: (err: AWSError, data: MemoryDB.Types.DescribeReservedNodesOfferingsResponse) => void): Request<MemoryDB.Types.DescribeReservedNodesOfferingsResponse, AWSError>;
174
190
  /**
175
191
  * Returns details of the service updates
176
192
  */
@@ -227,6 +243,14 @@ declare class MemoryDB extends Service {
227
243
  * Lists all tags currently on a named resource. A tag is a key-value pair where the key and value are case-sensitive. You can use tags to categorize and track your MemoryDB resources. For more information, see Tagging your MemoryDB resources
228
244
  */
229
245
  listTags(callback?: (err: AWSError, data: MemoryDB.Types.ListTagsResponse) => void): Request<MemoryDB.Types.ListTagsResponse, AWSError>;
246
+ /**
247
+ * Allows you to purchase a reserved node offering. Reserved nodes are not eligible for cancellation and are non-refundable.
248
+ */
249
+ purchaseReservedNodesOffering(params: MemoryDB.Types.PurchaseReservedNodesOfferingRequest, callback?: (err: AWSError, data: MemoryDB.Types.PurchaseReservedNodesOfferingResponse) => void): Request<MemoryDB.Types.PurchaseReservedNodesOfferingResponse, AWSError>;
250
+ /**
251
+ * Allows you to purchase a reserved node offering. Reserved nodes are not eligible for cancellation and are non-refundable.
252
+ */
253
+ purchaseReservedNodesOffering(callback?: (err: AWSError, data: MemoryDB.Types.PurchaseReservedNodesOfferingResponse) => void): Request<MemoryDB.Types.PurchaseReservedNodesOfferingResponse, AWSError>;
230
254
  /**
231
255
  * Modifies the parameters of a parameter group to the engine or system default value. You can reset specific parameters by submitting a list of parameter names. To reset the entire parameter group, specify the AllParameters and ParameterGroupName parameters.
232
256
  */
@@ -1063,6 +1087,82 @@ declare namespace MemoryDB {
1063
1087
  */
1064
1088
  Parameters?: ParametersList;
1065
1089
  }
1090
+ export interface DescribeReservedNodesOfferingsRequest {
1091
+ /**
1092
+ * The offering identifier filter value. Use this parameter to show only the available offering that matches the specified reservation identifier.
1093
+ */
1094
+ ReservedNodesOfferingId?: String;
1095
+ /**
1096
+ * The node type for the reserved nodes. For more information, see Supported node types.
1097
+ */
1098
+ NodeType?: String;
1099
+ /**
1100
+ * Duration filter value, specified in years or seconds. Use this parameter to show only reservations for a given duration.
1101
+ */
1102
+ Duration?: String;
1103
+ /**
1104
+ * The offering type filter value. Use this parameter to show only the available offerings matching the specified offering type. Valid values: "All Upfront"|"Partial Upfront"| "No Upfront"
1105
+ */
1106
+ OfferingType?: String;
1107
+ /**
1108
+ * The maximum number of records to include in the response. If more records exist than the specified MaxRecords value, a marker is included in the response so that the remaining results can be retrieved.
1109
+ */
1110
+ MaxResults?: IntegerOptional;
1111
+ /**
1112
+ * An optional marker returned from a prior request. Use this marker for pagination of results from this operation. If this parameter is specified, the response includes only records beyond the marker, up to the value specified by MaxRecords.
1113
+ */
1114
+ NextToken?: String;
1115
+ }
1116
+ export interface DescribeReservedNodesOfferingsResponse {
1117
+ /**
1118
+ * An optional marker returned from a prior request. Use this marker for pagination of results from this operation. If this parameter is specified, the response includes only records beyond the marker, up to the value specified by MaxRecords.
1119
+ */
1120
+ NextToken?: String;
1121
+ /**
1122
+ * Lists available reserved node offerings.
1123
+ */
1124
+ ReservedNodesOfferings?: ReservedNodesOfferingList;
1125
+ }
1126
+ export interface DescribeReservedNodesRequest {
1127
+ /**
1128
+ * The reserved node identifier filter value. Use this parameter to show only the reservation that matches the specified reservation ID.
1129
+ */
1130
+ ReservationId?: String;
1131
+ /**
1132
+ * The offering identifier filter value. Use this parameter to show only purchased reservations matching the specified offering identifier.
1133
+ */
1134
+ ReservedNodesOfferingId?: String;
1135
+ /**
1136
+ * The node type filter value. Use this parameter to show only those reservations matching the specified node type. For more information, see Supported node types.
1137
+ */
1138
+ NodeType?: String;
1139
+ /**
1140
+ * The duration filter value, specified in years or seconds. Use this parameter to show only reservations for this duration.
1141
+ */
1142
+ Duration?: String;
1143
+ /**
1144
+ * The offering type filter value. Use this parameter to show only the available offerings matching the specified offering type. Valid values: "All Upfront"|"Partial Upfront"| "No Upfront"
1145
+ */
1146
+ OfferingType?: String;
1147
+ /**
1148
+ * The maximum number of records to include in the response. If more records exist than the specified MaxRecords value, a marker is included in the response so that the remaining results can be retrieved.
1149
+ */
1150
+ MaxResults?: IntegerOptional;
1151
+ /**
1152
+ * An optional marker returned from a prior request. Use this marker for pagination of results from this operation. If this parameter is specified, the response includes only records beyond the marker, up to the value specified by MaxRecords.
1153
+ */
1154
+ NextToken?: String;
1155
+ }
1156
+ export interface DescribeReservedNodesResponse {
1157
+ /**
1158
+ * An optional marker returned from a prior request. Use this marker for pagination of results from this operation. If this parameter is specified, the response includes only records beyond the marker, up to the value specified by MaxRecords.
1159
+ */
1160
+ NextToken?: String;
1161
+ /**
1162
+ * Returns information about reserved nodes for this account, or about a specified reserved node.
1163
+ */
1164
+ ReservedNodes?: ReservedNodeList;
1165
+ }
1066
1166
  export interface DescribeServiceUpdatesRequest {
1067
1167
  /**
1068
1168
  * The unique ID of the service update to describe.
@@ -1385,12 +1485,121 @@ declare namespace MemoryDB {
1385
1485
  Status?: ServiceUpdateStatus;
1386
1486
  }
1387
1487
  export type PendingModifiedServiceUpdateList = PendingModifiedServiceUpdate[];
1488
+ export interface PurchaseReservedNodesOfferingRequest {
1489
+ /**
1490
+ * The ID of the reserved node offering to purchase.
1491
+ */
1492
+ ReservedNodesOfferingId: String;
1493
+ /**
1494
+ * A customer-specified identifier to track this reservation.
1495
+ */
1496
+ ReservationId?: String;
1497
+ /**
1498
+ * The number of node instances to reserve.
1499
+ */
1500
+ NodeCount?: IntegerOptional;
1501
+ /**
1502
+ * A list of tags to be added to this resource. A tag is a key-value pair. A tag key must be accompanied by a tag value, although null is accepted.
1503
+ */
1504
+ Tags?: TagList;
1505
+ }
1506
+ export interface PurchaseReservedNodesOfferingResponse {
1507
+ /**
1508
+ * Represents the output of a PurchaseReservedNodesOffering operation.
1509
+ */
1510
+ ReservedNode?: ReservedNode;
1511
+ }
1512
+ export interface RecurringCharge {
1513
+ /**
1514
+ * The amount of the recurring charge to run this reserved node.
1515
+ */
1516
+ RecurringChargeAmount?: Double;
1517
+ /**
1518
+ * The frequency of the recurring price charged to run this reserved node.
1519
+ */
1520
+ RecurringChargeFrequency?: String;
1521
+ }
1522
+ export type RecurringChargeList = RecurringCharge[];
1388
1523
  export interface ReplicaConfigurationRequest {
1389
1524
  /**
1390
1525
  * The number of replicas to scale up or down to
1391
1526
  */
1392
1527
  ReplicaCount?: Integer;
1393
1528
  }
1529
+ export interface ReservedNode {
1530
+ /**
1531
+ * A customer-specified identifier to track this reservation.
1532
+ */
1533
+ ReservationId?: String;
1534
+ /**
1535
+ * The ID of the reserved node offering to purchase.
1536
+ */
1537
+ ReservedNodesOfferingId?: String;
1538
+ /**
1539
+ * The node type for the reserved nodes.
1540
+ */
1541
+ NodeType?: String;
1542
+ /**
1543
+ * The time the reservation started.
1544
+ */
1545
+ StartTime?: TStamp;
1546
+ /**
1547
+ * The duration of the reservation in seconds.
1548
+ */
1549
+ Duration?: Integer;
1550
+ /**
1551
+ * The fixed price charged for this reserved node.
1552
+ */
1553
+ FixedPrice?: Double;
1554
+ /**
1555
+ * The number of nodes that have been reserved.
1556
+ */
1557
+ NodeCount?: Integer;
1558
+ /**
1559
+ * The offering type of this reserved node.
1560
+ */
1561
+ OfferingType?: String;
1562
+ /**
1563
+ * The state of the reserved node.
1564
+ */
1565
+ State?: String;
1566
+ /**
1567
+ * The recurring price charged to run this reserved node.
1568
+ */
1569
+ RecurringCharges?: RecurringChargeList;
1570
+ /**
1571
+ * The Amazon Resource Name (ARN) of the reserved node.
1572
+ */
1573
+ ARN?: String;
1574
+ }
1575
+ export type ReservedNodeList = ReservedNode[];
1576
+ export interface ReservedNodesOffering {
1577
+ /**
1578
+ * The offering identifier.
1579
+ */
1580
+ ReservedNodesOfferingId?: String;
1581
+ /**
1582
+ * The node type for the reserved nodes. For more information, see Supported node types.
1583
+ */
1584
+ NodeType?: String;
1585
+ /**
1586
+ * The duration of the reservation in seconds.
1587
+ */
1588
+ Duration?: Integer;
1589
+ /**
1590
+ * The fixed price charged for this reserved node.
1591
+ */
1592
+ FixedPrice?: Double;
1593
+ /**
1594
+ * The offering type of this reserved node.
1595
+ */
1596
+ OfferingType?: String;
1597
+ /**
1598
+ * The recurring price charged to run this reserved node.
1599
+ */
1600
+ RecurringCharges?: RecurringChargeList;
1601
+ }
1602
+ export type ReservedNodesOfferingList = ReservedNodesOffering[];
1394
1603
  export interface ResetParameterGroupRequest {
1395
1604
  /**
1396
1605
  * The name of the parameter group to reset.
@@ -83,7 +83,7 @@ return /******/ (function(modules) { // webpackBootstrap
83
83
  /**
84
84
  * @constant
85
85
  */
86
- VERSION: '2.1282.0',
86
+ VERSION: '2.1283.0',
87
87
 
88
88
  /**
89
89
  * @api private