VYPR
High severity8.3NVD Advisory· Published Apr 10, 2026· Updated Apr 17, 2026

CVE-2026-35595

CVE-2026-35595

Description

Vikunja is an open-source self-hosted task management platform. Prior to 2.3.0, the CanUpdate check at pkg/models/project_permissions.go:139-148 only requires CanWrite on the new parent project when changing parent_project_id. However, Vikunja's permission model uses a recursive CTE that walks up the project hierarchy to compute permissions. Moving a project under a different parent changes the permission inheritance chain. When a user has inherited Write access (from a parent project share) and reparents the child project under their own project tree, the CTE resolves their ownership of the new parent as Admin (permission level 2) on the moved project. This vulnerability is fixed in 2.3.0.

Affected packages

Versions sourced from the GitHub Security Advisory.

PackageAffected versionsPatched versions
code.vikunja.io/apiGo
< 2.3.02.3.0

Affected products

1

Patches

1
c03d682f48af

test(project): fix ParadeDB search expectation for fixture child

https://github.com/go-vikunja/vikunjakolaenteApr 9, 2026via ghsa
1 file changed · +4 1
  • pkg/models/project_test.go+4 1 modified
    @@ -591,12 +591,15 @@ func TestProject_ReadAll(t *testing.T) {
     		if db.ParadeDBAvailable() {
     			// ParadeDB fuzzy(1, prefix=true) on "TEST10" also matches
     			// "test1", "test11", "test19", "test30" (edit distance 1), etc.
    -			require.Len(t, ls, 6)
    +			// The recursive CTE also pulls in project 43 as a child of the
    +			// matched project 10 (reparent-escalation fixture).
    +			require.Len(t, ls, 7)
     			projectIDs := make([]int64, len(ls))
     			for i, p := range ls {
     				projectIDs[i] = p.ID
     			}
     			assert.Contains(t, projectIDs, int64(10))
    +			assert.Contains(t, projectIDs, int64(43))
     			assert.Contains(t, projectIDs, int64(-1))
     		} else {
     			// Expect project 10 (the search target), project 43 (its child —
    

Vulnerability mechanics

Generated by null/stub on May 9, 2026. Inputs: CWE entries + fix-commit diffs from this CVE's patches. Citations validated against bundle.

References

6

News mentions

0

No linked articles in our index yet.