for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/**
* This software package is licensed under AGPL or Commercial license.
*
* @package maslosoft/mangan
* @licence AGPL or Commercial
* @copyright Copyright (c) Piotr Masełkowski <[email protected]>
* @copyright Copyright (c) Maslosoft
* @copyright Copyright (c) Others as mentioned in code
* @link https://maslosoft.com/mangan/
*/
namespace Maslosoft\Mangan\Sanitizers;
use Maslosoft\Mangan\Interfaces\Sanitizers\Property\SanitizerInterface;
use UnexpectedValueException;
* String
* This sanitizer forces values to be string
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
class StringSanitizer implements SanitizerInterface
{
public function read($model, $dbValue)
$this->check($model, $dbValue);
if(empty($dbValue))
return '';
}
return (string) $dbValue;
public function write($model, $phpValue)
$this->check($model, $phpValue);
if(empty($phpValue))
return (string) $phpValue;
private function check($model, $value)
if (is_array($value))
$params = [
get_class($model),
var_export($value, true)
];
$msg = vsprintf('Got array (expected string) on model `%s`: %s', $params);
throw new UnexpectedValueException($msg);