* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace RectorPrefix202411\Symfony\Contracts\Service\Attribute; use RectorPrefix202411\Symfony\Contracts\Service\ServiceMethodsSubscriberTrait; use RectorPrefix202411\Symfony\Contracts\Service\ServiceSubscriberInterface; /** * For use as the return value for {@see ServiceSubscriberInterface}. * * @example new SubscribedService('http_client', HttpClientInterface::class, false, new Target('githubApi')) * * Use with {@see ServiceMethodsSubscriberTrait} to mark a method's return type * as a subscribed service. * * @author Kevin Bond */ #[\Attribute(\Attribute::TARGET_METHOD)] final class SubscribedService { /** * @var string|null */ public $key; /** * @var class-string|null */ public $type; /** * @var bool */ public $nullable = \false; /** @var object[] */ public $attributes; /** * @param string|null $key The key to use for the service * @param class-string|null $type The service class * @param bool $nullable Whether the service is optional * @param object|object[] $attributes One or more dependency injection attributes to use */ public function __construct(?string $key = null, ?string $type = null, bool $nullable = \false, $attributes = []) { $this->key = $key; $this->type = $type; $this->nullable = $nullable; $this->attributes = \is_array($attributes) ? $attributes : [$attributes]; } }