0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -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', title: 'Comment Improvements',
description: 'Enables new comment features', description: 'Enables new comment features',
flag: 'commentImprovements' flag: 'commentImprovements'
}, {
title: 'Staff 2FA',
description: 'Enables email verification for staff logins',
flag: 'staff2fa'
}]; }];
const AlphaFeatures: React.FC = () => { const AlphaFeatures: React.FC = () => {

View file

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

View file

@ -8,22 +8,43 @@ test.describe('2FA', () => {
await sharedPage.goto('/ghost'); await sharedPage.goto('/ghost');
await sharedPage.locator('.gh-nav a[href="#/settings/"]').click(); await sharedPage.locator('.gh-nav a[href="#/settings/"]').click();
const section = sharedPage.getByTestId('labs'); // Make an API call to get settings
await section.getByRole('button', {name: 'Open'}).click(); 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(); // Update settings
await section.getByLabel('Staff 2FA').click(); await sharedPage.request.put(`${adminUrl}/api/admin/settings/`, {
data: {
settings
}
});
}); });
test.afterAll(async ({sharedPage}) => { test.afterAll(async ({sharedPage}) => {
await sharedPage.goto('/ghost'); // Make an API call to get settings
await sharedPage.locator('.gh-nav a[href="#/settings/"]').click(); 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'); // Update settings
await section.getByRole('button', {name: 'Open'}).click(); await sharedPage.request.put(`${adminUrl}/api/admin/settings/`, {
data: {
await section.getByRole('tab', {name: 'Alpha features'}).click(); settings
await section.getByLabel('Staff 2FA').click(); }
});
}); });
test('Logging in with 2FA works', async ({page, verificationToken}) => { test('Logging in with 2FA works', async ({page, verificationToken}) => {

View file

@ -69,24 +69,30 @@ test.describe('Portal', () => {
}); });
test.describe('2FA invite test', () => { 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}) => { test('New staff member can signup using an invite link with 2FA enabled', async ({sharedPage}) => {
// Navigate to settings // Navigate to settings
await sharedPage.goto('/ghost'); await sharedPage.goto('/ghost');
await sharedPage.locator('[data-test-nav="settings"]').click(); await sharedPage.locator('[data-test-nav="settings"]').click();
await sharedPage.waitForLoadState('networkidle'); 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'; const testEmail = 'test@gmail.com';
// Send the invitation // Send the invitation
@ -115,7 +121,6 @@ test.describe('Portal', () => {
const token = invite.get('token'); const token = invite.get('token');
// Construct the invite URL // Construct the invite URL
const adminUrl = new URL(sharedPage.url()).origin + '/ghost';
const encodedToken = security.url.encodeBase64(token); const encodedToken = security.url.encodeBase64(token);
const inviteUrl = `${adminUrl}/signup/${encodedToken}/`; const inviteUrl = `${adminUrl}/signup/${encodedToken}/`;
const context = await sharedPage.context(); const context = await sharedPage.context();