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/job-board.corals.io/vendor/omise/omise-php/lib/omise/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/job-board.corals.io/vendor/omise/omise-php/lib/omise/OmiseSearch.php
<?php

/**
 * This class is not intended to be used directly from client code.
 *
 * Use Omise resource classes to begin searching:
 *
 *     $search = OmiseCharge::search('query');
 *
 *     foreach ($search['data'] as $result) {
 *         echo $result['object'];
 *     }
 *
 * @see OmiseCharge::search()
 * @see OmiseCustomer::search()
 * @see OmiseDispute::search()
 * @see OmiseLink::search()
 * @see OmiseRecipient::search()
 * @see OmiseRefund::search()
 * @see OmiseTransfer::search()
 */
class OmiseSearch extends OmiseApiResource
{
    const ENDPOINT = 'search';

    private $dirty = true;
    private $attributes = [];

    /**
     * Create an instance of `OmiseSearch` with the given scope.
     *
     * @param  string $scope  See supported scope at [Search API](https://www.omise.co/search-api) page.
     * @param  string $publickey
     * @param  string $secretkey
     *
     * @return OmiseSearch  The created instance.
     */
    public static function scope($scope, $publickey = null, $secretkey = null)
    {
        $resouce = self::getInstance($publickey = null, $secretkey = null);
        $resouce->mergeAttributes('scope', $scope);

        return $resouce;
    }

    /**
     * Update `query` parameter.
     *
     * @param  string $query  Searching text within the scope.
     *
     * @return OmiseSearch  This instance.
     */
    public function query($query)
    {
        return $this->mergeAttributes('query', $query);
    }

    /**
     * Update `filters` parameter.
     *
     * @param  string $filters  Searching text with specific key within the scope.
     *
     * @return OmiseSearch  This instance.
     */
    public function filter(array $filters = [])
    {
        foreach ($filters as $k => $v) {
            if (is_bool($v)) {
                $filters[$k] = $v ? 'true' : 'false';
            }
        }

        return $this->mergeAttributes('filters', $filters);
    }

    /**
     * Update `page` parameter.
     *
     * @param  int $page  Specific number of searching page.
     *
     * @return OmiseSearch  This instance.
     */
    public function page($page)
    {
        return $this->mergeAttributes('page', $page);
    }

    /**
     * Update `per_page` parameter.
     *
     * @param  int $limit   Number of items that will be shown per page.
     *
     * @return OmiseSearch  This instance.
     */
    public function per_page($limit)
    {
        return $this->mergeAttributes('per_page', $limit);
    }

    /**
     * Update `order` parameter.
     *
     * @param  string $order  The order of the list returned.
     *
     * @see    https://www.omise.co/search-api
     *
     * @return OmiseSearch  This instance.
     */
    public function order($order)
    {
        return $this->mergeAttributes('order', $order);
    }

    /**
     * Check whether this search instance is dirty or not.
     *
     * Dirty search instance needs to be reloaded before further usage. The
     * dirty search instance automatically reloads its data when client code
     * tries to access its array element.
     *
     *     $search = OmiseCharge::query('demo'); // the instance is dirty
     *     echo $search['object'];               // this will automatically retrive remote value
     *
     * @return bool  true if the instance is dirty and needs to be reloaded
     */
    public function isDirty()
    {
        return $this->dirty;
    }

    /**
     * Reload search data from Omise server.
     *
     * This method does not consider the dirty status of the instance and will
     * always call backend server and reset dirty flag.
     */
    public function reload()
    {
        $this->dirty = false;
        $this->g_reload($this->getUrl());
    }

    /**
     * Reload search data from Omise server if this instance is in dirty state.
     */
    private function reloadIfDirty()
    {
        if ($this->isDirty()) {
            $this->reload();
        }
    }

    /**
     * Merge the given key and value to search attributes, and set instance state
     * as dirty.
     *
     * @param  string $key    Search attribute key.
     * @param  mixed  $value  Search attribute value.
     *
     * @return OmiseSearch  This instance.
     */
    private function mergeAttributes($key, $value)
    {
        $this->dirty = true;
        $this->attributes[$key] = $value;

        return $this;
    }

    /**
     * Generate request url.
     *
     * @return string
     */
    private function getUrl()
    {
        $querystring = http_build_query($this->attributes);

        return OMISE_API_URL . self::ENDPOINT . '/?' . $querystring;
    }

    // Override methods of ArrayAccess

    /**
     * (non-PHPdoc)
     *
     * @see OmiseObject::offsetSet()
     */
    #[\ReturnTypeWillChange]
    public function offsetSet($key, $value)
    {
        $this->reloadIfDirty();
        parent::offsetSet($key, $value);
    }

    /**
     * (non-PHPdoc)
     *
     * @see OmiseObject::offsetExists()
     */
    #[\ReturnTypeWillChange]
    public function offsetExists($key)
    {
        $this->reloadIfDirty();

        return parent::offsetExists($key);
    }

    /**
     * (non-PHPdoc)
     *
     * @see OmiseObject::offsetUnset()
     */
    #[\ReturnTypeWillChange]
    public function offsetUnset($key)
    {
        $this->reloadIfDirty();
        parent::offsetUnset($key);
    }

    /**
     * (non-PHPdoc)
     *
     * @see OmiseObject::offsetGet()
     */
    #[\ReturnTypeWillChange]
    public function offsetGet($key)
    {
        $this->reloadIfDirty();

        return parent::offsetGet($key);
    }
}

Spamworldpro Mini