%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/graphicd/www/vebto/vendor/algolia/algoliasearch-client-php/src/
Upload File :
Create Path :
Current File : /home/graphicd/www/vebto/vendor/algolia/algoliasearch-client-php/src/SearchIndex.php

<?php

namespace Algolia\AlgoliaSearch;

use Algolia\AlgoliaSearch\Config\SearchConfig;
use Algolia\AlgoliaSearch\Exceptions\MissingObjectId;
use Algolia\AlgoliaSearch\Exceptions\NotFoundException;
use Algolia\AlgoliaSearch\Exceptions\ObjectNotFoundException;
use Algolia\AlgoliaSearch\Iterators\ObjectIterator;
use Algolia\AlgoliaSearch\Iterators\RuleIterator;
use Algolia\AlgoliaSearch\Iterators\SynonymIterator;
use Algolia\AlgoliaSearch\RequestOptions\RequestOptions;
use Algolia\AlgoliaSearch\RequestOptions\RequestOptionsFactory;
use Algolia\AlgoliaSearch\Response\BatchIndexingResponse;
use Algolia\AlgoliaSearch\Response\IndexingResponse;
use Algolia\AlgoliaSearch\Response\MultiResponse;
use Algolia\AlgoliaSearch\Response\NullResponse;
use Algolia\AlgoliaSearch\RetryStrategy\ApiWrapperInterface;
use Algolia\AlgoliaSearch\Support\Helpers;

class SearchIndex
{
    private $indexName;

    /**
     * @var ApiWrapperInterface
     */
    protected $api;

    /**
     * @var SearchConfig
     */
    protected $config;

    public function __construct($indexName, ApiWrapperInterface $apiWrapper, SearchConfig $config)
    {
        $this->indexName = $indexName;
        $this->api = $apiWrapper;
        $this->config = $config;
    }

    public function getIndexName()
    {
        return $this->indexName;
    }

    public function getAppId()
    {
        return $this->config->getAppId();
    }

    public function search($query, $requestOptions = [])
    {
        $query = (string) $query;

        if (is_array($requestOptions)) {
            $requestOptions['query'] = $query;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addBodyParameter('query', $query);
        }

        return $this->api->read('POST', api_path('/1/indexes/%s/query', $this->indexName), $requestOptions);
    }

    /**
     * @deprecated Please use searchForFacetValues instead
     */
    public function searchForFacetValue($facetName, $facetQuery, $requestOptions = [])
    {
        return $this->searchForFacetValues($facetName, $facetQuery, $requestOptions);
    }

    public function searchForFacetValues($facetName, $facetQuery, $requestOptions = [])
    {
        if (is_array($requestOptions)) {
            $requestOptions['facetQuery'] = $facetQuery;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addBodyParameter('facetQuery', $facetQuery);
        }

        return $this->api->read(
            'POST',
            api_path('/1/indexes/%s/facets/%s/query', $this->indexName, $facetName),
            $requestOptions
        );
    }

    public function getSettings($requestOptions = [])
    {
        if (is_array($requestOptions)) {
            $requestOptions['getVersion'] = 2;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addQueryParameter('getVersion', 2);
        }

        return $this->api->read(
            'GET',
            api_path('/1/indexes/%s/settings', $this->indexName),
            $requestOptions
        );
    }

