0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Moved staff2fa flag to BETA_FEATURES (#21749)

Closes https://linear.app/ghost/issue/ENG-1800/move-staff2fa-to-beta-features-and-disable-developer-experiments

Currently we have this flag in ALPHA_FEATURES. We want to enable 2fa for selected sites but we would want to disable developer experiments for them, so they don't see the UI and enable random things.
This commit is contained in:
Princi Vershwal 2024-11-28 17:43:59 +05:30 committed by GitHub
parent 0f5fb0a2f5
commit 6a70ba8895
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 53 additions and 31 deletions

View file

@ -59,10 +59,6 @@ const features = [{
title: 'Comment Improvements',
description: 'Enables new comment features',
flag: 'commentImprovements'
}, {
title: 'Staff 2FA',
description: 'Enables email verification for staff logins',
flag: 'staff2fa'
}];
const AlphaFeatures: React.FC = () => {

View file

@ -32,7 +32,8 @@ const BETA_FEATURES = [
'editorExcerpt',
'ActivityPub',
'importMemberTier',
'customFonts'
'customFonts',
'staff2fa'
];
const ALPHA_FEATURES = [
@ -45,8 +46,7 @@ const ALPHA_FEATURES = [
'lexicalIndicators',
'adminXDemo',
'contentVisibility',
'commentImprovements',
'staff2fa'
'commentImprovements'
];
module.exports.GA_KEYS = [...GA_FEATURES];

View file

@ -8,22 +8,43 @@ test.describe('2FA', () => {
await sharedPage.goto('/ghost');
await sharedPage.locator('.gh-nav a[href="#/settings/"]').click();
const section = sharedPage.getByTestId('labs');
await section.getByRole('button', {name: 'Open'}).click();
// Make an API call to get settings
const adminUrl = new URL(sharedPage.url()).origin + '/ghost';
const settingsResponse = await sharedPage.request.get(`${adminUrl}/api/admin/settings/`);
const settingsData = await settingsResponse.json();
// Add staff2fa flag to labs settings
const settings = settingsData.settings;
const labsSetting = settings.find(s => s.key === 'labs');
const labsValue = JSON.parse(labsSetting.value);
labsValue.staff2fa = true;
labsSetting.value = JSON.stringify(labsValue);
await section.getByRole('tab', {name: 'Alpha features'}).click();
await section.getByLabel('Staff 2FA').click();
// Update settings
await sharedPage.request.put(`${adminUrl}/api/admin/settings/`, {
data: {
settings
}
});
});
test.afterAll(async ({sharedPage}) => {
await sharedPage.goto('/ghost');
await sharedPage.locator('.gh-nav a[href="#/settings/"]').click();
// Make an API call to get settings
const adminUrl = new URL(sharedPage.url()).origin + '/ghost';
const settingsResponse = await sharedPage.request.get(`${adminUrl}/api/admin/settings/`);
const settingsData = await settingsResponse.json();
// Remove staff2fa flag from labs settings
const settings = settingsData.settings;
const labsSetting = settings.find(s => s.key === 'labs');
const labsValue = JSON.parse(labsSetting.value);
delete labsValue.staff2fa;
labsSetting.value = JSON.stringify(labsValue);
const section = sharedPage.getByTestId('labs');
await section.getByRole('button', {name: 'Open'}).click();
await section.getByRole('tab', {name: 'Alpha features'}).click();
await section.getByLabel('Staff 2FA').click();
// Update settings
await sharedPage.request.put(`${adminUrl}/api/admin/settings/`, {
data: {
settings
}
});
});
test('Logging in with 2FA works', async ({page, verificationToken}) => {

View file

@ -69,24 +69,30 @@ test.describe('Portal', () => {
});
test.describe('2FA invite test', () => {
test.beforeEach(async ({sharedPage}) => {
// Enable 2FA
await sharedPage.goto('/ghost');
await sharedPage.locator('[data-test-nav="settings"]').click();
const section = sharedPage.getByTestId('labs');
await section.getByRole('button', {name: 'Open'}).click();
await section.getByRole('tab', {name: 'Alpha features'}).click();
await section.getByLabel('Staff 2FA').click();
});
test('New staff member can signup using an invite link with 2FA enabled', async ({sharedPage}) => {
// Navigate to settings
await sharedPage.goto('/ghost');
await sharedPage.locator('[data-test-nav="settings"]').click();
await sharedPage.waitForLoadState('networkidle');
// Make an API call to get settings
const adminUrl = new URL(sharedPage.url()).origin + '/ghost';
const settingsResponse = await sharedPage.request.get(`${adminUrl}/api/admin/settings/`);
const settingsData = await settingsResponse.json();
// Add staff2fa flag to labs settings
const settings = settingsData.settings;
const labsSetting = settings.find(s => s.key === 'labs');
const labsValue = JSON.parse(labsSetting.value);
labsValue.staff2fa = true;
labsSetting.value = JSON.stringify(labsValue);
// Update settings
await sharedPage.request.put(`${adminUrl}/api/admin/settings/`, {
data: {
settings
}
});
const testEmail = 'test@gmail.com';
// Send the invitation
@ -115,7 +121,6 @@ test.describe('Portal', () => {
const token = invite.get('token');
// Construct the invite URL
const adminUrl = new URL(sharedPage.url()).origin + '/ghost';
const encodedToken = security.url.encodeBase64(token);
const inviteUrl = `${adminUrl}/signup/${encodedToken}/`;
const context = await sharedPage.context();