Security update for permissions_by_term
[yaffs-website] / vendor / behat / behat / src / Behat / Testwork / Hook / HookRepository.php
diff --git a/vendor/behat/behat/src/Behat/Testwork/Hook/HookRepository.php b/vendor/behat/behat/src/Behat/Testwork/Hook/HookRepository.php
new file mode 100644 (file)
index 0000000..527a11a
--- /dev/null
@@ -0,0 +1,77 @@
+<?php
+
+/*
+ * This file is part of the Behat Testwork.
+ * (c) Konstantin Kudryashov <ever.zet@gmail.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Behat\Testwork\Hook;
+
+use Behat\Testwork\Call\Callee;
+use Behat\Testwork\Environment\Environment;
+use Behat\Testwork\Environment\EnvironmentManager;
+use Behat\Testwork\Hook\Scope\HookScope;
+
+/**
+ * Finds hooks using provided environments or scopes.
+ *
+ * @author Konstantin Kudryashov <ever.zet@gmail.com>
+ */
+final class HookRepository
+{
+    /**
+     * @var EnvironmentManager
+     */
+    private $environmentManager;
+
+    /**
+     * Initializes repository.
+     *
+     * @param EnvironmentManager $environmentManager
+     */
+    public function __construct(EnvironmentManager $environmentManager)
+    {
+        $this->environmentManager = $environmentManager;
+    }
+
+    /**
+     * Returns all available hooks for a specific environment.
+     *
+     * @param Environment $environment
+     *
+     * @return Hook[]
+     */
+    public function getEnvironmentHooks(Environment $environment)
+    {
+        return array_filter(
+            $this->environmentManager->readEnvironmentCallees($environment),
+            function (Callee $callee) {
+                return $callee instanceof Hook;
+            }
+        );
+    }
+
+    /**
+     * Returns hooks for a specific event.
+     *
+     * @param HookScope $scope
+     *
+     * @return Hook[]
+     */
+    public function getScopeHooks(HookScope $scope)
+    {
+        return array_filter(
+            $this->getEnvironmentHooks($scope->getEnvironment()),
+            function (Hook $hook) use ($scope) {
+                if ($scope->getName() !== $hook->getScopeName()) {
+                    return false;
+                }
+
+                return !($hook instanceof FilterableHook && !$hook->filterMatches($scope));
+            }
+        );
+    }
+}