algorithms[$alias] = $algorithm; } /** * Returns the list of aliases. * * @return string[] */ public function aliases(): array { return array_keys($this->algorithms); } /** * Returns all algorithms supported by this factory. * This is an associative array. Keys are the aliases of the algorithms. * * @return Algorithm[] */ public function all(): array { return $this->algorithms; } /** * Create an algorithm manager using the given aliases. * * @param string[] $aliases * * @throws InvalidArgumentException if the alias is invalid or is not supported */ public function create(array $aliases): AlgorithmManager { $algorithms = []; foreach ($aliases as $alias) { if (!is_string($alias)) { throw new InvalidArgumentException('Invalid alias'); } if (!isset($this->algorithms[$alias])) { throw new InvalidArgumentException(sprintf('The algorithm with the alias "%s" is not supported.', $alias)); } $algorithms[] = $this->algorithms[$alias]; } return new AlgorithmManager($algorithms); } }