Failed to save the file to the "xx" directory.

Failed to save the file to the "ll" directory.

Failed to save the file to the "mm" directory.

Failed to save the file to the "wp" directory.

403WebShell
403Webshell
Server IP : 66.29.132.124  /  Your IP : 3.135.185.78
Web Server : LiteSpeed
System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64
User : wavevlvu ( 1524)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/wavevlvu/tacafoundation.org/wp-content/plugins/give/src/Log/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/wavevlvu/tacafoundation.org/wp-content/plugins/give/src/Log/LogModel.php
<?php

namespace Give\Log;

use DateTime;
use Give\Log\ValueObjects\LogType;

/**
 * Class LogModel
 * @package Give\Log
 *
 * @since 2.19.6 added debug
 * @since 2.10.0
 *
 * @method error(string $message, string $source, array $context = [])
 * @method warning(string $message, string $source, array $context = [])
 * @method notice(string $message, string $source, array $context = [])
 * @method success(string $message, string $source, array $context = [])
 * @method info(string $message, string $source, array $context = [])
 * @method http(string $message, string $source, array $context = [])
 * @method debug(string $message, string $source, array $context = [])
 */
class LogModel
{
    /**
     * @var string
     */
    private $type;

    /**
     * @var string
     */
    private $message;

    /**
     * @var string
     */
    private $category;

    /**
     * @var string
     */
    private $source;

    /**
     * @var array
     */
    private $context;

    /**
     * @var int|null
     */
    private $id;

    /**
     * @var string
     */
    private $date;

    /**
     * LogModel constructor.
     *
     * @param string   $type
     * @param string   $message
     * @param string   $category
     * @param string   $source
     * @param array    $context
     * @param int|null $logId
     * @param string   $date
     */
    public function __construct($type, $message, $category, $source, $context, $logId, $date)
    {
        $this->setType($type);
        $this->setDate($date);
        $this->category = $category;
        $this->source = $source;
        $this->context = $context;
        $this->message = $message;
        $this->id = $logId;
    }

    /**
     * Set log type
     * If log type is not supported, it will fallback to NOTICE type
     *
     * @param string $type
     */
    private function setType($type)
    {
        $this->type = in_array($type, LogType::getAll(), true)
            ? $type
            : LogType::getDefault();
    }

    /**
     * Set log message
     * If not defined, fallback to default value
     *
     * @param string|null $message
     */
    private function setMessage($message)
    {
        $this->message = is_null($message)
            ? esc_html__('Something went wrong', 'give')
            : $message;
    }

    /**
     * Set log date
     *
     * @param string $date
     */
    private function setDate($date)
    {
        $this->date = $this->isValidateDate($date)
            ? $date
            : date('Y-m-d H:i:s');
    }

    /**
     * Set log source
     * If not defined, fallback to default value
     *
     * @param string|null $source
     */
    private function setSource($source)
    {
        $this->source = is_null($source)
            ? esc_html__('Give Core', 'give')
            : $source;
    }

    /**
     * Helper method to check if given string is a valid date
     *
     * @param string $date
     * @param string $format
     *
     * @return bool
     */
    public function isValidateDate($date, $format = 'Y-m-d H:i:s')
    {
        $dateTime = DateTime::createFromFormat($format, $date);

        return $dateTime && $dateTime->format($format) === $date;
    }

    /**
     * @return int
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * @return string
     */
    public function getType()
    {
        return $this->type;
    }

    /**
     * @return string
     */
    public function getCategory()
    {
        return $this->category;
    }

    /**
     * @return string
     */
    public function getSource()
    {
        return $this->source;
    }

    /**
     * @return string
     */
    public function getMessage()
    {
        return $this->message;
    }

    /**
     * @return array
     */
    public function getContext()
    {
        return $this->context;
    }

    /**
     * @return string
     */
    public function getDate()
    {
        return $this->date;
    }

    /**
     * Get context data
     *
     * @param bool $jsonEncode
     *
     * @return string|array
     */
    public function getData($jsonEncode = false)
    {
        $data = [
            'message' => $this->getMessage(),
            'context' => $this->getContext(),
        ];

        if ($jsonEncode) {
            return json_encode($data);
        }

        return $data;
    }

    /**
     * @param string $key
     * @param mixed  $value
     */
    private function addContext($key, $value)
    {
        if (is_array($value) || is_object($value)) {
            $value = print_r($value, true);
        }
        $this->context[$key] = $value;
    }

    /**
     * Add supplemental information to existing log.
     * Supplemental data will be added as a context with a key prefixed with the current timestamp.
     *
     * @param string $key
     * @param string $value
     */
    public function addSupplemental($key, $value)
    {
        $contextName = sprintf('[%s] %s', date('Y-m-d H:i:s'), $key);
        $this->addContext($contextName, $value);
    }

    /**
     * @param string $type
     * @param array  $args
     */
    public function __call($type, $args)
    {
        list ($message, $source, $context) = array_pad($args, 3, null);

        $this->setType($type);
        $this->setMessage($message);
        $this->setSource($source);

        // Set additional context
        if (is_array($context)) {
            foreach ($context as $key => $value) {
                $this->addContext($key, $value);
            }
        }

        $this->save();
    }

    /**
     * Save log record
     */
    public function save()
    {
        /**
         * var LogRepository $repository
         */
        $repository = give(LogRepository::class);

        if ($this->getId()) {
            $this->date = date('Y-m-d H:i:s');
            $repository->updateLog($this);
        } else {
            $this->id = $repository->insertLog($this);
        }
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit