aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/api
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-web/src/main/js/api')
-rw-r--r--server/sonar-web/src/main/js/api/mocks/AuthenticationServiceMock.ts71
-rw-r--r--server/sonar-web/src/main/js/api/settings.ts14
2 files changed, 74 insertions, 11 deletions
diff --git a/server/sonar-web/src/main/js/api/mocks/AuthenticationServiceMock.ts b/server/sonar-web/src/main/js/api/mocks/AuthenticationServiceMock.ts
index 8aba451dd6e..f4986f2d69b 100644
--- a/server/sonar-web/src/main/js/api/mocks/AuthenticationServiceMock.ts
+++ b/server/sonar-web/src/main/js/api/mocks/AuthenticationServiceMock.ts
@@ -21,32 +21,79 @@ import { cloneDeep } from 'lodash';
import { mockSettingValue } from '../../helpers/mocks/settings';
import { BranchParameters } from '../../types/branch-like';
import { SettingDefinition, SettingValue } from '../../types/settings';
-import { getValues, resetSettingValue, setSettingValue } from '../settings';
+import {
+ activateScim,
+ deactivateScim,
+ fetchIsScimEnabled,
+ getValues,
+ resetSettingValue,
+ setSettingValue,
+} from '../settings';
export default class AuthenticationServiceMock {
settingValues: SettingValue[];
+ scimStatus: boolean;
defaulSettingValues: SettingValue[] = [
mockSettingValue({ key: 'test1', value: '' }),
mockSettingValue({ key: 'test2', value: 'test2' }),
- mockSettingValue({ key: 'sonar.auth.saml.certificate.secured' }),
- mockSettingValue({ key: 'sonar.auth.saml.enabled', value: 'false' }),
+ {
+ key: 'sonar.auth.saml.signature.enabled',
+ value: 'false',
+ inherited: true,
+ },
+ {
+ key: 'sonar.auth.saml.enabled',
+ value: 'false',
+ inherited: true,
+ },
+ {
+ key: 'sonar.auth.saml.applicationId',
+ value: 'sonarqube',
+ inherited: true,
+ },
+ {
+ key: 'sonar.auth.saml.providerName',
+ value: 'SAML',
+ inherited: true,
+ },
];
constructor() {
this.settingValues = cloneDeep(this.defaulSettingValues);
- (getValues as jest.Mock).mockImplementation(this.getValuesHandler);
- (setSettingValue as jest.Mock).mockImplementation(this.setValueHandler);
- (resetSettingValue as jest.Mock).mockImplementation(this.resetValueHandler);
+ this.scimStatus = false;
+ jest.mocked(getValues).mockImplementation(this.handleGetValues);
+ jest.mocked(setSettingValue).mockImplementation(this.handleSetValue);
+ jest.mocked(resetSettingValue).mockImplementation(this.handleResetValue);
+ jest.mocked(activateScim).mockImplementation(this.handleActivateScim);
+ jest.mocked(deactivateScim).mockImplementation(this.handleDeactivateScim);
+
+ jest.mocked(fetchIsScimEnabled).mockImplementation(this.handleFetchIsScimEnabled);
}
- getValuesHandler = (data: { keys: string; component?: string } & BranchParameters) => {
- if (data.keys) {
+ handleActivateScim = () => {
+ this.scimStatus = true;
+ return Promise.resolve();
+ };
+
+ handleDeactivateScim = () => {
+ this.scimStatus = false;
+ return Promise.resolve();
+ };
+
+ handleFetchIsScimEnabled = () => {
+ return Promise.resolve(this.scimStatus);
+ };
+
+ handleGetValues = (
+ data: { keys: string[]; component?: string } & BranchParameters
+ ): Promise<SettingValue[]> => {
+ if (data.keys.length > 1) {
return Promise.resolve(this.settingValues.filter((set) => data.keys.includes(set.key)));
}
return Promise.resolve(this.settingValues);
};
- setValueHandler = (definition: SettingDefinition, value: string) => {
+ handleSetValue = (definition: SettingDefinition, value: string | boolean) => {
if (value === 'error') {
const res = new Response('', {
status: 400,
@@ -57,12 +104,14 @@ export default class AuthenticationServiceMock {
}
const updatedSettingValue = this.settingValues.find((set) => set.key === definition.key);
if (updatedSettingValue) {
- updatedSettingValue.value = value;
+ updatedSettingValue.value = String(value);
+ } else {
+ this.settingValues.push({ key: definition.key, value: String(value), inherited: false });
}
return Promise.resolve();
};
- resetValueHandler = (data: { keys: string; component?: string } & BranchParameters) => {
+ handleResetValue = (data: { keys: string; component?: string } & BranchParameters) => {
if (data.keys) {
this.settingValues.forEach((set) => {
if (data.keys.includes(set.key)) {
diff --git a/server/sonar-web/src/main/js/api/settings.ts b/server/sonar-web/src/main/js/api/settings.ts
index 1d81865ddbe..d741cb0bc00 100644
--- a/server/sonar-web/src/main/js/api/settings.ts
+++ b/server/sonar-web/src/main/js/api/settings.ts
@@ -116,3 +116,17 @@ export function encryptValue(value: string): Promise<{ encryptedValue: string }>
export function getLoginMessage(): Promise<{ message: string }> {
return getJSON('/api/settings/login_message').catch(throwGlobalError);
}
+
+export function fetchIsScimEnabled(): Promise<boolean> {
+ return getJSON('/api/scim_management/status')
+ .then((r) => r.enabled)
+ .catch(throwGlobalError);
+}
+
+export function activateScim(): Promise<void> {
+ return post('/api/scim_management/enable').catch(throwGlobalError);
+}
+
+export function deactivateScim(): Promise<void> {
+ return post('/api/scim_management/disable').catch(throwGlobalError);
+}