aws-cdk 2.50.0 → 2.51.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/THIRD_PARTY_LICENSES +5 -5
- package/build-info.json +2 -2
- package/lib/api/aws-auth/sdk-provider.js +22 -7
- package/lib/api/aws-auth/sdk.js +16 -5
- package/lib/cdk-toolkit.d.ts +24 -0
- package/lib/cdk-toolkit.js +33 -11
- package/lib/cli.js +9 -3
- package/lib/index.js +14357 -6065
- package/lib/init-templates/app/typescript/tsconfig.json +2 -2
- package/lib/init-templates/lib/typescript/tsconfig.json +2 -2
- package/lib/init-templates/sample-app/javascript/tsconfig.json +2 -4
- package/lib/init-templates/sample-app/typescript/tsconfig.json +2 -2
- package/lib/init.js +2 -7
- package/lib/settings.js +2 -1
- package/lib/util/tracing.d.ts +9 -0
- package/lib/util/tracing.js +59 -0
- package/package.json +14 -14
- package/test/api/fake-sts.d.ts +1 -0
- package/test/api/fake-sts.js +16 -13
- package/test/api/sdk-provider.test.js +10 -1
- package/test/cdk-toolkit.test.js +23 -1
- package/test/init.test.js +4 -4
package/test/api/fake-sts.js
CHANGED
|
@@ -96,19 +96,19 @@ class FakeSts {
|
|
|
96
96
|
}
|
|
97
97
|
handleRequest(mockRequest) {
|
|
98
98
|
const response = (() => {
|
|
99
|
+
const identity = this.identity(mockRequest);
|
|
99
100
|
switch (mockRequest.parsedBody.Action) {
|
|
100
101
|
case 'GetCallerIdentity':
|
|
101
|
-
return this.handleGetCallerIdentity(
|
|
102
|
+
return this.handleGetCallerIdentity(identity);
|
|
102
103
|
case 'AssumeRole':
|
|
103
|
-
return this.handleAssumeRole(mockRequest);
|
|
104
|
+
return this.handleAssumeRole(identity, mockRequest);
|
|
104
105
|
}
|
|
105
106
|
throw new Error(`Unrecognized Action in MockAwsHttp: ${mockRequest.parsedBody.Action}`);
|
|
106
107
|
})();
|
|
107
108
|
// console.log(mockRequest.parsedBody, '->', response);
|
|
108
109
|
return response;
|
|
109
110
|
}
|
|
110
|
-
handleGetCallerIdentity(
|
|
111
|
-
const identity = this.identity(mockRequest);
|
|
111
|
+
handleGetCallerIdentity(identity) {
|
|
112
112
|
return {
|
|
113
113
|
GetCallerIdentityResponse: {
|
|
114
114
|
_attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },
|
|
@@ -123,14 +123,8 @@ class FakeSts {
|
|
|
123
123
|
},
|
|
124
124
|
};
|
|
125
125
|
}
|
|
126
|
-
handleAssumeRole(mockRequest) {
|
|
127
|
-
|
|
128
|
-
const failureRequested = mockRequest.parsedBody.RoleArn.match(/<FAIL:([^>]+)>/);
|
|
129
|
-
if (failureRequested) {
|
|
130
|
-
const err = new Error(`STS failing by user request: ${failureRequested[1]}`);
|
|
131
|
-
err.code = failureRequested[1];
|
|
132
|
-
throw err;
|
|
133
|
-
}
|
|
126
|
+
handleAssumeRole(identity, mockRequest) {
|
|
127
|
+
this.checkForFailure(mockRequest.parsedBody.RoleArn);
|
|
134
128
|
this.assumedRoles.push({
|
|
135
129
|
roleArn: mockRequest.parsedBody.RoleArn,
|
|
136
130
|
roleSessionName: mockRequest.parsedBody.RoleSessionName,
|
|
@@ -172,8 +166,17 @@ class FakeSts {
|
|
|
172
166
|
},
|
|
173
167
|
};
|
|
174
168
|
}
|
|
169
|
+
checkForFailure(s) {
|
|
170
|
+
const failureRequested = s.match(/<FAIL:([^>]+)>/);
|
|
171
|
+
if (failureRequested) {
|
|
172
|
+
const err = new Error(`STS failing by user request: ${failureRequested[1]}`);
|
|
173
|
+
err.code = failureRequested[1];
|
|
174
|
+
throw err;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
175
177
|
identity(mockRequest) {
|
|
176
178
|
const keyId = this.accessKeyId(mockRequest);
|
|
179
|
+
this.checkForFailure(keyId);
|
|
177
180
|
const ret = this.identities[keyId];
|
|
178
181
|
if (!ret) {
|
|
179
182
|
throw new Error(`Unrecognized access key used: ${keyId}`);
|
|
@@ -203,4 +206,4 @@ function urldecode(body) {
|
|
|
203
206
|
}
|
|
204
207
|
return ret;
|
|
205
208
|
}
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fake-sts.js","sourceRoot":"","sources":["fake-sts.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nock from 'nock';\nimport * as uuid from 'uuid';\nimport * as xmlJs from 'xml-js';\n\ninterface RegisteredIdentity {\n  readonly account: string;\n  readonly arn: string;\n  readonly userId: string;\n}\n\ninterface RegisteredRole {\n  readonly account: string;\n  readonly allowedAccounts: string[];\n  readonly arn: string;\n  readonly roleName: string;\n}\n\ninterface AssumedRole {\n  readonly roleArn: string;\n  readonly serialNumber: string;\n  readonly tokenCode: string;\n  readonly roleSessionName: string;\n}\n\n/**\n * Class for mocking AWS HTTP Requests and pretending to be STS\n *\n * This is necessary for testing our authentication layer. Most other mocking\n * libraries don't consider as they mock functional methods which happen BEFORE\n * the SDK's HTTP/Authentication layer.\n *\n * Instead, we want to validate how we're setting up credentials for the\n * SDK, so we pretend to be the STS server and have an in-memory database\n * of users and roles.\n */\nexport class FakeSts {\n  public readonly assumedRoles = new Array<AssumedRole>();\n\n  private identities: Record<string, RegisteredIdentity> = {};\n  private roles: Record<string, RegisteredRole> = {};\n\n  constructor() {\n  }\n\n  /**\n   * Begin mocking\n   */\n  public begin() {\n    const self = this;\n\n    nock.disableNetConnect();\n    if (!nock.isActive()) {\n      nock.activate();\n    }\n    nock(/.*/).persist().post(/.*/).reply(function (this, uri, body, cb) {\n      const parsedBody = typeof body === 'string' ? urldecode(body) : body;\n\n      try {\n        const response = self.handleRequest({\n          uri,\n          host: this.req.headers.host,\n          parsedBody,\n          headers: this.req.headers,\n        });\n        cb(null, [200, xmlJs.js2xml(response, { compact: true })]);\n      } catch (e) {\n        cb(null, [400, xmlJs.js2xml({\n          ErrorResponse: {\n            _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n            Error: {\n              Type: 'Sender',\n              Code: e.code ?? 'Error',\n              Message: e.message,\n            },\n            RequestId: '1',\n          },\n        }, { compact: true })]);\n      }\n    });\n\n    // Scrub some environment variables that might be set if we're running on CodeBuild which will interfere with the tests.\n    delete process.env.AWS_PROFILE;\n    delete process.env.AWS_REGION;\n    delete process.env.AWS_DEFAULT_REGION;\n    delete process.env.AWS_ACCESS_KEY_ID;\n    delete process.env.AWS_SECRET_ACCESS_KEY;\n    delete process.env.AWS_SESSION_TOKEN;\n  }\n\n  /**\n   * Restore everything to normal\n   */\n  public restore() {\n    nock.restore(); // https://github.com/nock/nock/issues/1817\n    nock.cleanAll();\n    nock.enableNetConnect();\n  }\n\n  /**\n   * Register a user\n   */\n  public registerUser(account: string, accessKey: string, options: RegisterUserOptions = {}) {\n    const userName = options.name ?? `User${Object.keys(this.identities).length + 1 }`;\n\n    this.identities[accessKey] = {\n      account: account,\n      arn: `arn:${options.partition ?? 'aws'}:sts::${account}:user/${userName}`,\n      userId: `${accessKey}:${userName}`,\n    };\n  }\n\n  /**\n   * Register an assumable role\n   */\n  public registerRole(account: string, roleArn: string, options: RegisterRoleOptions = {}) {\n    const roleName = options.name ?? `Role${Object.keys(this.roles).length + 1 }`;\n\n    this.roles[roleArn] = {\n      allowedAccounts: options.allowedAccounts ?? [account],\n      arn: roleArn,\n      roleName,\n      account,\n    };\n  }\n\n  private handleRequest(mockRequest: MockRequest): Record<string, any> {\n    const response = (() => {\n      switch (mockRequest.parsedBody.Action) {\n        case 'GetCallerIdentity':\n          return this.handleGetCallerIdentity(mockRequest);\n\n        case 'AssumeRole':\n          return this.handleAssumeRole(mockRequest);\n      }\n\n      throw new Error(`Unrecognized Action in MockAwsHttp: ${mockRequest.parsedBody.Action}`);\n    })();\n    // console.log(mockRequest.parsedBody, '->', response);\n    return response;\n  }\n\n  private handleGetCallerIdentity(mockRequest: MockRequest): Record<string, any> {\n    const identity = this.identity(mockRequest);\n    return {\n      GetCallerIdentityResponse: {\n        _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n        GetCallerIdentityResult: {\n          Arn: identity.arn,\n          UserId: identity.userId,\n          Account: identity.account,\n        },\n        ResponseMetadata: {\n          RequestId: '1',\n        },\n      },\n    };\n  }\n\n  private handleAssumeRole(mockRequest: MockRequest): Record<string, any> {\n    const identity = this.identity(mockRequest);\n\n    const failureRequested = mockRequest.parsedBody.RoleArn.match(/<FAIL:([^>]+)>/);\n    if (failureRequested) {\n      const err = new Error(`STS failing by user request: ${failureRequested[1]}`);\n      (err as any).code = failureRequested[1];\n      throw err;\n    }\n\n    this.assumedRoles.push({\n      roleArn: mockRequest.parsedBody.RoleArn,\n      roleSessionName: mockRequest.parsedBody.RoleSessionName,\n      serialNumber: mockRequest.parsedBody.SerialNumber,\n      tokenCode: mockRequest.parsedBody.TokenCode,\n    });\n\n    const roleArn = mockRequest.parsedBody.RoleArn;\n    const targetRole = this.roles[roleArn];\n    if (!targetRole) {\n      throw new Error(`No such role: ${roleArn}`);\n    }\n\n    if (!targetRole.allowedAccounts.includes(identity.account)) {\n      throw new Error(`Identity from account: ${identity.account} not allowed to assume ${roleArn}, must be one of: ${targetRole.allowedAccounts}`);\n    }\n\n    const freshAccessKey = uuid.v4();\n\n    // Register a new \"user\" (identity) for this access key\n    this.registerUser(targetRole.account, freshAccessKey, {\n      name: `AssumedRole-${targetRole.roleName}-${identity.userId}`,\n    });\n\n    return {\n      AssumeRoleResponse: {\n        _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n        AssumeRoleResult: {\n          AssumedRoleUser: {\n            Arn: roleArn,\n            AssumedRoleId: `${freshAccessKey}:${targetRole.roleName}`,\n          },\n          Credentials: {\n            AccessKeyId: freshAccessKey,\n            SecretAccessKey: 'Secret',\n            SessionToken: 'Token',\n            Expiration: new Date(Date.now() + 3600 * 1000).toISOString(),\n          },\n          PackedPolicySize: 6,\n        },\n      },\n      ResponseMetadata: {\n        RequestId: '1',\n      },\n    };\n  }\n\n  private identity(mockRequest: MockRequest) {\n    const keyId = this.accessKeyId(mockRequest);\n    const ret = this.identities[keyId];\n    if (!ret) { throw new Error(`Unrecognized access key used: ${keyId}`); }\n    return ret;\n  }\n\n  /**\n   * Return the access key from a signed request\n   */\n  private accessKeyId(mockRequest: MockRequest): string {\n    // \"AWS4-HMAC-SHA256 Credential=(ab1a5e4c-ff41-4811-ac5f-6d1230f7aa90)access/20201210/eu-bla-5/sts/aws4_request, SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=9b31011173a7842fa372d4ef7c431c08f0b1514fdaf54145560a4db7ecd24529\"\n    const auth = mockRequest.headers.authorization;\n\n    const m = auth?.match(/Credential=([^\\/]+)/);\n    if (!m) { throw new Error(`No correct authorization header: ${auth}`); }\n    return m[1];\n  }\n}\n\nexport interface RegisterUserOptions {\n  readonly name?: string;\n  readonly partition?: string;\n}\n\nexport interface RegisterRoleOptions {\n  readonly allowedAccounts?: string[];\n  readonly name?: string;\n  readonly partition?: string;\n}\n\ninterface MockRequest {\n  readonly host: string;\n  readonly uri: string;\n  readonly headers: Record<string, string>;\n  readonly parsedBody: Record<string, string>;\n}\n\nfunction urldecode(body: string): Record<string, string> {\n  const parts = body.split('&');\n  const ret: Record<string, string> = {};\n  for (const part of parts) {\n    const [k, v] = part.split('=');\n    ret[decodeURIComponent(k)] = decodeURIComponent(v);\n  }\n  return ret;\n}\n"]}
|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fake-sts.js","sourceRoot":"","sources":["fake-sts.ts"],"names":[],"mappings":";;;AAAA,6BAA6B;AAC7B,6BAA6B;AAC7B,gCAAgC;AAsBhC;;;;;;;;;;GAUG;AACH,MAAa,OAAO;IAMlB;QALgB,iBAAY,GAAG,IAAI,KAAK,EAAe,CAAC;QAEhD,eAAU,GAAuC,EAAE,CAAC;QACpD,UAAK,GAAmC,EAAE,CAAC;IAGnD,CAAC;IAED;;OAEG;IACI,KAAK;QACV,MAAM,IAAI,GAAG,IAAI,CAAC;QAElB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE;YACpB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;QACD,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,UAAgB,GAAG,EAAE,IAAI,EAAE,EAAE;YACjE,MAAM,UAAU,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAErE,IAAI;gBACF,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC;oBAClC,GAAG;oBACH,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI;oBAC3B,UAAU;oBACV,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO;iBAC1B,CAAC,CAAC;gBACH,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;aAC5D;YAAC,OAAO,CAAC,EAAE;gBACV,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC;wBAC1B,aAAa,EAAE;4BACb,WAAW,EAAE,EAAE,KAAK,EAAE,2CAA2C,EAAE;4BACnE,KAAK,EAAE;gCACL,IAAI,EAAE,QAAQ;gCACd,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO;gCACvB,OAAO,EAAE,CAAC,CAAC,OAAO;6BACnB;4BACD,SAAS,EAAE,GAAG;yBACf;qBACF,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;QAEH,wHAAwH;QACxH,OAAO,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC;QAC/B,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC;QAC9B,OAAO,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC;QACtC,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QACrC,OAAO,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC;QACzC,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,2CAA2C;QAC3D,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,OAAe,EAAE,SAAiB,EAAE,UAA+B,EAAE;QACvF,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAE,EAAE,CAAC;QAEnF,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG;YAC3B,OAAO,EAAE,OAAO;YAChB,GAAG,EAAE,OAAO,OAAO,CAAC,SAAS,IAAI,KAAK,SAAS,OAAO,SAAS,QAAQ,EAAE;YACzE,MAAM,EAAE,GAAG,SAAS,IAAI,QAAQ,EAAE;SACnC,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,OAAe,EAAE,OAAe,EAAE,UAA+B,EAAE;QACrF,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,CAAE,EAAE,CAAC;QAE9E,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG;YACpB,eAAe,EAAE,OAAO,CAAC,eAAe,IAAI,CAAC,OAAO,CAAC;YACrD,GAAG,EAAE,OAAO;YACZ,QAAQ;YACR,OAAO;SACR,CAAC;IACJ,CAAC;IAEO,aAAa,CAAC,WAAwB;QAC5C,MAAM,QAAQ,GAAG,CAAC,GAAG,EAAE;YACrB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;YAE5C,QAAQ,WAAW,CAAC,UAAU,CAAC,MAAM,EAAE;gBACrC,KAAK,mBAAmB;oBACtB,OAAO,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,CAAC;gBAEhD,KAAK,YAAY;oBACf,OAAO,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;aACvD;YAED,MAAM,IAAI,KAAK,CAAC,uCAAuC,WAAW,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;QAC1F,CAAC,CAAC,EAAE,CAAC;QACL,uDAAuD;QACvD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,uBAAuB,CAAC,QAA4B;QAC1D,OAAO;YACL,yBAAyB,EAAE;gBACzB,WAAW,EAAE,EAAE,KAAK,EAAE,2CAA2C,EAAE;gBACnE,uBAAuB,EAAE;oBACvB,GAAG,EAAE,QAAQ,CAAC,GAAG;oBACjB,MAAM,EAAE,QAAQ,CAAC,MAAM;oBACvB,OAAO,EAAE,QAAQ,CAAC,OAAO;iBAC1B;gBACD,gBAAgB,EAAE;oBAChB,SAAS,EAAE,GAAG;iBACf;aACF;SACF,CAAC;IACJ,CAAC;IAEO,gBAAgB,CAAC,QAA4B,EAAE,WAAwB;QAC7E,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAErD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,OAAO,EAAE,WAAW,CAAC,UAAU,CAAC,OAAO;YACvC,eAAe,EAAE,WAAW,CAAC,UAAU,CAAC,eAAe;YACvD,YAAY,EAAE,WAAW,CAAC,UAAU,CAAC,YAAY;YACjD,SAAS,EAAE,WAAW,CAAC,UAAU,CAAC,SAAS;SAC5C,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC;QAC/C,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,iBAAiB,OAAO,EAAE,CAAC,CAAC;SAC7C;QAED,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YAC1D,MAAM,IAAI,KAAK,CAAC,0BAA0B,QAAQ,CAAC,OAAO,0BAA0B,OAAO,qBAAqB,UAAU,CAAC,eAAe,EAAE,CAAC,CAAC;SAC/I;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QAEjC,uDAAuD;QACvD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,EAAE;YACpD,IAAI,EAAE,eAAe,UAAU,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,EAAE;SAC9D,CAAC,CAAC;QAEH,OAAO;YACL,kBAAkB,EAAE;gBAClB,WAAW,EAAE,EAAE,KAAK,EAAE,2CAA2C,EAAE;gBACnE,gBAAgB,EAAE;oBAChB,eAAe,EAAE;wBACf,GAAG,EAAE,OAAO;wBACZ,aAAa,EAAE,GAAG,cAAc,IAAI,UAAU,CAAC,QAAQ,EAAE;qBAC1D;oBACD,WAAW,EAAE;wBACX,WAAW,EAAE,cAAc;wBAC3B,eAAe,EAAE,QAAQ;wBACzB,YAAY,EAAE,OAAO;wBACrB,UAAU,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,WAAW,EAAE;qBAC7D;oBACD,gBAAgB,EAAE,CAAC;iBACpB;aACF;YACD,gBAAgB,EAAE;gBAChB,SAAS,EAAE,GAAG;aACf;SACF,CAAC;IACJ,CAAC;IAEO,eAAe,CAAC,CAAS;QAC/B,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACnD,IAAI,gBAAgB,EAAE;YACpB,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,gCAAgC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC5E,GAAW,CAAC,IAAI,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACxC,MAAM,GAAG,CAAC;SACX;IACH,CAAC;IAEO,QAAQ,CAAC,WAAwB;QACvC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAE5B,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,GAAG,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,KAAK,EAAE,CAAC,CAAC;SAAE;QACxE,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,WAAwB;QAC1C,gPAAgP;QAChP,MAAM,IAAI,GAAG,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC;QAE/C,MAAM,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAC7C,IAAI,CAAC,CAAC,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,oCAAoC,IAAI,EAAE,CAAC,CAAC;SAAE;QACxE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACd,CAAC;CACF;AA3MD,0BA2MC;AAoBD,SAAS,SAAS,CAAC,IAAY;IAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC9B,MAAM,GAAG,GAA2B,EAAE,CAAC;IACvC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACxB,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC/B,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC;KACpD;IACD,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["import * as nock from 'nock';\nimport * as uuid from 'uuid';\nimport * as xmlJs from 'xml-js';\n\ninterface RegisteredIdentity {\n  readonly account: string;\n  readonly arn: string;\n  readonly userId: string;\n}\n\ninterface RegisteredRole {\n  readonly account: string;\n  readonly allowedAccounts: string[];\n  readonly arn: string;\n  readonly roleName: string;\n}\n\ninterface AssumedRole {\n  readonly roleArn: string;\n  readonly serialNumber: string;\n  readonly tokenCode: string;\n  readonly roleSessionName: string;\n}\n\n/**\n * Class for mocking AWS HTTP Requests and pretending to be STS\n *\n * This is necessary for testing our authentication layer. Most other mocking\n * libraries don't consider as they mock functional methods which happen BEFORE\n * the SDK's HTTP/Authentication layer.\n *\n * Instead, we want to validate how we're setting up credentials for the\n * SDK, so we pretend to be the STS server and have an in-memory database\n * of users and roles.\n */\nexport class FakeSts {\n  public readonly assumedRoles = new Array<AssumedRole>();\n\n  private identities: Record<string, RegisteredIdentity> = {};\n  private roles: Record<string, RegisteredRole> = {};\n\n  constructor() {\n  }\n\n  /**\n   * Begin mocking\n   */\n  public begin() {\n    const self = this;\n\n    nock.disableNetConnect();\n    if (!nock.isActive()) {\n      nock.activate();\n    }\n    nock(/.*/).persist().post(/.*/).reply(function (this, uri, body, cb) {\n      const parsedBody = typeof body === 'string' ? urldecode(body) : body;\n\n      try {\n        const response = self.handleRequest({\n          uri,\n          host: this.req.headers.host,\n          parsedBody,\n          headers: this.req.headers,\n        });\n        cb(null, [200, xmlJs.js2xml(response, { compact: true })]);\n      } catch (e) {\n        cb(null, [400, xmlJs.js2xml({\n          ErrorResponse: {\n            _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n            Error: {\n              Type: 'Sender',\n              Code: e.code ?? 'Error',\n              Message: e.message,\n            },\n            RequestId: '1',\n          },\n        }, { compact: true })]);\n      }\n    });\n\n    // Scrub some environment variables that might be set if we're running on CodeBuild which will interfere with the tests.\n    delete process.env.AWS_PROFILE;\n    delete process.env.AWS_REGION;\n    delete process.env.AWS_DEFAULT_REGION;\n    delete process.env.AWS_ACCESS_KEY_ID;\n    delete process.env.AWS_SECRET_ACCESS_KEY;\n    delete process.env.AWS_SESSION_TOKEN;\n  }\n\n  /**\n   * Restore everything to normal\n   */\n  public restore() {\n    nock.restore(); // https://github.com/nock/nock/issues/1817\n    nock.cleanAll();\n    nock.enableNetConnect();\n  }\n\n  /**\n   * Register a user\n   */\n  public registerUser(account: string, accessKey: string, options: RegisterUserOptions = {}) {\n    const userName = options.name ?? `User${Object.keys(this.identities).length + 1 }`;\n\n    this.identities[accessKey] = {\n      account: account,\n      arn: `arn:${options.partition ?? 'aws'}:sts::${account}:user/${userName}`,\n      userId: `${accessKey}:${userName}`,\n    };\n  }\n\n  /**\n   * Register an assumable role\n   */\n  public registerRole(account: string, roleArn: string, options: RegisterRoleOptions = {}) {\n    const roleName = options.name ?? `Role${Object.keys(this.roles).length + 1 }`;\n\n    this.roles[roleArn] = {\n      allowedAccounts: options.allowedAccounts ?? [account],\n      arn: roleArn,\n      roleName,\n      account,\n    };\n  }\n\n  private handleRequest(mockRequest: MockRequest): Record<string, any> {\n    const response = (() => {\n      const identity = this.identity(mockRequest);\n\n      switch (mockRequest.parsedBody.Action) {\n        case 'GetCallerIdentity':\n          return this.handleGetCallerIdentity(identity);\n\n        case 'AssumeRole':\n          return this.handleAssumeRole(identity, mockRequest);\n      }\n\n      throw new Error(`Unrecognized Action in MockAwsHttp: ${mockRequest.parsedBody.Action}`);\n    })();\n    // console.log(mockRequest.parsedBody, '->', response);\n    return response;\n  }\n\n  private handleGetCallerIdentity(identity: RegisteredIdentity): Record<string, any> {\n    return {\n      GetCallerIdentityResponse: {\n        _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n        GetCallerIdentityResult: {\n          Arn: identity.arn,\n          UserId: identity.userId,\n          Account: identity.account,\n        },\n        ResponseMetadata: {\n          RequestId: '1',\n        },\n      },\n    };\n  }\n\n  private handleAssumeRole(identity: RegisteredIdentity, mockRequest: MockRequest): Record<string, any> {\n    this.checkForFailure(mockRequest.parsedBody.RoleArn);\n\n    this.assumedRoles.push({\n      roleArn: mockRequest.parsedBody.RoleArn,\n      roleSessionName: mockRequest.parsedBody.RoleSessionName,\n      serialNumber: mockRequest.parsedBody.SerialNumber,\n      tokenCode: mockRequest.parsedBody.TokenCode,\n    });\n\n    const roleArn = mockRequest.parsedBody.RoleArn;\n    const targetRole = this.roles[roleArn];\n    if (!targetRole) {\n      throw new Error(`No such role: ${roleArn}`);\n    }\n\n    if (!targetRole.allowedAccounts.includes(identity.account)) {\n      throw new Error(`Identity from account: ${identity.account} not allowed to assume ${roleArn}, must be one of: ${targetRole.allowedAccounts}`);\n    }\n\n    const freshAccessKey = uuid.v4();\n\n    // Register a new \"user\" (identity) for this access key\n    this.registerUser(targetRole.account, freshAccessKey, {\n      name: `AssumedRole-${targetRole.roleName}-${identity.userId}`,\n    });\n\n    return {\n      AssumeRoleResponse: {\n        _attributes: { xmlns: 'https://sts.amazonaws.com/doc/2011-06-15/' },\n        AssumeRoleResult: {\n          AssumedRoleUser: {\n            Arn: roleArn,\n            AssumedRoleId: `${freshAccessKey}:${targetRole.roleName}`,\n          },\n          Credentials: {\n            AccessKeyId: freshAccessKey,\n            SecretAccessKey: 'Secret',\n            SessionToken: 'Token',\n            Expiration: new Date(Date.now() + 3600 * 1000).toISOString(),\n          },\n          PackedPolicySize: 6,\n        },\n      },\n      ResponseMetadata: {\n        RequestId: '1',\n      },\n    };\n  }\n\n  private checkForFailure(s: string) {\n    const failureRequested = s.match(/<FAIL:([^>]+)>/);\n    if (failureRequested) {\n      const err = new Error(`STS failing by user request: ${failureRequested[1]}`);\n      (err as any).code = failureRequested[1];\n      throw err;\n    }\n  }\n\n  private identity(mockRequest: MockRequest) {\n    const keyId = this.accessKeyId(mockRequest);\n    this.checkForFailure(keyId);\n\n    const ret = this.identities[keyId];\n    if (!ret) { throw new Error(`Unrecognized access key used: ${keyId}`); }\n    return ret;\n  }\n\n  /**\n   * Return the access key from a signed request\n   */\n  private accessKeyId(mockRequest: MockRequest): string {\n    // \"AWS4-HMAC-SHA256 Credential=(ab1a5e4c-ff41-4811-ac5f-6d1230f7aa90)access/20201210/eu-bla-5/sts/aws4_request, SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=9b31011173a7842fa372d4ef7c431c08f0b1514fdaf54145560a4db7ecd24529\"\n    const auth = mockRequest.headers.authorization;\n\n    const m = auth?.match(/Credential=([^\\/]+)/);\n    if (!m) { throw new Error(`No correct authorization header: ${auth}`); }\n    return m[1];\n  }\n}\n\nexport interface RegisterUserOptions {\n  readonly name?: string;\n  readonly partition?: string;\n}\n\nexport interface RegisterRoleOptions {\n  readonly allowedAccounts?: string[];\n  readonly name?: string;\n  readonly partition?: string;\n}\n\ninterface MockRequest {\n  readonly host: string;\n  readonly uri: string;\n  readonly headers: Record<string, string>;\n  readonly parsedBody: Record<string, string>;\n}\n\nfunction urldecode(body: string): Record<string, string> {\n  const parts = body.split('&');\n  const ret: Record<string, string> = {};\n  for (const part of parts) {\n    const [k, v] = part.split('=');\n    ret[decodeURIComponent(k)] = decodeURIComponent(v);\n  }\n  return ret;\n}\n"]}
|
|
@@ -470,6 +470,15 @@ describe('with intercepted network calls', () => {
|
|
|
470
470
|
// THEN
|
|
471
471
|
await expect(provider.defaultAccount()).resolves.toBe(undefined);
|
|
472
472
|
});
|
|
473
|
+
test('defaultAccount returns undefined, event if STS call fails with ExpiredToken', async () => {
|
|
474
|
+
// GIVEN
|
|
475
|
+
process.env.AWS_ACCESS_KEY_ID = `${uid}'<FAIL:ExpiredToken>'`;
|
|
476
|
+
process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';
|
|
477
|
+
// WHEN
|
|
478
|
+
const provider = await providerFromProfile(undefined);
|
|
479
|
+
// THEN
|
|
480
|
+
await expect(provider.defaultAccount()).resolves.toBe(undefined);
|
|
481
|
+
});
|
|
473
482
|
});
|
|
474
483
|
test('even when using a profile to assume another profile, STS calls goes through the proxy', async () => {
|
|
475
484
|
prepareCreds({
|
|
@@ -574,4 +583,4 @@ function isProfileRole(x) {
|
|
|
574
583
|
function providerFromProfile(profile) {
|
|
575
584
|
return aws_auth_1.SdkProvider.withAwsCliCompatibleDefaults({ ...defaultCredOptions, profile });
|
|
576
585
|
}
|
|
577
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sdk-provider.test.js","sourceRoot":"","sources":["sdk-provider.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as AWS from 'aws-sdk';\nimport type { ConfigurationOptions } from 'aws-sdk/lib/config-base';\nimport * as promptly from 'promptly';\nimport * as uuid from 'uuid';\nimport { ISDK, Mode, SDK, SdkProvider } from '../../lib/api/aws-auth';\nimport { PluginHost } from '../../lib/api/plugin';\nimport * as logging from '../../lib/logging';\nimport * as bockfs from '../bockfs';\nimport { withMocked } from '../util';\nimport { FakeSts, RegisterRoleOptions, RegisterUserOptions } from './fake-sts';\n\njest.mock('promptly', () => ({\n  prompt: jest.fn().mockResolvedValue('1234'),\n}));\n\nconst defaultCredOptions = {\n  ec2creds: false,\n  containerCreds: false,\n};\n\nlet uid: string;\nlet pluginQueried = false;\n\nbeforeEach(() => {\n  // Cache busters!\n  // We prefix everything with UUIDs because:\n  //\n  // - We have a cache from account# -> credentials\n  // - We have a cache from access key -> account\n  uid = `(${uuid.v4()})`;\n\n  logging.setLogLevel(logging.LogLevel.TRACE);\n\n  PluginHost.instance.credentialProviderSources.splice(0);\n  PluginHost.instance.credentialProviderSources.push({\n    isAvailable() { return Promise.resolve(true); },\n    canProvideCredentials(account) { return Promise.resolve(account === uniq('99999')); },\n    getProvider() {\n      pluginQueried = true;\n      return Promise.resolve(new AWS.Credentials({\n        accessKeyId: `${uid}plugin_key`,\n        secretAccessKey: 'plugin_secret',\n        sessionToken: 'plugin_token',\n      }));\n    },\n    name: 'test plugin',\n  });\n\n  // Make sure these point to nonexistant files to start, if we don't call\n  // prepare() then we don't accidentally want to fall back to system config.\n  process.env.AWS_CONFIG_FILE = '/dev/null';\n  process.env.AWS_SHARED_CREDENTIALS_FILE = '/dev/null';\n});\n\nafterEach(() => {\n  bockfs.restore();\n});\n\nfunction uniq(account: string) {\n  return `${uid}${account}`;\n}\n\nfunction env(account: string) {\n  return cxapi.EnvironmentUtils.make(account, 'def');\n}\n\ndescribe('with intercepted network calls', () => {\n  // Most tests will use intercepted network calls, except one test that tests\n  // that the right HTTP `Agent` is used.\n\n  let fakeSts: FakeSts;\n  beforeEach(() => {\n    fakeSts = new FakeSts();\n    fakeSts.begin();\n\n    // Make sure the KeyID returned by the plugin is recognized\n    fakeSts.registerUser(uniq('99999'), uniq('plugin_key'));\n  });\n\n  afterEach(() => {\n    fakeSts.restore();\n  });\n\n  // Set of tests where the CDK will not trigger assume-role\n  // (the INI file might still do assume-role)\n  describe('when CDK does not AssumeRole', () => {\n    test('uses default credentials by default', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          default: { aws_access_key_id: 'access', $account: '11111', $fakeStsOptions: { partition: 'aws-here' } },\n        },\n        config: {\n          default: { region: 'eu-bla-5' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-bla-5');\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('11111'), partition: 'aws-here' });\n\n      // Ask for a different region\n      const sdk = (await provider.forEnvironment({ ...env(uniq('11111')), region: 'rgn' }, Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('access'));\n      expect(sdk.currentRegion).toEqual('rgn');\n    });\n\n    test('throws if profile credentials are not for the right account', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          'profile boo': { aws_access_key_id: 'access', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile('boo');\n\n      await expect(provider.forEnvironment(env(uniq('some_account_#')), Mode.ForReading)).rejects.toThrow('Need to perform AWS calls');\n    });\n\n    test('use profile acct/region if agnostic env requested', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          default: { aws_access_key_id: 'access', $account: '11111' },\n        },\n        config: {\n          default: { region: 'eu-bla-5' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // THEN\n      const sdk = (await provider.forEnvironment(cxapi.EnvironmentUtils.make(cxapi.UNKNOWN_ACCOUNT, cxapi.UNKNOWN_REGION), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('access'));\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('11111'));\n      expect(sdk.currentRegion).toEqual('eu-bla-5');\n    });\n\n    test('passing profile skips EnvironmentCredentials', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          foo: { aws_access_key_id: 'access', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile('foo');\n\n      const environmentCredentialsPrototype = (new AWS.EnvironmentCredentials('AWS')).constructor.prototype;\n\n      await withMocked(environmentCredentialsPrototype, 'refresh', async (refresh) => {\n        refresh.mockImplementation((callback: (err?: Error) => void) => callback(new Error('This function should not have been called')));\n\n        // WHEN\n        expect((await provider.defaultAccount())?.accountId).toEqual(uniq('11111'));\n\n        expect(refresh).not.toHaveBeenCalled();\n      });\n    });\n\n    test('supports profile spread over config_file and credentials_file', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          foo: { aws_access_key_id: 'fooccess', $account: '22222' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile foo': { region: 'eu-west-1' },\n        },\n      });\n      const provider = await SdkProvider.withAwsCliCompatibleDefaults({ ...defaultCredOptions, profile: 'foo' });\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-west-1');\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('22222'), partition: 'aws' });\n\n      const sdk = (await provider.forEnvironment(env(uniq('22222')), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('fooccess'));\n    });\n\n    test('supports profile only in config_file', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile foo': { aws_access_key_id: 'fooccess', $account: '22222' },\n        },\n      });\n      const provider = await providerFromProfile('foo');\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-bla-5'); // Fall back to default config\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('22222'), partition: 'aws' });\n\n      const sdk = (await provider.forEnvironment(env(uniq('22222')), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('fooccess'));\n    });\n\n    test('can assume-role configured in config', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '11111' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile assumer': { region: 'us-east-2' },\n          'profile assumable': {\n            role_arn: 'arn:aws:iam::66666:role/Assumable',\n            source_profile: 'assumer',\n            $account: '66666',\n            $fakeStsOptions: { allowedAccounts: ['11111'] },\n          },\n        },\n      });\n      const provider = await providerFromProfile('assumable');\n\n      // WHEN\n      const sdk = (await provider.forEnvironment(env(uniq('66666')), Mode.ForReading)).sdk;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('66666'));\n    });\n\n    test('can assume role even if [default] profile is missing', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '22222' },\n          assumable: { role_arn: 'arn:aws:iam::12356789012:role/Assumable', source_profile: 'assumer', $account: '22222' },\n        },\n        config: {\n          'profile assumable': { region: 'eu-bla-5' },\n        },\n      });\n\n      // WHEN\n      const provider = await providerFromProfile('assumable');\n\n      // THEN\n      expect((await provider.defaultAccount())?.accountId).toEqual(uniq('22222'));\n    });\n\n    test('mfa_serial in profile will ask user for token', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '66666' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile assumer': { region: 'us-east-2' },\n          'profile mfa-role': {\n            role_arn: 'arn:aws:iam::66666:role/Assumable',\n            source_profile: 'assumer',\n            mfa_serial: 'arn:aws:iam::account:mfa/user',\n            $account: '66666',\n          },\n        },\n      });\n      const provider = await providerFromProfile('mfa-role');\n\n      const promptlyMockCalls = (promptly.prompt as jest.Mock).mock.calls.length;\n\n      // THEN\n      const sdk = (await provider.forEnvironment(env(uniq('66666')), Mode.ForReading)).sdk;\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('66666'));\n      expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n        roleArn: 'arn:aws:iam::66666:role/Assumable',\n        serialNumber: 'arn:aws:iam::account:mfa/user',\n        tokenCode: '1234',\n      }));\n\n      // Mock response was set to fail to make sure we don't call STS\n      // Make sure the MFA mock was called during this test\n      expect((promptly.prompt as jest.Mock).mock.calls.length).toBe(promptlyMockCalls + 1);\n    });\n  });\n\n  // For DefaultSynthesis we will do an assume-role after having gotten base credentials\n  describe('when CDK AssumeRoles', () => {\n    beforeEach(() => {\n      // All these tests share that 'arn:aws:role' is a role into account 88888 which can be assumed from 11111\n      fakeSts.registerRole(uniq('88888'), 'arn:aws:role', { allowedAccounts: [uniq('11111')] });\n    });\n\n    test('error we get from assuming a role is useful', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      const promise = provider.forEnvironment(env(uniq('88888')), Mode.ForReading, {\n        assumeRoleArn: 'doesnotexist.role.arn',\n      });\n\n      // THEN - error message contains both a helpful hint and the underlying AssumeRole message\n      await expect(promise).rejects.toThrow('(re)-bootstrap the environment');\n      await expect(promise).rejects.toThrow('doesnotexist.role.arn');\n    });\n\n    test('assuming a role sanitizes the username into the session name', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n\n      await withMocked(os, 'userInfo', async (userInfo) => {\n        userInfo.mockReturnValue({ username: 'skål', uid: 1, gid: 1, homedir: '/here', shell: '/bin/sh' });\n\n        // WHEN\n        const provider = await providerFromProfile(undefined);\n\n        const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n        await sdk.currentAccount();\n\n        // THEN\n        expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n          roleSessionName: 'aws-cdk-sk@l',\n        }));\n      });\n    });\n\n    test('assuming a role does not fail when OS username cannot be read', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n\n      await withMocked(os, 'userInfo', async (userInfo) => {\n        userInfo.mockImplementation(() => {\n          // SystemError thrown as documented: https://nodejs.org/docs/latest-v16.x/api/os.html#osuserinfooptions\n          throw new Error('SystemError on Linux: uv_os_get_passwd returned ENOENT. See #19401 issue.');\n        });\n\n        // WHEN\n        const provider = await providerFromProfile(undefined);\n\n        const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n        await sdk.currentAccount();\n\n        // THEN\n        expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n          roleSessionName: 'aws-cdk-noname',\n        }));\n      });\n    });\n\n    test('even if current credentials are for the wrong account, we will still use them to AssumeRole', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('88888'));\n    });\n\n    test('if AssumeRole fails but current credentials are for the right account, we will still use them', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '88888' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN - assumeRole fails because the role can only be assumed from account 11111\n      const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('88888'));\n    });\n\n    test('if AssumeRole fails because of ExpiredToken, then fail completely', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '88888' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN - assumeRole fails with a specific error\n      await expect(async () => {\n        await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: '<FAIL:ExpiredToken>' });\n      }).rejects.toThrow(/ExpiredToken/);\n    });\n  });\n\n  describe('Plugins', () => {\n    test('does not use plugins if current credentials are for expected account', async () => {\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('11111')), Mode.ForReading);\n      expect(pluginQueried).toEqual(false);\n    });\n\n    test('uses plugin for account 99999', async () => {\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading);\n      expect(pluginQueried).toEqual(true);\n    });\n\n    test('can assume role with credentials from plugin', async () => {\n      fakeSts.registerRole(uniq('99999'), 'arn:aws:iam::99999:role/Assumable');\n\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading, {\n        assumeRoleArn: 'arn:aws:iam::99999:role/Assumable',\n      });\n\n      expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n        roleArn: 'arn:aws:iam::99999:role/Assumable',\n      }));\n      expect(pluginQueried).toEqual(true);\n    });\n\n    test('even if AssumeRole fails but current credentials are from a plugin, we will still use them', async () => {\n      const provider = await providerFromProfile(undefined);\n      const sdk = (await provider.forEnvironment(env(uniq('99999')), Mode.ForReading, { assumeRoleArn: 'does:not:exist' })).sdk;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('99999'));\n    });\n\n    test('plugins are still queried even if current credentials are expired (or otherwise invalid)', async () => {\n      // GIVEN\n      process.env.AWS_ACCESS_KEY_ID = `${uid}akid`;\n      process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading);\n\n      // THEN\n      expect(pluginQueried).toEqual(true);\n    });\n  });\n\n  describe('support for credential_source', () => {\n    test('can assume role with ecs credentials', async () => {\n      return withMocked(AWS.ECSCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'EcsContainer', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n      });\n\n    });\n\n    test('can assume role with ec2 credentials', async () => {\n      return withMocked(AWS.EC2MetadataCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'Ec2InstanceMetadata', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n\n      });\n\n    });\n\n    test('can assume role with env credentials', async () => {\n      return withMocked(AWS.EnvironmentCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'Environment', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n      });\n    });\n\n    test('assume fails with unsupported credential_source', async () => {\n      // GIVEN\n      prepareCreds({\n        config: {\n          'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'unsupported', $account: '22222' },\n        },\n      });\n      const provider = await providerFromProfile('ecs');\n\n      // WHEN\n      const account = await provider.defaultAccount();\n\n      // THEN\n      expect(account?.accountId).toEqual(undefined);\n    });\n  });\n\n  test('defaultAccount returns undefined if STS call fails', async () => {\n    // GIVEN\n    process.env.AWS_ACCESS_KEY_ID = `${uid}akid`;\n    process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';\n\n    // WHEN\n    const provider = await providerFromProfile(undefined);\n\n    // THEN\n    await expect(provider.defaultAccount()).resolves.toBe(undefined);\n  });\n});\n\ntest('even when using a profile to assume another profile, STS calls goes through the proxy', async () => {\n  prepareCreds({\n    credentials: {\n      assumer: { aws_access_key_id: 'assumer' },\n    },\n    config: {\n      'default': { region: 'eu-bla-5' },\n      'profile assumable': { role_arn: 'arn:aws:iam::66666:role/Assumable', source_profile: 'assumer', $account: '66666' },\n      'profile assumer': { region: 'us-east-2' },\n    },\n  });\n\n  // Messy mocking\n  let called = false;\n  jest.mock('proxy-agent', () => {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    class FakeAgent extends require('https').Agent {\n      public addRequest(_: any, __: any) {\n        // FIXME: this error takes 6 seconds to be completely handled. It\n        // might be retries in the SDK somewhere, or something about the Node\n        // event loop. I've spent an hour trying to figure it out and I can't,\n        // and I gave up. We'll just have to live with this until someone gets\n        // inspired.\n        const error = new Error('ABORTED BY TEST');\n        (error as any).code = 'RequestAbortedError';\n        (error as any).retryable = false;\n        called = true;\n        throw error;\n      }\n    }\n    return FakeAgent;\n  });\n\n  // WHEN\n  const provider = await SdkProvider.withAwsCliCompatibleDefaults({\n    ...defaultCredOptions,\n    profile: 'assumable',\n    httpOptions: {\n      proxyAddress: 'http://DOESNTMATTER/',\n    },\n  });\n\n  await provider.defaultAccount();\n\n  // THEN -- the fake proxy agent got called, we don't care about the result\n  expect(called).toEqual(true);\n});\n\n/**\n * Use object hackery to get the credentials out of the SDK object\n */\nfunction sdkConfig(sdk: ISDK): ConfigurationOptions {\n  return (sdk as any).config;\n}\n\n/**\n * Fixture for SDK auth for this test suite\n *\n * Has knowledge of the cache buster, will write proper fake config files and\n * register users and roles in FakeSts at the same time.\n */\nfunction prepareCreds(options: PrepareCredsOptions) {\n  function convertSections(sections?: Record<string, ProfileUser | ProfileRole>) {\n    const ret = [];\n    for (const [profile, user] of Object.entries(sections ?? {})) {\n      ret.push(`[${profile}]`);\n\n      if (isProfileRole(user)) {\n        ret.push(`role_arn=${user.role_arn}`);\n        if ('source_profile' in user) {\n          ret.push(`source_profile=${user.source_profile}`);\n        }\n        if ('credential_source' in user) {\n          ret.push(`credential_source=${user.credential_source}`);\n        }\n        if (user.mfa_serial) {\n          ret.push(`mfa_serial=${user.mfa_serial}`);\n        }\n        options.fakeSts?.registerRole(uniq(user.$account ?? '00000'), user.role_arn, {\n          ...user.$fakeStsOptions,\n          allowedAccounts: user.$fakeStsOptions?.allowedAccounts?.map(uniq),\n        });\n      } else {\n        if (user.aws_access_key_id) {\n          ret.push(`aws_access_key_id=${uniq(user.aws_access_key_id)}`);\n          ret.push('aws_secret_access_key=secret');\n          options.fakeSts?.registerUser(uniq(user.$account ?? '00000'), uniq(user.aws_access_key_id), user.$fakeStsOptions);\n        }\n      }\n\n      if (user.region) {\n        ret.push(`region=${user.region}`);\n      }\n    }\n    return ret.join('\\n');\n  }\n\n  bockfs({\n    '/home/me/.bxt/credentials': convertSections(options.credentials),\n    '/home/me/.bxt/config': convertSections(options.config),\n  });\n\n  // Set environment variables that we want\n  process.env.AWS_CONFIG_FILE = bockfs.path('/home/me/.bxt/config');\n  process.env.AWS_SHARED_CREDENTIALS_FILE = bockfs.path('/home/me/.bxt/credentials');\n}\n\ninterface PrepareCredsOptions {\n  /**\n   * Write the aws/credentials file\n   */\n  readonly credentials?: Record<string, ProfileUser | ProfileRole>;\n\n  /**\n   * Write the aws/config file\n   */\n  readonly config?: Record<string, ProfileUser | ProfileRole>;\n\n  /**\n   * If given, add users to FakeSTS\n   */\n  readonly fakeSts?: FakeSts;\n}\n\ninterface ProfileUser {\n  readonly aws_access_key_id?: string;\n  readonly $account?: string;\n  readonly region?: string;\n  readonly $fakeStsOptions?: RegisterUserOptions;\n}\n\ntype ProfileRole = {\n  readonly role_arn: string;\n  readonly mfa_serial?: string;\n  readonly $account: string;\n  readonly region?: string;\n  readonly $fakeStsOptions?: RegisterRoleOptions;\n} & ({ readonly source_profile: string } | { readonly credential_source: string });\n\nfunction isProfileRole(x: ProfileUser | ProfileRole): x is ProfileRole {\n  return 'role_arn' in x;\n}\n\nfunction providerFromProfile(profile: string | undefined) {\n  return SdkProvider.withAwsCliCompatibleDefaults({ ...defaultCredOptions, profile });\n}\n"]}
|
|
586
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sdk-provider.test.js","sourceRoot":"","sources":["sdk-provider.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as AWS from 'aws-sdk';\nimport type { ConfigurationOptions } from 'aws-sdk/lib/config-base';\nimport * as promptly from 'promptly';\nimport * as uuid from 'uuid';\nimport { ISDK, Mode, SDK, SdkProvider } from '../../lib/api/aws-auth';\nimport { PluginHost } from '../../lib/api/plugin';\nimport * as logging from '../../lib/logging';\nimport * as bockfs from '../bockfs';\nimport { withMocked } from '../util';\nimport { FakeSts, RegisterRoleOptions, RegisterUserOptions } from './fake-sts';\n\njest.mock('promptly', () => ({\n  prompt: jest.fn().mockResolvedValue('1234'),\n}));\n\nconst defaultCredOptions = {\n  ec2creds: false,\n  containerCreds: false,\n};\n\nlet uid: string;\nlet pluginQueried = false;\n\nbeforeEach(() => {\n  // Cache busters!\n  // We prefix everything with UUIDs because:\n  //\n  // - We have a cache from account# -> credentials\n  // - We have a cache from access key -> account\n  uid = `(${uuid.v4()})`;\n\n  logging.setLogLevel(logging.LogLevel.TRACE);\n\n  PluginHost.instance.credentialProviderSources.splice(0);\n  PluginHost.instance.credentialProviderSources.push({\n    isAvailable() { return Promise.resolve(true); },\n    canProvideCredentials(account) { return Promise.resolve(account === uniq('99999')); },\n    getProvider() {\n      pluginQueried = true;\n      return Promise.resolve(new AWS.Credentials({\n        accessKeyId: `${uid}plugin_key`,\n        secretAccessKey: 'plugin_secret',\n        sessionToken: 'plugin_token',\n      }));\n    },\n    name: 'test plugin',\n  });\n\n  // Make sure these point to nonexistant files to start, if we don't call\n  // prepare() then we don't accidentally want to fall back to system config.\n  process.env.AWS_CONFIG_FILE = '/dev/null';\n  process.env.AWS_SHARED_CREDENTIALS_FILE = '/dev/null';\n});\n\nafterEach(() => {\n  bockfs.restore();\n});\n\nfunction uniq(account: string) {\n  return `${uid}${account}`;\n}\n\nfunction env(account: string) {\n  return cxapi.EnvironmentUtils.make(account, 'def');\n}\n\ndescribe('with intercepted network calls', () => {\n  // Most tests will use intercepted network calls, except one test that tests\n  // that the right HTTP `Agent` is used.\n\n  let fakeSts: FakeSts;\n  beforeEach(() => {\n    fakeSts = new FakeSts();\n    fakeSts.begin();\n\n    // Make sure the KeyID returned by the plugin is recognized\n    fakeSts.registerUser(uniq('99999'), uniq('plugin_key'));\n  });\n\n  afterEach(() => {\n    fakeSts.restore();\n  });\n\n  // Set of tests where the CDK will not trigger assume-role\n  // (the INI file might still do assume-role)\n  describe('when CDK does not AssumeRole', () => {\n    test('uses default credentials by default', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          default: { aws_access_key_id: 'access', $account: '11111', $fakeStsOptions: { partition: 'aws-here' } },\n        },\n        config: {\n          default: { region: 'eu-bla-5' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-bla-5');\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('11111'), partition: 'aws-here' });\n\n      // Ask for a different region\n      const sdk = (await provider.forEnvironment({ ...env(uniq('11111')), region: 'rgn' }, Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('access'));\n      expect(sdk.currentRegion).toEqual('rgn');\n    });\n\n    test('throws if profile credentials are not for the right account', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          'profile boo': { aws_access_key_id: 'access', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile('boo');\n\n      await expect(provider.forEnvironment(env(uniq('some_account_#')), Mode.ForReading)).rejects.toThrow('Need to perform AWS calls');\n    });\n\n    test('use profile acct/region if agnostic env requested', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          default: { aws_access_key_id: 'access', $account: '11111' },\n        },\n        config: {\n          default: { region: 'eu-bla-5' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // THEN\n      const sdk = (await provider.forEnvironment(cxapi.EnvironmentUtils.make(cxapi.UNKNOWN_ACCOUNT, cxapi.UNKNOWN_REGION), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('access'));\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('11111'));\n      expect(sdk.currentRegion).toEqual('eu-bla-5');\n    });\n\n    test('passing profile skips EnvironmentCredentials', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          foo: { aws_access_key_id: 'access', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile('foo');\n\n      const environmentCredentialsPrototype = (new AWS.EnvironmentCredentials('AWS')).constructor.prototype;\n\n      await withMocked(environmentCredentialsPrototype, 'refresh', async (refresh) => {\n        refresh.mockImplementation((callback: (err?: Error) => void) => callback(new Error('This function should not have been called')));\n\n        // WHEN\n        expect((await provider.defaultAccount())?.accountId).toEqual(uniq('11111'));\n\n        expect(refresh).not.toHaveBeenCalled();\n      });\n    });\n\n    test('supports profile spread over config_file and credentials_file', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          foo: { aws_access_key_id: 'fooccess', $account: '22222' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile foo': { region: 'eu-west-1' },\n        },\n      });\n      const provider = await SdkProvider.withAwsCliCompatibleDefaults({ ...defaultCredOptions, profile: 'foo' });\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-west-1');\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('22222'), partition: 'aws' });\n\n      const sdk = (await provider.forEnvironment(env(uniq('22222')), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('fooccess'));\n    });\n\n    test('supports profile only in config_file', async () => {\n      // WHEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile foo': { aws_access_key_id: 'fooccess', $account: '22222' },\n        },\n      });\n      const provider = await providerFromProfile('foo');\n\n      // THEN\n      expect(provider.defaultRegion).toEqual('eu-bla-5'); // Fall back to default config\n      await expect(provider.defaultAccount()).resolves.toEqual({ accountId: uniq('22222'), partition: 'aws' });\n\n      const sdk = (await provider.forEnvironment(env(uniq('22222')), Mode.ForReading)).sdk;\n      expect(sdkConfig(sdk).credentials!.accessKeyId).toEqual(uniq('fooccess'));\n    });\n\n    test('can assume-role configured in config', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '11111' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile assumer': { region: 'us-east-2' },\n          'profile assumable': {\n            role_arn: 'arn:aws:iam::66666:role/Assumable',\n            source_profile: 'assumer',\n            $account: '66666',\n            $fakeStsOptions: { allowedAccounts: ['11111'] },\n          },\n        },\n      });\n      const provider = await providerFromProfile('assumable');\n\n      // WHEN\n      const sdk = (await provider.forEnvironment(env(uniq('66666')), Mode.ForReading)).sdk;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('66666'));\n    });\n\n    test('can assume role even if [default] profile is missing', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '22222' },\n          assumable: { role_arn: 'arn:aws:iam::12356789012:role/Assumable', source_profile: 'assumer', $account: '22222' },\n        },\n        config: {\n          'profile assumable': { region: 'eu-bla-5' },\n        },\n      });\n\n      // WHEN\n      const provider = await providerFromProfile('assumable');\n\n      // THEN\n      expect((await provider.defaultAccount())?.accountId).toEqual(uniq('22222'));\n    });\n\n    test('mfa_serial in profile will ask user for token', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        credentials: {\n          assumer: { aws_access_key_id: 'assumer', $account: '66666' },\n        },\n        config: {\n          'default': { region: 'eu-bla-5' },\n          'profile assumer': { region: 'us-east-2' },\n          'profile mfa-role': {\n            role_arn: 'arn:aws:iam::66666:role/Assumable',\n            source_profile: 'assumer',\n            mfa_serial: 'arn:aws:iam::account:mfa/user',\n            $account: '66666',\n          },\n        },\n      });\n      const provider = await providerFromProfile('mfa-role');\n\n      const promptlyMockCalls = (promptly.prompt as jest.Mock).mock.calls.length;\n\n      // THEN\n      const sdk = (await provider.forEnvironment(env(uniq('66666')), Mode.ForReading)).sdk;\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('66666'));\n      expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n        roleArn: 'arn:aws:iam::66666:role/Assumable',\n        serialNumber: 'arn:aws:iam::account:mfa/user',\n        tokenCode: '1234',\n      }));\n\n      // Mock response was set to fail to make sure we don't call STS\n      // Make sure the MFA mock was called during this test\n      expect((promptly.prompt as jest.Mock).mock.calls.length).toBe(promptlyMockCalls + 1);\n    });\n  });\n\n  // For DefaultSynthesis we will do an assume-role after having gotten base credentials\n  describe('when CDK AssumeRoles', () => {\n    beforeEach(() => {\n      // All these tests share that 'arn:aws:role' is a role into account 88888 which can be assumed from 11111\n      fakeSts.registerRole(uniq('88888'), 'arn:aws:role', { allowedAccounts: [uniq('11111')] });\n    });\n\n    test('error we get from assuming a role is useful', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      const promise = provider.forEnvironment(env(uniq('88888')), Mode.ForReading, {\n        assumeRoleArn: 'doesnotexist.role.arn',\n      });\n\n      // THEN - error message contains both a helpful hint and the underlying AssumeRole message\n      await expect(promise).rejects.toThrow('(re)-bootstrap the environment');\n      await expect(promise).rejects.toThrow('doesnotexist.role.arn');\n    });\n\n    test('assuming a role sanitizes the username into the session name', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n\n      await withMocked(os, 'userInfo', async (userInfo) => {\n        userInfo.mockReturnValue({ username: 'skål', uid: 1, gid: 1, homedir: '/here', shell: '/bin/sh' });\n\n        // WHEN\n        const provider = await providerFromProfile(undefined);\n\n        const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n        await sdk.currentAccount();\n\n        // THEN\n        expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n          roleSessionName: 'aws-cdk-sk@l',\n        }));\n      });\n    });\n\n    test('assuming a role does not fail when OS username cannot be read', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n\n      await withMocked(os, 'userInfo', async (userInfo) => {\n        userInfo.mockImplementation(() => {\n          // SystemError thrown as documented: https://nodejs.org/docs/latest-v16.x/api/os.html#osuserinfooptions\n          throw new Error('SystemError on Linux: uv_os_get_passwd returned ENOENT. See #19401 issue.');\n        });\n\n        // WHEN\n        const provider = await providerFromProfile(undefined);\n\n        const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n        await sdk.currentAccount();\n\n        // THEN\n        expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n          roleSessionName: 'aws-cdk-noname',\n        }));\n      });\n    });\n\n    test('even if current credentials are for the wrong account, we will still use them to AssumeRole', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('88888'));\n    });\n\n    test('if AssumeRole fails but current credentials are for the right account, we will still use them', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '88888' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN - assumeRole fails because the role can only be assumed from account 11111\n      const sdk = (await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: 'arn:aws:role' })).sdk as SDK;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('88888'));\n    });\n\n    test('if AssumeRole fails because of ExpiredToken, then fail completely', async () => {\n      // GIVEN\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '88888' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN - assumeRole fails with a specific error\n      await expect(async () => {\n        await provider.forEnvironment(env(uniq('88888')), Mode.ForReading, { assumeRoleArn: '<FAIL:ExpiredToken>' });\n      }).rejects.toThrow(/ExpiredToken/);\n    });\n  });\n\n  describe('Plugins', () => {\n    test('does not use plugins if current credentials are for expected account', async () => {\n      prepareCreds({\n        fakeSts,\n        config: {\n          default: { aws_access_key_id: 'foo', $account: '11111' },\n        },\n      });\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('11111')), Mode.ForReading);\n      expect(pluginQueried).toEqual(false);\n    });\n\n    test('uses plugin for account 99999', async () => {\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading);\n      expect(pluginQueried).toEqual(true);\n    });\n\n    test('can assume role with credentials from plugin', async () => {\n      fakeSts.registerRole(uniq('99999'), 'arn:aws:iam::99999:role/Assumable');\n\n      const provider = await providerFromProfile(undefined);\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading, {\n        assumeRoleArn: 'arn:aws:iam::99999:role/Assumable',\n      });\n\n      expect(fakeSts.assumedRoles[0]).toEqual(expect.objectContaining({\n        roleArn: 'arn:aws:iam::99999:role/Assumable',\n      }));\n      expect(pluginQueried).toEqual(true);\n    });\n\n    test('even if AssumeRole fails but current credentials are from a plugin, we will still use them', async () => {\n      const provider = await providerFromProfile(undefined);\n      const sdk = (await provider.forEnvironment(env(uniq('99999')), Mode.ForReading, { assumeRoleArn: 'does:not:exist' })).sdk;\n\n      // THEN\n      expect((await sdk.currentAccount()).accountId).toEqual(uniq('99999'));\n    });\n\n    test('plugins are still queried even if current credentials are expired (or otherwise invalid)', async () => {\n      // GIVEN\n      process.env.AWS_ACCESS_KEY_ID = `${uid}akid`;\n      process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';\n      const provider = await providerFromProfile(undefined);\n\n      // WHEN\n      await provider.forEnvironment(env(uniq('99999')), Mode.ForReading);\n\n      // THEN\n      expect(pluginQueried).toEqual(true);\n    });\n  });\n\n  describe('support for credential_source', () => {\n    test('can assume role with ecs credentials', async () => {\n      return withMocked(AWS.ECSCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'EcsContainer', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n      });\n\n    });\n\n    test('can assume role with ec2 credentials', async () => {\n      return withMocked(AWS.EC2MetadataCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'Ec2InstanceMetadata', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n\n      });\n\n    });\n\n    test('can assume role with env credentials', async () => {\n      return withMocked(AWS.EnvironmentCredentials.prototype, 'needsRefresh', async (needsRefresh) => {\n        // GIVEN\n        prepareCreds({\n          config: {\n            'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'Environment', $account: '22222' },\n          },\n        });\n        const provider = await providerFromProfile('ecs');\n\n        // WHEN\n        await provider.defaultAccount();\n\n        // THEN\n        expect(needsRefresh).toHaveBeenCalled();\n      });\n    });\n\n    test('assume fails with unsupported credential_source', async () => {\n      // GIVEN\n      prepareCreds({\n        config: {\n          'profile ecs': { role_arn: 'arn:aws:iam::12356789012:role/Assumable', credential_source: 'unsupported', $account: '22222' },\n        },\n      });\n      const provider = await providerFromProfile('ecs');\n\n      // WHEN\n      const account = await provider.defaultAccount();\n\n      // THEN\n      expect(account?.accountId).toEqual(undefined);\n    });\n  });\n\n  test('defaultAccount returns undefined if STS call fails', async () => {\n    // GIVEN\n    process.env.AWS_ACCESS_KEY_ID = `${uid}akid`;\n    process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';\n\n    // WHEN\n    const provider = await providerFromProfile(undefined);\n\n    // THEN\n    await expect(provider.defaultAccount()).resolves.toBe(undefined);\n  });\n\n  test('defaultAccount returns undefined, event if STS call fails with ExpiredToken', async () => {\n    // GIVEN\n    process.env.AWS_ACCESS_KEY_ID = `${uid}'<FAIL:ExpiredToken>'`;\n    process.env.AWS_SECRET_ACCESS_KEY = 'sekrit';\n\n    // WHEN\n    const provider = await providerFromProfile(undefined);\n\n    // THEN\n    await expect(provider.defaultAccount()).resolves.toBe(undefined);\n  });\n});\n\ntest('even when using a profile to assume another profile, STS calls goes through the proxy', async () => {\n  prepareCreds({\n    credentials: {\n      assumer: { aws_access_key_id: 'assumer' },\n    },\n    config: {\n      'default': { region: 'eu-bla-5' },\n      'profile assumable': { role_arn: 'arn:aws:iam::66666:role/Assumable', source_profile: 'assumer', $account: '66666' },\n      'profile assumer': { region: 'us-east-2' },\n    },\n  });\n\n  // Messy mocking\n  let called = false;\n  jest.mock('proxy-agent', () => {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    class FakeAgent extends require('https').Agent {\n      public addRequest(_: any, __: any) {\n        // FIXME: this error takes 6 seconds to be completely handled. It\n        // might be retries in the SDK somewhere, or something about the Node\n        // event loop. I've spent an hour trying to figure it out and I can't,\n        // and I gave up. We'll just have to live with this until someone gets\n        // inspired.\n        const error = new Error('ABORTED BY TEST');\n        (error as any).code = 'RequestAbortedError';\n        (error as any).retryable = false;\n        called = true;\n        throw error;\n      }\n    }\n    return FakeAgent;\n  });\n\n  // WHEN\n  const provider = await SdkProvider.withAwsCliCompatibleDefaults({\n    ...defaultCredOptions,\n    profile: 'assumable',\n    httpOptions: {\n      proxyAddress: 'http://DOESNTMATTER/',\n    },\n  });\n\n  await provider.defaultAccount();\n\n  // THEN -- the fake proxy agent got called, we don't care about the result\n  expect(called).toEqual(true);\n});\n\n/**\n * Use object hackery to get the credentials out of the SDK object\n */\nfunction sdkConfig(sdk: ISDK): ConfigurationOptions {\n  return (sdk as any).config;\n}\n\n/**\n * Fixture for SDK auth for this test suite\n *\n * Has knowledge of the cache buster, will write proper fake config files and\n * register users and roles in FakeSts at the same time.\n */\nfunction prepareCreds(options: PrepareCredsOptions) {\n  function convertSections(sections?: Record<string, ProfileUser | ProfileRole>) {\n    const ret = [];\n    for (const [profile, user] of Object.entries(sections ?? {})) {\n      ret.push(`[${profile}]`);\n\n      if (isProfileRole(user)) {\n        ret.push(`role_arn=${user.role_arn}`);\n        if ('source_profile' in user) {\n          ret.push(`source_profile=${user.source_profile}`);\n        }\n        if ('credential_source' in user) {\n          ret.push(`credential_source=${user.credential_source}`);\n        }\n        if (user.mfa_serial) {\n          ret.push(`mfa_serial=${user.mfa_serial}`);\n        }\n        options.fakeSts?.registerRole(uniq(user.$account ?? '00000'), user.role_arn, {\n          ...user.$fakeStsOptions,\n          allowedAccounts: user.$fakeStsOptions?.allowedAccounts?.map(uniq),\n        });\n      } else {\n        if (user.aws_access_key_id) {\n          ret.push(`aws_access_key_id=${uniq(user.aws_access_key_id)}`);\n          ret.push('aws_secret_access_key=secret');\n          options.fakeSts?.registerUser(uniq(user.$account ?? '00000'), uniq(user.aws_access_key_id), user.$fakeStsOptions);\n        }\n      }\n\n      if (user.region) {\n        ret.push(`region=${user.region}`);\n      }\n    }\n    return ret.join('\\n');\n  }\n\n  bockfs({\n    '/home/me/.bxt/credentials': convertSections(options.credentials),\n    '/home/me/.bxt/config': convertSections(options.config),\n  });\n\n  // Set environment variables that we want\n  process.env.AWS_CONFIG_FILE = bockfs.path('/home/me/.bxt/config');\n  process.env.AWS_SHARED_CREDENTIALS_FILE = bockfs.path('/home/me/.bxt/credentials');\n}\n\ninterface PrepareCredsOptions {\n  /**\n   * Write the aws/credentials file\n   */\n  readonly credentials?: Record<string, ProfileUser | ProfileRole>;\n\n  /**\n   * Write the aws/config file\n   */\n  readonly config?: Record<string, ProfileUser | ProfileRole>;\n\n  /**\n   * If given, add users to FakeSTS\n   */\n  readonly fakeSts?: FakeSts;\n}\n\ninterface ProfileUser {\n  readonly aws_access_key_id?: string;\n  readonly $account?: string;\n  readonly region?: string;\n  readonly $fakeStsOptions?: RegisterUserOptions;\n}\n\ntype ProfileRole = {\n  readonly role_arn: string;\n  readonly mfa_serial?: string;\n  readonly $account: string;\n  readonly region?: string;\n  readonly $fakeStsOptions?: RegisterRoleOptions;\n} & ({ readonly source_profile: string } | { readonly credential_source: string });\n\nfunction isProfileRole(x: ProfileUser | ProfileRole): x is ProfileRole {\n  return 'role_arn' in x;\n}\n\nfunction providerFromProfile(profile: string | undefined) {\n  return SdkProvider.withAwsCliCompatibleDefaults({ ...defaultCredOptions, profile });\n}\n"]}
|