Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php namespace Webkul\Product\Helpers\Indexers; use Illuminate\Support\Carbon; use Webk..

Decoded Output download

<?php

namespace Webkul\Product\Helpers\Indexers;

use Illuminate\Support\Carbon;
use Webkul\Customer\Repositories\CustomerGroupRepository;
use Webkul\Product\Repositories\ProductPriceIndexRepository;
use Webkul\Product\Repositories\ProductRepository;

class Price extends AbstractIndexer
{
    /**
     * @var int
     */
    private $batchSize;

    /**
     * Channels
     *
     * @var array
     */
    protected $channels;

    /**
     * Customer Groups
     *
     * @var array
     */
    protected $customerGroups;

    /**
     * Create a new indexer instance.
     *
     * @return void
     */
    public function __construct(
        protected CustomerGroupRepository $customerGroupRepository,
        protected ProductRepository $productRepository,
        protected ProductPriceIndexRepository $productPriceIndexRepository
    ) {
        $this->batchSize = self::BATCH_SIZE;
    }

    /**
     * Reindex all products
     *
     * @return void
     */
    public function reindexFull()
    {
        while (true) {
            $paginator = $this->productRepository
                ->with([
                    'variants',
                    'attribute_family',
                    'attribute_values',
                    'variants.attribute_family',
                    'variants.attribute_values',
                    'price_indices',
                    'inventory_indices',
                    'variants.price_indices',
                    'variants.inventory_indices',
                    'customer_group_prices',
                    'variants.customer_group_prices',
                    'catalog_rule_prices',
                    'variants.catalog_rule_prices',
                ])
                ->cursorPaginate($this->batchSize);

            $this->reindexBatch($paginator->items());

            if (! $cursor = $paginator->nextCursor()) {
                break;
            }

            request()->query->add(['cursor' => $cursor->encode()]);
        }

        request()->query->remove('cursor');
    }

    /**
     * Reindexed products with price which depends on date
     *
     * @return void
     */
    public function reindexSelective()
    {
        while (true) {
            $paginator = $this->productRepository
                ->distinct()
                ->select('products.*')
                ->with([
                    'variants',
                    'attribute_values',
                    'variants.attribute_values',
                    'price_indices',
                    'inventory_indices',
                    'variants.price_indices',
                    'variants.inventory_indices',
                    'customer_group_prices',
                    'variants.customer_group_prices',
                    'catalog_rule_prices',
                    'variants.catalog_rule_prices',
                ])
                ->join('product_attribute_values as special_price_from_pav', function ($join) {
                    $join->on('products.id', '=', 'special_price_from_pav.product_id')
                        ->where('special_price_from_pav.attribute_id', self::SPECIAL_PRICE_FROM_ATTRIBUTE_ID);
                })
                ->join('product_attribute_values as special_price_to_pav', function ($join) {
                    $join->on('products.id', '=', 'special_price_to_pav.product_id')
                        ->where('special_price_to_pav.attribute_id', self::SPECIAL_PRICE_TO_ATTRIBUTE_ID);
                })
                ->leftJoin('catalog_rule_product_prices', 'products.id', '=', 'catalog_rule_product_prices.product_id')
                ->where(function ($query) {
                    return $query->orWhere('special_price_from_pav.date_value', Carbon::now()->format('Y-m-d'))
                        ->orWhere('special_price_to_pav.date_value', Carbon::now()->subDays(1)->format('Y-m-d'))
                        ->orWhere('catalog_rule_product_prices.rule_date', Carbon::now()->subDays(1)->format('Y-m-d'));
                })
                ->cursorPaginate($this->batchSize);

            $this->reindexBatch($paginator->items());

            if (! $cursor = $paginator->nextCursor()) {
                break;
            }

            request()->query->add(['cursor' => $cursor->encode()]);
        }

        request()->query->remove('cursor');
    }

