diff --git a/CHANGELOG.md b/CHANGELOG.md index 33aab7b445..8db89a5fb1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,7 +10,7 @@ All notable changes to the Wazuh app project will be documented in this file. ### Changed -- +- Changed of regular expression in RBAC. [#5201](https://github.com/wazuh/wazuh-kibana-app/pull/5201) ### Fixed diff --git a/public/react-services/wz-user-permissions.ts b/public/react-services/wz-user-permissions.ts index 1b720620ba..523ad0777d 100644 --- a/public/react-services/wz-user-permissions.ts +++ b/public/react-services/wz-user-permissions.ts @@ -21,7 +21,7 @@ export class WzUserPermissions{ const missingOrPermissions = WzUserPermissions.checkMissingUserPermissions(permission, userPermissions); return Array.isArray(missingOrPermissions) ? missingOrPermissions.length === permission.length : missingOrPermissions; } - + const isGenericResource = (permission.resource.match(':\\*') || []).index === permission.resource.length - 2 const actionName = typeof permission === 'string' ? permission : permission.action; @@ -48,8 +48,8 @@ export class WzUserPermissions{ const simplePermission = (resource: string) => { return ( ![actionResource, actionResourceAll].includes(resource) && - (resource.match(actionResource.replace('*', '\\*')) || - resource.match(actionResourceAll.replace('*', '\*'))) + (resource.match(actionResource.replace(/\*/g, '.+')) || + resource.match(actionResourceAll.replace(/\*/g, '.+'))) ); }; @@ -102,10 +102,10 @@ export class WzUserPermissions{ return userPermissions[actionName][actionResource] ? notAllowInWazuhPermissions(actionResource) : Object.keys(userPermissions[actionName]).some((resource) => { - return resource.match(actionResourceAll.replace('*', '\\*')) !== null; + return resource.match(actionResourceAll.replace(/\*/g, '.+')) !== null; }) ? Object.keys(userPermissions[actionName]).some((resource) => { - if (resource.match(actionResourceAll.replace('*', '\\*'))) { + if (resource.match(actionResourceAll.replace(/\*/g, '.+'))) { return notAllowInWazuhPermissions(resource); } })