mirror of
https://github.com/MeowLynxSea/Proksea.git
synced 2025-07-11 03:44:39 +00:00
75 lines
3.9 KiB
JavaScript
75 lines
3.9 KiB
JavaScript
/*! @azure/msal-node v2.9.2 2024-06-10 */
|
|
'use strict';
|
|
import { AppService } from './ManagedIdentitySources/AppService.mjs';
|
|
import { AzureArc } from './ManagedIdentitySources/AzureArc.mjs';
|
|
import { CloudShell } from './ManagedIdentitySources/CloudShell.mjs';
|
|
import { Imds } from './ManagedIdentitySources/Imds.mjs';
|
|
import { ServiceFabric } from './ManagedIdentitySources/ServiceFabric.mjs';
|
|
import { createManagedIdentityError } from '../error/ManagedIdentityError.mjs';
|
|
import { ManagedIdentitySourceNames } from '../utils/Constants.mjs';
|
|
import { unableToCreateSource } from '../error/ManagedIdentityErrorCodes.mjs';
|
|
|
|
/*
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License.
|
|
*/
|
|
/*
|
|
* Class to initialize a managed identity and identify the service.
|
|
* Original source of code: https://github.com/Azure/azure-sdk-for-net/blob/main/sdk/identity/Azure.Identity/src/ManagedIdentityClient.cs
|
|
*/
|
|
class ManagedIdentityClient {
|
|
constructor(logger, nodeStorage, networkClient, cryptoProvider) {
|
|
this.logger = logger;
|
|
this.nodeStorage = nodeStorage;
|
|
this.networkClient = networkClient;
|
|
this.cryptoProvider = cryptoProvider;
|
|
}
|
|
async sendManagedIdentityTokenRequest(managedIdentityRequest, managedIdentityId, fakeAuthority, refreshAccessToken) {
|
|
if (!ManagedIdentityClient.identitySource) {
|
|
ManagedIdentityClient.identitySource =
|
|
this.selectManagedIdentitySource(this.logger, this.nodeStorage, this.networkClient, this.cryptoProvider, managedIdentityId);
|
|
}
|
|
return ManagedIdentityClient.identitySource.acquireTokenWithManagedIdentity(managedIdentityRequest, managedIdentityId, fakeAuthority, refreshAccessToken);
|
|
}
|
|
allEnvironmentVariablesAreDefined(environmentVariables) {
|
|
return Object.values(environmentVariables).every((environmentVariable) => {
|
|
return environmentVariable !== undefined;
|
|
});
|
|
}
|
|
/**
|
|
* Determine the Managed Identity Source based on available environment variables. This API is consumed by ManagedIdentityApplication's getManagedIdentitySource.
|
|
* @returns ManagedIdentitySourceNames - The Managed Identity source's name
|
|
*/
|
|
getManagedIdentitySource() {
|
|
ManagedIdentityClient.sourceName =
|
|
this.allEnvironmentVariablesAreDefined(ServiceFabric.getEnvironmentVariables())
|
|
? ManagedIdentitySourceNames.SERVICE_FABRIC
|
|
: this.allEnvironmentVariablesAreDefined(AppService.getEnvironmentVariables())
|
|
? ManagedIdentitySourceNames.APP_SERVICE
|
|
: this.allEnvironmentVariablesAreDefined(CloudShell.getEnvironmentVariables())
|
|
? ManagedIdentitySourceNames.CLOUD_SHELL
|
|
: this.allEnvironmentVariablesAreDefined(AzureArc.getEnvironmentVariables())
|
|
? ManagedIdentitySourceNames.AZURE_ARC
|
|
: ManagedIdentitySourceNames.DEFAULT_TO_IMDS;
|
|
return ManagedIdentityClient.sourceName;
|
|
}
|
|
/**
|
|
* Tries to create a managed identity source for all sources
|
|
* @returns the managed identity Source
|
|
*/
|
|
selectManagedIdentitySource(logger, nodeStorage, networkClient, cryptoProvider, managedIdentityId) {
|
|
const source = ServiceFabric.tryCreate(logger, nodeStorage, networkClient, cryptoProvider, managedIdentityId) ||
|
|
AppService.tryCreate(logger, nodeStorage, networkClient, cryptoProvider) ||
|
|
CloudShell.tryCreate(logger, nodeStorage, networkClient, cryptoProvider, managedIdentityId) ||
|
|
AzureArc.tryCreate(logger, nodeStorage, networkClient, cryptoProvider, managedIdentityId) ||
|
|
Imds.tryCreate(logger, nodeStorage, networkClient, cryptoProvider);
|
|
if (!source) {
|
|
throw createManagedIdentityError(unableToCreateSource);
|
|
}
|
|
return source;
|
|
}
|
|
}
|
|
|
|
export { ManagedIdentityClient };
|
|
//# sourceMappingURL=ManagedIdentityClient.mjs.map
|