    /**
     * Reindex products by batch size
     *
     * @return void
     */
    public function reindexBatch($products)
    {
        $newIndices = [];

        foreach ($products as $product) {
            $indexer = $this->getTypeIndexer($product)
                ->setProduct($product);

            foreach ($this->getChannels() as $channel) {
                foreach ($this->getCustomerGroups() as $customerGroup) {
                    $customerGroupIndex = $product->price_indices
                        ->where('channel_id', $channel->id)
                        ->where('customer_group_id', $customerGroup->id)
                        ->where('product_id', $product->id)
                        ->first();

                    $newIndex = $indexer
                        ->setChannel($channel)
                        ->setCustomerGroup($customerGroup)
                        ->getIndices();

                    if ($customerGroupIndex) {
                        $oldIndex = collect($customerGroupIndex->toArray())
                            ->except('id', 'created_at', 'updated_at')
                            ->toArray();

                        $isIndexChanged = $this->isIndexChanged(
                            $oldIndex,
                            $newIndex
                        );

                        if ($isIndexChanged) {
                            $this->productPriceIndexRepository->update($newIndex, $customerGroupIndex->id);
                        }
                    } else {
                        $newIndices[] = $newIndex;
                    }
                }
            }
        }

        $this->productPriceIndexRepository->insert($newIndices);
    }

    /**
     * Check if index value changed
     *
     * @return bool
     */
    public function isIndexChanged($oldIndex, $newIndex)
    {
        return (bool) count(array_diff_assoc($oldIndex, $newIndex));
    }

    /**
     * Returns indexer for product type
     *
     * @return string
     */
    public function getTypeIndexer($product)
    {
        static $typeIndexers = [];

        if (isset($typeIndexers[$product->type])) {
            return $typeIndexers[$product->type];
        }

        return $typeIndexers[$product->type] = $product->getTypeInstance()->getPriceIndexer();
    }

    /**
     * Returns all customer groups
     *
     * @return Collection
     */
    public function getChannels()
    {
        if ($this->channels) {
            return $this->channels;
        }

        return $this->channels = core()->getAllChannels();
    }

