1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

fix: handle empty strings on permissions gracefully in access service (#8306)

Splitting #8271 into smaller pieces. This first PR will focus on making
access service handle empty string inputs gracefully and converting them
to null before inserting them into the database.
This commit is contained in:
Fredrik Strand Oseberg 2024-10-01 09:03:46 +02:00 committed by GitHub
parent b037bfb71c
commit dcb0228105
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 131 additions and 3 deletions

View File

@ -108,6 +108,17 @@ export interface AccessWithRoles {
const isProjectPermission = (permission) => PROJECT_ADMIN.includes(permission); const isProjectPermission = (permission) => PROJECT_ADMIN.includes(permission);
export const cleanPermissionEnvironment = (
permissions: PermissionRef[] | undefined,
) => {
return permissions?.map((permission) => {
if (permission.environment === '') {
return { ...permission, environment: null };
}
return permission;
});
};
export class AccessService { export class AccessService {
private store: IAccessStore; private store: IAccessStore;
@ -721,7 +732,7 @@ export class AccessService {
roleType, roleType,
}; };
const rolePermissions = role.permissions; const rolePermissions = cleanPermissionEnvironment(role.permissions);
const newRole = await this.roleStore.create(baseRole); const newRole = await this.roleStore.create(baseRole);
if (rolePermissions) { if (rolePermissions) {
if (roleType === CUSTOM_ROOT_ROLE_TYPE) { if (roleType === CUSTOM_ROOT_ROLE_TYPE) {
@ -770,7 +781,7 @@ export class AccessService {
description: role.description, description: role.description,
roleType, roleType,
}; };
const rolePermissions = role.permissions; const rolePermissions = cleanPermissionEnvironment(role.permissions);
const updatedRole = await this.roleStore.update(baseRole); const updatedRole = await this.roleStore.update(baseRole);
const existingPermissions = await this.store.getPermissionsForRole( const existingPermissions = await this.store.getPermissionsForRole(
role.id, role.id,

View File

@ -0,0 +1,117 @@
import { cleanPermissionEnvironment } from './access-service';
test('should convert all empty strings to null', () => {
const permissions = [
{
name: 'UPDATE_PROJECT',
environment: '',
},
{
name: 'UPDATE_FEATURE_VARIANTS',
environment: '',
},
{
name: 'READ_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'CREATE_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'DELETE_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'UPDATE_PROJECT_SEGMENT',
environment: '',
},
];
const result = cleanPermissionEnvironment(permissions);
expect(result).toEqual([
{
name: 'UPDATE_PROJECT',
environment: null,
},
{
name: 'UPDATE_FEATURE_VARIANTS',
environment: null,
},
{
name: 'READ_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'CREATE_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'DELETE_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'UPDATE_PROJECT_SEGMENT',
environment: null,
},
]);
});
test('should handle some permissions already having null values', () => {
const permissions = [
{
name: 'UPDATE_PROJECT',
environment: null,
},
{
name: 'UPDATE_FEATURE_VARIANTS',
environment: null,
},
{
name: 'READ_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'CREATE_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'DELETE_PROJECT_API_TOKEN',
environment: '',
},
{
name: 'UPDATE_PROJECT_SEGMENT',
environment: '',
},
];
const result = cleanPermissionEnvironment(permissions);
expect(result).toEqual([
{
name: 'UPDATE_PROJECT',
environment: null,
},
{
name: 'UPDATE_FEATURE_VARIANTS',
environment: null,
},
{
name: 'READ_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'CREATE_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'DELETE_PROJECT_API_TOKEN',
environment: null,
},
{
name: 'UPDATE_PROJECT_SEGMENT',
environment: null,
},
]);
});

View File

@ -419,7 +419,7 @@ export interface IPermission {
name: string; name: string;
displayName: string; displayName: string;
type: string; type: string;
environment?: string; environment?: string | null;
} }
export interface IEnvironmentPermission { export interface IEnvironmentPermission {