    public function setSettings($settings, $requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        $response = $this->api->write(
            'PUT',
            api_path('/1/indexes/%s/settings', $this->indexName),
            $settings,
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function getObject($objectId, $requestOptions = [])
    {
        return $this->api->read(
            'GET',
            api_path('/1/indexes/%s/%s', $this->indexName, $objectId),
            $requestOptions
        );
    }

    public function getObjects($objectIds, $requestOptions = [])
    {
        if (is_array($requestOptions)) {
            $attributesToRetrieve = '';
            if (isset($requestOptions['attributesToRetrieve'])) {
                $attributesToRetrieve = $requestOptions['attributesToRetrieve'];
                unset($requestOptions['attributesToRetrieve']);
            }

            $request = [];
            foreach ($objectIds as $id) {
                $req = [
                    'indexName' => $this->indexName,
                    'objectID' => (string) $id,
                ];

                if ($attributesToRetrieve) {
                    $req['attributesToRetrieve'] = $attributesToRetrieve;
                }

                $request[] = $req;
            }

            $requestOptions['requests'] = $request;
        }

        return $this->api->read(
            'POST',
            api_path('/1/indexes/*/objects'),
            $requestOptions
        );
    }

    public function saveObject($object, $requestOptions = [])
    {
        return $this->saveObjects([$object], $requestOptions);
    }

    public function saveObjects($objects, $requestOptions = [])
    {
        if (isset($requestOptions['autoGenerateObjectIDIfNotExist'])
            && $requestOptions['autoGenerateObjectIDIfNotExist']) {
            unset($requestOptions['autoGenerateObjectIDIfNotExist']);

            return $this->addObjects($objects, $requestOptions);
        }

        if (isset($requestOptions['objectIDKey']) && $requestOptions['objectIDKey']) {
            $objects = Helpers::mapObjectIDs($requestOptions['objectIDKey'], $objects);
            unset($requestOptions['objectIDKey']);
        }

        try {
            return $this->splitIntoBatches('updateObject', $objects, $requestOptions);
        } catch (MissingObjectId $e) {
            $message = "\nAll objects must have an unique objectID (like a primary key) to be valid.\n\n";
            $message .= "If your batch has a unique identifier but isn't called objectID,\n";
            $message .= "you can map it automatically using `saveObjects(\$objects, ['objectIDKey' => 'primary'])`\n\n";
            $message .= "Algolia is also able to generate objectIDs automatically but *it's not recommended*.\n";
            $message .= "To do it, use `['autoGenerateObjectIDIfNotExist' => true] on the request options parameter`\n\n";

            throw new MissingObjectId($message);
        }
    }

    protected function addObjects($objects, $requestOptions = [])
    {
        return $this->splitIntoBatches('addObject', $objects, $requestOptions);
    }

    public function partialUpdateObject($object, $requestOptions = [])
    {
        return $this->partialUpdateObjects([$object], $requestOptions);
    }

    public function partialUpdateObjects($objects, $requestOptions = [])
    {
        $action = 'partialUpdateObjectNoCreate';

        if (isset($requestOptions['createIfNotExists']) && $requestOptions['createIfNotExists']) {
            $action = 'partialUpdateObject';
            unset($requestOptions['createIfNotExists']);
        }

        return $this->splitIntoBatches($action, $objects, $requestOptions);
    }

    public function replaceAllObjects($objects, $requestOptions = [])
    {
        $safe = isset($requestOptions['safe']) && $requestOptions['safe'];
        unset($requestOptions['safe']);

        $tmpName = $this->indexName.'_tmp_'.uniqid('php_', true);
        $tmpIndex = new static($tmpName, $this->api, $this->config);

        // Copy all index resources from production index
        $copyResponse = $this->copyTo($tmpIndex->getIndexName(), [
            'scope' => ['settings', 'synonyms', 'rules'],
        ]);

        if ($safe) {
            $copyResponse->wait();
        }

        // Send records (batched automatically)
        $batchResponse = $tmpIndex->saveObjects($objects, $requestOptions);

        if ($safe) {
            $batchResponse->wait();
        }

        // Move temporary index to production
        $moveResponse = $this->moveFrom($tmpName);

        if ($safe) {
            $moveResponse->wait();
        }

        return new MultiResponse([$copyResponse, $batchResponse, $moveResponse]);
    }

    public function deleteObject($objectId, $requestOptions = [])
    {
        return $this->deleteObjects([$objectId], $requestOptions);
    }

    public function deleteObjects($objectIds, $requestOptions = [])
    {
        $objects = array_map(function ($id) {
            return ['objectID' => $id];
        }, $objectIds);

        return $this->splitIntoBatches('deleteObject', $objects, $requestOptions);
    }

    public function deleteBy($filters, $requestOptions = [])
    {
        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/deleteByQuery', $this->indexName),
            $filters,
            $requestOptions
        );

        return new IndexingResponse($response, $this);
    }

    public function clearObjects($requestOptions = [])
    {
        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/clear', $this->indexName),
            [],
            $requestOptions
        );

        return new IndexingResponse($response, $this);
    }

    public function batch($requests, $requestOptions = [])
    {
        $response = $this->rawBatch($requests, $requestOptions);

        return new IndexingResponse($response, $this);
    }

    protected function rawBatch($requests, $requestOptions = [])
    {
        return $this->api->write(
            'POST',
            api_path('/1/indexes/%s/batch', $this->indexName),
            ['requests' => $requests],
            $requestOptions
        );
    }

    protected function splitIntoBatches($action, $objects, $requestOptions = [])
    {
        $allResponses = [];
        $batch = [];
        $batchSize = $this->config->getBatchSize();
        $count = 0;

        foreach ($objects as $object) {
            $batch[] = $object;
            $count++;

            if ($count === $batchSize) {
                if ('addObject' !== $action) {
                    Helpers::ensureObjectID($batch, 'All objects must have an unique objectID (like a primary key) to be valid.');
                }
                $allResponses[] = $this->rawBatch(Helpers::buildBatch($batch, $action), $requestOptions);
                $batch = [];
                $count = 0;
            }
        }

        if ('addObject' !== $action) {
            Helpers::ensureObjectID($batch, 'All objects must have an unique objectID (like a primary key) to be valid.');
        }

        // If not calls were made previously, not objects are passed
        // so we return a NullResponse
        // If there are already responses and something left in the
        // batch, we send it.
        if (empty($allResponses) && empty($batch)) {
            return new NullResponse();
        } elseif (!empty($batch)) {
            $allResponses[] = $this->rawBatch(Helpers::buildBatch($batch, $action), $requestOptions);
        }

        return new BatchIndexingResponse($allResponses, $this);
    }

