HEX
Server: LiteSpeed
System: Linux php-prod-3.spaceapp.ru 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC 2025 x86_64
User: sarli3128 (1010)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/marketing.cfbon.ru/public_html/vendor/laravel/pail/src/File.php
<?php

namespace Laravel\Pail;

use Stringable;

class File implements Stringable
{
    /**
     * The time to live of the file.
     */
    protected const TTL = 3600;

    /**
     * Creates a new instance of the file.
     */
    public function __construct(
        protected string $file,
    ) {
        //
    }

    /**
     * Ensure the file exists.
     */
    public function create(): void
    {
        if (! $this->exists()) {
            $directory = dirname($this->file);

            if (! is_dir($directory)) {
                mkdir($directory, 0755, true);

                file_put_contents($directory.'/.gitignore', "*\n!.gitignore\n");
            }

            touch($this->file);
        }
    }

    /**
     * Determines if the file exists.
     */
    public function exists(): bool
    {
        return file_exists($this->file);
    }

    /**
     * Deletes the file.
     */
    public function destroy(): void
    {
        if ($this->exists()) {
            unlink($this->file);
        }
    }

    /**
     * Log a log message to the file.
     *
     * @param  array<string, mixed>  $context
     */
    public function log(string $level, string $message, array $context = []): void
    {
        if ($this->isStale()) {
            $this->destroy();

            return;
        }

        $loggerFactory = new LoggerFactory($this);

        $logger = $loggerFactory->create();

        $logger->log($level, $message, $context);
    }

    /**
     * Returns the file as string.
     */
    public function __toString(): string
    {
        return $this->file;
    }

    /**
     * Determines if the file is staled.
     */
    protected function isStale(): bool
    {
        $modificationTime = @filemtime($this->file);

        if ($modificationTime === false) {
            return true;
        }

        return time() - $modificationTime > static::TTL;
    }
}