| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | <?php/* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace Symfony\Component\Console\CI;use Symfony\Component\Console\Output\OutputInterface;/** * Utility class for Github actions. * * @author Maxime Steinhausser <maxime.steinhausser@gmail.com> */class GithubActionReporter{    private $output;    /**     * @see https://github.com/actions/toolkit/blob/5e5e1b7aacba68a53836a34db4a288c3c1c1585b/packages/core/src/command.ts#L80-L85     */    private const ESCAPED_DATA = [        '%' => '%25',        "\r" => '%0D',        "\n" => '%0A',    ];    /**     * @see https://github.com/actions/toolkit/blob/5e5e1b7aacba68a53836a34db4a288c3c1c1585b/packages/core/src/command.ts#L87-L94     */    private const ESCAPED_PROPERTIES = [        '%' => '%25',        "\r" => '%0D',        "\n" => '%0A',        ':' => '%3A',        ',' => '%2C',    ];    public function __construct(OutputInterface $output)    {        $this->output = $output;    }    public static function isGithubActionEnvironment(): bool    {        return false !== getenv('GITHUB_ACTIONS');    }    /**     * Output an error using the Github annotations format.     *     * @see https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-commands-for-github-actions#setting-an-error-message     */    public function error(string $message, ?string $file = null, ?int $line = null, ?int $col = null): void    {        $this->log('error', $message, $file, $line, $col);    }    /**     * Output a warning using the Github annotations format.     *     * @see https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-commands-for-github-actions#setting-a-warning-message     */    public function warning(string $message, ?string $file = null, ?int $line = null, ?int $col = null): void    {        $this->log('warning', $message, $file, $line, $col);    }    /**     * Output a debug log using the Github annotations format.     *     * @see https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-commands-for-github-actions#setting-a-debug-message     */    public function debug(string $message, ?string $file = null, ?int $line = null, ?int $col = null): void    {        $this->log('debug', $message, $file, $line, $col);    }    private function log(string $type, string $message, ?string $file = null, ?int $line = null, ?int $col = null): void    {        // Some values must be encoded.        $message = strtr($message, self::ESCAPED_DATA);        if (!$file) {            // No file provided, output the message solely:            $this->output->writeln(sprintf('::%s::%s', $type, $message));            return;        }        $this->output->writeln(sprintf('::%s file=%s,line=%s,col=%s::%s', $type, strtr($file, self::ESCAPED_PROPERTIES), strtr($line ?? 1, self::ESCAPED_PROPERTIES), strtr($col ?? 0, self::ESCAPED_PROPERTIES), $message));    }}
 |