1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00

chore: remove customRootRoles flag in favor of killswitch (#4431)

https://linear.app/unleash/issue/2-1303/adapt-existing-customrootroles-flag-to-a-customrootroleskillswitch

Removes the existing `customRootRoles` flag in favor of a
`customRootRolesKillSwitch` which should follow the same logic but
negated/inverted.

Once released, this will effectively make custom root roles GA, and we
can use
[customRootRolesKillSwitch](https://app.unleash-hosted.com/hosted/projects/eg/features/customRootRolesKillSwitch)
to disable the feature if needed.
This commit is contained in:
Nuno Góis 2023-08-10 13:11:55 +01:00 committed by GitHub
parent 22273d79e3
commit ded33a6d81
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 19 additions and 107 deletions

View File

@ -41,7 +41,7 @@ export const RolesPage = () => {
const [modalOpen, setModalOpen] = useState(false);
const [selectedRole, setSelectedRole] = useState<IRole>();
const tabs = uiConfig.flags.customRootRoles
const tabs = !uiConfig.flags.customRootRolesKillSwitch
? [
{
label: 'Root roles',
@ -65,7 +65,8 @@ export const RolesPage = () => {
const isSmallScreen = useMediaQuery(theme.breakpoints.down('md'));
const type =
!uiConfig.flags.customRootRoles || pathname.includes('project-roles')
uiConfig.flags.customRootRolesKillSwitch ||
pathname.includes('project-roles')
? PROJECT_ROLE_TYPE
: ROOT_ROLE_TYPE;
@ -157,7 +158,7 @@ export const RolesPage = () => {
element={
<RolesTable
type={
uiConfig.flags.customRootRoles
!uiConfig.flags.customRootRolesKillSwitch
? ROOT_ROLE_TYPE
: PROJECT_ROLE_TYPE
}

View File

@ -50,7 +50,7 @@ export interface IFlags {
disableBulkToggle?: boolean;
disableNotifications?: boolean;
advancedPlayground?: boolean;
customRootRoles?: boolean;
customRootRolesKillSwitch?: boolean;
strategyVariant?: boolean;
newProjectLayout?: boolean;
configurableFeatureTypeLifetimes?: boolean;

View File

@ -70,7 +70,7 @@ exports[`should create default config 1`] = `
"anonymiseEventLog": false,
"caseInsensitiveInOperators": false,
"configurableFeatureTypeLifetimes": false,
"customRootRoles": false,
"customRootRolesKillSwitch": false,
"demo": false,
"disableBulkToggle": false,
"disableNotifications": false,
@ -107,7 +107,7 @@ exports[`should create default config 1`] = `
"anonymiseEventLog": false,
"caseInsensitiveInOperators": false,
"configurableFeatureTypeLifetimes": false,
"customRootRoles": false,
"customRootRolesKillSwitch": false,
"demo": false,
"disableBulkToggle": false,
"disableNotifications": false,

View File

@ -14,12 +14,12 @@ import FakeEventStore from '../../test/fixtures/fake-event-store';
import { IRole } from 'lib/types/stores/access-store';
import { IGroup } from 'lib/types';
function getSetup(customRootRoles: boolean = false) {
function getSetup(customRootRolesKillSwitch: boolean = true) {
const config = createTestConfig({
getLogger,
experimental: {
flags: {
customRootRoles: customRootRoles,
customRootRolesKillSwitch,
},
},
});
@ -161,7 +161,7 @@ test('should be able to validate and cleanup with additional properties', async
});
test('user with custom root role should get a user root role', async () => {
const { accessService } = getSetup(true);
const { accessService } = getSetup(false);
const customRootRole = await accessService.createRole({
name: 'custom-root-role',
description: 'test custom root role',
@ -185,11 +185,6 @@ test('throws error when trying to delete a project role in use by group', async
};
const config = createTestConfig({
getLogger,
experimental: {
flags: {
customRootRoles: false,
},
},
});
const eventStore = new FakeEventStore();

View File

@ -519,7 +519,7 @@ export class AccessService {
if (
roleType === CUSTOM_ROOT_ROLE_TYPE &&
!this.flagResolver.isEnabled('customRootRoles')
this.flagResolver.isEnabled('customRootRolesKillSwitch')
) {
throw new InvalidOperationError(
'Custom root roles are not enabled.',
@ -557,7 +557,7 @@ export class AccessService {
if (
roleType === CUSTOM_ROOT_ROLE_TYPE &&
!this.flagResolver.isEnabled('customRootRoles')
this.flagResolver.isEnabled('customRootRolesKillSwitch')
) {
throw new InvalidOperationError(
'Custom root roles are not enabled.',

View File

@ -20,7 +20,6 @@ export type IFlagKey =
| 'disableBulkToggle'
| 'disableNotifications'
| 'advancedPlayground'
| 'customRootRoles'
| 'strategyVariant'
| 'newProjectLayout'
| 'slackAppAddon'
@ -29,7 +28,8 @@ export type IFlagKey =
| 'filterInvalidClientMetrics'
| 'frontendNavigationUpdate'
| 'lastSeenByEnvironment'
| 'segmentChangeRequests';
| 'segmentChangeRequests'
| 'customRootRolesKillSwitch';
export type IFlags = Partial<{ [key in IFlagKey]: boolean | Variant }>;
@ -97,10 +97,6 @@ const flags: IFlags = {
process.env.DISABLE_NOTIFICATIONS,
false,
),
customRootRoles: parseEnvVarBoolean(
process.env.UNLEASH_EXPERIMENTAL_CUSTOM_ROOT_ROLES,
false,
),
newProjectLayout: parseEnvVarBoolean(
process.env.UNLEASH_EXPERIMENTAL_NEW_PROJECT_LAYOUT,
false,
@ -113,7 +109,6 @@ const flags: IFlags = {
process.env.UNLEASH_SLACK_APP_ADDON,
false,
),
emitPotentiallyStaleEvents: parseEnvVarBoolean(
process.env.UNLEASH_EXPERIMENTAL_EMIT_POTENTIALLY_STALE_EVENTS,
false,
@ -138,6 +133,10 @@ const flags: IFlags = {
process.env.UNLEASH_EXPERIMENTAL_SEGMENT_CHANGE_REQUESTS,
false,
),
customRootRolesKillSwitch: parseEnvVarBoolean(
process.env.UNLEASH_EXPERIMENTAL_CUSTOM_ROOT_ROLES_KILL_SWITCH,
false,
),
};
export const defaultExperimentalOptions: IExperimentalOptions = {

View File

@ -206,13 +206,7 @@ test('A role with only CREATE_PROJECT_API_TOKEN can create project tokens', asyn
});
};
const { request, destroy } = await setupAppWithCustomAuth(stores, preHook, {
experimental: {
flags: {
customRootRoles: true,
},
},
});
const { request, destroy } = await setupAppWithCustomAuth(stores, preHook);
await request
.post('/api/admin/projects/default/api-tokens')
@ -261,13 +255,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
await request
.post('/api/admin/api-tokens')
@ -312,13 +299,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
await request
.post('/api/admin/api-tokens')
@ -363,13 +343,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
await request
.post('/api/admin/api-tokens')
@ -417,13 +390,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
await stores.apiTokenStore.insert({
username: 'client',
@ -486,13 +452,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
await stores.apiTokenStore.insert({
username: 'client',
@ -650,13 +609,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'cilent',
@ -706,13 +658,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'frontend',
@ -763,13 +708,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'admin',
@ -823,13 +761,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'cilent',
@ -879,13 +810,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'frontend',
@ -935,13 +859,6 @@ describe('Fine grained API token permissions', () => {
const { request, destroy } = await setupAppWithCustomAuth(
stores,
preHook,
{
experimental: {
flags: {
customRootRoles: true,
},
},
},
);
const token = await stores.apiTokenStore.insert({
username: 'admin',