mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Setup route * Set up the page * Add orgs * Load settings * Make API call * Remove log * Add FormPrompt * Update types * Add tests * Fix tests * Cleanup * Load settings * Fix naming * Switch to PUT endpoint * Switch to CSS object * Setup fields * Render fields * Extend types * Dynamic provider page * Rename page * Filter out non-implemented providers * Fix types * Add teamIDs validation * Update tests * Fix URL * Update name * Send full data * Add password input * Update test * Expand default values * Fix test * Use SecretInput * Remove dev mode for the feature toggle * Convert fields * Remove fieldFormat utils * Update fields logic * Update tests * Update betterer * SSO: Make client secret not required * Update field name * Revert feature toggle to dev mode * Use provider endpoint * Fix form state check * Update tests * Fix URL redirect after form submit * Mock locationService * Separate Form component * Fix trailing slash
93 lines
2.9 KiB
TypeScript
93 lines
2.9 KiB
TypeScript
import { lastValueFrom } from 'rxjs';
|
|
|
|
import { config, getBackendSrv, isFetchError } from '@grafana/runtime';
|
|
import { contextSrv } from 'app/core/core';
|
|
import { AccessControlAction, Settings, ThunkResult, UpdateSettingsQuery } from 'app/types';
|
|
|
|
import { getAuthProviderStatus, getRegisteredAuthProviders, SSOProvider } from '..';
|
|
import { AuthProviderStatus, SettingsError } from '../types';
|
|
|
|
import {
|
|
loadingBegin,
|
|
loadingEnd,
|
|
providersLoaded,
|
|
providerStatusesLoaded,
|
|
resetError,
|
|
setError,
|
|
settingsUpdated,
|
|
} from './reducers';
|
|
|
|
export function loadSettings(): ThunkResult<Promise<Settings>> {
|
|
return async (dispatch) => {
|
|
if (contextSrv.hasPermission(AccessControlAction.SettingsRead)) {
|
|
dispatch(loadingBegin());
|
|
dispatch(loadProviders());
|
|
const result = await getBackendSrv().get('/api/admin/settings');
|
|
dispatch(settingsUpdated(result));
|
|
await dispatch(loadProviderStatuses());
|
|
dispatch(loadingEnd());
|
|
return result;
|
|
}
|
|
};
|
|
}
|
|
|
|
export function loadProviders(provider = ''): ThunkResult<Promise<SSOProvider[]>> {
|
|
return async (dispatch) => {
|
|
if (!config.featureToggles.ssoSettingsApi) {
|
|
return [];
|
|
}
|
|
const result = await getBackendSrv().get(`/api/v1/sso-settings${provider ? `/${provider}` : ''}`);
|
|
dispatch(providersLoaded(provider ? [result] : result));
|
|
return result;
|
|
};
|
|
}
|
|
|
|
export function loadProviderStatuses(): ThunkResult<void> {
|
|
return async (dispatch) => {
|
|
const registeredProviders = getRegisteredAuthProviders();
|
|
const providerStatuses: Record<string, AuthProviderStatus> = {};
|
|
const getStatusPromises: Array<Promise<AuthProviderStatus>> = [];
|
|
for (const provider of registeredProviders) {
|
|
getStatusPromises.push(getAuthProviderStatus(provider.id));
|
|
}
|
|
const statuses = await Promise.all(getStatusPromises);
|
|
for (let i = 0; i < registeredProviders.length; i++) {
|
|
const provider = registeredProviders[i];
|
|
providerStatuses[provider.id] = statuses[i];
|
|
}
|
|
dispatch(providerStatusesLoaded(providerStatuses));
|
|
};
|
|
}
|
|
|
|
export function saveSettings(data: UpdateSettingsQuery): ThunkResult<Promise<boolean>> {
|
|
return async (dispatch) => {
|
|
if (contextSrv.hasPermission(AccessControlAction.SettingsWrite)) {
|
|
try {
|
|
await lastValueFrom(
|
|
getBackendSrv().fetch({
|
|
url: '/api/admin/settings',
|
|
method: 'PUT',
|
|
data,
|
|
showSuccessAlert: false,
|
|
showErrorAlert: false,
|
|
})
|
|
);
|
|
dispatch(resetError());
|
|
return true;
|
|
} catch (error) {
|
|
console.log(error);
|
|
if (isFetchError(error)) {
|
|
error.isHandled = true;
|
|
const updateErr: SettingsError = {
|
|
message: error.data?.message,
|
|
errors: error.data?.errors,
|
|
};
|
|
dispatch(setError(updateErr));
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
};
|
|
}
|