"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var http = _interopRequireWildcard(require("http"), true); var https = _interopRequireWildcard(require("https"), true); var _url = require("url"); var _CredentialProvider = require("./CredentialProvider.js"); var _Credentials = require("./Credentials.js"); var _helper = require("./internal/helper.js"); var _request = require("./internal/request.js"); var _response = require("./internal/response.js"); var _signing = require("./signing.js"); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } /** * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html */ const defaultExpirySeconds = 900; class AssumeRoleProvider extends _CredentialProvider.CredentialProvider { accessExpiresAt = ''; constructor({ stsEndpoint, accessKey, secretKey, durationSeconds = defaultExpirySeconds, sessionToken, policy, region = '', roleArn, roleSessionName, externalId, token, webIdentityToken, action = 'AssumeRole', transportAgent = undefined }) { super({ accessKey, secretKey, sessionToken }); this.stsEndpoint = new _url.URL(stsEndpoint); this.accessKey = accessKey; this.secretKey = secretKey; this.policy = policy; this.region = region; this.roleArn = roleArn; this.roleSessionName = roleSessionName; this.externalId = externalId; this.token = token; this.webIdentityToken = webIdentityToken; this.action = action; this.durationSeconds = parseInt(durationSeconds); let expirySeconds = this.durationSeconds; if (this.durationSeconds < defaultExpirySeconds) { expirySeconds = defaultExpirySeconds; } this.expirySeconds = expirySeconds; // for calculating refresh of credentials. // By default, nodejs uses a global agent if the 'agent' property // is set to undefined. Otherwise, it's okay to assume the users // know what they're doing if they specify a custom transport agent. this.transportAgent = transportAgent; const isHttp = this.stsEndpoint.protocol === 'http:'; this.transport = isHttp ? http : https; /** * Internal Tracking variables */ this._credentials = null; } getRequestConfig() { const hostValue = this.stsEndpoint.hostname; const portValue = this.stsEndpoint.port; const qryParams = new _url.URLSearchParams({ Action: this.action, Version: '2011-06-15' }); qryParams.set('DurationSeconds', this.expirySeconds.toString()); if (this.policy) { qryParams.set('Policy', this.policy); } if (this.roleArn) { qryParams.set('RoleArn', this.roleArn); } if (this.roleSessionName != null) { qryParams.set('RoleSessionName', this.roleSessionName); } if (this.token != null) { qryParams.set('Token', this.token); } if (this.webIdentityToken) { qryParams.set('WebIdentityToken', this.webIdentityToken); } if (this.externalId) { qryParams.set('ExternalId', this.externalId); } const urlParams = qryParams.toString(); const contentSha256 = (0, _helper.toSha256)(urlParams); const date = new Date(); const requestOptions = { hostname: hostValue, port: portValue, path: '/', protocol: this.stsEndpoint.protocol, method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded', 'content-length': urlParams.length.toString(), host: hostValue, 'x-amz-date': (0, _helper.makeDateLong)(date), 'x-amz-content-sha256': contentSha256 }, agent: this.transportAgent }; requestOptions.headers.authorization = (0, _signing.signV4ByServiceName)(requestOptions, this.accessKey, this.secretKey, this.region, date, contentSha256, 'sts'); return { requestOptions, requestData: urlParams }; } async performRequest() { const { requestOptions, requestData } = this.getRequestConfig(); const res = await (0, _request.request)(this.transport, requestOptions, requestData); const body = await (0, _response.readAsString)(res); return (0, _helper.parseXml)(body); } parseCredentials(respObj) { if (respObj.ErrorResponse) { var _respObj$ErrorRespons, _respObj$ErrorRespons2, _respObj$ErrorRespons3, _respObj$ErrorRespons4; throw new Error(`Unable to obtain credentials: ${(_respObj$ErrorRespons = respObj.ErrorResponse) === null || _respObj$ErrorRespons === void 0 ? void 0 : (_respObj$ErrorRespons2 = _respObj$ErrorRespons.Error) === null || _respObj$ErrorRespons2 === void 0 ? void 0 : _respObj$ErrorRespons2.Code} ${(_respObj$ErrorRespons3 = respObj.ErrorResponse) === null || _respObj$ErrorRespons3 === void 0 ? void 0 : (_respObj$ErrorRespons4 = _respObj$ErrorRespons3.Error) === null || _respObj$ErrorRespons4 === void 0 ? void 0 : _respObj$ErrorRespons4.Message}`, { cause: respObj }); } const { AssumeRoleResponse: { AssumeRoleResult: { Credentials: { AccessKeyId: accessKey, SecretAccessKey: secretKey, SessionToken: sessionToken, Expiration: expiresAt } } } } = respObj; this.accessExpiresAt = expiresAt; return new _Credentials.Credentials({ accessKey, secretKey, sessionToken }); } async refreshCredentials() { try { const assumeRoleCredentials = await this.performRequest(); this._credentials = this.parseCredentials(assumeRoleCredentials); } catch (err) { throw new Error(`Failed to get Credentials: ${err}`, { cause: err }); } return this._credentials; } async getCredentials() { if (this._credentials && !this.isAboutToExpire()) { return this._credentials; } this._credentials = await this.refreshCredentials(); return this._credentials; } isAboutToExpire() { const expiresAt = new Date(this.accessExpiresAt); const provisionalExpiry = new Date(Date.now() + 1000 * 10); // check before 10 seconds. return provisionalExpiry > expiresAt; } } // deprecated default export, please use named exports. // keep for backward compatibility. // eslint-disable-next-line import/no-default-export exports.AssumeRoleProvider = AssumeRoleProvider; var _default = AssumeRoleProvider; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["http","_interopRequireWildcard","require","https","_url","_CredentialProvider","_Credentials","_helper","_request","_response","_signing","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","defaultExpirySeconds","AssumeRoleProvider","CredentialProvider","accessExpiresAt","constructor","stsEndpoint","accessKey","secretKey","durationSeconds","sessionToken","policy","region","roleArn","roleSessionName","externalId","token","webIdentityToken","action","transportAgent","undefined","URL","parseInt","expirySeconds","isHttp","protocol","transport","_credentials","getRequestConfig","hostValue","hostname","portValue","port","qryParams","URLSearchParams","Action","Version","toString","urlParams","contentSha256","toSha256","date","Date","requestOptions","path","method","headers","length","host","makeDateLong","agent","authorization","signV4ByServiceName","requestData","performRequest","res","request","body","readAsString","parseXml","parseCredentials","respObj","ErrorResponse","_respObj$ErrorRespons","_respObj$ErrorRespons2","_respObj$ErrorRespons3","_respObj$ErrorRespons4","Error","Code","Message","cause","AssumeRoleResponse","AssumeRoleResult","Credentials","AccessKeyId","SecretAccessKey","SessionToken","Expiration","expiresAt","refreshCredentials","assumeRoleCredentials","err","getCredentials","isAboutToExpire","provisionalExpiry","now","exports","_default"],"sources":["AssumeRoleProvider.ts"],"sourcesContent":["import * as http from 'node:http'\nimport * as https from 'node:https'\nimport { URL, URLSearchParams } from 'node:url'\n\nimport { CredentialProvider } from './CredentialProvider.ts'\nimport { Credentials } from './Credentials.ts'\nimport { makeDateLong, parseXml, toSha256 } from './internal/helper.ts'\nimport { request } from './internal/request.ts'\nimport { readAsString } from './internal/response.ts'\nimport type { Transport } from './internal/type.ts'\nimport { signV4ByServiceName } from './signing.ts'\n\n/**\n * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html\n */\ntype CredentialResponse = {\n  ErrorResponse?: {\n    Error?: {\n      Code?: string\n      Message?: string\n    }\n  }\n\n  AssumeRoleResponse: {\n    AssumeRoleResult: {\n      Credentials: {\n        AccessKeyId: string\n        SecretAccessKey: string\n        SessionToken: string\n        Expiration: string\n      }\n    }\n  }\n}\n\nexport interface AssumeRoleProviderOptions {\n  stsEndpoint: string\n  accessKey: string\n  secretKey: string\n  durationSeconds?: number\n  sessionToken?: string\n  policy?: string\n  region?: string\n  roleArn?: string\n  roleSessionName?: string\n  externalId?: string\n  token?: string\n  webIdentityToken?: string\n  action?: string\n  transportAgent?: http.Agent\n}\n\nconst defaultExpirySeconds = 900\n\nexport class AssumeRoleProvider extends CredentialProvider {\n  private readonly stsEndpoint: URL\n  private readonly accessKey: string\n  private readonly secretKey: string\n  private readonly durationSeconds: number\n  private readonly policy?: string\n  private readonly region: string\n  private readonly roleArn?: string\n  private readonly roleSessionName?: string\n  private readonly externalId?: string\n  private readonly token?: string\n  private readonly webIdentityToken?: string\n  private readonly action: string\n\n  private _credentials: Credentials | null\n  private readonly expirySeconds: number\n  private accessExpiresAt = ''\n  private readonly transportAgent?: http.Agent\n\n  private readonly transport: Transport\n\n  constructor({\n    stsEndpoint,\n    accessKey,\n    secretKey,\n    durationSeconds = defaultExpirySeconds,\n    sessionToken,\n    policy,\n    region = '',\n    roleArn,\n    roleSessionName,\n    externalId,\n    token,\n    webIdentityToken,\n    action = 'AssumeRole',\n    transportAgent = undefined,\n  }: AssumeRoleProviderOptions) {\n    super({ accessKey, secretKey, sessionToken })\n\n    this.stsEndpoint = new URL(stsEndpoint)\n    this.accessKey = accessKey\n    this.secretKey = secretKey\n    this.policy = policy\n    this.region = region\n    this.roleArn = roleArn\n    this.roleSessionName = roleSessionName\n    this.externalId = externalId\n    this.token = token\n    this.webIdentityToken = webIdentityToken\n    this.action = action\n\n    this.durationSeconds = parseInt(durationSeconds as unknown as string)\n\n    let expirySeconds = this.durationSeconds\n    if (this.durationSeconds < defaultExpirySeconds) {\n      expirySeconds = defaultExpirySeconds\n    }\n    this.expirySeconds = expirySeconds // for calculating refresh of credentials.\n\n    // By default, nodejs uses a global agent if the 'agent' property\n    // is set to undefined. Otherwise, it's okay to assume the users\n    // know what they're doing if they specify a custom transport agent.\n    this.transportAgent = transportAgent\n    const isHttp: boolean = this.stsEndpoint.protocol === 'http:'\n    this.transport = isHttp ? http : https\n\n    /**\n     * Internal Tracking variables\n     */\n    this._credentials = null\n  }\n\n  getRequestConfig(): {\n    requestOptions: http.RequestOptions\n    requestData: string\n  } {\n    const hostValue = this.stsEndpoint.hostname\n    const portValue = this.stsEndpoint.port\n    const qryParams = new URLSearchParams({ Action: this.action, Version: '2011-06-15' })\n\n    qryParams.set('DurationSeconds', this.expirySeconds.toString())\n\n    if (this.policy) {\n      qryParams.set('Policy', this.policy)\n    }\n    if (this.roleArn) {\n      qryParams.set('RoleArn', this.roleArn)\n    }\n\n    if (this.roleSessionName != null) {\n      qryParams.set('RoleSessionName', this.roleSessionName)\n    }\n    if (this.token != null) {\n      qryParams.set('Token', this.token)\n    }\n\n    if (this.webIdentityToken) {\n      qryParams.set('WebIdentityToken', this.webIdentityToken)\n    }\n\n    if (this.externalId) {\n      qryParams.set('ExternalId', this.externalId)\n    }\n\n    const urlParams = qryParams.toString()\n    const contentSha256 = toSha256(urlParams)\n\n    const date = new Date()\n\n    const requestOptions = {\n      hostname: hostValue,\n      port: portValue,\n      path: '/',\n      protocol: this.stsEndpoint.protocol,\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/x-www-form-urlencoded',\n        'content-length': urlParams.length.toString(),\n        host: hostValue,\n        'x-amz-date': makeDateLong(date),\n        'x-amz-content-sha256': contentSha256,\n      } as Record<string, string>,\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    requestOptions.headers.authorization = signV4ByServiceName(\n      requestOptions,\n      this.accessKey,\n      this.secretKey,\n      this.region,\n      date,\n      contentSha256,\n      'sts',\n    )\n\n    return {\n      requestOptions,\n      requestData: urlParams,\n    }\n  }\n\n  async performRequest(): Promise<CredentialResponse> {\n    const { requestOptions, requestData } = this.getRequestConfig()\n\n    const res = await request(this.transport, requestOptions, requestData)\n\n    const body = await readAsString(res)\n\n    return parseXml(body)\n  }\n\n  parseCredentials(respObj: CredentialResponse): Credentials {\n    if (respObj.ErrorResponse) {\n      throw new Error(\n        `Unable to obtain credentials: ${respObj.ErrorResponse?.Error?.Code} ${respObj.ErrorResponse?.Error?.Message}`,\n        { cause: respObj },\n      )\n    }\n\n    const {\n      AssumeRoleResponse: {\n        AssumeRoleResult: {\n          Credentials: {\n            AccessKeyId: accessKey,\n            SecretAccessKey: secretKey,\n            SessionToken: sessionToken,\n            Expiration: expiresAt,\n          },\n        },\n      },\n    } = respObj\n\n    this.accessExpiresAt = expiresAt\n\n    return new Credentials({ accessKey, secretKey, sessionToken })\n  }\n\n  async refreshCredentials(): Promise<Credentials> {\n    try {\n      const assumeRoleCredentials = await this.performRequest()\n      this._credentials = this.parseCredentials(assumeRoleCredentials)\n    } catch (err) {\n      throw new Error(`Failed to get Credentials: ${err}`, { cause: err })\n    }\n\n    return this._credentials\n  }\n\n  async getCredentials(): Promise<Credentials> {\n    if (this._credentials && !this.isAboutToExpire()) {\n      return this._credentials\n    }\n\n    this._credentials = await this.refreshCredentials()\n    return this._credentials\n  }\n\n  isAboutToExpire() {\n    const expiresAt = new Date(this.accessExpiresAt)\n    const provisionalExpiry = new Date(Date.now() + 1000 * 10) // check before 10 seconds.\n    return provisionalExpiry > expiresAt\n  }\n}\n\n// deprecated default export, please use named exports.\n// keep for backward compatibility.\n// eslint-disable-next-line import/no-default-export\nexport default AssumeRoleProvider\n"],"mappings":"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"}