Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8fc94aaeb8 | ||
|
|
aba089db5e | ||
|
|
43e529dcad | ||
|
|
5bef4f577e |
@@ -9,5 +9,5 @@ composer create-project rmphp/skeleton project-name
|
|||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
composer create-project rmphp/skeleton:"^4.2" project-name
|
composer create-project rmphp/skeleton:"^4.5" project-name
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -2,26 +2,40 @@
|
|||||||
|
|
||||||
namespace Base\Application;
|
namespace Base\Application;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
use ReflectionClass;
|
use ReflectionClass;
|
||||||
|
use Rmphp\Storage\Component\AbstractDataObject;
|
||||||
|
|
||||||
|
abstract class AbstractDTO extends AbstractDataObject {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array|object ...$data
|
||||||
|
* @return static
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public static function fromData(array|object ...$data) : static {
|
||||||
|
$array = array_map(function($item) {
|
||||||
|
return (is_object($item)) ? get_object_vars($item) : $item;
|
||||||
|
}, $data);
|
||||||
|
return self::fromArray(array_merge(...$array));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param object $data
|
||||||
|
* @return static
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public static function fromObject(object $data) : static {
|
||||||
|
return self::fromArray(get_object_vars($data));
|
||||||
|
}
|
||||||
|
|
||||||
abstract class AbstractDTO {
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $data
|
* @param array $data
|
||||||
* @return static
|
* @return static
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
static function fromArray(array $data) : static {
|
public static function fromArray(array $data) : static {
|
||||||
$class = new ReflectionClass(static::class);
|
return self::fillObject(new ReflectionClass(static::class), new static(), $data);
|
||||||
$self = new static();
|
|
||||||
foreach ($class->getProperties() as $property) {
|
|
||||||
$propertyNameSnakeCase = strtolower(preg_replace("'([A-Z])'", "_$1", $property->getName()));
|
|
||||||
// data[propertyName] ?? data[property_name] ?? null
|
|
||||||
$value = $data[$property->getName()] ?? $data[$propertyNameSnakeCase] ?? null;
|
|
||||||
// если есть внутренний метод (приоритетная обработка)
|
|
||||||
if($class->hasMethod('set'.ucfirst($property->getName()))) $self->{'set'.ucfirst($property->getName())}($value);
|
|
||||||
// прямое присовение по умолчанию
|
|
||||||
elseif(isset($value)) $self->{$property->getName()} = $value;
|
|
||||||
}
|
|
||||||
return $self;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,7 +17,7 @@
|
|||||||
"rmphp/router": "^1.2",
|
"rmphp/router": "^1.2",
|
||||||
"rmphp/session": "^1.1",
|
"rmphp/session": "^1.1",
|
||||||
"rmphp/redis": "^1.0",
|
"rmphp/redis": "^1.0",
|
||||||
"rmphp/storage": "^4.1",
|
"rmphp/storage": "^6.0",
|
||||||
"symfony/dotenv": "^6.2"
|
"symfony/dotenv": "^6.2"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
|
|||||||
Reference in New Issue
Block a user