mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
83 lines
3.0 KiB
TypeScript
83 lines
3.0 KiB
TypeScript
import React, { FunctionComponent, FormEvent, useMemo, useState } from 'react';
|
|
|
|
import { config } from '@grafana/runtime';
|
|
import { InlineField, InlineFieldRow, InlineSwitch, Input } from '@grafana/ui';
|
|
import { HttpSettingsBaseProps } from '@grafana/ui/src/components/DataSourceSettings/types';
|
|
|
|
import { KnownAzureClouds, AzureCredentials } from './AzureCredentials';
|
|
import { getCredentials, updateCredentials } from './AzureCredentialsConfig';
|
|
import { AzureCredentialsForm } from './AzureCredentialsForm';
|
|
|
|
export const AzureAuthSettings: FunctionComponent<HttpSettingsBaseProps> = (props: HttpSettingsBaseProps) => {
|
|
const { dataSourceConfig, onChange } = props;
|
|
|
|
const [overrideAudienceAllowed] = useState<boolean>(
|
|
config.featureToggles.prometheusAzureOverrideAudience || !!dataSourceConfig.jsonData.azureEndpointResourceId
|
|
);
|
|
const [overrideAudienceChecked, setOverrideAudienceChecked] = useState<boolean>(
|
|
!!dataSourceConfig.jsonData.azureEndpointResourceId
|
|
);
|
|
|
|
const credentials = useMemo(() => getCredentials(dataSourceConfig), [dataSourceConfig]);
|
|
|
|
const onCredentialsChange = (credentials: AzureCredentials): void => {
|
|
onChange(updateCredentials(dataSourceConfig, credentials));
|
|
};
|
|
|
|
const onOverrideAudienceChange = (ev: FormEvent<HTMLInputElement>): void => {
|
|
setOverrideAudienceChecked(ev.currentTarget.checked);
|
|
if (!ev.currentTarget.checked) {
|
|
onChange({
|
|
...dataSourceConfig,
|
|
jsonData: { ...dataSourceConfig.jsonData, azureEndpointResourceId: undefined },
|
|
});
|
|
}
|
|
};
|
|
|
|
const onResourceIdChange = (ev: FormEvent<HTMLInputElement>): void => {
|
|
if (overrideAudienceChecked) {
|
|
onChange({
|
|
...dataSourceConfig,
|
|
jsonData: { ...dataSourceConfig.jsonData, azureEndpointResourceId: ev.currentTarget.value },
|
|
});
|
|
}
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<h6>Azure Authentication</h6>
|
|
<AzureCredentialsForm
|
|
managedIdentityEnabled={config.azure.managedIdentityEnabled}
|
|
credentials={credentials}
|
|
azureCloudOptions={KnownAzureClouds}
|
|
onCredentialsChange={onCredentialsChange}
|
|
/>
|
|
{overrideAudienceAllowed && (
|
|
<>
|
|
<h6>Azure Configuration</h6>
|
|
<div className="gf-form-group">
|
|
<InlineFieldRow>
|
|
<InlineField labelWidth={26} label="Override AAD audience">
|
|
<InlineSwitch value={overrideAudienceChecked} onChange={onOverrideAudienceChange} />
|
|
</InlineField>
|
|
</InlineFieldRow>
|
|
{overrideAudienceChecked && (
|
|
<InlineFieldRow>
|
|
<InlineField labelWidth={26} label="Resource ID">
|
|
<Input
|
|
className="width-30"
|
|
value={dataSourceConfig.jsonData.azureEndpointResourceId || ''}
|
|
onChange={onResourceIdChange}
|
|
/>
|
|
</InlineField>
|
|
</InlineFieldRow>
|
|
)}
|
|
</div>
|
|
</>
|
|
)}
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default AzureAuthSettings;
|