Skip to content

Commit

Permalink
Merge pull request #142 from signify-nz/exclude-all-form-data
Browse files Browse the repository at this point in the history
Provide configuration to filter out all POSTed form data.
  • Loading branch information
Deacon-McIntyre authored Dec 5, 2021
2 parents 648acd7 + ea9cf55 commit b24d084
Show file tree
Hide file tree
Showing 3 changed files with 90 additions and 8 deletions.
5 changes: 5 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,11 @@ $raygunClient->setFilterParams([
// Example output: ['Email' => 'test@...']
```

If you want to ensure all form submission data is filtered out irrespective of field names for situations where there are a lot of forms that might request private information, you can do that too. The field names will still be transmitted, but the values will be filtered out.
```php
$raygunClient->setFilterAllFormValues(true);
```

Note that when any filters are defined, the Raygun error will no longer contain the raw HTTP data, since there's no effective way to filter it.

### Updating Cookie options
Expand Down
50 changes: 42 additions & 8 deletions src/Raygun4php/RaygunClient.php
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,11 @@ class RaygunClient
*/
protected $filterParams = array();

/**
* @var boolean If true, all values from the $_POST array will be filtered out.
*/
protected $filterAllFormValues = false;

/**
* Creates a new RaygunClient instance.
*
Expand Down Expand Up @@ -383,17 +388,18 @@ public function filterParamsFromMessage($message, $replace = '[filtered]')
{
$filterParams = $this->getFilterParams();

// Skip checks if none are defined
if (!$filterParams) {
// Skip checks if none are defined
if (!$filterParams && !$this->getFilterAllFormValues()) {
return $message;
}

// Ensure all filters are callable
// Ensure all filters are callable
$defaultFn = function ($key, $val) use ($replace) {
return $replace;
};
foreach ($filterParams as $filterKey => $filterFn) {
if (!is_callable($filterFn)) {
$filterParams[$filterKey] = function ($key, $val) use ($replace) {
return $replace;
};
$filterParams[$filterKey] = $defaultFn;
}
}

Expand All @@ -408,8 +414,18 @@ public function filterParamsFromMessage($message, $replace = '[filtered]')
}
};

// Filter form values
if ($message->Details->Request->Form) {
array_walk_recursive($message->Details->Request->Form, $walkFn);
if ($this->getFilterAllFormValues()) {
// Filter out ALL form values.
$filterAllDataFn = function (&$val, $key) use ($defaultFn) {
$val = $defaultFn($key, $val);
};
array_walk_recursive($message->Details->Request->Form, $filterAllDataFn);
} else {
// Filter only form values that match a filter param.
array_walk_recursive($message->Details->Request->Form, $walkFn);
}
}

if ($message->Details->Request->Headers) {
Expand All @@ -428,7 +444,7 @@ public function filterParamsFromMessage($message, $replace = '[filtered]')
array_walk_recursive($message->Details->UserCustomData, $walkFn);
}

// Unset raw HTTP data since we can't accurately filter it
// Unset raw HTTP data since we can't accurately filter it
if ($message->Details->Request->RawData) {
$message->Details->Request->RawData = null;
}
Expand All @@ -454,6 +470,24 @@ public function getFilterParams()
return $this->filterParams;
}

/**
* @param boolean $filterAll
* @return $this
*/
public function setFilterAllFormValues(bool $filterAll)
{
$this->filterAllFormValues = $filterAll;
return $this;
}

/**
* @return boolean
*/
public function getFilterAllFormValues()
{
return $this->filterAllFormValues;
}

/**
* Sets the given cookie options
*
Expand Down
43 changes: 43 additions & 0 deletions tests/RaygunClientTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,49 @@ public function testGetFilteredParamsParsesRegex()
);
}

public function testFilterAllFormValues()
{
$this->client->setFilterParams(array());
$this->client->setFilterAllFormValues(true);
$message = $this->getEmptyMessage();
$message->Details->Request->Form = array(
'MyParam' => 'some val',
'MyRegexParam' => 'secret',
);

$filteredMessage = $this->client->filterParamsFromMessage($message);
$this->assertEquals(
$filteredMessage->Details->Request->Form,
array(
'MyParam' => '[filtered]',
'MyRegexParam' => '[filtered]',
)
);
}

public function testFilterFormValuesDoesntFilterOtherValues()
{
$this->client->setFilterParams(array());
$this->client->setFilterAllFormValues(true);
$message = $this->getEmptyMessage();
$message->Details->Request->Headers = array(
'MyParam' => 'secret',
);
$message->Details->Request->Data = array(
'MyParam' => 'secret',
);

$filteredMessage = $this->client->filterParamsFromMessage($message);
$this->assertEquals(
$filteredMessage->Details->Request->Headers,
array('MyParam' => 'secret',)
);
$this->assertEquals(
$filteredMessage->Details->Request->Data,
array('MyParam' => 'secret',)
);
}

protected function getEmptyMessage()
{
$requestMessage = new RaygunRequestMessage();
Expand Down

0 comments on commit b24d084

Please sign in to comment.