2019-11-11 13:21:19 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
*
|
2020-01-07 01:13:47 +01:00
|
|
|
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
|
2019-11-11 13:21:19 +01:00
|
|
|
*
|
|
|
|
* @license https://opensource.org/licenses/AAL
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\Utils\Traits;
|
|
|
|
|
|
|
|
use App\DataMapper\CompanySettings;
|
|
|
|
use App\DataMapper\FeesAndLimits;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class CompanyGatewayFeesAndLimitsSaver
|
|
|
|
* @package App\Utils\Traits
|
|
|
|
*/
|
|
|
|
trait CompanyGatewayFeesAndLimitsSaver
|
|
|
|
{
|
2019-12-30 22:59:12 +01:00
|
|
|
public function validateFeesAndLimits($fees_and_limits)
|
|
|
|
{
|
|
|
|
$fees_and_limits = (object)$fees_and_limits;
|
|
|
|
$casts = FeesAndLimits::$casts;
|
|
|
|
|
|
|
|
foreach ($fees_and_limits as $fee_and_limit) {
|
|
|
|
$fee_and_limit = (object)$fee_and_limit;
|
|
|
|
|
|
|
|
foreach ($casts as $key => $value) {
|
|
|
|
|
|
|
|
|
|
|
|
/* Handles unset settings or blank strings */
|
|
|
|
if (!property_exists($fee_and_limit, $key) || is_null($fee_and_limit->{$key}) || !isset($fee_and_limit->{$key}) || $fee_and_limit->{$key} == '') {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*Catch all filter */
|
|
|
|
if (!$this->checkAttribute($value, $fee_and_limit->{$key})) {
|
|
|
|
return [$key, $value];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type checks a object property.
|
|
|
|
* @param string $key The type
|
|
|
|
* @param string $value The object property
|
|
|
|
* @return bool TRUE if the property is the expected type
|
|
|
|
*/
|
|
|
|
private function checkAttribute($key, $value) :bool
|
|
|
|
{
|
|
|
|
switch ($key) {
|
|
|
|
case 'int':
|
|
|
|
case 'integer':
|
|
|
|
return ctype_digit(strval($value));
|
|
|
|
case 'real':
|
|
|
|
case 'float':
|
|
|
|
case 'double':
|
|
|
|
return is_float($value) || is_numeric(strval($value));
|
|
|
|
case 'string':
|
|
|
|
return method_exists($value, '__toString') || is_null($value) || is_string($value);
|
|
|
|
case 'bool':
|
|
|
|
case 'boolean':
|
|
|
|
return is_bool($value) || (int) filter_var($value, FILTER_VALIDATE_BOOLEAN);
|
|
|
|
case 'object':
|
|
|
|
return is_object($value);
|
|
|
|
case 'array':
|
|
|
|
return is_array($value);
|
|
|
|
case 'json':
|
|
|
|
json_decode($string);
|
|
|
|
return (json_last_error() == JSON_ERROR_NONE);
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function cleanFeesAndLimits($fees_and_limits)
|
|
|
|
{
|
|
|
|
$new_arr = [];
|
|
|
|
|
|
|
|
foreach ($fees_and_limits as $key => $value) {
|
|
|
|
$fal = new FeesAndLimits;
|
|
|
|
|
|
|
|
foreach ($value as $k => $v) {
|
2020-02-26 08:55:01 +01:00
|
|
|
$fal->{$k} = $v;
|
2019-12-30 22:59:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$new_arr[$key] = (array)$fal;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $new_arr;
|
|
|
|
}
|
|
|
|
}
|