Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
3.5 KiB
3.5 KiB
Tag Permissions Requirements
Overview
This document outlines the permission requirements for tag functionality in the system. The permissions are based on a combination of tagged entity permissions and tag-specific permissions.
Permission Matrix
1. View Tags
Action: Display tags on an entity
Required Permissions:
- Read permission for the tagged entity (e.g.,
ticket:read,project:read,company:read)
2. Create New Tag
Action: Create a brand new tag with custom text
Required Permissions:
- Update permission for the tagged entity (e.g.,
ticket:update,project:update) tag:createpermission
3. Add Existing Tag
Action: Select and add a tag from the suggestion dropdown
Required Permissions:
- Update permission for the tagged entity (e.g.,
ticket:update,project:update) - Note:
tag:createpermission is NOT required for adding existing tags
4. Edit Tag Properties
Action: Modify tag text or colors
Required Permissions:
- Update permission for the tagged entity
tag:updatepermission
5. Delete Single Tag
Action: Remove a single tag from an entity
Required Permissions:
- Update permission for the tagged entity
- Additional Check: User can only delete tags they created (requires
created_byfield) - Note: Legacy tags without
created_bycan be deleted by anyone with entity update permission
6. Delete All Tags
Action: Remove all instances of a tag across entities (Delete All button)
Required Permissions:
- Update permission for the tagged entity
tag:deletepermission
Entity Type Mapping
The tagged_type field in tag_definitions table maps to the following entities:
| tagged_type | Required Entity Permission |
|---|---|
| company | company:[action] |
| contact | contact:[action] |
| ticket | ticket:[action] |
| project | project:[action] |
| project_task | project_task:[action] |
| workflow_form | workflow_form:[action] |
Implementation Notes
Implementation Approach
- Permission checks are implemented server-side in tag actions
- Follows the existing pattern used throughout the application (e.g., ticket actions)
- Uses
hasPermissionfrom the RBAC module with user, resource, and action parameters - Throws descriptive error messages when permissions are denied
Updated Data
- The
created_bycolumn is now populated for new tag mappings - The
Tag.insertmethod accepts an optional userId parameter - The
createTagaction gets the current user and passes it to Tag.insert
User Experience
- When a user lacks permissions, actions throw errors with clear messages
- Client-side components should handle these errors and display appropriate feedback
- The TagContext handles permission errors and shows toast notifications
Updated Actions
All tag actions now include permission checks:
createTag- Checks entity update permission; tag create permission only required for new tagsupdateTag- Checks entity update + tag update permissionsdeleteTag- Checks entity update + verifies user created the tagupdateTagColor- Checks entity update + tag update permissionsupdateTagText- Checks entity update + tag update permissionsdeleteAllTagsByText- Checks entity update + tag delete permissions
Error Handling Pattern
if (!await hasPermission(currentUser, entityResource, 'update', trx)) {
throw new Error(`Permission denied: Cannot update ${tag.tagged_type.replace('_', ' ')}`);
}