Throw on missing type of rich subject parameter

Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
pull/34807/head
Côme Chilliet 3 years ago
parent 8a04bf5584
commit f676076482
No known key found for this signature in database
GPG Key ID: A3E2F658B28C760A
  1. 12
      lib/private/Activity/Event.php
  2. 12
      lib/private/Notification/Notification.php

@ -276,19 +276,21 @@ class Event implements IEvent {
}
/**
* @throws \InvalidArgumentException if a parameter has no name
* @throws \InvalidArgumentException if a parameter has no name or no type
*/
private function richToParsed(string $message, array $parameters): string {
$placeholders = [];
$replacements = [];
foreach ($parameters as $placeholder => $parameter) {
$placeholders[] = '{' . $placeholder . '}';
if (!isset($parameter['name']) || !is_string($parameter['name'])) {
throw new \InvalidArgumentException('Invalid rich object, name field is missing');
foreach (['name','type'] as $requiredField) {
if (!isset($parameter[$requiredField]) || !is_string($parameter[$requiredField])) {
throw new \InvalidArgumentException("Invalid rich object, {$requiredField} field is missing");
}
}
if (($parameter['type'] ?? '') === 'user') {
if ($parameter['type'] === 'user') {
$replacements[] = '@' . $parameter['name'];
} elseif (($parameter['type'] ?? '') === 'file') {
} elseif ($parameter['type'] === 'file') {
$replacements[] = $parameter['path'] ?? $parameter['name'];
} else {
$replacements[] = $parameter['name'];

@ -303,19 +303,21 @@ class Notification implements INotification {
}
/**
* @throws \InvalidArgumentException if a parameter has no name
* @throws \InvalidArgumentException if a parameter has no name or no type
*/
private function richToParsed(string $message, array $parameters): string {
$placeholders = [];
$replacements = [];
foreach ($parameters as $placeholder => $parameter) {
$placeholders[] = '{' . $placeholder . '}';
if (!isset($parameter['name']) || !is_string($parameter['name'])) {
throw new \InvalidArgumentException('Invalid rich object, name field is missing');
foreach (['name','type'] as $requiredField) {
if (!isset($parameter[$requiredField]) || !is_string($parameter[$requiredField])) {
throw new \InvalidArgumentException("Invalid rich object, {$requiredField} field is missing");
}
}
if (($parameter['type'] ?? '') === 'user') {
if ($parameter['type'] === 'user') {
$replacements[] = '@' . $parameter['name'];
} elseif (($parameter['type'] ?? '') === 'file') {
} elseif ($parameter['type'] === 'file') {
$replacements[] = $parameter['path'] ?? $parameter['name'];
} else {
$replacements[] = $parameter['name'];

Loading…
Cancel
Save