canCreate($serviceLocator, $requestedName); } /** * Determine if we can create a service (SM v3) * * @param ContainerInterface $container * @param string $requestedName * @return bool */ public function canCreate(ContainerInterface $container, $requestedName) { if (isset($this->configs[$requestedName])) { return true; } if (! $container->has('Config')) { return false; } $key = $this->match($requestedName); if (null === $key) { return false; } $config = $container->get('Config'); return isset($config[$key]); } /** * Create service with name (SM v2) * * @param ServiceLocatorInterface $serviceLocator * @param string $name * @param string $requestedName * @return string|mixed|array */ public function createServiceWithName(ServiceLocatorInterface $serviceLocator, $name, $requestedName) { return $this($serviceLocator, $requestedName); } /** * Create service with name (SM v3) * * @param ContainerInterface $container * @param string $requestedName * @param array $options * @return string|mixed|array */ public function __invoke(ContainerInterface $container, $requestedName, array $options = null) { if (isset($this->configs[$requestedName])) { return $this->configs[$requestedName]; } $key = $this->match($requestedName); if (isset($this->configs[$key])) { $this->configs[$requestedName] = $this->configs[$key]; return $this->configs[$key]; } $config = $container->get('Config'); $this->configs[$requestedName] = $this->configs[$key] = $config[$key]; return $config[$key]; } /** * @param string $pattern * @return self * @throws Exception\InvalidArgumentException */ public function addPattern($pattern) { if (! is_string($pattern)) { throw new Exception\InvalidArgumentException('pattern must be string'); } $patterns = $this->getPatterns(); array_unshift($patterns, $pattern); $this->setPatterns($patterns); return $this; } /** * @param array|Traversable $patterns * @return self * @throws Exception\InvalidArgumentException */ public function addPatterns($patterns) { if ($patterns instanceof Traversable) { $patterns = iterator_to_array($patterns); } if (! is_array($patterns)) { throw new Exception\InvalidArgumentException("patterns must be array or Traversable"); } foreach ($patterns as $pattern) { $this->addPattern($pattern); } return $this; } /** * @param array|Traversable $patterns * @return self * @throws \InvalidArgumentException */ public function setPatterns($patterns) { if ($patterns instanceof Traversable) { $patterns = iterator_to_array($patterns); } if (! is_array($patterns)) { throw new \InvalidArgumentException("patterns must be array or Traversable"); } $this->patterns = $patterns; return $this; } /** * @return array */ public function getPatterns() { if (null === $this->patterns) { $this->setPatterns($this->defaultPatterns); } return $this->patterns; } /** * @param string $requestedName * @return null|string */ protected function match($requestedName) { foreach ($this->getPatterns() as $pattern) { if (preg_match($pattern, $requestedName, $matches)) { return $matches[1]; } } return; } }