grafana/public/app/features/auth-config/state/actions.ts
Alex Khomenko fde8a00721
SSO: Add GitHub auth configuration page (#78933)
* 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
2023-12-21 15:26:42 +02:00

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;
};
}