cdk-assets 2.152.0 → 3.0.0-rc.0

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/LICENSE CHANGED
@@ -1,3 +1,4 @@
1
+
1
2
  Apache License
2
3
  Version 2.0, January 2004
3
4
  http://www.apache.org/licenses/
@@ -186,7 +187,7 @@
186
187
  same "printed page" as the copyright notice for easier
187
188
  identification within third-party archives.
188
189
 
189
- Copyright 2018-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
190
+ Copyright [yyyy] [name of copyright owner]
190
191
 
191
192
  Licensed under the Apache License, Version 2.0 (the "License");
192
193
  you may not use this file except in compliance with the License.
package/README.md CHANGED
@@ -1,15 +1,19 @@
1
1
  # cdk-assets
2
+
2
3
  <!--BEGIN STABILITY BANNER-->
3
4
 
4
5
  ---
5
6
 
6
- ![cdk-constructs: Stable](https://img.shields.io/badge/cdk--constructs-stable-success.svg?style=for-the-badge)
7
+ > V3 of cdk-assets is still under active development and is subject to non-backward compatible changes while
8
+ > being released with the `rc` suffix.
9
+ >
10
+ > These changes are not subject to the [Semantic Versioning](https://semver.org/) model and breaking changes
11
+ > will be announced in the release notes.
7
12
 
8
13
  ---
9
14
 
10
15
  <!--END STABILITY BANNER-->
11
16
 
12
-
13
17
  A tool for publishing CDK assets to AWS environments.
14
18
 
15
19
  ## Overview
@@ -21,9 +25,9 @@ the manifest.
21
25
 
22
26
  Currently the following asset types are supported:
23
27
 
24
- * Files and archives, uploaded to S3
25
- * Docker Images, uploaded to ECR
26
- * Files, archives, and Docker images built by external utilities
28
+ - Files and archives, uploaded to S3
29
+ - Docker Images, uploaded to ECR
30
+ - Files, archives, and Docker images built by external utilities
27
31
 
28
32
  S3 buckets and ECR repositories to upload to are expected to exist already.
29
33
 
@@ -31,9 +35,9 @@ We expect assets to be immutable, and we expect that immutability to be
31
35
  reflected both in the asset ID and in the destination location. This reflects
32
36
  itself in the following behaviors:
33
37
 
34
- * If the indicated asset already exists in the given destination location, it
38
+ - If the indicated asset already exists in the given destination location, it
35
39
  will not be packaged and uploaded.
36
- * If some locally cached artifact (depending on the asset type a file or an
40
+ - If some locally cached artifact (depending on the asset type a file or an
37
41
  image in the local Docker cache) already exists named after the asset's ID, it
38
42
  will not be packaged, but will be uploaded directly to the destination
39
43
  location.
@@ -49,7 +53,8 @@ asset, or the name of the local Docker image.
49
53
 
50
54
  The `cdk-asset` tool can be used programmatically and via the CLI. Use
51
55
  programmatic access if you need more control over authentication than the
52
- default [`aws-sdk`](https://github.com/aws/aws-sdk-js) implementation allows.
56
+ default [AWS SDK for JavaScript v3](https://github.com/aws/aws-sdk-js-v3)
57
+ implementation allows.
53
58
 
54
59
  Command-line use looks like this:
55
60
 
@@ -97,12 +102,12 @@ An asset manifest looks like this:
97
102
  "objectKey": "3dfe2b80b050e7e4e168f84feff678d4.zip"
98
103
  }
99
104
  }
100
- },
105
+ }
101
106
  },
102
107
  "dockerImages": {
103
108
  "b48783c58a86f7b8c68a4591c4f9be31": {
104
109
  "source": {
105
- "directory": "dockerdir",
110
+ "directory": "dockerdir"
106
111
  },
107
112
  "destinations": {
108
113
  "us-east-1": {
@@ -110,13 +115,13 @@ An asset manifest looks like this:
110
115
  "assumeRoleArn": "arn:aws:iam::12345789012:role/my-account",
111
116
  "repositoryName": "MyRepository",
112
117
  "imageTag": "b48783c58a86f7b8c68a4591c4f9be31",
113
- "imageUri": "123456789012.dkr.ecr.us-east-1.amazonaws.com/MyRepository:1234567891b48783c58a86f7b8c68a4591c4f9be31",
118
+ "imageUri": "123456789012.dkr.ecr.us-east-1.amazonaws.com/MyRepository:1234567891b48783c58a86f7b8c68a4591c4f9be31"
114
119
  }
115
120
  }
116
121
  },
117
122
  "d92753c58a86f7b8c68a4591c4f9cf28": {
118
123
  "source": {
119
- "executable": ["mytool", "package", "dockerdir"],
124
+ "executable": ["mytool", "package", "dockerdir"]
120
125
  },
121
126
  "destinations": {
122
127
  "us-east-1": {
@@ -124,7 +129,7 @@ An asset manifest looks like this:
124
129
  "assumeRoleArn": "arn:aws:iam::12345789012:role/my-account",
125
130
  "repositoryName": "MyRepository2",
126
131
  "imageTag": "d92753c58a86f7b8c68a4591c4f9cf28",
127
- "imageUri": "123456789987.dkr.ecr.us-east-1.amazonaws.com/MyRepository2:1234567891b48783c58a86f7b8c68a4591c4f9be31",
132
+ "imageUri": "123456789987.dkr.ecr.us-east-1.amazonaws.com/MyRepository2:1234567891b48783c58a86f7b8c68a4591c4f9be31"
128
133
  }
129
134
  }
130
135
  }
@@ -137,15 +142,15 @@ An asset manifest looks like this:
137
142
  The `destination` block of an asset manifest may contain the following region
138
143
  and account placeholders:
139
144
 
140
- * `${AWS::Region}`
141
- * `${AWS::AccountId}`
145
+ - `${AWS::Region}`
146
+ - `${AWS::AccountId}`
142
147
 
143
148
  These will be substituted with the region and account IDs currently configured
144
149
  on the AWS SDK (through environment variables or `~/.aws/...` config files).
145
150
 
146
- * The `${AWS::AccountId}` placeholder will *not* be re-evaluated after
151
+ - The `${AWS::AccountId}` placeholder will _not_ be re-evaluated after
147
152
  performing the `AssumeRole` call.
148
- * If `${AWS::Region}` is used, it will principally be replaced with the value
153
+ - If `${AWS::Region}` is used, it will principally be replaced with the value
149
154
  in the `region` key. If the default region is intended, leave the `region`
150
155
  key out of the manifest at all.
151
156
 
package/bin/cdk-assets.js CHANGED
@@ -23,12 +23,19 @@ async function main() {
23
23
  default: '.',
24
24
  requiresArg: true,
25
25
  })
