Spamworldpro Mini Shell
Spamworldpro


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/dceprojects.corals.io/vendor/nesk/rialto/src/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/dceprojects.corals.io/vendor/nesk/rialto/src/Instruction.php
<?php

namespace Nesk\Rialto;

use BadMethodCallException;
use InvalidArgumentException;
use Nesk\Rialto\Interfaces\ShouldIdentifyResource;
use Nesk\Rialto\Exceptions\Node\Exception as NodeException;

class Instruction implements \JsonSerializable
{
    public const TYPE_CALL = 'call';
    public const TYPE_GET = 'get';
    public const TYPE_SET = 'set';
    public const TYPE_NOOP = 'noop';

    /**
     * The instruction type.
     *
     * @var string
     */
    protected $type = self::TYPE_NOOP;

    /**
     * The name the instruction refers to.
     *
     * @var string|null
     */
    protected $name;

    /**
     * The value(s) the instruction should use.
     *
     * @var array[]|array|null
     */
    protected $value;

    /**
     * The resource associated to the instruction.
     *
     * @var \Nesk\Rialto\Traits\IdentifiesResource|null
     */
    protected $resource;

    /**
     * Define whether instruction errors should be catched.
     *
     * @var boolean
     */
    protected $shouldCatchErrors = false;

    /**
     * Create a no-op instruction.
     */
    public static function noop(): self
    {
        return new self;
    }

    /**
     * Define a method call.
     */
    public function call(string $name, ...$arguments): self
    {
        $this->type = self::TYPE_CALL;
        $this->name = $name;
        $this->setValue($arguments, $this->type);

        return $this;
    }

    /**
     * Define a getter.
     */
    public function get(string $name): self
    {
        $this->type = self::TYPE_GET;
        $this->name = $name;
        $this->setValue(null, $this->type);

        return $this;
    }

    /**
     * Define a setter.
     */
    public function set(string $name, $value): self
    {
        $this->type = self::TYPE_SET;
        $this->name = $name;
        $this->setValue($value, $this->type);

        return $this;
    }

    /**
     * Link the instruction to the provided resource.
     */
    public function linkToResource(?ShouldIdentifyResource $resource): self
    {
        $this->resource = $resource;

        return $this;
    }

    /**
     * Define if instruction errors should be catched.
     */
    public function shouldCatchErrors(bool $catch): self
    {
        $this->shouldCatchErrors = $catch;

        return $this;
    }

    /**
     * Set the instruction value.
     */
    protected function setValue($value, string $type)
    {
        $this->value = $type !== self::TYPE_CALL
            ? $this->validateValue($value)
            : array_map(function ($value) {
                return $this->validateValue($value);
            }, $value);
    }

    /**
     * Validate a value.
     *
     * @throws \InvalidArgumentException if the value contains PHP closures.
     */
    protected function validateValue($value)
    {
        if (is_object($value) && ($value instanceof Closure)) {
            throw new InvalidArgumentException('You must use JS function wrappers instead of PHP closures.');
        }

        return $value;
    }

    /**
     * Serialize the object to a value that can be serialized natively by {@see json_encode}.
     */
    public function jsonSerialize(): array
    {
        $instruction = ['type' => $this->type];

        if ($this->type !== self::TYPE_NOOP) {
            $instruction = array_merge($instruction, [
                'name' => $this->name,
                'catched' => $this->shouldCatchErrors,
            ]);

            if ($this->type !== self::TYPE_GET) {
                $instruction['value'] = $this->value;
            }

            if ($this->resource !== null) {
                $instruction['resource'] = $this->resource;
            }
        }

        return $instruction;
    }

    /**
     * Proxy the "with*" static method calls to the "*" non-static method calls of a new instance.
     */
    public static function __callStatic(string $name, array $arguments)
    {
        $name = lcfirst(substr($name, strlen('with')));

        if ($name === 'jsonSerialize') {
            throw new BadMethodCallException;
        }

        return call_user_func([new self, $name], ...$arguments);
    }
}

Spamworldpro Mini