    public function browseObjects($requestOptions = [])
    {
        return new ObjectIterator($this->indexName, $this->api, $requestOptions);
    }

    public function searchSynonyms($query, $requestOptions = [])
    {
        $query = (string) $query;

        if (is_array($requestOptions)) {
            $requestOptions['query'] = $query;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addBodyParameter('query', $query);
        }

        return $this->api->read(
            'POST',
            api_path('/1/indexes/%s/synonyms/search', $this->indexName),
            $requestOptions
        );
    }

    public function getSynonym($objectId, $requestOptions = [])
    {
        return $this->api->read(
            'GET',
            api_path('/1/indexes/%s/synonyms/%s', $this->indexName, $objectId),
            $requestOptions
        );
    }

    public function saveSynonym($synonym, $requestOptions = [])
    {
        return $this->saveSynonyms([$synonym], $requestOptions);
    }

    public function saveSynonyms($synonyms, $requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        if ($synonyms instanceof \Iterator) {
            $iteratedOver = [];
            foreach ($synonyms as $r) {
                $iteratedOver[] = $r;
            }
            $synonyms = $iteratedOver;
        }

        if (empty($synonyms)) {
            return new NullResponse();
        }

        Helpers::ensureObjectID($synonyms, 'All synonyms must have an unique objectID to be valid');

        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/synonyms/batch', $this->indexName),
            $synonyms,
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function replaceAllSynonyms($synonyms, $requestOptions = [])
    {
        if (is_array($requestOptions)) {
            $requestOptions['replaceExistingSynonyms'] = true;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addQueryParameter('replaceExistingSynonyms', true);
        }

        return $this->saveSynonyms($synonyms, $requestOptions);
    }

    public function deleteSynonym($objectId, $requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        $response = $this->api->write(
            'DELETE',
            api_path('/1/indexes/%s/synonyms/%s', $this->indexName, $objectId),
            [],
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function clearSynonyms($requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/synonyms/clear', $this->indexName),
            [],
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function browseSynonyms($requestOptions = [])
    {
        return new SynonymIterator($this->indexName, $this->api, $requestOptions);
    }

    public function searchRules($query, $requestOptions = [])
    {
        $query = (string) $query;

        if (is_array($requestOptions)) {
            $requestOptions['query'] = $query;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addBodyParameter('query', $query);
        }

        return $this->api->read(
            'POST',
            api_path('/1/indexes/%s/rules/search', $this->indexName),
            $requestOptions
        );
    }

    public function getRule($objectId, $requestOptions = [])
    {
        return $this->api->read(
            'GET',
            api_path('/1/indexes/%s/rules/%s', $this->indexName, $objectId),
            $requestOptions
        );
    }

    public function saveRule($rule, $requestOptions = [])
    {
        return $this->saveRules([$rule], $requestOptions);
    }

    public function saveRules($rules, $requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        if ($rules instanceof \Iterator) {
            $iteratedOver = [];
            foreach ($rules as $r) {
                $iteratedOver[] = $r;
            }
            $rules = $iteratedOver;
        }

        if (empty($rules)) {
            return new NullResponse();
        }

        Helpers::ensureObjectID($rules, 'All rules must have an unique objectID to be valid');

        /*
         * If consequence `params` is an array without keys, we are going to remove it
         * from the payload of the rule. Otherwise the transporter layer will serialize
         * `params` to an empty array [] instead of an empty object {} making an invalid
         * rule on the engine side.
         */
        foreach ($rules as $key => $rule) {
            if (isset($rule['consequence']) && empty($rule['consequence']['params'])) {
                unset($rules[$key]['consequence']['params']);
            }
        }

        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/rules/batch', $this->indexName),
            $rules,
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function replaceAllRules($rules, $requestOptions = [])
    {
        if (is_array($requestOptions)) {
            $requestOptions['clearExistingRules'] = true;
        } elseif ($requestOptions instanceof RequestOptions) {
            $requestOptions->addQueryParameter('clearExistingRules', true);
        }

        return $this->saveRules($rules, $requestOptions);
    }

    public function deleteRule($objectId, $requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        $response = $this->api->write(
            'DELETE',
            api_path('/1/indexes/%s/rules/%s', $this->indexName, $objectId),
            [],
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function clearRules($requestOptions = [])
    {
        $default = [];
        if (is_bool($fwd = $this->config->getDefaultForwardToReplicas())) {
            $default['forwardToReplicas'] = $fwd;
        }

        $response = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/rules/clear', $this->indexName),
            [],
            $requestOptions,
            $default
        );

        return new IndexingResponse($response, $this);
    }

    public function browseRules($requestOptions = [])
    {
        return new RuleIterator($this->indexName, $this->api, $requestOptions);
    }

    public function getTask($taskId, $requestOptions = [])
    {
        if (!$taskId) {
            throw new \InvalidArgumentException('taskID cannot be empty');
        }

        return $this->api->read(
            'GET',
            api_path('/1/indexes/%s/task/%s', $this->indexName, $taskId),
            $requestOptions
        );
    }

    public function waitTask($taskId, $requestOptions = [])
    {
        $retry = 1;
        $time = $this->config->getWaitTaskTimeBeforeRetry();

        do {
            $res = $this->getTask($taskId, $requestOptions);

            if ('published' === $res['status']) {
                return;
            }

            $retry++;
            $factor = ceil($retry / 10);
            usleep($factor * $time); // 0.1 second
        } while (true);
    }

    public function custom($method, $path, $requestOptions = [], $hosts = null)
    {
        return $this->api->send($method, $path, $requestOptions, $hosts);
    }

    public function delete($requestOptions = [])
    {
        $response = $this->api->write(
            'DELETE',
            api_path('/1/indexes/%s', $this->indexName),
            [],
            $requestOptions
        );

        return new IndexingResponse($response, $this);
    }

    /**
     * Check whether an index exists or not.
     *
     * @param array<string, int|string|array>|RequestOptions $requestOptions array of options or RequestOptions object
     *
     * @return bool
     */
    public function exists($requestOptions = [])
    {
        try {
            $this->getSettings($requestOptions);
        } catch (NotFoundException $exception) {
            return false;
        }

        return true;
    }

    /**
     * Find object by the given $callback.
     * Options can be passed in $requestOptions body:
     *  - query (string): pass a query
     *  - paginate (bool): choose if you want to iterate through all the
     * documents (true) or only the first page (false). Default is true.
     *
     * Usage:
     *
     * $index->findObject(
     *  function($object) { return $object['objectID'] === 'foo'; },
     *  array(
     *      'query' => 'bar',
     *      'paginate' => false,
     *      'hitsPerPage' => 50,
     *  )
     * );
     *
     * @param callable                                       $callback       The callback used to find the object
     *                                                                       Takes an array as parameter and returns a boolean
     * @param array<string, int|string|array>|RequestOptions $requestOptions array of options or RequestOptions object
     *
     * @return array<string, int|string|array>
     *
     * @throws ObjectNotFoundException
     */
    public function findObject($callback, $requestOptions = [])
    {
        $query = '';
        $paginate = true;
        $page = 0;
        $requestOptionsFactory = new RequestOptionsFactory($this->config);

        if (is_array($requestOptions)) {
            if (array_key_exists('query', $requestOptions)) {
                $query = $requestOptions['query'];
                unset($requestOptions['query']);
            }

            if (array_key_exists('paginate', $requestOptions)) {
                $paginate = $requestOptions['paginate'];
                unset($requestOptions['paginate']);
            }
        }

        $requestOptions = $requestOptionsFactory->create($requestOptions);

        while (true) {
            $requestOptions->addBodyParameter('page', $page);

            $result = $this->search($query, $requestOptions);
            foreach ($result['hits'] as $key => $hit) {
                if ($callback($hit)) {
                    return [
                        'object' => $hit,
                        'position' => $key,
                        'page' => $page,
                    ];
                }
            }

            $hasNextPage = $page + 1 < $result['nbPages'];
            if (!$paginate || !$hasNextPage) {
                throw new ObjectNotFoundException('Object not found');
            }

            $page++;
        }
    }

    /**
     * Retrieve the given object position in a set of results.
     *
     * @param array<string, array|string|int> $result   The set of results you want to iterate in
     * @param string                          $objectID The objectID you want to find
     *
     * @return int
     */
    public static function getObjectPosition($result, $objectID)
    {
        foreach ($result['hits'] as $key => $hit) {
            if ($hit['objectID'] === $objectID) {
                return $key;
            }
        }

        return -1;
    }

    private function copyTo($tmpIndexName, $requestOptions = [])
    {
        $apiResponse = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/operation', $this->indexName),
            [
                'operation' => 'copy',
                'destination' => $tmpIndexName,
            ],
            $requestOptions
        );

        return new IndexingResponse($apiResponse, $this);
    }

    private function moveFrom($tmpIndexName, $requestOptions = [])
    {
        $apiResponse = $this->api->write(
            'POST',
            api_path('/1/indexes/%s/operation', $tmpIndexName),
            [
                'operation' => 'move',
                'destination' => $this->indexName,
            ],
            $requestOptions
        );

        return new IndexingResponse($apiResponse, $this);
    }
}

Zerion Mini Shell 1.0