26
- .command('ls', 'List assets from the given manifest', command => command, wrapHandler(async (args) => {
26
+ .command('ls', 'List assets from the given manifest', (command) => command, wrapHandler(async (args) => {
27
27
  await (0, list_1.list)(args);
28
28
  }))
29
- .command('publish [ASSET..]', 'Publish assets in the given manifest', command => command
30
- .option('profile', { type: 'string', describe: 'Profile to use from AWS Credentials file' })
31
- .positional('ASSET', { type: 'string', array: true, describe: 'Assets to publish (format: "ASSET[:DEST]"), default all' }), wrapHandler(async (args) => {
29
+ .command('publish [ASSET..]', 'Publish assets in the given manifest', (command) => command
30
+ .option('profile', {
31
+ type: 'string',
32
+ describe: 'Profile to use from AWS Credentials file',
33
+ })
34
+ .positional('ASSET', {
35
+ type: 'string',
36
+ array: true,
37
+ describe: 'Assets to publish (format: "ASSET[:DEST]"), default all',
38
+ }), wrapHandler(async (args) => {
32
39
  await (0, publish_1.publish)({
33
40
  path: args.path,
34
41
  assets: args.ASSET,
@@ -39,8 +46,7 @@ async function main() {
39
46
  .help()
40
47
  .strict() // Error on wrong command
41
48
  .version(logging_1.VERSION)
42
- .showHelpOnFail(false)
43
- .argv;
49
+ .showHelpOnFail(false).argv;
44
50
  // Evaluating .argv triggers the parsing but the command gets implicitly executed,
45
51
  // so we don't need the output.
46
52
  Array.isArray(argv);
@@ -56,9 +62,9 @@ function wrapHandler(handler) {
56
62
  await handler(argv);
57
63
  };
58
64
  }
59
- main().catch(e => {
65
+ main().catch((e) => {
60
66
  // eslint-disable-next-line no-console
61
67
  console.error(e.stack);
62
68
  process.exitCode = 1;
63
69
  });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLWFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNkay1hc3NldHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwrQkFBK0I7QUFDL0IsaUNBQThCO0FBQzlCLHVDQUFxRDtBQUNyRCx1Q0FBb0M7QUFDcEMsZ0NBQXVDO0FBRXZDLEtBQUssVUFBVSxJQUFJO0lBQ2pCLE1BQU0sSUFBSSxHQUFHLEtBQUs7U0FDZixLQUFLLENBQUMsaUJBQWlCLENBQUM7U0FDeEIsTUFBTSxDQUFDLFNBQVMsRUFBRTtRQUNqQixLQUFLLEVBQUUsR0FBRztRQUNWLElBQUksRUFBRSxTQUFTO1FBQ2YsSUFBSSxFQUFFLDRCQUE0QjtRQUNsQyxLQUFLLEVBQUUsSUFBSTtRQUNYLE9BQU8sRUFBRSxDQUFDO0tBQ1gsQ0FBQztTQUNELE1BQU0sQ0FBQyxNQUFNLEVBQUU7UUFDZCxLQUFLLEVBQUUsR0FBRztRQUNWLElBQUksRUFBRSxRQUFRO1FBQ2QsSUFBSSxFQUFFLHdFQUF3RTtZQUNoRixhQUFhLG1CQUFhLENBQUMsZ0JBQWdCLDJCQUEyQjtRQUNwRSxPQUFPLEVBQUUsR0FBRztRQUNaLFdBQVcsRUFBRSxJQUFJO0tBQ2xCLENBQUM7U0FDRCxPQUFPLENBQUMsSUFBSSxFQUFFLHFDQUFxQyxFQUFFLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUNwRSxXQUFXLENBQUMsS0FBSyxFQUFDLElBQUksRUFBQyxFQUFFO1FBQ3pCLE1BQU0sSUFBQSxXQUFJLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQUM7U0FDSixPQUFPLENBQUMsbUJBQW1CLEVBQUUsc0NBQXNDLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPO1NBQ3JGLE1BQU0sQ0FBQyxTQUFTLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSwwQ0FBMEMsRUFBRSxDQUFDO1NBQzNGLFVBQVUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLHlEQUF5RCxFQUFFLENBQUMsRUFDMUgsV0FBVyxDQUFDLEtBQUssRUFBQyxJQUFJLEVBQUMsRUFBRTtRQUN6QixNQUFNLElBQUEsaUJBQU8sRUFBQztZQUNaLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLE1BQU0sRUFBRSxJQUFJLENBQUMsS0FBSztZQUNsQixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87U0FDdEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7U0FDRixhQUFhLEVBQUU7U0FDZixJQUFJLEVBQUU7U0FDTixNQUFNLEVBQUUsQ0FBQyx5QkFBeUI7U0FDbEMsT0FBTyxDQUFDLGlCQUFPLENBQUM7U0FDaEIsY0FBYyxDQUFDLEtBQUssQ0FBQztTQUNyQixJQUFJLENBQUM7SUFFUixrRkFBa0Y7SUFDbEYsK0JBQStCO0lBQy9CLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7QUFDdEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBUyxXQUFXLENBQW9DLE9BQTZCO0lBQ25GLE9BQU8sS0FBSyxFQUFFLElBQU8sRUFBRSxFQUFFO1FBQ3ZCLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2pCLElBQUEseUJBQWUsRUFBQyxTQUFTLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQUVELElBQUksRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRTtJQUNmLHNDQUFzQztJQUN0QyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QixPQUFPLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQztBQUN2QixDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHlhcmdzIGZyb20gJ3lhcmdzJztcbmltcG9ydCB7IGxpc3QgfSBmcm9tICcuL2xpc3QnO1xuaW1wb3J0IHsgc2V0TG9nVGhyZXNob2xkLCBWRVJTSU9OIH0gZnJvbSAnLi9sb2dnaW5nJztcbmltcG9ydCB7IHB1Ymxpc2ggfSBmcm9tICcuL3B1Ymxpc2gnO1xuaW1wb3J0IHsgQXNzZXRNYW5pZmVzdCB9IGZyb20gJy4uL2xpYic7XG5cbmFzeW5jIGZ1bmN0aW9uIG1haW4oKSB7XG4gIGNvbnN0IGFyZ3YgPSB5YXJnc1xuICAgIC51c2FnZSgnJDAgPGNtZD4gW2FyZ3NdJylcbiAgICAub3B0aW9uKCd2ZXJib3NlJywge1xuICAgICAgYWxpYXM6ICd2JyxcbiAgICAgIHR5cGU6ICdib29sZWFuJyxcbiAgICAgIGRlc2M6ICdJbmNyZWFzZSBsb2dnaW5nIHZlcmJvc2l0eScsXG4gICAgICBjb3VudDogdHJ1ZSxcbiAgICAgIGRlZmF1bHQ6IDAsXG4gICAgfSlcbiAgICAub3B0aW9uKCdwYXRoJywge1xuICAgICAgYWxpYXM6ICdwJyxcbiAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgZGVzYzogJ1RoZSBwYXRoIChmaWxlIG9yIGRpcmVjdG9yeSkgdG8gbG9hZCB0aGUgYXNzZXRzIGZyb20uIElmIGEgZGlyZWN0b3J5LCAnICtcbiAgICBgdGhlIGZpbGUgJyR7QXNzZXRNYW5pZmVzdC5ERUZBVUxUX0ZJTEVOQU1FfScgd2lsbCBiZSBsb2FkZWQgZnJvbSBpdC5gLFxuICAgICAgZGVmYXVsdDogJy4nLFxuICAgICAgcmVxdWlyZXNBcmc6IHRydWUsXG4gICAgfSlcbiAgICAuY29tbWFuZCgnbHMnLCAnTGlzdCBhc3NldHMgZnJvbSB0aGUgZ2l2ZW4gbWFuaWZlc3QnLCBjb21tYW5kID0+IGNvbW1hbmRcbiAgICAgICwgd3JhcEhhbmRsZXIoYXN5bmMgYXJncyA9PiB7XG4gICAgICAgIGF3YWl0IGxpc3QoYXJncyk7XG4gICAgICB9KSlcbiAgICAuY29tbWFuZCgncHVibGlzaCBbQVNTRVQuLl0nLCAnUHVibGlzaCBhc3NldHMgaW4gdGhlIGdpdmVuIG1hbmlmZXN0JywgY29tbWFuZCA9PiBjb21tYW5kXG4gICAgICAub3B0aW9uKCdwcm9maWxlJywgeyB0eXBlOiAnc3RyaW5nJywgZGVzY3JpYmU6ICdQcm9maWxlIHRvIHVzZSBmcm9tIEFXUyBDcmVkZW50aWFscyBmaWxlJyB9KVxuICAgICAgLnBvc2l0aW9uYWwoJ0FTU0VUJywgeyB0eXBlOiAnc3RyaW5nJywgYXJyYXk6IHRydWUsIGRlc2NyaWJlOiAnQXNzZXRzIHRvIHB1Ymxpc2ggKGZvcm1hdDogXCJBU1NFVFs6REVTVF1cIiksIGRlZmF1bHQgYWxsJyB9KVxuICAgICwgd3JhcEhhbmRsZXIoYXN5bmMgYXJncyA9PiB7XG4gICAgICBhd2FpdCBwdWJsaXNoKHtcbiAgICAgICAgcGF0aDogYXJncy5wYXRoLFxuICAgICAgICBhc3NldHM6IGFyZ3MuQVNTRVQsXG4gICAgICAgIHByb2ZpbGU6IGFyZ3MucHJvZmlsZSxcbiAgICAgIH0pO1xuICAgIH0pKVxuICAgIC5kZW1hbmRDb21tYW5kKClcbiAgICAuaGVscCgpXG4gICAgLnN0cmljdCgpIC8vIEVycm9yIG9uIHdyb25nIGNvbW1hbmRcbiAgICAudmVyc2lvbihWRVJTSU9OKVxuICAgIC5zaG93SGVscE9uRmFpbChmYWxzZSlcbiAgICAuYXJndjtcblxuICAvLyBFdmFsdWF0aW5nIC5hcmd2IHRyaWdnZXJzIHRoZSBwYXJzaW5nIGJ1dCB0aGUgY29tbWFuZCBnZXRzIGltcGxpY2l0bHkgZXhlY3V0ZWQsXG4gIC8vIHNvIHdlIGRvbid0IG5lZWQgdGhlIG91dHB1dC5cbiAgQXJyYXkuaXNBcnJheShhcmd2KTtcbn1cblxuLyoqXG4gKiBXcmFwIGEgY29tbWFuZCdzIGhhbmRsZXIgd2l0aCBzdGFuZGFyZCBwcmUtIGFuZCBwb3N0LXdvcmtcbiAqL1xuZnVuY3Rpb24gd3JhcEhhbmRsZXI8QSBleHRlbmRzIHsgdmVyYm9zZT86IG51bWJlciB9LCBSPihoYW5kbGVyOiAoeDogQSkgPT4gUHJvbWlzZTxSPikge1xuICByZXR1cm4gYXN5bmMgKGFyZ3Y6IEEpID0+IHtcbiAgICBpZiAoYXJndi52ZXJib3NlKSB7XG4gICAgICBzZXRMb2dUaHJlc2hvbGQoJ3ZlcmJvc2UnKTtcbiAgICB9XG4gICAgYXdhaXQgaGFuZGxlcihhcmd2KTtcbiAgfTtcbn1cblxubWFpbigpLmNhdGNoKGUgPT4ge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmVycm9yKGUuc3RhY2spO1xuICBwcm9jZXNzLmV4aXRDb2RlID0gMTtcbn0pO1xuIl19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLWFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNkay1hc3NldHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwrQkFBK0I7QUFDL0IsaUNBQThCO0FBQzlCLHVDQUFxRDtBQUNyRCx1Q0FBb0M7QUFDcEMsZ0NBQXVDO0FBRXZDLEtBQUssVUFBVSxJQUFJO0lBQ2pCLE1BQU0sSUFBSSxHQUFHLEtBQUs7U0FDZixLQUFLLENBQUMsaUJBQWlCLENBQUM7U0FDeEIsTUFBTSxDQUFDLFNBQVMsRUFBRTtRQUNqQixLQUFLLEVBQUUsR0FBRztRQUNWLElBQUksRUFBRSxTQUFTO1FBQ2YsSUFBSSxFQUFFLDRCQUE0QjtRQUNsQyxLQUFLLEVBQUUsSUFBSTtRQUNYLE9BQU8sRUFBRSxDQUFDO0tBQ1gsQ0FBQztTQUNELE1BQU0sQ0FBQyxNQUFNLEVBQUU7UUFDZCxLQUFLLEVBQUUsR0FBRztRQUNWLElBQUksRUFBRSxRQUFRO1FBQ2QsSUFBSSxFQUNGLHdFQUF3RTtZQUN4RSxhQUFhLG1CQUFhLENBQUMsZ0JBQWdCLDJCQUEyQjtRQUN4RSxPQUFPLEVBQUUsR0FBRztRQUNaLFdBQVcsRUFBRSxJQUFJO0tBQ2xCLENBQUM7U0FDRCxPQUFPLENBQ04sSUFBSSxFQUNKLHFDQUFxQyxFQUNyQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxFQUNwQixXQUFXLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFO1FBQ3pCLE1BQU0sSUFBQSxXQUFJLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQ0g7U0FDQSxPQUFPLENBQ04sbUJBQW1CLEVBQ25CLHNDQUFzQyxFQUN0QyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQ1YsT0FBTztTQUNKLE1BQU0sQ0FBQyxTQUFTLEVBQUU7UUFDakIsSUFBSSxFQUFFLFFBQVE7UUFDZCxRQUFRLEVBQUUsMENBQTBDO0tBQ3JELENBQUM7U0FDRCxVQUFVLENBQUMsT0FBTyxFQUFFO1FBQ25CLElBQUksRUFBRSxRQUFRO1FBQ2QsS0FBSyxFQUFFLElBQUk7UUFDWCxRQUFRLEVBQUUseURBQXlEO0tBQ3BFLENBQUMsRUFDTixXQUFXLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFO1FBQ3pCLE1BQU0sSUFBQSxpQkFBTyxFQUFDO1lBQ1osSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsTUFBTSxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2xCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztTQUN0QixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FDSDtTQUNBLGFBQWEsRUFBRTtTQUNmLElBQUksRUFBRTtTQUNOLE1BQU0sRUFBRSxDQUFDLHlCQUF5QjtTQUNsQyxPQUFPLENBQUMsaUJBQU8sQ0FBQztTQUNoQixjQUFjLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBRTlCLGtGQUFrRjtJQUNsRiwrQkFBK0I7SUFDL0IsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUN0QixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLFdBQVcsQ0FBb0MsT0FBNkI7SUFDbkYsT0FBTyxLQUFLLEVBQUUsSUFBTyxFQUFFLEVBQUU7UUFDdkIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDakIsSUFBQSx5QkFBZSxFQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzdCLENBQUM7UUFDRCxNQUFNLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0QixDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDakIsc0NBQXNDO0lBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZCLE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgeWFyZ3MgZnJvbSAneWFyZ3MnO1xuaW1wb3J0IHsgbGlzdCB9IGZyb20gJy4vbGlzdCc7XG5pbXBvcnQgeyBzZXRMb2dUaHJlc2hvbGQsIFZFUlNJT04gfSBmcm9tICcuL2xvZ2dpbmcnO1xuaW1wb3J0IHsgcHVibGlzaCB9IGZyb20gJy4vcHVibGlzaCc7XG5pbXBvcnQgeyBBc3NldE1hbmlmZXN0IH0gZnJvbSAnLi4vbGliJztcblxuYXN5bmMgZnVuY3Rpb24gbWFpbigpIHtcbiAgY29uc3QgYXJndiA9IHlhcmdzXG4gICAgLnVzYWdlKCckMCA8Y21kPiBbYXJnc10nKVxuICAgIC5vcHRpb24oJ3ZlcmJvc2UnLCB7XG4gICAgICBhbGlhczogJ3YnLFxuICAgICAgdHlwZTogJ2Jvb2xlYW4nLFxuICAgICAgZGVzYzogJ0luY3JlYXNlIGxvZ2dpbmcgdmVyYm9zaXR5JyxcbiAgICAgIGNvdW50OiB0cnVlLFxuICAgICAgZGVmYXVsdDogMCxcbiAgICB9KVxuICAgIC5vcHRpb24oJ3BhdGgnLCB7XG4gICAgICBhbGlhczogJ3AnLFxuICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICBkZXNjOlxuICAgICAgICAnVGhlIHBhdGggKGZpbGUgb3IgZGlyZWN0b3J5KSB0byBsb2FkIHRoZSBhc3NldHMgZnJvbS4gSWYgYSBkaXJlY3RvcnksICcgK1xuICAgICAgICBgdGhlIGZpbGUgJyR7QXNzZXRNYW5pZmVzdC5ERUZBVUxUX0ZJTEVOQU1FfScgd2lsbCBiZSBsb2FkZWQgZnJvbSBpdC5gLFxuICAgICAgZGVmYXVsdDogJy4nLFxuICAgICAgcmVxdWlyZXNBcmc6IHRydWUsXG4gICAgfSlcbiAgICAuY29tbWFuZChcbiAgICAgICdscycsXG4gICAgICAnTGlzdCBhc3NldHMgZnJvbSB0aGUgZ2l2ZW4gbWFuaWZlc3QnLFxuICAgICAgKGNvbW1hbmQpID0+IGNvbW1hbmQsXG4gICAgICB3cmFwSGFuZGxlcihhc3luYyAoYXJncykgPT4ge1xuICAgICAgICBhd2FpdCBsaXN0KGFyZ3MpO1xuICAgICAgfSlcbiAgICApXG4gICAgLmNvbW1hbmQoXG4gICAgICAncHVibGlzaCBbQVNTRVQuLl0nLFxuICAgICAgJ1B1Ymxpc2ggYXNzZXRzIGluIHRoZSBnaXZlbiBtYW5pZmVzdCcsXG4gICAgICAoY29tbWFuZCkgPT5cbiAgICAgICAgY29tbWFuZFxuICAgICAgICAgIC5vcHRpb24oJ3Byb2ZpbGUnLCB7XG4gICAgICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgICAgICAgIGRlc2NyaWJlOiAnUHJvZmlsZSB0byB1c2UgZnJvbSBBV1MgQ3JlZGVudGlhbHMgZmlsZScsXG4gICAgICAgICAgfSlcbiAgICAgICAgICAucG9zaXRpb25hbCgnQVNTRVQnLCB7XG4gICAgICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgICAgICAgIGFycmF5OiB0cnVlLFxuICAgICAgICAgICAgZGVzY3JpYmU6ICdBc3NldHMgdG8gcHVibGlzaCAoZm9ybWF0OiBcIkFTU0VUWzpERVNUXVwiKSwgZGVmYXVsdCBhbGwnLFxuICAgICAgICAgIH0pLFxuICAgICAgd3JhcEhhbmRsZXIoYXN5bmMgKGFyZ3MpID0+IHtcbiAgICAgICAgYXdhaXQgcHVibGlzaCh7XG4gICAgICAgICAgcGF0aDogYXJncy5wYXRoLFxuICAgICAgICAgIGFzc2V0czogYXJncy5BU1NFVCxcbiAgICAgICAgICBwcm9maWxlOiBhcmdzLnByb2ZpbGUsXG4gICAgICAgIH0pO1xuICAgICAgfSlcbiAgICApXG4gICAgLmRlbWFuZENvbW1hbmQoKVxuICAgIC5oZWxwKClcbiAgICAuc3RyaWN0KCkgLy8gRXJyb3Igb24gd3JvbmcgY29tbWFuZFxuICAgIC52ZXJzaW9uKFZFUlNJT04pXG4gICAgLnNob3dIZWxwT25GYWlsKGZhbHNlKS5hcmd2O1xuXG4gIC8vIEV2YWx1YXRpbmcgLmFyZ3YgdHJpZ2dlcnMgdGhlIHBhcnNpbmcgYnV0IHRoZSBjb21tYW5kIGdldHMgaW1wbGljaXRseSBleGVjdXRlZCxcbiAgLy8gc28gd2UgZG9uJ3QgbmVlZCB0aGUgb3V0cHV0LlxuICBBcnJheS5pc0FycmF5KGFyZ3YpO1xufVxuXG4vKipcbiAqIFdyYXAgYSBjb21tYW5kJ3MgaGFuZGxlciB3aXRoIHN0YW5kYXJkIHByZS0gYW5kIHBvc3Qtd29ya1xuICovXG5mdW5jdGlvbiB3cmFwSGFuZGxlcjxBIGV4dGVuZHMgeyB2ZXJib3NlPzogbnVtYmVyIH0sIFI+KGhhbmRsZXI6ICh4OiBBKSA9PiBQcm9taXNlPFI+KSB7XG4gIHJldHVybiBhc3luYyAoYXJndjogQSkgPT4ge1xuICAgIGlmIChhcmd2LnZlcmJvc2UpIHtcbiAgICAgIHNldExvZ1RocmVzaG9sZCgndmVyYm9zZScpO1xuICAgIH1cbiAgICBhd2FpdCBoYW5kbGVyKGFyZ3YpO1xuICB9O1xufVxuXG5tYWluKCkuY2F0Y2goKGUpID0+IHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgY29uc29sZS5lcnJvcihlLnN0YWNrKTtcbiAgcHJvY2Vzcy5leGl0Q29kZSA9IDE7XG59KTtcbiJdfQ==
@@ -31,9 +31,9 @@ async function main() {
31
31
  // Write the credentials back to stdout
32
32
  fs.writeFileSync(1, JSON.stringify(credentials));
33
33
  }
34
- main().catch(e => {
34
+ main().catch((e) => {
35
35
  // eslint-disable-next-line no-console
36
36
  console.error(e.stack);
37
37
  process.exitCode = 1;
38
38
  });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2VyLWNyZWRlbnRpYWwtY2RrLWFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRvY2tlci1jcmVkZW50aWFsLWNkay1hc3NldHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7OztHQVdHOztBQUVILHlCQUF5QjtBQUN6QixnQ0FBMEM7QUFFMUMsMEVBQWdJO0FBRWhJLEtBQUssVUFBVSxJQUFJO0lBQ2pCLDRGQUE0RjtJQUM1RixrRUFBa0U7SUFDbEUsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLEVBQUUsQ0FBQztRQUMzRCxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xCLENBQUM7SUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFBLHlDQUFvQixHQUFFLENBQUM7SUFDdEMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQyw2Q0FBNkMsSUFBQSw2Q0FBd0IsR0FBRSxFQUFFLENBQUMsQ0FBQztJQUM3RixDQUFDO0lBRUQsc0NBQXNDO0lBQ3RDLElBQUksUUFBUSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEUsTUFBTSxXQUFXLEdBQUcsTUFBTSxJQUFBLGdEQUEyQixFQUFDLElBQUksc0JBQWdCLEVBQUUsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDaEcsdUNBQXVDO0lBQ3ZDLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztBQUNuRCxDQUFDO0FBRUQsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFO0lBQ2Ysc0NBQXNDO0lBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZCLE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEb2NrZXIgQ3JlZGVudGlhbCBIZWxwZXIgdG8gcmV0cmlldmUgY3JlZGVudGlhbHMgYmFzZWQgb24gYW4gZXh0ZXJuYWwgY29uZmlndXJhdGlvbiBmaWxlLlxuICogU3VwcG9ydHMgbG9hZGluZyBjcmVkZW50aWFscyBmcm9tIEVDUiByZXBvc2l0b3JpZXMgYW5kIGZyb20gU2VjcmV0cyBNYW5hZ2VyLFxuICogb3B0aW9uYWxseSB2aWEgYW4gYXNzdW1lZCByb2xlLlxuICpcbiAqIFRoZSBvbmx5IG9wZXJhdGlvbiBjdXJyZW50bHkgc3VwcG9ydGVkIGJ5IHRoaXMgY3JlZGVudGlhbCBoZWxwZXIgYXQgdGhpcyB0aW1lIGlzIHRoZSBgZ2V0YFxuICogY29tbWFuZCwgd2hpY2ggcmVjZWl2ZXMgYSBkb21haW4gbmFtZSBhcyBpbnB1dCBvbiBzdGRpbiBhbmQgcmV0dXJucyBhIFVzZXJuYW1lL1NlY3JldCBpblxuICogSlNPTiBmb3JtYXQgb24gc3Rkb3V0LlxuICpcbiAqIElNUE9SVEFOVCAtIFRoZSBjcmVkZW50aWFsIGhlbHBlciBtdXN0IG5vdCBvdXRwdXQgYW55dGhpbmcgZWxzZSBiZXNpZGVzIHRoZSBmaW5hbCBjcmVkZW50aWFsc1xuICogaW4gYW55IHN1Y2Nlc3MgY2FzZTsgZG9pbmcgc28gYnJlYWtzIGRvY2tlcidzIHBhcnNpbmcgb2YgdGhlIG91dHB1dCBhbmQgY2F1c2VzIHRoZSBsb2dpbiB0byBmYWlsLlxuICovXG5cbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCB7IERlZmF1bHRBd3NDbGllbnQgfSBmcm9tICcuLi9saWInO1xuXG5pbXBvcnQgeyBjZGtDcmVkZW50aWFsc0NvbmZpZywgY2RrQ3JlZGVudGlhbHNDb25maWdGaWxlLCBmZXRjaERvY2tlckxvZ2luQ3JlZGVudGlhbHMgfSBmcm9tICcuLi9saWIvcHJpdmF0ZS9kb2NrZXItY3JlZGVudGlhbHMnO1xuXG5hc3luYyBmdW5jdGlvbiBtYWluKCkge1xuICAvLyBFeHBlY3RlZCBpbnZvY2F0aW9uIGlzIFtub2RlLCBkb2NrZXItY3JlZGVudGlhbC1jZGstYXNzZXRzLCBnZXRdIHdpdGggaW5wdXQgZmVkIHZpYSBTVERJTlxuICAvLyBGb3Igb3RoZXIgdmFsaWQgZG9ja2VyIGNvbW1hbmRzIChzdG9yZSwgbGlzdCwgZXJhc2UpLCB3ZSBuby1vcC5cbiAgaWYgKHByb2Nlc3MuYXJndi5sZW5ndGggIT09IDMgfHwgcHJvY2Vzcy5hcmd2WzJdICE9PSAnZ2V0Jykge1xuICAgIHByb2Nlc3MuZXhpdCgwKTtcbiAgfVxuXG4gIGNvbnN0IGNvbmZpZyA9IGNka0NyZWRlbnRpYWxzQ29uZmlnKCk7XG4gIGlmICghY29uZmlnKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGB1bmFibGUgdG8gZmluZCBDREsgRG9ja2VyIGNyZWRlbnRpYWxzIGF0OiAke2Nka0NyZWRlbnRpYWxzQ29uZmlnRmlsZSgpfWApO1xuICB9XG5cbiAgLy8gUmVhZCB0aGUgZG9tYWluIHRvIGZldGNoIGZyb20gc3RkaW5cbiAgbGV0IGVuZHBvaW50ID0gZnMucmVhZEZpbGVTeW5jKDAsIHsgZW5jb2Rpbmc6ICd1dGYtOCcgfSkudHJpbSgpO1xuICBjb25zdCBjcmVkZW50aWFscyA9IGF3YWl0IGZldGNoRG9ja2VyTG9naW5DcmVkZW50aWFscyhuZXcgRGVmYXVsdEF3c0NsaWVudCgpLCBjb25maWcsIGVuZHBvaW50KTtcbiAgLy8gV3JpdGUgdGhlIGNyZWRlbnRpYWxzIGJhY2sgdG8gc3Rkb3V0XG4gIGZzLndyaXRlRmlsZVN5bmMoMSwgSlNPTi5zdHJpbmdpZnkoY3JlZGVudGlhbHMpKTtcbn1cblxubWFpbigpLmNhdGNoKGUgPT4ge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmVycm9yKGUuc3RhY2spO1xuICBwcm9jZXNzLmV4aXRDb2RlID0gMTtcbn0pO1xuIl19
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2VyLWNyZWRlbnRpYWwtY2RrLWFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRvY2tlci1jcmVkZW50aWFsLWNkay1hc3NldHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7OztHQVdHOztBQUVILHlCQUF5QjtBQUN6QixnQ0FBMEM7QUFFMUMsMEVBSTJDO0FBRTNDLEtBQUssVUFBVSxJQUFJO0lBQ2pCLDRGQUE0RjtJQUM1RixrRUFBa0U7SUFDbEUsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLEVBQUUsQ0FBQztRQUMzRCxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xCLENBQUM7SUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFBLHlDQUFvQixHQUFFLENBQUM7SUFDdEMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQyw2Q0FBNkMsSUFBQSw2Q0FBd0IsR0FBRSxFQUFFLENBQUMsQ0FBQztJQUM3RixDQUFDO0lBRUQsc0NBQXNDO0lBQ3RDLElBQUksUUFBUSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEUsTUFBTSxXQUFXLEdBQUcsTUFBTSxJQUFBLGdEQUEyQixFQUFDLElBQUksc0JBQWdCLEVBQUUsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDaEcsdUNBQXVDO0lBQ3ZDLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztBQUNuRCxDQUFDO0FBRUQsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDakIsc0NBQXNDO0lBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZCLE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEb2NrZXIgQ3JlZGVudGlhbCBIZWxwZXIgdG8gcmV0cmlldmUgY3JlZGVudGlhbHMgYmFzZWQgb24gYW4gZXh0ZXJuYWwgY29uZmlndXJhdGlvbiBmaWxlLlxuICogU3VwcG9ydHMgbG9hZGluZyBjcmVkZW50aWFscyBmcm9tIEVDUiByZXBvc2l0b3JpZXMgYW5kIGZyb20gU2VjcmV0cyBNYW5hZ2VyLFxuICogb3B0aW9uYWxseSB2aWEgYW4gYXNzdW1lZCByb2xlLlxuICpcbiAqIFRoZSBvbmx5IG9wZXJhdGlvbiBjdXJyZW50bHkgc3VwcG9ydGVkIGJ5IHRoaXMgY3JlZGVudGlhbCBoZWxwZXIgYXQgdGhpcyB0aW1lIGlzIHRoZSBgZ2V0YFxuICogY29tbWFuZCwgd2hpY2ggcmVjZWl2ZXMgYSBkb21haW4gbmFtZSBhcyBpbnB1dCBvbiBzdGRpbiBhbmQgcmV0dXJucyBhIFVzZXJuYW1lL1NlY3JldCBpblxuICogSlNPTiBmb3JtYXQgb24gc3Rkb3V0LlxuICpcbiAqIElNUE9SVEFOVCAtIFRoZSBjcmVkZW50aWFsIGhlbHBlciBtdXN0IG5vdCBvdXRwdXQgYW55dGhpbmcgZWxzZSBiZXNpZGVzIHRoZSBmaW5hbCBjcmVkZW50aWFsc1xuICogaW4gYW55IHN1Y2Nlc3MgY2FzZTsgZG9pbmcgc28gYnJlYWtzIGRvY2tlcidzIHBhcnNpbmcgb2YgdGhlIG91dHB1dCBhbmQgY2F1c2VzIHRoZSBsb2dpbiB0byBmYWlsLlxuICovXG5cbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCB7IERlZmF1bHRBd3NDbGllbnQgfSBmcm9tICcuLi9saWInO1xuXG5pbXBvcnQge1xuICBjZGtDcmVkZW50aWFsc0NvbmZpZyxcbiAgY2RrQ3JlZGVudGlhbHNDb25maWdGaWxlLFxuICBmZXRjaERvY2tlckxvZ2luQ3JlZGVudGlhbHMsXG59IGZyb20gJy4uL2xpYi9wcml2YXRlL2RvY2tlci1jcmVkZW50aWFscyc7XG5cbmFzeW5jIGZ1bmN0aW9uIG1haW4oKSB7XG4gIC8vIEV4cGVjdGVkIGludm9jYXRpb24gaXMgW25vZGUsIGRvY2tlci1jcmVkZW50aWFsLWNkay1hc3NldHMsIGdldF0gd2l0aCBpbnB1dCBmZWQgdmlhIFNURElOXG4gIC8vIEZvciBvdGhlciB2YWxpZCBkb2NrZXIgY29tbWFuZHMgKHN0b3JlLCBsaXN0LCBlcmFzZSksIHdlIG5vLW9wLlxuICBpZiAocHJvY2Vzcy5hcmd2Lmxlbmd0aCAhPT0gMyB8fCBwcm9jZXNzLmFyZ3ZbMl0gIT09ICdnZXQnKSB7XG4gICAgcHJvY2Vzcy5leGl0KDApO1xuICB9XG5cbiAgY29uc3QgY29uZmlnID0gY2RrQ3JlZGVudGlhbHNDb25maWcoKTtcbiAgaWYgKCFjb25maWcpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYHVuYWJsZSB0byBmaW5kIENESyBEb2NrZXIgY3JlZGVudGlhbHMgYXQ6ICR7Y2RrQ3JlZGVudGlhbHNDb25maWdGaWxlKCl9YCk7XG4gIH1cblxuICAvLyBSZWFkIHRoZSBkb21haW4gdG8gZmV0Y2ggZnJvbSBzdGRpblxuICBsZXQgZW5kcG9pbnQgPSBmcy5yZWFkRmlsZVN5bmMoMCwgeyBlbmNvZGluZzogJ3V0Zi04JyB9KS50cmltKCk7XG4gIGNvbnN0IGNyZWRlbnRpYWxzID0gYXdhaXQgZmV0Y2hEb2NrZXJMb2dpbkNyZWRlbnRpYWxzKG5ldyBEZWZhdWx0QXdzQ2xpZW50KCksIGNvbmZpZywgZW5kcG9pbnQpO1xuICAvLyBXcml0ZSB0aGUgY3JlZGVudGlhbHMgYmFjayB0byBzdGRvdXRcbiAgZnMud3JpdGVGaWxlU3luYygxLCBKU09OLnN0cmluZ2lmeShjcmVkZW50aWFscykpO1xufVxuXG5tYWluKCkuY2F0Y2goKGUpID0+IHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgY29uc29sZS5lcnJvcihlLnN0YWNrKTtcbiAgcHJvY2Vzcy5leGl0Q29kZSA9IDE7XG59KTtcbiJdfQ==
package/bin/list.js CHANGED
@@ -1,11 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.list = void 0;
3
+ exports.list = list;
4
4
  const lib_1 = require("../lib");
5
5
  async function list(args) {
6
6
  const manifest = lib_1.AssetManifest.fromPath(args.path);
7
7
  // eslint-disable-next-line no-console
8
8
  console.log(manifest.list().join('\n'));
9
9
  }
10
- exports.list = list;
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxpc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsZ0NBQXVDO0FBRWhDLEtBQUssVUFBVSxJQUFJLENBQUMsSUFFMUI7SUFDQyxNQUFNLFFBQVEsR0FBRyxtQkFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkQsc0NBQXNDO0lBQ3RDLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQzFDLENBQUM7QUFORCxvQkFNQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzc2V0TWFuaWZlc3QgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbGlzdChhcmdzOiB7XG4gIHBhdGg6IHN0cmluZztcbn0pIHtcbiAgY29uc3QgbWFuaWZlc3QgPSBBc3NldE1hbmlmZXN0LmZyb21QYXRoKGFyZ3MucGF0aCk7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gIGNvbnNvbGUubG9nKG1hbmlmZXN0Lmxpc3QoKS5qb2luKCdcXG4nKSk7XG59Il19
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxpc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxvQkFJQztBQU5ELGdDQUF1QztBQUVoQyxLQUFLLFVBQVUsSUFBSSxDQUFDLElBQXNCO0lBQy9DLE1BQU0sUUFBUSxHQUFHLG1CQUFhLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuRCxzQ0FBc0M7SUFDdEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDMUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzc2V0TWFuaWZlc3QgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbGlzdChhcmdzOiB7IHBhdGg6IHN0cmluZyB9KSB7XG4gIGNvbnN0IG1hbmlmZXN0ID0gQXNzZXRNYW5pZmVzdC5mcm9tUGF0aChhcmdzLnBhdGgpO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhtYW5pZmVzdC5saXN0KCkuam9pbignXFxuJykpO1xufVxuIl19
package/bin/logging.js CHANGED
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.log = exports.setLogThreshold = exports.VERSION = void 0;
3
+ exports.VERSION = void 0;
4
+ exports.setLogThreshold = setLogThreshold;
5
+ exports.log = log;
4
6
  const fs = require("fs");
5
7
  const path = require("path");
6
8
  let logThreshold = 'info';
@@ -13,12 +15,10 @@ const LOG_LEVELS = {
13
15
  function setLogThreshold(threshold) {
14
16
  logThreshold = threshold;
15
17
  }
16
- exports.setLogThreshold = setLogThreshold;
17
18
  function log(level, message) {
18
19
  if (LOG_LEVELS[level] >= LOG_LEVELS[logThreshold]) {
19
20
  // eslint-disable-next-line no-console
20
21
  console.error(`${level.padEnd(7, ' ')}: ${message}`);
21
22
  }
22
23
  }
23
- exports.log = log;
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUc3QixJQUFJLFlBQVksR0FBYSxNQUFNLENBQUM7QUFFdkIsUUFBQSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsRUFBRSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO0FBRTlILE1BQU0sVUFBVSxHQUE2QjtJQUMzQyxPQUFPLEVBQUUsQ0FBQztJQUNWLElBQUksRUFBRSxDQUFDO0lBQ1AsS0FBSyxFQUFFLENBQUM7Q0FDVCxDQUFDO0FBRUYsU0FBZ0IsZUFBZSxDQUFDLFNBQW1CO0lBQ2pELFlBQVksR0FBRyxTQUFTLENBQUM7QUFDM0IsQ0FBQztBQUZELDBDQUVDO0FBRUQsU0FBZ0IsR0FBRyxDQUFDLEtBQWUsRUFBRSxPQUFlO0lBQ2xELElBQUksVUFBVSxDQUFDLEtBQUssQ0FBQyxJQUFJLFVBQVUsQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUFDO1FBQ2xELHNDQUFzQztRQUN0QyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEtBQUssT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0FBQ0gsQ0FBQztBQUxELGtCQUtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuZXhwb3J0IHR5cGUgTG9nTGV2ZWwgPSAndmVyYm9zZScgfCAnaW5mbycgfCAnZXJyb3InO1xubGV0IGxvZ1RocmVzaG9sZDogTG9nTGV2ZWwgPSAnaW5mbyc7XG5cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gSlNPTi5wYXJzZShmcy5yZWFkRmlsZVN5bmMocGF0aC5qb2luKF9fZGlybmFtZSwgJy4uJywgJ3BhY2thZ2UuanNvbicpLCB7IGVuY29kaW5nOiAndXRmLTgnIH0pKS52ZXJzaW9uO1xuXG5jb25zdCBMT0dfTEVWRUxTOiBSZWNvcmQ8TG9nTGV2ZWwsIG51bWJlcj4gPSB7XG4gIHZlcmJvc2U6IDEsXG4gIGluZm86IDIsXG4gIGVycm9yOiAzLFxufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHNldExvZ1RocmVzaG9sZCh0aHJlc2hvbGQ6IExvZ0xldmVsKSB7XG4gIGxvZ1RocmVzaG9sZCA9IHRocmVzaG9sZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxvZyhsZXZlbDogTG9nTGV2ZWwsIG1lc3NhZ2U6IHN0cmluZykge1xuICBpZiAoTE9HX0xFVkVMU1tsZXZlbF0gPj0gTE9HX0xFVkVMU1tsb2dUaHJlc2hvbGRdKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICBjb25zb2xlLmVycm9yKGAke2xldmVsLnBhZEVuZCg3LCAnICcpfTogJHttZXNzYWdlfWApO1xuICB9XG59Il19
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBZ0JBLDBDQUVDO0FBRUQsa0JBS0M7QUF6QkQseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUc3QixJQUFJLFlBQVksR0FBYSxNQUFNLENBQUM7QUFFdkIsUUFBQSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FDL0IsRUFBRSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsY0FBYyxDQUFDLEVBQUUsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FDbkYsQ0FBQyxPQUFPLENBQUM7QUFFVixNQUFNLFVBQVUsR0FBNkI7SUFDM0MsT0FBTyxFQUFFLENBQUM7SUFDVixJQUFJLEVBQUUsQ0FBQztJQUNQLEtBQUssRUFBRSxDQUFDO0NBQ1QsQ0FBQztBQUVGLFNBQWdCLGVBQWUsQ0FBQyxTQUFtQjtJQUNqRCxZQUFZLEdBQUcsU0FBUyxDQUFDO0FBQzNCLENBQUM7QUFFRCxTQUFnQixHQUFHLENBQUMsS0FBZSxFQUFFLE9BQWU7SUFDbEQsSUFBSSxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksVUFBVSxDQUFDLFlBQVksQ0FBQyxFQUFFLENBQUM7UUFDbEQsc0NBQXNDO1FBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsS0FBSyxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuZXhwb3J0IHR5cGUgTG9nTGV2ZWwgPSAndmVyYm9zZScgfCAnaW5mbycgfCAnZXJyb3InO1xubGV0IGxvZ1RocmVzaG9sZDogTG9nTGV2ZWwgPSAnaW5mbyc7XG5cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gSlNPTi5wYXJzZShcbiAgZnMucmVhZEZpbGVTeW5jKHBhdGguam9pbihfX2Rpcm5hbWUsICcuLicsICdwYWNrYWdlLmpzb24nKSwgeyBlbmNvZGluZzogJ3V0Zi04JyB9KVxuKS52ZXJzaW9uO1xuXG5jb25zdCBMT0dfTEVWRUxTOiBSZWNvcmQ8TG9nTGV2ZWwsIG51bWJlcj4gPSB7XG4gIHZlcmJvc2U6IDEsXG4gIGluZm86IDIsXG4gIGVycm9yOiAzLFxufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHNldExvZ1RocmVzaG9sZCh0aHJlc2hvbGQ6IExvZ0xldmVsKSB7XG4gIGxvZ1RocmVzaG9sZCA9IHRocmVzaG9sZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxvZyhsZXZlbDogTG9nTGV2ZWwsIG1lc3NhZ2U6IHN0cmluZykge1xuICBpZiAoTE9HX0xFVkVMU1tsZXZlbF0gPj0gTE9HX0xFVkVMU1tsb2dUaHJlc2hvbGRdKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICBjb25zb2xlLmVycm9yKGAke2xldmVsLnBhZEVuZCg3LCAnICcpfTogJHttZXNzYWdlfWApO1xuICB9XG59XG4iXX0=
package/bin/publish.js CHANGED
@@ -1,13 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.publish = void 0;
3
+ exports.publish = publish;
4
4
  const logging_1 = require("./logging");
5
5
  const lib_1 = require("../lib");
6
6
  async function publish(args) {
7
7
  let manifest = lib_1.AssetManifest.fromPath(args.path);
8
8
  (0, logging_1.log)('verbose', `Loaded manifest from ${args.path}: ${manifest.entries.length} assets found`);
9
9
  if (args.assets && args.assets.length > 0) {
10
- const selection = args.assets.map(a => lib_1.DestinationPattern.parse(a));
10
+ const selection = args.assets.map((a) => lib_1.DestinationPattern.parse(a));
11
11
  manifest = manifest.select(selection);
12
12
  (0, logging_1.log)('verbose', `Applied selection: ${manifest.entries.length} assets selected.`);
13
13
  }
@@ -25,7 +25,6 @@ async function publish(args) {
25
25
  process.exitCode = 1;
26
26
  }
27
27
  }
28
- exports.publish = publish;
29
28
  const EVENT_TO_LEVEL = {
30
29
  build: 'verbose',
31
30
  cached: 'verbose',
@@ -42,4 +41,4 @@ class ConsoleProgress {
42
41
  (0, logging_1.log)(EVENT_TO_LEVEL[type], `[${event.percentComplete}%] ${type}: ${event.message}`);
43
42
  }
44
43
  }
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGlzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInB1Ymxpc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBQTBDO0FBQzFDLGdDQUdnQjtBQUVULEtBQUssVUFBVSxPQUFPLENBQUMsSUFJN0I7SUFFQyxJQUFJLFFBQVEsR0FBRyxtQkFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakQsSUFBQSxhQUFHLEVBQUMsU0FBUyxFQUFFLHdCQUF3QixJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVEsQ0FBQyxPQUFPLENBQUMsTUFBTSxlQUFlLENBQUMsQ0FBQztJQUU3RixJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDMUMsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyx3QkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwRSxRQUFRLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN0QyxJQUFBLGFBQUcsRUFBQyxTQUFTLEVBQUUsc0JBQXNCLFFBQVEsQ0FBQyxPQUFPLENBQUMsTUFBTSxtQkFBbUIsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxNQUFNLEdBQUcsR0FBRyxJQUFJLHFCQUFlLENBQUMsUUFBUSxFQUFFO1FBQ3hDLEdBQUcsRUFBRSxJQUFJLHNCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7UUFDdkMsZ0JBQWdCLEVBQUUsSUFBSSxlQUFlLEVBQUU7UUFDdkMsWUFBWSxFQUFFLEtBQUs7S0FDcEIsQ0FBQyxDQUFDO0lBRUgsTUFBTSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7SUFFcEIsSUFBSSxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsS0FBSyxNQUFNLE9BQU8sSUFBSSxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbkMsc0NBQXNDO1lBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakQsQ0FBQztRQUVELE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7QUFDSCxDQUFDO0FBL0JELDBCQStCQztBQUVELE1BQU0sY0FBYyxHQUFnQztJQUNsRCxLQUFLLEVBQUUsU0FBUztJQUNoQixNQUFNLEVBQUUsU0FBUztJQUNqQixLQUFLLEVBQUUsU0FBUztJQUNoQixLQUFLLEVBQUUsU0FBUztJQUNoQixJQUFJLEVBQUUsT0FBTztJQUNiLEtBQUssRUFBRSxTQUFTO0lBQ2hCLEtBQUssRUFBRSxNQUFNO0lBQ2IsT0FBTyxFQUFFLE1BQU07SUFDZixNQUFNLEVBQUUsU0FBUztDQUNsQixDQUFDO0FBRUYsTUFBTSxlQUFlO0lBQ1osY0FBYyxDQUFDLElBQWUsRUFBRSxLQUF1QjtRQUM1RCxJQUFBLGFBQUcsRUFBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxLQUFLLENBQUMsZUFBZSxNQUFNLElBQUksS0FBSyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUNyRixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2csIExvZ0xldmVsIH0gZnJvbSAnLi9sb2dnaW5nJztcbmltcG9ydCB7XG4gIEFzc2V0TWFuaWZlc3QsIEFzc2V0UHVibGlzaGluZywgRGVmYXVsdEF3c0NsaWVudCwgRGVzdGluYXRpb25QYXR0ZXJuLCBFdmVudFR5cGUsXG4gIElQdWJsaXNoUHJvZ3Jlc3MsIElQdWJsaXNoUHJvZ3Jlc3NMaXN0ZW5lcixcbn0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHB1Ymxpc2goYXJnczoge1xuICBwYXRoOiBzdHJpbmc7XG4gIGFzc2V0cz86IHN0cmluZ1tdO1xuICBwcm9maWxlPzogc3RyaW5nO1xufSkge1xuXG4gIGxldCBtYW5pZmVzdCA9IEFzc2V0TWFuaWZlc3QuZnJvbVBhdGgoYXJncy5wYXRoKTtcbiAgbG9nKCd2ZXJib3NlJywgYExvYWRlZCBtYW5pZmVzdCBmcm9tICR7YXJncy5wYXRofTogJHttYW5pZmVzdC5lbnRyaWVzLmxlbmd0aH0gYXNzZXRzIGZvdW5kYCk7XG5cbiAgaWYgKGFyZ3MuYXNzZXRzICYmIGFyZ3MuYXNzZXRzLmxlbmd0aCA+IDApIHtcbiAgICBjb25zdCBzZWxlY3Rpb24gPSBhcmdzLmFzc2V0cy5tYXAoYSA9PiBEZXN0aW5hdGlvblBhdHRlcm4ucGFyc2UoYSkpO1xuICAgIG1hbmlmZXN0ID0gbWFuaWZlc3Quc2VsZWN0KHNlbGVjdGlvbik7XG4gICAgbG9nKCd2ZXJib3NlJywgYEFwcGxpZWQgc2VsZWN0aW9uOiAke21hbmlmZXN0LmVudHJpZXMubGVuZ3RofSBhc3NldHMgc2VsZWN0ZWQuYCk7XG4gIH1cblxuICBjb25zdCBwdWIgPSBuZXcgQXNzZXRQdWJsaXNoaW5nKG1hbmlmZXN0LCB7XG4gICAgYXdzOiBuZXcgRGVmYXVsdEF3c0NsaWVudChhcmdzLnByb2ZpbGUpLFxuICAgIHByb2dyZXNzTGlzdGVuZXI6IG5ldyBDb25zb2xlUHJvZ3Jlc3MoKSxcbiAgICB0aHJvd09uRXJyb3I6IGZhbHNlLFxuICB9KTtcblxuICBhd2FpdCBwdWIucHVibGlzaCgpO1xuXG4gIGlmIChwdWIuaGFzRmFpbHVyZXMpIHtcbiAgICBmb3IgKGNvbnN0IGZhaWx1cmUgb2YgcHViLmZhaWx1cmVzKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS5lcnJvcignRmFpbHVyZTonLCBmYWlsdXJlLmVycm9yLnN0YWNrKTtcbiAgICB9XG5cbiAgICBwcm9jZXNzLmV4aXRDb2RlID0gMTtcbiAgfVxufVxuXG5jb25zdCBFVkVOVF9UT19MRVZFTDogUmVjb3JkPEV2ZW50VHlwZSwgTG9nTGV2ZWw+ID0ge1xuICBidWlsZDogJ3ZlcmJvc2UnLFxuICBjYWNoZWQ6ICd2ZXJib3NlJyxcbiAgY2hlY2s6ICd2ZXJib3NlJyxcbiAgZGVidWc6ICd2ZXJib3NlJyxcbiAgZmFpbDogJ2Vycm9yJyxcbiAgZm91bmQ6ICd2ZXJib3NlJyxcbiAgc3RhcnQ6ICdpbmZvJyxcbiAgc3VjY2VzczogJ2luZm8nLFxuICB1cGxvYWQ6ICd2ZXJib3NlJyxcbn07XG5cbmNsYXNzIENvbnNvbGVQcm9ncmVzcyBpbXBsZW1lbnRzIElQdWJsaXNoUHJvZ3Jlc3NMaXN0ZW5lciB7XG4gIHB1YmxpYyBvblB1Ymxpc2hFdmVudCh0eXBlOiBFdmVudFR5cGUsIGV2ZW50OiBJUHVibGlzaFByb2dyZXNzKTogdm9pZCB7XG4gICAgbG9nKEVWRU5UX1RPX0xFVkVMW3R5cGVdLCBgWyR7ZXZlbnQucGVyY2VudENvbXBsZXRlfSVdICR7dHlwZX06ICR7ZXZlbnQubWVzc2FnZX1gKTtcbiAgfVxufVxuIl19
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGlzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInB1Ymxpc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFXQSwwQkEwQkM7QUFyQ0QsdUNBQTBDO0FBQzFDLGdDQVFnQjtBQUVULEtBQUssVUFBVSxPQUFPLENBQUMsSUFBMkQ7SUFDdkYsSUFBSSxRQUFRLEdBQUcsbUJBQWEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2pELElBQUEsYUFBRyxFQUFDLFNBQVMsRUFBRSx3QkFBd0IsSUFBSSxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsT0FBTyxDQUFDLE1BQU0sZUFBZSxDQUFDLENBQUM7SUFFN0YsSUFBSSxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzFDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyx3QkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN0RSxRQUFRLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN0QyxJQUFBLGFBQUcsRUFBQyxTQUFTLEVBQUUsc0JBQXNCLFFBQVEsQ0FBQyxPQUFPLENBQUMsTUFBTSxtQkFBbUIsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxNQUFNLEdBQUcsR0FBRyxJQUFJLHFCQUFlLENBQUMsUUFBUSxFQUFFO1FBQ3hDLEdBQUcsRUFBRSxJQUFJLHNCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7UUFDdkMsZ0JBQWdCLEVBQUUsSUFBSSxlQUFlLEVBQUU7UUFDdkMsWUFBWSxFQUFFLEtBQUs7S0FDcEIsQ0FBQyxDQUFDO0lBRUgsTUFBTSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7SUFFcEIsSUFBSSxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsS0FBSyxNQUFNLE9BQU8sSUFBSSxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbkMsc0NBQXNDO1lBQ3RDLE9BQU8sQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakQsQ0FBQztRQUVELE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7QUFDSCxDQUFDO0FBRUQsTUFBTSxjQUFjLEdBQWdDO0lBQ2xELEtBQUssRUFBRSxTQUFTO0lBQ2hCLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEtBQUssRUFBRSxTQUFTO0lBQ2hCLEtBQUssRUFBRSxTQUFTO0lBQ2hCLElBQUksRUFBRSxPQUFPO0lBQ2IsS0FBSyxFQUFFLFNBQVM7SUFDaEIsS0FBSyxFQUFFLE1BQU07SUFDYixPQUFPLEVBQUUsTUFBTTtJQUNmLE1BQU0sRUFBRSxTQUFTO0NBQ2xCLENBQUM7QUFFRixNQUFNLGVBQWU7SUFDWixjQUFjLENBQUMsSUFBZSxFQUFFLEtBQXVCO1FBQzVELElBQUEsYUFBRyxFQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLEtBQUssQ0FBQyxlQUFlLE1BQU0sSUFBSSxLQUFLLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3JGLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGxvZywgTG9nTGV2ZWwgfSBmcm9tICcuL2xvZ2dpbmcnO1xuaW1wb3J0IHtcbiAgQXNzZXRNYW5pZmVzdCxcbiAgQXNzZXRQdWJsaXNoaW5nLFxuICBEZWZhdWx0QXdzQ2xpZW50LFxuICBEZXN0aW5hdGlvblBhdHRlcm4sXG4gIEV2ZW50VHlwZSxcbiAgSVB1Ymxpc2hQcm9ncmVzcyxcbiAgSVB1Ymxpc2hQcm9ncmVzc0xpc3RlbmVyLFxufSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcHVibGlzaChhcmdzOiB7IHBhdGg6IHN0cmluZzsgYXNzZXRzPzogc3RyaW5nW107IHByb2ZpbGU/OiBzdHJpbmcgfSkge1xuICBsZXQgbWFuaWZlc3QgPSBBc3NldE1hbmlmZXN0LmZyb21QYXRoKGFyZ3MucGF0aCk7XG4gIGxvZygndmVyYm9zZScsIGBMb2FkZWQgbWFuaWZlc3QgZnJvbSAke2FyZ3MucGF0aH06ICR7bWFuaWZlc3QuZW50cmllcy5sZW5ndGh9IGFzc2V0cyBmb3VuZGApO1xuXG4gIGlmIChhcmdzLmFzc2V0cyAmJiBhcmdzLmFzc2V0cy5sZW5ndGggPiAwKSB7XG4gICAgY29uc3Qgc2VsZWN0aW9uID0gYXJncy5hc3NldHMubWFwKChhKSA9PiBEZXN0aW5hdGlvblBhdHRlcm4ucGFyc2UoYSkpO1xuICAgIG1hbmlmZXN0ID0gbWFuaWZlc3Quc2VsZWN0KHNlbGVjdGlvbik7XG4gICAgbG9nKCd2ZXJib3NlJywgYEFwcGxpZWQgc2VsZWN0aW9uOiAke21hbmlmZXN0LmVudHJpZXMubGVuZ3RofSBhc3NldHMgc2VsZWN0ZWQuYCk7XG4gIH1cblxuICBjb25zdCBwdWIgPSBuZXcgQXNzZXRQdWJsaXNoaW5nKG1hbmlmZXN0LCB7XG4gICAgYXdzOiBuZXcgRGVmYXVsdEF3c0NsaWVudChhcmdzLnByb2ZpbGUpLFxuICAgIHByb2dyZXNzTGlzdGVuZXI6IG5ldyBDb25zb2xlUHJvZ3Jlc3MoKSxcbiAgICB0aHJvd09uRXJyb3I6IGZhbHNlLFxuICB9KTtcblxuICBhd2FpdCBwdWIucHVibGlzaCgpO1xuXG4gIGlmIChwdWIuaGFzRmFpbHVyZXMpIHtcbiAgICBmb3IgKGNvbnN0IGZhaWx1cmUgb2YgcHViLmZhaWx1cmVzKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS5lcnJvcignRmFpbHVyZTonLCBmYWlsdXJlLmVycm9yLnN0YWNrKTtcbiAgICB9XG5cbiAgICBwcm9jZXNzLmV4aXRDb2RlID0gMTtcbiAgfVxufVxuXG5jb25zdCBFVkVOVF9UT19MRVZFTDogUmVjb3JkPEV2ZW50VHlwZSwgTG9nTGV2ZWw+ID0ge1xuICBidWlsZDogJ3ZlcmJvc2UnLFxuICBjYWNoZWQ6ICd2ZXJib3NlJyxcbiAgY2hlY2s6ICd2ZXJib3NlJyxcbiAgZGVidWc6ICd2ZXJib3NlJyxcbiAgZmFpbDogJ2Vycm9yJyxcbiAgZm91bmQ6ICd2ZXJib3NlJyxcbiAgc3RhcnQ6ICdpbmZvJyxcbiAgc3VjY2VzczogJ2luZm8nLFxuICB1cGxvYWQ6ICd2ZXJib3NlJyxcbn07XG5cbmNsYXNzIENvbnNvbGVQcm9ncmVzcyBpbXBsZW1lbnRzIElQdWJsaXNoUHJvZ3Jlc3NMaXN0ZW5lciB7XG4gIHB1YmxpYyBvblB1Ymxpc2hFdmVudCh0eXBlOiBFdmVudFR5cGUsIGV2ZW50OiBJUHVibGlzaFByb2dyZXNzKTogdm9pZCB7XG4gICAgbG9nKEVWRU5UX1RPX0xFVkVMW3R5cGVdLCBgWyR7ZXZlbnQucGVyY2VudENvbXBsZXRlfSVdICR7dHlwZX06ICR7ZXZlbnQubWVzc2FnZX1gKTtcbiAgfVxufVxuIl19
@@ -53,10 +53,14 @@ class AssetManifest {
53
53
  if (selection === undefined) {
54
54
  return this;
55
55
  }
56
- const ret = { version: this.manifest.version, dockerImages: {}, files: {} };
56
+ const ret = {
57
+ version: this.manifest.version,
58
+ dockerImages: {},
59
+ files: {},
60
+ };
57
61
  for (const assetType of ASSET_TYPES) {
58
62
  for (const [assetId, asset] of Object.entries(this.manifest[assetType] || {})) {
59
- const filteredDestinations = filterDict(asset.destinations, (_, destId) => selection.some(sel => sel.matches(new DestinationIdentifier(assetId, destId))));
63
+ const filteredDestinations = filterDict(asset.destinations, (_, destId) => selection.some((sel) => sel.matches(new DestinationIdentifier(assetId, destId))));
60
64
  if (Object.keys(filteredDestinations).length > 0) {
61
65
  ret[assetType][assetId] = {
62
66
  ...asset,
@@ -198,7 +202,7 @@ class DestinationPattern {
198
202
  if (!s) {
199
203
  throw new Error('Empty string is not a valid destination identifier');
200
204
  }
201
- const parts = s.split(':').map(x => x !== '*' ? x : undefined);
205
+ const parts = s.split(':').map((x) => (x !== '*' ? x : undefined));
202
206
  if (parts.length === 1) {
203
207
  return new DestinationPattern(parts[0]);
204
208
  }
@@ -215,8 +219,8 @@ class DestinationPattern {
215
219
  * Whether or not this pattern matches the given identifier
216
220
  */
217
221
  matches(id) {
218
- return (this.assetId === undefined || this.assetId === id.assetId)
219
- && (this.destinationId === undefined || this.destinationId === id.destinationId);
222
+ return ((this.assetId === undefined || this.assetId === id.assetId) &&
223
+ (this.destinationId === undefined || this.destinationId === id.destinationId));
220
224
  }
221
225
  /**
222
226
  * Return a string representation for this asset identifier
@@ -238,4 +242,4 @@ function prefixTreeChars(xs, prefix = '') {
238
242
  }
239
243
  return ret;
240
244
  }
241
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-manifest.js","sourceRoot":"","sources":["asset-manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  AssetManifest as AssetManifestSchema, DockerImageDestination, DockerImageSource,\n  FileDestination, FileSource, Manifest,\n} from '@aws-cdk/cloud-assembly-schema';\n\n/**\n * A manifest of assets\n */\nexport class AssetManifest {\n  /**\n   * The default name of the asset manifest in a cdk.out directory\n   */\n  public static readonly DEFAULT_FILENAME = 'assets.json';\n\n  /**\n   * Load an asset manifest from the given file\n   */\n  public static fromFile(fileName: string) {\n    try {\n      const obj = Manifest.loadAssetManifest(fileName);\n      return new AssetManifest(path.dirname(fileName), obj);\n    } catch (e: any) {\n      throw new Error(`Canot read asset manifest '${fileName}': ${e.message}`);\n    }\n  }\n\n  /**\n   * Load an asset manifest from the given file or directory\n   *\n   * If the argument given is a directoy, the default asset file name will be used.\n   */\n  public static fromPath(filePath: string) {\n    let st;\n    try {\n      st = fs.statSync(filePath);\n    } catch (e: any) {\n      throw new Error(`Cannot read asset manifest at '${filePath}': ${e.message}`);\n    }\n    if (st.isDirectory()) {\n      return AssetManifest.fromFile(path.join(filePath, AssetManifest.DEFAULT_FILENAME));\n    }\n    return AssetManifest.fromFile(filePath);\n  }\n\n  /**\n   * The directory where the manifest was found\n   */\n  public readonly directory: string;\n\n  constructor(directory: string, private readonly manifest: AssetManifestSchema) {\n    this.directory = directory;\n  }\n\n  /**\n   * Select a subset of assets and destinations from this manifest.\n   *\n   * Only assets with at least 1 selected destination are retained.\n   *\n   * If selection is not given, everything is returned.\n   */\n  public select(selection?: DestinationPattern[]): AssetManifest {\n    if (selection === undefined) { return this; }\n\n    const ret: AssetManifestSchema & Required<Pick<AssetManifestSchema, AssetType>>\n     = { version: this.manifest.version, dockerImages: {}, files: {} };\n\n    for (const assetType of ASSET_TYPES) {\n      for (const [assetId, asset] of Object.entries(this.manifest[assetType] || {})) {\n        const filteredDestinations = filterDict(\n          asset.destinations,\n          (_, destId) => selection.some(sel => sel.matches(new DestinationIdentifier(assetId, destId))));\n\n        if (Object.keys(filteredDestinations).length > 0) {\n          ret[assetType][assetId] = {\n            ...asset,\n            destinations: filteredDestinations,\n          };\n        }\n      }\n    }\n\n    return new AssetManifest(this.directory, ret);\n  }\n\n  /**\n   * Describe the asset manifest as a list of strings\n   */\n  public list() {\n    return [\n      ...describeAssets('file', this.manifest.files || {}),\n      ...describeAssets('docker-image', this.manifest.dockerImages || {}),\n    ];\n\n    function describeAssets(type: string, assets: Record<string, { source: any; destinations: Record<string, any> }>) {\n      const ret = new Array<string>();\n      for (const [assetId, asset] of Object.entries(assets || {})) {\n        ret.push(`${assetId} ${type} ${JSON.stringify(asset.source)}`);\n\n        const destStrings = Object.entries(asset.destinations).map(([destId, dest]) => ` ${assetId}:${destId} ${JSON.stringify(dest)}`);\n        ret.push(...prefixTreeChars(destStrings, '  '));\n      }\n      return ret;\n    }\n  }\n\n  /**\n   * List of assets per destination\n   *\n   * Returns one asset for every publishable destination. Multiple asset\n   * destinations may share the same asset source.\n   */\n  public get entries(): IManifestEntry[] {\n    return [\n      ...makeEntries(this.manifest.files || {}, FileManifestEntry),\n      ...makeEntries(this.manifest.dockerImages || {}, DockerImageManifestEntry),\n    ];\n  }\n\n  /**\n   * List of file assets, splat out to destinations\n   */\n  public get files(): FileManifestEntry[] {\n    return makeEntries(this.manifest.files || {}, FileManifestEntry);\n  }\n}\n\nfunction makeEntries<A, B, C>(\n  assets: Record<string, { source: A; destinations: Record<string, B> }>,\n  ctor: new (id: DestinationIdentifier, source: A, destination: B) => C): C[] {\n\n  const ret = new Array<C>();\n  for (const [assetId, asset] of Object.entries(assets)) {\n    for (const [destId, destination] of Object.entries(asset.destinations)) {\n      ret.push(new ctor(new DestinationIdentifier(assetId, destId), asset.source, destination));\n    }\n  }\n  return ret;\n}\n\ntype AssetType = 'files' | 'dockerImages';\n\nconst ASSET_TYPES: AssetType[] = ['files', 'dockerImages'];\n\n/**\n * A single asset from an asset manifest'\n */\nexport interface IManifestEntry {\n  /**\n   * The identifier of the asset and its destination\n   */\n  readonly id: DestinationIdentifier;\n\n  /**\n   * The type of asset\n   */\n  readonly type: string;\n\n  /**\n   * Type-dependent source data\n   */\n  readonly genericSource: unknown;\n\n  /**\n   * Type-dependent destination data\n   */\n  readonly genericDestination: unknown;\n}\n\n/**\n * A manifest entry for a file asset\n */\nexport class FileManifestEntry implements IManifestEntry {\n  public readonly genericSource: unknown;\n  public readonly genericDestination: unknown;\n  public readonly type = 'file';\n\n  constructor(\n    /** Identifier for this asset */\n    public readonly id: DestinationIdentifier,\n    /** Source of the file asset */\n    public readonly source: FileSource,\n    /** Destination for the file asset */\n    public readonly destination: FileDestination,\n  ) {\n    this.genericSource = source;\n    this.genericDestination = destination;\n  }\n}\n\n/**\n * A manifest entry for a docker image asset\n */\nexport class DockerImageManifestEntry implements IManifestEntry {\n  public readonly genericSource: unknown;\n  public readonly genericDestination: unknown;\n  public readonly type = 'docker-image';\n\n  constructor(\n    /** Identifier for this asset */\n    public readonly id: DestinationIdentifier,\n    /** Source of the file asset */\n    public readonly source: DockerImageSource,\n    /** Destination for the file asset */\n    public readonly destination: DockerImageDestination,\n  ) {\n    this.genericSource = source;\n    this.genericDestination = destination;\n  }\n}\n\n/**\n * Identify an asset destination in an asset manifest\n *\n * When stringified, this will be a combination of the source\n * and destination IDs.\n */\nexport class DestinationIdentifier {\n  /**\n   * Identifies the asset, by source.\n   *\n   * The assetId will be the same between assets that represent\n   * the same physical file or image.\n   */\n  public readonly assetId: string;\n\n  /**\n   * Identifies the destination where this asset will be published\n   */\n  public readonly destinationId: string;\n\n  constructor(assetId: string, destinationId: string) {\n    this.assetId = assetId;\n    this.destinationId = destinationId;\n  }\n\n  /**\n   * Return a string representation for this asset identifier\n   */\n  public toString() {\n    return this.destinationId ? `${this.assetId}:${this.destinationId}` : this.assetId;\n  }\n}\n\nfunction filterDict<A>(xs: Record<string, A>, pred: (x: A, key: string) => boolean): Record<string, A> {\n  const ret: Record<string, A> = {};\n  for (const [key, value] of Object.entries(xs)) {\n    if (pred(value, key)) {\n      ret[key] = value;\n    }\n  }\n  return ret;\n}\n\n/**\n * A filter pattern for an destination identifier\n */\nexport class DestinationPattern {\n  /**\n   * Parse a ':'-separated string into an asset/destination identifier\n   */\n  public static parse(s: string) {\n    if (!s) { throw new Error('Empty string is not a valid destination identifier'); }\n    const parts = s.split(':').map(x => x !== '*' ? x : undefined);\n    if (parts.length === 1) { return new DestinationPattern(parts[0]); }\n    if (parts.length === 2) { return new DestinationPattern(parts[0] || undefined, parts[1] || undefined); }\n    throw new Error(`Asset identifier must contain at most 2 ':'-separated parts, got '${s}'`);\n  }\n\n  /**\n   * Identifies the asset, by source.\n   */\n  public readonly assetId?: string;\n\n  /**\n   * Identifies the destination where this asset will be published\n   */\n  public readonly destinationId?: string;\n\n  constructor(assetId?: string, destinationId?: string) {\n    this.assetId = assetId;\n    this.destinationId = destinationId;\n  }\n\n  /**\n   * Whether or not this pattern matches the given identifier\n   */\n  public matches(id: DestinationIdentifier) {\n    return (this.assetId === undefined || this.assetId === id.assetId)\n    && (this.destinationId === undefined || this.destinationId === id.destinationId);\n  }\n\n  /**\n   * Return a string representation for this asset identifier\n   */\n  public toString() {\n    return `${this.assetId ?? '*'}:${this.destinationId ?? '*'}`;\n  }\n}\n\n/**\n * Prefix box-drawing characters to make lines look like a hanging tree\n */\nfunction prefixTreeChars(xs: string[], prefix = '') {\n  const ret = new Array<string>();\n  for (let i = 0; i < xs.length; i++) {\n    const isLast = i === xs.length - 1;\n    const boxChar = isLast ? '└' : '├';\n    ret.push(`${prefix}${boxChar}${xs[i]}`);\n  }\n  return ret;\n}\n"]}
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-manifest.js","sourceRoot":"","sources":["asset-manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  AssetManifest as AssetManifestSchema,\n  DockerImageDestination,\n  DockerImageSource,\n  FileDestination,\n  FileSource,\n  Manifest,\n} from '@aws-cdk/cloud-assembly-schema';\n\n/**\n * A manifest of assets\n */\nexport class AssetManifest {\n  /**\n   * The default name of the asset manifest in a cdk.out directory\n   */\n  public static readonly DEFAULT_FILENAME = 'assets.json';\n\n  /**\n   * Load an asset manifest from the given file\n   */\n  public static fromFile(fileName: string) {\n    try {\n      const obj = Manifest.loadAssetManifest(fileName);\n      return new AssetManifest(path.dirname(fileName), obj);\n    } catch (e: any) {\n      throw new Error(`Canot read asset manifest '${fileName}': ${e.message}`);\n    }\n  }\n\n  /**\n   * Load an asset manifest from the given file or directory\n   *\n   * If the argument given is a directoy, the default asset file name will be used.\n   */\n  public static fromPath(filePath: string) {\n    let st;\n    try {\n      st = fs.statSync(filePath);\n    } catch (e: any) {\n      throw new Error(`Cannot read asset manifest at '${filePath}': ${e.message}`);\n    }\n    if (st.isDirectory()) {\n      return AssetManifest.fromFile(path.join(filePath, AssetManifest.DEFAULT_FILENAME));\n    }\n    return AssetManifest.fromFile(filePath);\n  }\n\n  /**\n   * The directory where the manifest was found\n   */\n  public readonly directory: string;\n\n  constructor(\n    directory: string,\n    private readonly manifest: AssetManifestSchema\n  ) {\n    this.directory = directory;\n  }\n\n  /**\n   * Select a subset of assets and destinations from this manifest.\n   *\n   * Only assets with at least 1 selected destination are retained.\n   *\n   * If selection is not given, everything is returned.\n   */\n  public select(selection?: DestinationPattern[]): AssetManifest {\n    if (selection === undefined) {\n      return this;\n    }\n\n    const ret: AssetManifestSchema & Required<Pick<AssetManifestSchema, AssetType>> = {\n      version: this.manifest.version,\n      dockerImages: {},\n      files: {},\n    };\n\n    for (const assetType of ASSET_TYPES) {\n      for (const [assetId, asset] of Object.entries(this.manifest[assetType] || {})) {\n        const filteredDestinations = filterDict(asset.destinations, (_, destId) =>\n          selection.some((sel) => sel.matches(new DestinationIdentifier(assetId, destId)))\n        );\n\n        if (Object.keys(filteredDestinations).length > 0) {\n          ret[assetType][assetId] = {\n            ...asset,\n            destinations: filteredDestinations,\n          };\n        }\n      }\n    }\n\n    return new AssetManifest(this.directory, ret);\n  }\n\n  /**\n   * Describe the asset manifest as a list of strings\n   */\n  public list() {\n    return [\n      ...describeAssets('file', this.manifest.files || {}),\n      ...describeAssets('docker-image', this.manifest.dockerImages || {}),\n    ];\n\n    function describeAssets(\n      type: string,\n      assets: Record<string, { source: any; destinations: Record<string, any> }>\n    ) {\n      const ret = new Array<string>();\n      for (const [assetId, asset] of Object.entries(assets || {})) {\n        ret.push(`${assetId} ${type} ${JSON.stringify(asset.source)}`);\n\n        const destStrings = Object.entries(asset.destinations).map(\n          ([destId, dest]) => ` ${assetId}:${destId} ${JSON.stringify(dest)}`\n        );\n        ret.push(...prefixTreeChars(destStrings, '  '));\n      }\n      return ret;\n    }\n  }\n\n  /**\n   * List of assets per destination\n   *\n   * Returns one asset for every publishable destination. Multiple asset\n   * destinations may share the same asset source.\n   */\n  public get entries(): IManifestEntry[] {\n    return [\n      ...makeEntries(this.manifest.files || {}, FileManifestEntry),\n      ...makeEntries(this.manifest.dockerImages || {}, DockerImageManifestEntry),\n    ];\n  }\n\n  /**\n   * List of file assets, splat out to destinations\n   */\n  public get files(): FileManifestEntry[] {\n    return makeEntries(this.manifest.files || {}, FileManifestEntry);\n  }\n}\n\nfunction makeEntries<A, B, C>(\n  assets: Record<string, { source: A; destinations: Record<string, B> }>,\n  ctor: new (id: DestinationIdentifier, source: A, destination: B) => C\n): C[] {\n  const ret = new Array<C>();\n  for (const [assetId, asset] of Object.entries(assets)) {\n    for (const [destId, destination] of Object.entries(asset.destinations)) {\n      ret.push(new ctor(new DestinationIdentifier(assetId, destId), asset.source, destination));\n    }\n  }\n  return ret;\n}\n\ntype AssetType = 'files' | 'dockerImages';\n\nconst ASSET_TYPES: AssetType[] = ['files', 'dockerImages'];\n\n/**\n * A single asset from an asset manifest'\n */\nexport interface IManifestEntry {\n  /**\n   * The identifier of the asset and its destination\n   */\n  readonly id: DestinationIdentifier;\n\n  /**\n   * The type of asset\n   */\n  readonly type: string;\n\n  /**\n   * Type-dependent source data\n   */\n  readonly genericSource: unknown;\n\n  /**\n   * Type-dependent destination data\n   */\n  readonly genericDestination: unknown;\n}\n\n/**\n * A manifest entry for a file asset\n */\nexport class FileManifestEntry implements IManifestEntry {\n  public readonly genericSource: unknown;\n  public readonly genericDestination: unknown;\n  public readonly type = 'file';\n\n  constructor(\n    /** Identifier for this asset */\n    public readonly id: DestinationIdentifier,\n    /** Source of the file asset */\n    public readonly source: FileSource,\n    /** Destination for the file asset */\n    public readonly destination: FileDestination\n  ) {\n    this.genericSource = source;\n    this.genericDestination = destination;\n  }\n}\n\n/**\n * A manifest entry for a docker image asset\n */\nexport class DockerImageManifestEntry implements IManifestEntry {\n  public readonly genericSource: unknown;\n  public readonly genericDestination: unknown;\n  public readonly type = 'docker-image';\n\n  constructor(\n    /** Identifier for this asset */\n    public readonly id: DestinationIdentifier,\n    /** Source of the file asset */\n    public readonly source: DockerImageSource,\n    /** Destination for the file asset */\n    public readonly destination: DockerImageDestination\n  ) {\n    this.genericSource = source;\n    this.genericDestination = destination;\n  }\n}\n\n/**\n * Identify an asset destination in an asset manifest\n *\n * When stringified, this will be a combination of the source\n * and destination IDs.\n */\nexport class DestinationIdentifier {\n  /**\n   * Identifies the asset, by source.\n   *\n   * The assetId will be the same between assets that represent\n   * the same physical file or image.\n   */\n  public readonly assetId: string;\n\n  /**\n   * Identifies the destination where this asset will be published\n   */\n  public readonly destinationId: string;\n\n  constructor(assetId: string, destinationId: string) {\n    this.assetId = assetId;\n    this.destinationId = destinationId;\n  }\n\n  /**\n   * Return a string representation for this asset identifier\n   */\n  public toString() {\n    return this.destinationId ? `${this.assetId}:${this.destinationId}` : this.assetId;\n  }\n}\n\nfunction filterDict<A>(\n  xs: Record<string, A>,\n  pred: (x: A, key: string) => boolean\n): Record<string, A> {\n  const ret: Record<string, A> = {};\n  for (const [key, value] of Object.entries(xs)) {\n    if (pred(value, key)) {\n      ret[key] = value;\n    }\n  }\n  return ret;\n}\n\n/**\n * A filter pattern for an destination identifier\n */\nexport class DestinationPattern {\n  /**\n   * Parse a ':'-separated string into an asset/destination identifier\n   */\n  public static parse(s: string) {\n    if (!s) {\n      throw new Error('Empty string is not a valid destination identifier');\n    }\n    const parts = s.split(':').map((x) => (x !== '*' ? x : undefined));\n    if (parts.length === 1) {\n      return new DestinationPattern(parts[0]);\n    }\n    if (parts.length === 2) {\n      return new DestinationPattern(parts[0] || undefined, parts[1] || undefined);\n    }\n    throw new Error(`Asset identifier must contain at most 2 ':'-separated parts, got '${s}'`);\n  }\n\n  /**\n   * Identifies the asset, by source.\n   */\n  public readonly assetId?: string;\n\n  /**\n   * Identifies the destination where this asset will be published\n   */\n  public readonly destinationId?: string;\n\n  constructor(assetId?: string, destinationId?: string) {\n    this.assetId = assetId;\n    this.destinationId = destinationId;\n  }\n\n  /**\n   * Whether or not this pattern matches the given identifier\n   */\n  public matches(id: DestinationIdentifier) {\n    return (\n      (this.assetId === undefined || this.assetId === id.assetId) &&\n      (this.destinationId === undefined || this.destinationId === id.destinationId)\n    );\n  }\n\n  /**\n   * Return a string representation for this asset identifier\n   */\n  public toString() {\n    return `${this.assetId ?? '*'}:${this.destinationId ?? '*'}`;\n  }\n}\n\n/**\n * Prefix box-drawing characters to make lines look like a hanging tree\n */\nfunction prefixTreeChars(xs: string[], prefix = '') {\n  const ret = new Array<string>();\n  for (let i = 0; i < xs.length; i++) {\n    const isLast = i === xs.length - 1;\n    const boxChar = isLast ? '└' : '├';\n    ret.push(`${prefix}${boxChar}${xs[i]}`);\n  }\n  return ret;\n}\n"]}
package/lib/aws.d.ts CHANGED
@@ -1,3 +1,6 @@
1
+ import { ECRClient } from '@aws-sdk/client-ecr';
2
+ import { CompleteMultipartUploadCommandOutput, PutObjectCommandInput, S3Client } from '@aws-sdk/client-s3';
3
+ import { SecretsManagerClient } from '@aws-sdk/client-secrets-manager';
1
4
  /**
2
5
  * AWS SDK operations required by Asset Publishing
3
6
  */
@@ -6,9 +9,10 @@ export interface IAws {
6
9
  discoverDefaultRegion(): Promise<string>;
7
10
  discoverCurrentAccount(): Promise<Account>;
8
11
  discoverTargetAccount(options: ClientOptions): Promise<Account>;
9
- s3Client(options: ClientOptions): Promise<AWS.S3>;
10
- ecrClient(options: ClientOptions): Promise<AWS.ECR>;
11
- secretsManagerClient(options: ClientOptions): Promise<AWS.SecretsManager>;
12
+ s3Client(options: ClientOptions): Promise<S3Client>;
13
+ ecrClient(options: ClientOptions): Promise<ECRClient>;
14
+ secretsManagerClient(options: ClientOptions): Promise<SecretsManagerClient>;
15
+ upload(params: PutObjectCommandInput, options?: ClientOptions): Promise<CompleteMultipartUploadCommandOutput>;
12
16
  }
13
17
  export interface ClientOptions {
14
18
  region?: string;
@@ -36,24 +40,18 @@ export interface Account {
36
40
  * AWS client using the AWS SDK for JS with no special configuration
37
41
  */
38
42
  export declare class DefaultAwsClient implements IAws {
39
- private readonly AWS;
43
+ private readonly profile?;
40
44
  private account?;
41
- constructor(profile?: string);
42
- s3Client(options: ClientOptions): Promise<import("aws-sdk").S3>;
43
- ecrClient(options: ClientOptions): Promise<import("aws-sdk").ECR>;
44
- secretsManagerClient(options: ClientOptions): Promise<import("aws-sdk").SecretsManager>;
45
+ private config;
46
+ constructor(profile?: string | undefined);
47
+ s3Client(options: ClientOptions): Promise<S3Client>;
48
+ upload(params: PutObjectCommandInput, options?: ClientOptions): Promise<CompleteMultipartUploadCommandOutput>;
49
+ ecrClient(options: ClientOptions): Promise<ECRClient>;
50
+ secretsManagerClient(options: ClientOptions): Promise<SecretsManagerClient>;
45
51
  discoverPartition(): Promise<string>;
46
52
  discoverDefaultRegion(): Promise<string>;
47
53
  discoverCurrentAccount(): Promise<Account>;
48
54
  discoverTargetAccount(options: ClientOptions): Promise<Account>;
55
+ private getAccount;
49
56
  private awsOptions;
50
- /**
51
- * Explicit manual AssumeRole call
52
- *
53
- * Necessary since I can't seem to get the built-in support for ChainableTemporaryCredentials to work.
54
- *
55
- * It needs an explicit configuration of `masterCredentials`, we need to put
56
- * a `DefaultCredentialProverChain()` in there but that is not possible.
57
- */
58
- private assumeRole;
59
57
  }