![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/captainhook/captainhook/src/Hook/Notify/Action/ |
<?php /** * This file is part of CaptainHook * * (c) Sebastian Feldmann <[email protected]> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace CaptainHook\App\Hook\Notify\Action; use CaptainHook\App\Config; use CaptainHook\App\Console\IO; use CaptainHook\App\Exception\ActionFailed; use CaptainHook\App\Hook\Action; use CaptainHook\App\Hook\Constrained; use CaptainHook\App\Hook\Restriction; use CaptainHook\App\Git\Rev\Util as RevUtil; use CaptainHook\App\Hooks; use SebastianFeldmann\Git\Repository; /** * Class IntegrateBeforePush * * @package CaptainHook * @author Sebastian Feldmann <[email protected]> * @link https://github.com/captainhookphp/captainhook * @since Class available since Release 5.19.1 */ class IntegrateBeforePush implements Action, Constrained { /** * Returns a list of applicable hooks * * @return \CaptainHook\App\Hook\Restriction */ public static function getRestriction(): Restriction { return Restriction::fromArray([Hooks::PRE_PUSH]); } /** * Executes the action * * @param \CaptainHook\App\Config $config * @param \CaptainHook\App\Console\IO $io * @param \SebastianFeldmann\Git\Repository $repository * @param \CaptainHook\App\Config\Action $action * @return void * @throws \Exception */ public function execute(Config $config, IO $io, Repository $repository, Config\Action $action): void { $trigger = $action->getOptions()->get('trigger', '[merge]'); $branchToWatch = $action->getOptions()->get('branch', 'origin/main'); $branchInfo = RevUtil::extractBranchInfo($branchToWatch); $repository->getRemoteOperator()->fetchBranch($branchInfo['remote'], $branchInfo['branch']); foreach ($repository->getLogOperator()->getCommitsBetween('HEAD', $branchToWatch) as $commit) { $message = $commit->getSubject() . PHP_EOL . $commit->getBody(); if (str_contains($message, $trigger)) { throw new ActionFailed('integrate ' . $branchInfo['branch'] . ' before you push!'); } } } }