1 | import { fromEnv } from "@aws-sdk/credential-provider-env";
|
2 | import { fromIni } from "@aws-sdk/credential-provider-ini";
|
3 | import { fromProcess } from "@aws-sdk/credential-provider-process";
|
4 | import { fromSSO } from "@aws-sdk/credential-provider-sso";
|
5 | import { fromTokenFile } from "@aws-sdk/credential-provider-web-identity";
|
6 | import { chain, CredentialsProviderError, memoize } from "@aws-sdk/property-provider";
|
7 | import { ENV_PROFILE } from "@aws-sdk/shared-ini-file-loader";
|
8 | import { remoteProvider } from "./remoteProvider";
|
9 | export const defaultProvider = (init = {}) => memoize(chain(...(init.profile || process.env[ENV_PROFILE] ? [] : [fromEnv()]), fromSSO(init), fromIni(init), fromProcess(init), fromTokenFile(init), remoteProvider(init), async () => {
|
10 | throw new CredentialsProviderError("Could not load credentials from any providers", false);
|
11 | }), (credentials) => credentials.expiration !== undefined && credentials.expiration.getTime() - Date.now() < 300000, (credentials) => credentials.expiration !== undefined);
|