Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 39 additions & 0 deletions ProcessMaker/Http/Controllers/Api/ProcessController.php
Original file line number Diff line number Diff line change
Expand Up @@ -601,6 +601,11 @@ public function update(Request $request, Process $process)
}
}

// Non-administrators cannot change retention metadata: persist pre-request values.
if (!auth()->user()->is_administrator) {
$this->restoreProcessRetentionPropertiesFromOriginal($process, $original);
}

// Catch errors to send more specific status
try {
$process->saveOrFail();
Expand Down Expand Up @@ -670,6 +675,40 @@ private function validateMaxManagers(Request $request)
return $managerIds;
}

/**
* Re-apply retention-related keys on $process->properties from the model snapshot taken before fill().
* Non-admins cannot add these keys if absent originally, or change values if present.
*
* @param array<string, mixed> $original
*/
private function restoreProcessRetentionPropertiesFromOriginal(Process $process, array $original): void
{
$originalProperties = $original['properties'] ?? null;
if (is_string($originalProperties)) {
$decoded = json_decode($originalProperties, true);
$originalProperties = is_array($decoded) ? $decoded : [];
}
if (!is_array($originalProperties)) {
$originalProperties = [];
}

$properties = $process->properties;
if (!is_array($properties)) {
$properties = [];
}

$keys = ['retention_updated_by', 'retention_updated_at', 'retention_period'];
foreach ($keys as $key) {
if (array_key_exists($key, $originalProperties)) {
$properties[$key] = $originalProperties[$key];
} else {
unset($properties[$key]);
}
}

$process->properties = $properties;
}

/**
* Validate the structure of stages.
*
Expand Down
Loading