@semiont/graph 0.5.5 → 0.5.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/README.md +0 -6
  2. package/dist/bowser-D72SKZAH.js +2820 -0
  3. package/dist/bowser-D72SKZAH.js.map +1 -0
  4. package/dist/chunk-27S56UPF.js +4754 -0
  5. package/dist/chunk-27S56UPF.js.map +1 -0
  6. package/dist/chunk-4UP2SG3N.js +2095 -0
  7. package/dist/chunk-4UP2SG3N.js.map +1 -0
  8. package/dist/chunk-6DEJAFBY.js +125 -0
  9. package/dist/chunk-6DEJAFBY.js.map +1 -0
  10. package/dist/chunk-7UD62TQI.js +3317 -0
  11. package/dist/chunk-7UD62TQI.js.map +1 -0
  12. package/dist/chunk-B2W57CWL.js +47 -0
  13. package/dist/chunk-B2W57CWL.js.map +1 -0
  14. package/dist/chunk-DCLCNCC5.js +1051 -0
  15. package/dist/chunk-DCLCNCC5.js.map +1 -0
  16. package/dist/chunk-KE4TRQI4.js +576 -0
  17. package/dist/chunk-KE4TRQI4.js.map +1 -0
  18. package/dist/chunk-MWZWSKZD.js +1166 -0
  19. package/dist/chunk-MWZWSKZD.js.map +1 -0
  20. package/dist/chunk-V4VXQDJC.js +436 -0
  21. package/dist/chunk-V4VXQDJC.js.map +1 -0
  22. package/dist/dist-es-2CKOZ7UJ.js +69 -0
  23. package/dist/dist-es-2CKOZ7UJ.js.map +1 -0
  24. package/dist/dist-es-CUJAAJXF.js +6632 -0
  25. package/dist/dist-es-CUJAAJXF.js.map +1 -0
  26. package/dist/dist-es-LM7J2FUI.js +87 -0
  27. package/dist/dist-es-LM7J2FUI.js.map +1 -0
  28. package/dist/dist-es-QTXLRLLM.js +169 -0
  29. package/dist/dist-es-QTXLRLLM.js.map +1 -0
  30. package/dist/dist-es-R223S2WP.js +484 -0
  31. package/dist/dist-es-R223S2WP.js.map +1 -0
  32. package/dist/dist-es-SI3C7IEH.js +22 -0
  33. package/dist/dist-es-SI3C7IEH.js.map +1 -0
  34. package/dist/dist-es-XNPYIYQW.js +314 -0
  35. package/dist/dist-es-XNPYIYQW.js.map +1 -0
  36. package/dist/dist-es-ZYIOCGDF.js +376 -0
  37. package/dist/dist-es-ZYIOCGDF.js.map +1 -0
  38. package/dist/event-streams-AI5RIQ2F.js +1376 -0
  39. package/dist/event-streams-AI5RIQ2F.js.map +1 -0
  40. package/dist/index.js +2 -1
  41. package/dist/index.js.map +1 -1
  42. package/dist/loadSso-6PVX5KA7.js +576 -0
  43. package/dist/loadSso-6PVX5KA7.js.map +1 -0
  44. package/dist/signin-GV4P4PGF.js +662 -0
  45. package/dist/signin-GV4P4PGF.js.map +1 -0
  46. package/dist/sso-oidc-WFVKSVW6.js +829 -0
  47. package/dist/sso-oidc-WFVKSVW6.js.map +1 -0
  48. package/dist/sts-7N7QMJRQ.js +1244 -0
  49. package/dist/sts-7N7QMJRQ.js.map +1 -0
  50. package/package.json +12 -7
