| 1 | <?php  | 
            ||
| 2 | namespace Yoanm\SymfonyJsonRpcHttpServer\DependencyInjection;  | 
            ||
| 3 | |||
| 4 | use Symfony\Component\DependencyInjection\ContainerBuilder;  | 
            ||
| 
                                                                                                    
                         1 ignored issue 
                            –
                            show
                         | 
                |||
| 5 | use Symfony\Component\DependencyInjection\Definition;  | 
            ||
| 6 | use Symfony\Component\DependencyInjection\Exception\LogicException;  | 
            ||
| 7 | use Yoanm\JsonRpcServer\Domain\JsonRpcMethodInterface;  | 
            ||
| 8 | |||
| 9 | /**  | 
            ||
| 10 | * Class JsonRpcMethodDefinitionHelper  | 
            ||
| 11 | */  | 
            ||
| 12 | class JsonRpcMethodDefinitionHelper  | 
            ||
| 13 | { | 
            ||
| 14 | /**  | 
            ||
| 15 | * @param ContainerBuilder $container  | 
            ||
| 16 | *  | 
            ||
| 17 | * @return array  | 
            ||
| 18 | */  | 
            ||
| 19 | 5 | public function findAndValidateJsonRpcMethodDefinition(ContainerBuilder $container) : array  | 
            |
| 20 |     { | 
            ||
| 21 | 5 | $definitionList = [];  | 
            |
| 22 | |||
| 23 | 5 | $taggedServiceList = $container->findTaggedServiceIds(JsonRpcHttpServerExtension::JSONRPC_METHOD_TAG);  | 
            |
| 24 | |||
| 25 | 5 |         foreach ($taggedServiceList as $serviceId => $tagAttributeList) { | 
            |
| 26 | 5 | $this->validateJsonRpcMethodDefinition($serviceId, $container->getDefinition($serviceId));  | 
            |
| 27 | |||
| 28 | 5 |             foreach ($tagAttributeList as $tagAttributeKey => $tagAttributeData) { | 
            |
| 29 | 5 | $this->validateJsonRpcMethodTagAttributes($serviceId, $tagAttributeData);  | 
            |
| 30 | 5 | $methodName = $tagAttributeData[JsonRpcHttpServerExtension::JSONRPC_METHOD_TAG_METHOD_NAME_KEY];  | 
            |
| 31 | 5 | $definitionList[$serviceId][] = $methodName;  | 
            |
| 32 | }  | 
            ||
| 33 | }  | 
            ||
| 34 | |||
| 35 | 3 | return $definitionList;  | 
            |
| 36 | }  | 
            ||
| 37 | |||
| 38 | /**  | 
            ||
| 39 | * @param string $serviceId  | 
            ||
| 40 | * @param array $tagAttributeData  | 
            ||
| 41 | */  | 
            ||
| 42 | 5 | private function validateJsonRpcMethodTagAttributes(string $serviceId, array $tagAttributeData) : void  | 
            |
| 43 |     { | 
            ||
| 44 | 5 |         if (!isset($tagAttributeData[JsonRpcHttpServerExtension::JSONRPC_METHOD_TAG_METHOD_NAME_KEY])) { | 
            |
| 45 | 1 | throw new LogicException(sprintf(  | 
            |
| 46 | 1 | 'Service "%s" is taggued as JSON-RPC method but does not have'  | 
            |
| 47 | 1 | . ' method name defined under "%s" tag attribute key',  | 
            |
| 48 | 1 | $serviceId,  | 
            |
| 49 | 1 | JsonRpcHttpServerExtension::JSONRPC_METHOD_TAG_METHOD_NAME_KEY  | 
            |
| 50 | 1 | ));  | 
            |
| 51 | }  | 
            ||
| 52 | }  | 
            ||
| 53 | |||
| 54 | /**  | 
            ||
| 55 | * @param string $serviceId  | 
            ||
| 56 | * @param Definition $definition  | 
            ||
| 57 | *  | 
            ||
| 58 | * @throws \LogicException In case definition is not valid  | 
            ||
| 59 | */  | 
            ||
| 60 | 5 | private function validateJsonRpcMethodDefinition(string $serviceId, Definition $definition) : void  | 
            |
| 61 |     { | 
            ||
| 62 | 5 |         if (!in_array(JsonRpcMethodInterface::class, class_implements($definition->getClass()))) { | 
            |
| 63 | 1 | throw new LogicException(sprintf(  | 
            |
| 64 | 1 | 'Service "%s" is taggued as JSON-RPC method but does not implement %s',  | 
            |
| 65 | 1 | $serviceId,  | 
            |
| 66 | 1 | JsonRpcMethodInterface::class  | 
            |
| 67 | 1 | ));  | 
            |
| 68 | }  | 
            ||
| 69 | }  | 
            ||
| 70 | }  | 
            ||
| 71 | 
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths