refactor(editor): Remove legacy audit logs view (no-changelog) (#9053)

This commit is contained in:
Iván Ovejero 2024-04-05 10:23:27 +02:00 committed by GitHub
parent 637b6c4d3e
commit ba986fb018
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 1 additions and 147 deletions

View file

@ -83,14 +83,7 @@ export default defineComponent({
available: this.canAccessExternalSecrets(), available: this.canAccessExternalSecrets(),
route: { to: { name: VIEWS.EXTERNAL_SECRETS_SETTINGS } }, route: { to: { name: VIEWS.EXTERNAL_SECRETS_SETTINGS } },
}, },
{
id: 'settings-audit-logs',
icon: 'clipboard-list',
label: this.$locale.baseText('settings.auditLogs.title'),
position: 'top',
available: this.canAccessAuditLogs(),
route: { to: { name: VIEWS.AUDIT_LOGS } },
},
{ {
id: 'settings-source-control', id: 'settings-source-control',
icon: 'code-branch', icon: 'code-branch',
@ -189,9 +182,6 @@ export default defineComponent({
canAccessSourceControl(): boolean { canAccessSourceControl(): boolean {
return this.canUserAccessRouteByName(VIEWS.SOURCE_CONTROL); return this.canUserAccessRouteByName(VIEWS.SOURCE_CONTROL);
}, },
canAccessAuditLogs(): boolean {
return this.canUserAccessRouteByName(VIEWS.AUDIT_LOGS);
},
canAccessSso(): boolean { canAccessSso(): boolean {
return this.canUserAccessRouteByName(VIEWS.SSO_SETTINGS); return this.canUserAccessRouteByName(VIEWS.SSO_SETTINGS);
}, },

View file

@ -466,7 +466,6 @@ export const enum VIEWS {
EXTERNAL_SECRETS_SETTINGS = 'ExternalSecretsSettings', EXTERNAL_SECRETS_SETTINGS = 'ExternalSecretsSettings',
SAML_ONBOARDING = 'SamlOnboarding', SAML_ONBOARDING = 'SamlOnboarding',
SOURCE_CONTROL = 'SourceControl', SOURCE_CONTROL = 'SourceControl',
AUDIT_LOGS = 'AuditLogs',
MFA_VIEW = 'MfaView', MFA_VIEW = 'MfaView',
WORKFLOW_HISTORY = 'WorkflowHistory', WORKFLOW_HISTORY = 'WorkflowHistory',
WORKER_VIEW = 'WorkerView', WORKER_VIEW = 'WorkerView',

View file

@ -1783,10 +1783,6 @@
"settings.sourceControl.error.not.connected.title": "Environments have not been enabled", "settings.sourceControl.error.not.connected.title": "Environments have not been enabled",
"settings.sourceControl.error.not.connected.message": "Please head over to <a href='/settings/environments'>environment settings</a> to connect a git repository first to activate this functionality.", "settings.sourceControl.error.not.connected.message": "Please head over to <a href='/settings/environments'>environment settings</a> to connect a git repository first to activate this functionality.",
"showMessage.cancel": "@:_reusableBaseText.cancel", "showMessage.cancel": "@:_reusableBaseText.cancel",
"settings.auditLogs.title": "Audit Logs",
"settings.auditLogs.actionBox.title": "Available on the Enterprise plan",
"settings.auditLogs.actionBox.description": "Upgrade to see the audit logs of your n8n instance.",
"settings.auditLogs.actionBox.buttonText": "See plans",
"showMessage.ok": "OK", "showMessage.ok": "OK",
"showMessage.showDetails": "Show Details", "showMessage.showDetails": "Show Details",
"startupError": "Error connecting to n8n", "startupError": "Error connecting to n8n",

View file

@ -1,5 +1,3 @@
import { useStorage } from '@/composables/useStorage';
import type { import type {
NavigationGuardNext, NavigationGuardNext,
RouteLocation, RouteLocation,
@ -59,7 +57,6 @@ const SignoutView = async () => await import('@/views/SignoutView.vue');
const SamlOnboarding = async () => await import('@/views/SamlOnboarding.vue'); const SamlOnboarding = async () => await import('@/views/SamlOnboarding.vue');
const SettingsSourceControl = async () => await import('./views/SettingsSourceControl.vue'); const SettingsSourceControl = async () => await import('./views/SettingsSourceControl.vue');
const SettingsExternalSecrets = async () => await import('./views/SettingsExternalSecrets.vue'); const SettingsExternalSecrets = async () => await import('./views/SettingsExternalSecrets.vue');
const SettingsAuditLogs = async () => await import('./views/SettingsAuditLogs.vue');
const WorkerView = async () => await import('./views/WorkerView.vue'); const WorkerView = async () => await import('./views/WorkerView.vue');
const WorkflowHistory = async () => await import('@/views/WorkflowHistory.vue'); const WorkflowHistory = async () => await import('@/views/WorkflowHistory.vue');
const WorkflowOnboardingView = async () => await import('@/views/WorkflowOnboardingView.vue'); const WorkflowOnboardingView = async () => await import('@/views/WorkflowOnboardingView.vue');
@ -712,32 +709,6 @@ export const routes = [
}, },
}, },
}, },
{
path: 'audit-logs',
name: VIEWS.AUDIT_LOGS,
components: {
settingsView: SettingsAuditLogs,
},
meta: {
middleware: ['authenticated', 'rbac', 'custom'],
middlewareOptions: {
custom: () => {
return !!useStorage('audit-logs').value;
},
rbac: {
scope: 'auditLogs:manage',
},
},
telemetry: {
pageCategory: 'settings',
getProperties(route: RouteLocation) {
return {
feature: 'audit-logs',
};
},
},
},
},
], ],
}, },
{ {

View file

@ -1,43 +0,0 @@
<script lang="ts" setup>
import { useI18n } from '@/composables/useI18n';
import { useAuditLogsStore } from '@/stores/auditLogs.store';
import { useUIStore } from '@/stores/ui.store';
const locale = useI18n();
const uiStore = useUIStore();
const auditLogsStore = useAuditLogsStore();
const goToUpgrade = () => {
void uiStore.goToUpgrade('audit-logs', 'upgrade-audit-logs');
};
</script>
<template>
<div>
<n8n-heading size="2xlarge" tag="h1">{{
locale.baseText('settings.auditLogs.title')
}}</n8n-heading>
<div
v-if="auditLogsStore.isEnterpriseAuditLogsFeatureEnabled"
data-test-id="audit-logs-content-licensed"
></div>
<n8n-action-box
v-else
data-test-id="audit-logs-content-unlicensed"
:class="$style.actionBox"
:description="locale.baseText('settings.auditLogs.actionBox.description')"
:button-text="locale.baseText('settings.auditLogs.actionBox.buttonText')"
@click:button="goToUpgrade"
>
<template #heading>
<span>{{ locale.baseText('settings.auditLogs.actionBox.title') }}</span>
</template>
</n8n-action-box>
</div>
</template>
<style lang="scss" module>
.actionBox {
margin: var(--spacing-2xl) 0 0;
}
</style>

View file

@ -1,59 +0,0 @@
import { vi } from 'vitest';
import { createPinia, setActivePinia } from 'pinia';
import { useAuditLogsStore } from '@/stores/auditLogs.store';
import { useSettingsStore } from '@/stores/settings.store';
import SettingsAuditLogs from '@/views/SettingsAuditLogs.vue';
import { createComponentRenderer } from '@/__tests__/render';
import { EnterpriseEditionFeature } from '@/constants';
import { nextTick } from 'vue';
import { setupServer } from '@/__tests__/server';
let pinia: ReturnType<typeof createPinia>;
let settingsStore: ReturnType<typeof useSettingsStore>;
let auditLogsStore: ReturnType<typeof useAuditLogsStore>;
let server: ReturnType<typeof setupServer>;
const renderComponent = createComponentRenderer(SettingsAuditLogs);
describe('SettingsAuditLogs', () => {
beforeAll(() => {
server = setupServer();
});
beforeEach(async () => {
pinia = createPinia();
setActivePinia(pinia);
settingsStore = useSettingsStore();
auditLogsStore = useAuditLogsStore();
await settingsStore.getSettings();
});
afterEach(() => {
vi.clearAllMocks();
});
afterAll(() => {
server.shutdown();
});
it('should render paywall state when there is no license', async () => {
settingsStore.settings.enterprise[EnterpriseEditionFeature.AuditLogs] = false;
await nextTick();
const { getByTestId, queryByTestId } = renderComponent({ pinia });
expect(queryByTestId('audit-logs-content-licensed')).not.toBeInTheDocument();
expect(getByTestId('audit-logs-content-unlicensed')).toBeInTheDocument();
});
it('should render licensed content', async () => {
settingsStore.settings.enterprise[EnterpriseEditionFeature.AuditLogs] = true;
await nextTick();
const { getByTestId, queryByTestId } = renderComponent({ pinia });
expect(getByTestId('audit-logs-content-licensed')).toBeInTheDocument();
expect(queryByTestId('audit-logs-content-unlicensed')).not.toBeInTheDocument();
});
});