@@ -0,0 +1,87 @@
1
+ import {
2
+ setCredentialFeature
3
+ } from "./chunk-7UD62TQI.js";
4
+ import {
5
+ CredentialsProviderError,
6
+ externalDataInterceptor,
7
+ getProfileName,
8
+ parseKnownFiles
9
+ } from "./chunk-4UP2SG3N.js";
10
+ import "./chunk-DCLCNCC5.js";
11
+
12
+ // ../../node_modules/@aws-sdk/credential-provider-process/dist-es/resolveProcessCredentials.js
13
+ import { exec } from "child_process";
14
+ import { promisify } from "util";
15
+
16
+ // ../../node_modules/@aws-sdk/credential-provider-process/dist-es/getValidatedProcessCredentials.js
17
+ var getValidatedProcessCredentials = (profileName, data, profiles) => {
18
+ if (data.Version !== 1) {
19
+ throw Error(`Profile ${profileName} credential_process did not return Version 1.`);
20
+ }
21
+ if (data.AccessKeyId === void 0 || data.SecretAccessKey === void 0) {
22
+ throw Error(`Profile ${profileName} credential_process returned invalid credentials.`);
23
+ }
24
+ if (data.Expiration) {
25
+ const currentTime = /* @__PURE__ */ new Date();
26
+ const expireTime = new Date(data.Expiration);
27
+ if (expireTime < currentTime) {
28
+ throw Error(`Profile ${profileName} credential_process returned expired credentials.`);
29
+ }
30
+ }
31
+ let accountId = data.AccountId;
32
+ if (!accountId && profiles?.[profileName]?.aws_account_id) {
33
+ accountId = profiles[profileName].aws_account_id;
34
+ }
35
+ const credentials = {
36
+ accessKeyId: data.AccessKeyId,
37
+ secretAccessKey: data.SecretAccessKey,
38
+ ...data.SessionToken && { sessionToken: data.SessionToken },
39
+ ...data.Expiration && { expiration: new Date(data.Expiration) },
40
+ ...data.CredentialScope && { credentialScope: data.CredentialScope },
41
+ ...accountId && { accountId }
42
+ };
43
+ setCredentialFeature(credentials, "CREDENTIALS_PROCESS", "w");
44
+ return credentials;
45
+ };
46
+
47
+ // ../../node_modules/@aws-sdk/credential-provider-process/dist-es/resolveProcessCredentials.js
48
+ var resolveProcessCredentials = async (profileName, profiles, logger) => {
49
+ const profile = profiles[profileName];
50
+ if (profiles[profileName]) {
51
+ const credentialProcess = profile["credential_process"];
52
+ if (credentialProcess !== void 0) {
53
+ const execPromise = promisify(externalDataInterceptor?.getTokenRecord?.().exec ?? exec);
54
+ try {
55
+ const { stdout } = await execPromise(credentialProcess);
56
+ let data;
57
+ try {
58
+ data = JSON.parse(stdout.trim());
59
+ } catch {
60
+ throw Error(`Profile ${profileName} credential_process returned invalid JSON.`);
61
+ }
62
+ return getValidatedProcessCredentials(profileName, data, profiles);
63
+ } catch (error) {
64
+ throw new CredentialsProviderError(error.message, { logger });
65
+ }
66
+ } else {
67
+ throw new CredentialsProviderError(`Profile ${profileName} did not contain credential_process.`, { logger });
68
+ }
69
+ } else {
70
+ throw new CredentialsProviderError(`Profile ${profileName} could not be found in shared credentials file.`, {
71
+ logger
72
+ });
73
+ }
74
+ };
75
+
76
+ // ../../node_modules/@aws-sdk/credential-provider-process/dist-es/fromProcess.js
77
+ var fromProcess = (init = {}) => async ({ callerClientConfig } = {}) => {
78
+ init.logger?.debug("@aws-sdk/credential-provider-process - fromProcess");
79
+ const profiles = await parseKnownFiles(init);
80
+ return resolveProcessCredentials(getProfileName({
81
+ profile: init.profile ?? callerClientConfig?.profile
82
+ }), profiles, init.logger);
83
+ };
84
+ export {
85
+ fromProcess
86
+ };
87
+ //# sourceMappingURL=dist-es-LM7J2FUI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../node_modules/@aws-sdk/credential-provider-process/dist-es/resolveProcessCredentials.js","../../../node_modules/@aws-sdk/credential-provider-process/dist-es/getValidatedProcessCredentials.js","../../../node_modules/@aws-sdk/credential-provider-process/dist-es/fromProcess.js"],"sourcesContent":["import { CredentialsProviderError, externalDataInterceptor } from \"@smithy/core/config\";\nimport { exec } from \"node:child_process\";\nimport { promisify } from \"node:util\";\nimport { getValidatedProcessCredentials } from \"./getValidatedProcessCredentials\";\nexport const resolveProcessCredentials = async (profileName, profiles, logger) => {\n const profile = profiles[profileName];\n if (profiles[profileName]) {\n const credentialProcess = profile[\"credential_process\"];\n if (credentialProcess !== undefined) {\n const execPromise = promisify(externalDataInterceptor?.getTokenRecord?.().exec ?? exec);\n try {\n const { stdout } = await execPromise(credentialProcess);\n let data;\n try {\n data = JSON.parse(stdout.trim());\n }\n catch {\n throw Error(`Profile ${profileName} credential_process returned invalid JSON.`);\n }\n return getValidatedProcessCredentials(profileName, data, profiles);\n }\n catch (error) {\n throw new CredentialsProviderError(error.message, { logger });\n }\n }\n else {\n throw new CredentialsProviderError(`Profile ${profileName} did not contain credential_process.`, { logger });\n }\n }\n else {\n throw new CredentialsProviderError(`Profile ${profileName} could not be found in shared credentials file.`, {\n logger,\n });\n }\n};\n","import { setCredentialFeature } from \"@aws-sdk/core/client\";\nexport const getValidatedProcessCredentials = (profileName, data, profiles) => {\n if (data.Version !== 1) {\n throw Error(`Profile ${profileName} credential_process did not return Version 1.`);\n }\n if (data.AccessKeyId === undefined || data.SecretAccessKey === undefined) {\n throw Error(`Profile ${profileName} credential_process returned invalid credentials.`);\n }\n if (data.Expiration) {\n const currentTime = new Date();\n const expireTime = new Date(data.Expiration);\n if (expireTime < currentTime) {\n throw Error(`Profile ${profileName} credential_process returned expired credentials.`);\n }\n }\n let accountId = data.AccountId;\n if (!accountId && profiles?.[profileName]?.aws_account_id) {\n accountId = profiles[profileName].aws_account_id;\n }\n const credentials = {\n accessKeyId: data.AccessKeyId,\n secretAccessKey: data.SecretAccessKey,\n ...(data.SessionToken && { sessionToken: data.SessionToken }),\n ...(data.Expiration && { expiration: new Date(data.Expiration) }),\n ...(data.CredentialScope && { credentialScope: data.CredentialScope }),\n ...(accountId && { accountId }),\n };\n setCredentialFeature(credentials, \"CREDENTIALS_PROCESS\", \"w\");\n return credentials;\n};\n","import { getProfileName, parseKnownFiles } from \"@smithy/core/config\";\nimport { resolveProcessCredentials } from \"./resolveProcessCredentials\";\nexport const fromProcess = (init = {}) => async ({ callerClientConfig } = {}) => {\n init.logger?.debug(\"@aws-sdk/credential-provider-process - fromProcess\");\n const profiles = await parseKnownFiles(init);\n return resolveProcessCredentials(getProfileName({\n profile: init.profile ?? callerClientConfig?.profile,\n }), profiles, init.logger);\n};\n"],"mappings":";;;;;;;;;;;;AACA,SAAS,YAAY;AACrB,SAAS,iBAAiB;;;ACDnB,IAAM,iCAAiC,CAAC,aAAa,MAAM,aAAa;AAC3E,MAAI,KAAK,YAAY,GAAG;AACpB,UAAM,MAAM,WAAW,WAAW,+CAA+C;AAAA,EACrF;AACA,MAAI,KAAK,gBAAgB,UAAa,KAAK,oBAAoB,QAAW;AACtE,UAAM,MAAM,WAAW,WAAW,mDAAmD;AAAA,EACzF;AACA,MAAI,KAAK,YAAY;AACjB,UAAM,cAAc,oBAAI,KAAK;AAC7B,UAAM,aAAa,IAAI,KAAK,KAAK,UAAU;AAC3C,QAAI,aAAa,aAAa;AAC1B,YAAM,MAAM,WAAW,WAAW,mDAAmD;AAAA,IACzF;AAAA,EACJ;AACA,MAAI,YAAY,KAAK;AACrB,MAAI,CAAC,aAAa,WAAW,WAAW,GAAG,gBAAgB;AACvD,gBAAY,SAAS,WAAW,EAAE;AAAA,EACtC;AACA,QAAM,cAAc;AAAA,IAChB,aAAa,KAAK;AAAA,IAClB,iBAAiB,KAAK;AAAA,IACtB,GAAI,KAAK,gBAAgB,EAAE,cAAc,KAAK,aAAa;AAAA,IAC3D,GAAI,KAAK,cAAc,EAAE,YAAY,IAAI,KAAK,KAAK,UAAU,EAAE;AAAA,IAC/D,GAAI,KAAK,mBAAmB,EAAE,iBAAiB,KAAK,gBAAgB;AAAA,IACpE,GAAI,aAAa,EAAE,UAAU;AAAA,EACjC;AACA,uBAAqB,aAAa,uBAAuB,GAAG;AAC5D,SAAO;AACX;;;ADzBO,IAAM,4BAA4B,OAAO,aAAa,UAAU,WAAW;AAC9E,QAAM,UAAU,SAAS,WAAW;AACpC,MAAI,SAAS,WAAW,GAAG;AACvB,UAAM,oBAAoB,QAAQ,oBAAoB;AACtD,QAAI,sBAAsB,QAAW;AACjC,YAAM,cAAc,UAAU,yBAAyB,iBAAiB,EAAE,QAAQ,IAAI;AACtF,UAAI;AACA,cAAM,EAAE,OAAO,IAAI,MAAM,YAAY,iBAAiB;AACtD,YAAI;AACJ,YAAI;AACA,iBAAO,KAAK,MAAM,OAAO,KAAK,CAAC;AAAA,QACnC,QACM;AACF,gBAAM,MAAM,WAAW,WAAW,4CAA4C;AAAA,QAClF;AACA,eAAO,+BAA+B,aAAa,MAAM,QAAQ;AAAA,MACrE,SACO,OAAO;AACV,cAAM,IAAI,yBAAyB,MAAM,SAAS,EAAE,OAAO,CAAC;AAAA,MAChE;AAAA,IACJ,OACK;AACD,YAAM,IAAI,yBAAyB,WAAW,WAAW,wCAAwC,EAAE,OAAO,CAAC;AAAA,IAC/G;AAAA,EACJ,OACK;AACD,UAAM,IAAI,yBAAyB,WAAW,WAAW,mDAAmD;AAAA,MACxG;AAAA,IACJ,CAAC;AAAA,EACL;AACJ;;;AEhCO,IAAM,cAAc,CAAC,OAAO,CAAC,MAAM,OAAO,EAAE,mBAAmB,IAAI,CAAC,MAAM;AAC7E,OAAK,QAAQ,MAAM,oDAAoD;AACvE,QAAM,WAAW,MAAM,gBAAgB,IAAI;AAC3C,SAAO,0BAA0B,eAAe;AAAA,IAC5C,SAAS,KAAK,WAAW,oBAAoB;AAAA,EACjD,CAAC,GAAG,UAAU,KAAK,MAAM;AAC7B;","names":[]}
@@ -0,0 +1,169 @@
1
+ import {
2
+ NodeHttpHandler
3
+ } from "./chunk-V4VXQDJC.js";
4
+ import {
5
+ setCredentialFeature
6
+ } from "./chunk-7UD62TQI.js";
7
+ import {
8
+ CredentialsProviderError,
9
+ HttpRequest
10
+ } from "./chunk-4UP2SG3N.js";
11
+ import {
12
+ parseRfc3339DateTime,
13
+ sdkStreamMixin
14
+ } from "./chunk-DCLCNCC5.js";
15
+
16
+ // ../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/fromHttp.js
17
+ import fs from "fs/promises";
18
+
19
+ // ../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/checkUrl.js
20
+ var ECS_CONTAINER_HOST = "169.254.170.2";
21
+ var EKS_CONTAINER_HOST_IPv4 = "169.254.170.23";
22
+ var EKS_CONTAINER_HOST_IPv6 = "[fd00:ec2::23]";
23
+ var checkUrl = (url, logger) => {
24
+ if (url.protocol === "https:") {
25
+ return;
26
+ }
27
+ if (url.hostname === ECS_CONTAINER_HOST || url.hostname === EKS_CONTAINER_HOST_IPv4 || url.hostname === EKS_CONTAINER_HOST_IPv6) {
28
+ return;
29
+ }
30
+ if (url.hostname.includes("[")) {
31
+ if (url.hostname === "[::1]" || url.hostname === "[0000:0000:0000:0000:0000:0000:0000:0001]") {
32
+ return;
33
+ }
34
+ } else {
35
+ if (url.hostname === "localhost") {
36
+ return;
37
+ }
38
+ const ipComponents = url.hostname.split(".");
39
+ const inRange = (component) => {
40
+ const num = parseInt(component, 10);
41
+ return 0 <= num && num <= 255;
42
+ };
43
+ if (ipComponents[0] === "127" && inRange(ipComponents[1]) && inRange(ipComponents[2]) && inRange(ipComponents[3]) && ipComponents.length === 4) {
44
+ return;
45
+ }
46
+ }
47
+ throw new CredentialsProviderError(`URL not accepted. It must either be HTTPS or match one of the following:
48
+ - loopback CIDR 127.0.0.0/8 or [::1/128]
49
+ - ECS container host 169.254.170.2
50
+ - EKS container host 169.254.170.23 or [fd00:ec2::23]`, { logger });
51
+ };
52
+
53
+ // ../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/requestHelpers.js
54
+ function createGetRequest(url) {
55
+ return new HttpRequest({
56
+ protocol: url.protocol,
57
+ hostname: url.hostname,
58
+ port: Number(url.port),
59
+ path: url.pathname,
60
+ query: Array.from(url.searchParams.entries()).reduce((acc, [k, v]) => {
61
+ acc[k] = v;
62
+ return acc;
63
+ }, {}),
64
+ fragment: url.hash
65
+ });
66
+ }
67
+ async function getCredentials(response, logger) {
68
+ const stream = sdkStreamMixin(response.body);
69
+ const str = await stream.transformToString();
70
+ if (response.statusCode === 200) {
71
+ const parsed = JSON.parse(str);
72
+ if (typeof parsed.AccessKeyId !== "string" || typeof parsed.SecretAccessKey !== "string" || typeof parsed.Token !== "string" || typeof parsed.Expiration !== "string") {
73
+ throw new CredentialsProviderError("HTTP credential provider response not of the required format, an object matching: { AccessKeyId: string, SecretAccessKey: string, Token: string, Expiration: string(rfc3339) }", { logger });
74
+ }
75
+ return {
76
+ accessKeyId: parsed.AccessKeyId,
77
+ secretAccessKey: parsed.SecretAccessKey,
78
+ sessionToken: parsed.Token,
79
+ expiration: parseRfc3339DateTime(parsed.Expiration)
80
+ };
81
+ }
82
+ if (response.statusCode >= 400 && response.statusCode < 500) {
83
+ let parsedBody = {};
84
+ try {
85
+ parsedBody = JSON.parse(str);
86
+ } catch (e) {
87
+ }
88
+ throw Object.assign(new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger }), {
89
+ Code: parsedBody.Code,
90
+ Message: parsedBody.Message
91
+ });
92
+ }
93
+ throw new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger });
94
+ }
95
+
96
+ // ../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/retry-wrapper.js
97
+ var retryWrapper = (toRetry, maxRetries, delayMs) => {
98
+ return async () => {
99
+ for (let i = 0; i < maxRetries; ++i) {
100
+ try {
101
+ return await toRetry();
102
+ } catch (e) {
103
+ await new Promise((resolve) => setTimeout(resolve, delayMs));
104
+ }
105
+ }
106
+ return await toRetry();
107
+ };
108
+ };
109
+
110
+ // ../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/fromHttp.js
111
+ var AWS_CONTAINER_CREDENTIALS_RELATIVE_URI = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI";
112
+ var DEFAULT_LINK_LOCAL_HOST = "http://169.254.170.2";
113
+ var AWS_CONTAINER_CREDENTIALS_FULL_URI = "AWS_CONTAINER_CREDENTIALS_FULL_URI";
114
+ var AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE = "AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE";
115
+ var AWS_CONTAINER_AUTHORIZATION_TOKEN = "AWS_CONTAINER_AUTHORIZATION_TOKEN";
116
+ var fromHttp = (options = {}) => {
117
+ options.logger?.debug("@aws-sdk/credential-provider-http - fromHttp");
118
+ let host;
119
+ const relative = options.awsContainerCredentialsRelativeUri ?? process.env[AWS_CONTAINER_CREDENTIALS_RELATIVE_URI];
120
+ const full = options.awsContainerCredentialsFullUri ?? process.env[AWS_CONTAINER_CREDENTIALS_FULL_URI];
121
+ const token = options.awsContainerAuthorizationToken ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN];
122
+ const tokenFile = options.awsContainerAuthorizationTokenFile ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE];
123
+ const warn = options.logger?.constructor?.name === "NoOpLogger" || !options.logger?.warn ? console.warn : options.logger.warn.bind(options.logger);
124
+ if (relative && full) {
125
+ warn("@aws-sdk/credential-provider-http: you have set both awsContainerCredentialsRelativeUri and awsContainerCredentialsFullUri.");
126
+ warn("awsContainerCredentialsFullUri will take precedence.");
127
+ }
128
+ if (token && tokenFile) {
129
+ warn("@aws-sdk/credential-provider-http: you have set both awsContainerAuthorizationToken and awsContainerAuthorizationTokenFile.");
130
+ warn("awsContainerAuthorizationToken will take precedence.");
131
+ }
132
+ if (full) {
133
+ host = full;
134
+ } else if (relative) {
135
+ host = `${DEFAULT_LINK_LOCAL_HOST}${relative}`;
136
+ } else {
137
+ throw new CredentialsProviderError(`No HTTP credential provider host provided.
138
+ Set AWS_CONTAINER_CREDENTIALS_FULL_URI or AWS_CONTAINER_CREDENTIALS_RELATIVE_URI.`, { logger: options.logger });
139
+ }
140
+ const url = new URL(host);
141
+ checkUrl(url, options.logger);
142
+ const requestHandler = NodeHttpHandler.create({ connectionTimeout: options.timeout ?? 1e3 });
143
+ const requestTimeout = options.timeout ?? 1e3;
144
+ const provider = retryWrapper(async () => {
145
+ const request = createGetRequest(url);
146
+ if (token) {
147
+ request.headers.Authorization = token;
148
+ } else if (tokenFile) {
149
+ request.headers.Authorization = (await fs.readFile(tokenFile)).toString();
150
+ }
151
+ try {
152
+ const result = await requestHandler.handle(request, { requestTimeout });
153
+ return getCredentials(result.response).then((creds) => setCredentialFeature(creds, "CREDENTIALS_HTTP", "z"));
154
+ } catch (e) {
155
+ throw new CredentialsProviderError(String(e), { logger: options.logger });
156
+ }
157
+ }, options.maxRetries ?? 3, options.timeout ?? 1e3);
158
+ return async () => {
159
+ try {
160
+ return await provider();
161
+ } finally {
162
+ requestHandler.destroy?.();
163
+ }
164
+ };
165
+ };
166
+ export {
167
+ fromHttp
168
+ };
169
+ //# sourceMappingURL=dist-es-QTXLRLLM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/fromHttp.js","../../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/checkUrl.js","../../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/requestHelpers.js","../../../node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/retry-wrapper.js"],"sourcesContent":["import { setCredentialFeature } from \"@aws-sdk/core/client\";\nimport { CredentialsProviderError } from \"@smithy/core/config\";\nimport { NodeHttpHandler } from \"@smithy/node-http-handler\";\nimport fs from \"node:fs/promises\";\nimport { checkUrl } from \"./checkUrl\";\nimport { createGetRequest, getCredentials } from \"./requestHelpers\";\nimport { retryWrapper } from \"./retry-wrapper\";\nconst AWS_CONTAINER_CREDENTIALS_RELATIVE_URI = \"AWS_CONTAINER_CREDENTIALS_RELATIVE_URI\";\nconst DEFAULT_LINK_LOCAL_HOST = \"http://169.254.170.2\";\nconst AWS_CONTAINER_CREDENTIALS_FULL_URI = \"AWS_CONTAINER_CREDENTIALS_FULL_URI\";\nconst AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE = \"AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE\";\nconst AWS_CONTAINER_AUTHORIZATION_TOKEN = \"AWS_CONTAINER_AUTHORIZATION_TOKEN\";\nexport const fromHttp = (options = {}) => {\n options.logger?.debug(\"@aws-sdk/credential-provider-http - fromHttp\");\n let host;\n const relative = options.awsContainerCredentialsRelativeUri ?? process.env[AWS_CONTAINER_CREDENTIALS_RELATIVE_URI];\n const full = options.awsContainerCredentialsFullUri ?? process.env[AWS_CONTAINER_CREDENTIALS_FULL_URI];\n const token = options.awsContainerAuthorizationToken ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN];\n const tokenFile = options.awsContainerAuthorizationTokenFile ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE];\n const warn = options.logger?.constructor?.name === \"NoOpLogger\" || !options.logger?.warn\n ? console.warn\n : options.logger.warn.bind(options.logger);\n if (relative && full) {\n warn(\"@aws-sdk/credential-provider-http: \" +\n \"you have set both awsContainerCredentialsRelativeUri and awsContainerCredentialsFullUri.\");\n warn(\"awsContainerCredentialsFullUri will take precedence.\");\n }\n if (token && tokenFile) {\n warn(\"@aws-sdk/credential-provider-http: \" +\n \"you have set both awsContainerAuthorizationToken and awsContainerAuthorizationTokenFile.\");\n warn(\"awsContainerAuthorizationToken will take precedence.\");\n }\n if (full) {\n host = full;\n }\n else if (relative) {\n host = `${DEFAULT_LINK_LOCAL_HOST}${relative}`;\n }\n else {\n throw new CredentialsProviderError(`No HTTP credential provider host provided.\nSet AWS_CONTAINER_CREDENTIALS_FULL_URI or AWS_CONTAINER_CREDENTIALS_RELATIVE_URI.`, { logger: options.logger });\n }\n const url = new URL(host);\n checkUrl(url, options.logger);\n const requestHandler = NodeHttpHandler.create({ connectionTimeout: options.timeout ?? 1000 });\n const requestTimeout = options.timeout ?? 1000;\n const provider = retryWrapper(async () => {\n const request = createGetRequest(url);\n if (token) {\n request.headers.Authorization = token;\n }\n else if (tokenFile) {\n request.headers.Authorization = (await fs.readFile(tokenFile)).toString();\n }\n try {\n const result = await requestHandler.handle(request, { requestTimeout });\n return getCredentials(result.response).then((creds) => setCredentialFeature(creds, \"CREDENTIALS_HTTP\", \"z\"));\n }\n catch (e) {\n throw new CredentialsProviderError(String(e), { logger: options.logger });\n }\n }, options.maxRetries ?? 3, options.timeout ?? 1000);\n return async () => {\n try {\n return await provider();\n }\n finally {\n requestHandler.destroy?.();\n }\n };\n};\n","import { CredentialsProviderError } from \"@smithy/core/config\";\nconst LOOPBACK_CIDR_IPv4 = \"127.0.0.0/8\";\nconst LOOPBACK_CIDR_IPv6 = \"::1/128\";\nconst ECS_CONTAINER_HOST = \"169.254.170.2\";\nconst EKS_CONTAINER_HOST_IPv4 = \"169.254.170.23\";\nconst EKS_CONTAINER_HOST_IPv6 = \"[fd00:ec2::23]\";\nexport const checkUrl = (url, logger) => {\n if (url.protocol === \"https:\") {\n return;\n }\n if (url.hostname === ECS_CONTAINER_HOST ||\n url.hostname === EKS_CONTAINER_HOST_IPv4 ||\n url.hostname === EKS_CONTAINER_HOST_IPv6) {\n return;\n }\n if (url.hostname.includes(\"[\")) {\n if (url.hostname === \"[::1]\" || url.hostname === \"[0000:0000:0000:0000:0000:0000:0000:0001]\") {\n return;\n }\n }\n else {\n if (url.hostname === \"localhost\") {\n return;\n }\n const ipComponents = url.hostname.split(\".\");\n const inRange = (component) => {\n const num = parseInt(component, 10);\n return 0 <= num && num <= 255;\n };\n if (ipComponents[0] === \"127\" &&\n inRange(ipComponents[1]) &&\n inRange(ipComponents[2]) &&\n inRange(ipComponents[3]) &&\n ipComponents.length === 4) {\n return;\n }\n }\n throw new CredentialsProviderError(`URL not accepted. It must either be HTTPS or match one of the following:\n - loopback CIDR 127.0.0.0/8 or [::1/128]\n - ECS container host 169.254.170.2\n - EKS container host 169.254.170.23 or [fd00:ec2::23]`, { logger });\n};\n","import { CredentialsProviderError } from \"@smithy/core/config\";\nimport { HttpRequest } from \"@smithy/core/protocols\";\nimport { parseRfc3339DateTime } from \"@smithy/core/serde\";\nimport { sdkStreamMixin } from \"@smithy/core/serde\";\nexport function createGetRequest(url) {\n return new HttpRequest({\n protocol: url.protocol,\n hostname: url.hostname,\n port: Number(url.port),\n path: url.pathname,\n query: Array.from(url.searchParams.entries()).reduce((acc, [k, v]) => {\n acc[k] = v;\n return acc;\n }, {}),\n fragment: url.hash,\n });\n}\nexport async function getCredentials(response, logger) {\n const stream = sdkStreamMixin(response.body);\n const str = await stream.transformToString();\n if (response.statusCode === 200) {\n const parsed = JSON.parse(str);\n if (typeof parsed.AccessKeyId !== \"string\" ||\n typeof parsed.SecretAccessKey !== \"string\" ||\n typeof parsed.Token !== \"string\" ||\n typeof parsed.Expiration !== \"string\") {\n throw new CredentialsProviderError(\"HTTP credential provider response not of the required format, an object matching: \" +\n \"{ AccessKeyId: string, SecretAccessKey: string, Token: string, Expiration: string(rfc3339) }\", { logger });\n }\n return {\n accessKeyId: parsed.AccessKeyId,\n secretAccessKey: parsed.SecretAccessKey,\n sessionToken: parsed.Token,\n expiration: parseRfc3339DateTime(parsed.Expiration),\n };\n }\n if (response.statusCode >= 400 && response.statusCode < 500) {\n let parsedBody = {};\n try {\n parsedBody = JSON.parse(str);\n }\n catch (e) { }\n throw Object.assign(new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger }), {\n Code: parsedBody.Code,\n Message: parsedBody.Message,\n });\n }\n throw new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger });\n}\n","export const retryWrapper = (toRetry, maxRetries, delayMs) => {\n return async () => {\n for (let i = 0; i < maxRetries; ++i) {\n try {\n return await toRetry();\n }\n catch (e) {\n await new Promise((resolve) => setTimeout(resolve, delayMs));\n }\n }\n return await toRetry();\n };\n};\n"],"mappings":"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","names":[]}