-
-
Notifications
You must be signed in to change notification settings - Fork 961
Expand file tree
/
Copy pathPhpFileResourceExtractor.php
More file actions
59 lines (48 loc) · 1.42 KB
/
PhpFileResourceExtractor.php
File metadata and controls
59 lines (48 loc) · 1.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<?php
/*
* This file is part of the API Platform project.
*
* (c) Kévin Dunglas <dunglas@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace ApiPlatform\Metadata\Extractor;
use ApiPlatform\Metadata\ApiResource;
/**
* Extracts an array of metadata from a list of PHP files.
*
* @author Loïc Frémont <lc.fremont@gmail.com>
*/
final class PhpFileResourceExtractor extends AbstractResourceExtractor
{
use ResourceExtractorTrait;
/**
* {@inheritdoc}
*/
protected function extractPath(string $path): void
{
$resource = $this->getPHPFileClosure($path)();
if (!$resource instanceof ApiResource) {
return;
}
$resourceReflection = new \ReflectionClass($resource);
foreach ($resourceReflection->getProperties() as $property) {
$resolvedValue = $this->resolve($property->getValue($resource));
$property->setValue($resource, $resolvedValue);
}
$this->resources[] = $resource;
}
/**
* Scope isolated include.
*
* Prevents access to $this/self from included files.
*/
private function getPHPFileClosure(string $filePath): \Closure
{
return \Closure::bind(function () use ($filePath): mixed {
return require $filePath;
}, null, null);
}
}