    /**
     * Returns all customer groups
     *
     * @return Collection
     */
    public function getCustomerGroups()
    {
        if ($this->customerGroups) {
            return $this->customerGroups;
        }

        return $this->customerGroups = $this->customerGroupRepository->all();
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

namespace Webkul\Product\Helpers\Indexers;

use Illuminate\Support\Carbon;
use Webkul\Customer\Repositories\CustomerGroupRepository;
use Webkul\Product\Repositories\ProductPriceIndexRepository;
use Webkul\Product\Repositories\ProductRepository;

class Price extends AbstractIndexer
{
    /**
     * @var int
     */
    private $batchSize;

    /**
     * Channels
     *
     * @var array
     */
    protected $channels;

    /**
     * Customer Groups
     *
     * @var array
     */
    protected $customerGroups;

    /**
     * Create a new indexer instance.
     *
     * @return void
     */
    public function __construct(
        protected CustomerGroupRepository $customerGroupRepository,
        protected ProductRepository $productRepository,
        protected ProductPriceIndexRepository $productPriceIndexRepository
    ) {
        $this->batchSize = self::BATCH_SIZE;
    }

    /**
     * Reindex all products
     *
     * @return void
     */
    public function reindexFull()
    {
        while (true) {
            $paginator = $this->productRepository
                ->with([
                    'variants',
                    'attribute_family',
                    'attribute_values',
                    'variants.attribute_family',
                    'variants.attribute_values',
                    'price_indices',
                    'inventory_indices',
                    'variants.price_indices',
                    'variants.inventory_indices',
                    'customer_group_prices',
                    'variants.customer_group_prices',
                    'catalog_rule_prices',
                    'variants.catalog_rule_prices',
                ])
                ->cursorPaginate($this->batchSize);

            $this->reindexBatch($paginator->items());

            if (! $cursor = $paginator->nextCursor()) {
                break;
            }

            request()->query->add(['cursor' => $cursor->encode()]);
        }

        request()->query->remove('cursor');
    }

    /**
     * Reindexed products with price which depends on date
     *
     * @return void
     */
    public function reindexSelective()
    {
        while (true) {
            $paginator = $this->productRepository
                ->distinct()
                ->select('products.*')
                ->with([
                    'variants',
                    'attribute_values',
                    'variants.attribute_values',
                    'price_indices',
                    'inventory_indices',
                    'variants.price_indices',
                    'variants.inventory_indices',
                    'customer_group_prices',
                    'variants.customer_group_prices',
                    'catalog_rule_prices',
                    'variants.catalog_rule_prices',
                ])
                ->join('product_attribute_values as special_price_from_pav', function ($join) {
                    $join->on('products.id', '=', 'special_price_from_pav.product_id')
                        ->where('special_price_from_pav.attribute_id', self::SPECIAL_PRICE_FROM_ATTRIBUTE_ID);
                })
                ->join('product_attribute_values as special_price_to_pav', function ($join) {
                    $join->on('products.id', '=', 'special_price_to_pav.product_id')
                        ->where('special_price_to_pav.attribute_id', self::SPECIAL_PRICE_TO_ATTRIBUTE_ID);
                })
                ->leftJoin('catalog_rule_product_prices', 'products.id', '=', 'catalog_rule_product_prices.product_id')
                ->where(function ($query) {
                    return $query->orWhere('special_price_from_pav.date_value', Carbon::now()->format('Y-m-d'))
                        ->orWhere('special_price_to_pav.date_value', Carbon::now()->subDays(1)->format('Y-m-d'))
                        ->orWhere('catalog_rule_product_prices.rule_date', Carbon::now()->subDays(1)->format('Y-m-d'));
                })
                ->cursorPaginate($this->batchSize);

            $this->reindexBatch($paginator->items());

            if (! $cursor = $paginator->nextCursor()) {
                break;
            }

            request()->query->add(['cursor' => $cursor->encode()]);
        }

        request()->query->remove('cursor');
    }

    /**
     * Reindex products by batch size
     *
     * @return void
     */
    public function reindexBatch($products)
    {
        $newIndices = [];

        foreach ($products as $product) {
            $indexer = $this->getTypeIndexer($product)
                ->setProduct($product);

            foreach ($this->getChannels() as $channel) {
                foreach ($this->getCustomerGroups() as $customerGroup) {
                    $customerGroupIndex = $product->price_indices
                        ->where('channel_id', $channel->id)
                        ->where('customer_group_id', $customerGroup->id)
                        ->where('product_id', $product->id)
                        ->first();

                    $newIndex = $indexer
                        ->setChannel($channel)
                        ->setCustomerGroup($customerGroup)
                        ->getIndices();

                    if ($customerGroupIndex) {
                        $oldIndex = collect($customerGroupIndex->toArray())
                            ->except('id', 'created_at', 'updated_at')
                            ->toArray();

                        $isIndexChanged = $this->isIndexChanged(
                            $oldIndex,
                            $newIndex
                        );

                        if ($isIndexChanged) {
                            $this->productPriceIndexRepository->update($newIndex, $customerGroupIndex->id);
                        }
                    } else {
                        $newIndices[] = $newIndex;
                    }
                }
            }
        }

        $this->productPriceIndexRepository->insert($newIndices);
    }

    /**
     * Check if index value changed
     *
     * @return bool
     */
    public function isIndexChanged($oldIndex, $newIndex)
    {
        return (bool) count(array_diff_assoc($oldIndex, $newIndex));
    }

    /**
     * Returns indexer for product type
     *
     * @return string
     */
    public function getTypeIndexer($product)
    {
        static $typeIndexers = [];

        if (isset($typeIndexers[$product->type])) {
            return $typeIndexers[$product->type];
        }

        return $typeIndexers[$product->type] = $product->getTypeInstance()->getPriceIndexer();
    }

    /**
     * Returns all customer groups
     *
     * @return Collection
     */
    public function getChannels()
    {
        if ($this->channels) {
            return $this->channels;
        }

        return $this->channels = core()->getAllChannels();
    }

    /**
     * Returns all customer groups
     *
     * @return Collection
     */
    public function getCustomerGroups()
    {
        if ($this->customerGroups) {
            return $this->customerGroups;
        }

        return $this->customerGroups = $this->customerGroupRepository->all();
    }
}

Function Calls

None

Variables

None

Stats

MD5 03b436fbcc5ed8e7e926eac2ec86db6f
Eval Count 0
Decode Time 81 ms