Initial
This commit is contained in:
1
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/ProcessCredentials.js
generated
vendored
Normal file
1
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/ProcessCredentials.js
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export {};
|
||||
7
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/fromProcess.js
generated
vendored
Normal file
7
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/fromProcess.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
import { getProfileName, parseKnownFiles } from "@smithy/shared-ini-file-loader";
|
||||
import { resolveProcessCredentials } from "./resolveProcessCredentials";
|
||||
export const fromProcess = (init = {}) => async () => {
|
||||
init.logger?.debug("@aws-sdk/credential-provider-process", "fromProcess");
|
||||
const profiles = await parseKnownFiles(init);
|
||||
return resolveProcessCredentials(getProfileName(init), profiles);
|
||||
};
|
||||
22
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/getValidatedProcessCredentials.js
generated
vendored
Normal file
22
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/getValidatedProcessCredentials.js
generated
vendored
Normal file
@@ -0,0 +1,22 @@
|
||||
export const getValidatedProcessCredentials = (profileName, data) => {
|
||||
if (data.Version !== 1) {
|
||||
throw Error(`Profile ${profileName} credential_process did not return Version 1.`);
|
||||
}
|
||||
if (data.AccessKeyId === undefined || data.SecretAccessKey === undefined) {
|
||||
throw Error(`Profile ${profileName} credential_process returned invalid credentials.`);
|
||||
}
|
||||
if (data.Expiration) {
|
||||
const currentTime = new Date();
|
||||
const expireTime = new Date(data.Expiration);
|
||||
if (expireTime < currentTime) {
|
||||
throw Error(`Profile ${profileName} credential_process returned expired credentials.`);
|
||||
}
|
||||
}
|
||||
return {
|
||||
accessKeyId: data.AccessKeyId,
|
||||
secretAccessKey: data.SecretAccessKey,
|
||||
...(data.SessionToken && { sessionToken: data.SessionToken }),
|
||||
...(data.Expiration && { expiration: new Date(data.Expiration) }),
|
||||
...(data.CredentialScope && { credentialScope: data.CredentialScope }),
|
||||
};
|
||||
};
|
||||
1
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/index.js
generated
vendored
Normal file
1
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/index.js
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export * from "./fromProcess";
|
||||
33
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/resolveProcessCredentials.js
generated
vendored
Normal file
33
resources/app/node_modules/@aws-sdk/credential-provider-process/dist-es/resolveProcessCredentials.js
generated
vendored
Normal file
@@ -0,0 +1,33 @@
|
||||
import { CredentialsProviderError } from "@smithy/property-provider";
|
||||
import { exec } from "child_process";
|
||||
import { promisify } from "util";
|
||||
import { getValidatedProcessCredentials } from "./getValidatedProcessCredentials";
|
||||
export const resolveProcessCredentials = async (profileName, profiles) => {
|
||||
const profile = profiles[profileName];
|
||||
if (profiles[profileName]) {
|
||||
const credentialProcess = profile["credential_process"];
|
||||
if (credentialProcess !== undefined) {
|
||||
const execPromise = promisify(exec);
|
||||
try {
|
||||
const { stdout } = await execPromise(credentialProcess);
|
||||
let data;
|
||||
try {
|
||||
data = JSON.parse(stdout.trim());
|
||||
}
|
||||
catch {
|
||||
throw Error(`Profile ${profileName} credential_process returned invalid JSON.`);
|
||||
}
|
||||
return getValidatedProcessCredentials(profileName, data);
|
||||
}
|
||||
catch (error) {
|
||||
throw new CredentialsProviderError(error.message);
|
||||
}
|
||||
}
|
||||
else {
|
||||
throw new CredentialsProviderError(`Profile ${profileName} did not contain credential_process.`);
|
||||
}
|
||||
}
|
||||
else {
|
||||
throw new CredentialsProviderError(`Profile ${profileName} could not be found in shared credentials file.`);
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user