![]() 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/old/vendor/mageworx/module-seoxtemplates/Model/CsvWriter/Category/ |
<?php /** * Copyright © 2016 MageWorx. All rights reserved. * See LICENSE.txt for license details. */ namespace MageWorx\SeoXTemplates\Model\CsvWriter\Category; class Eav extends \MageWorx\SeoXTemplates\Model\CsvWriter\Category { /** * @var \Magento\Framework\Data\Collection|null */ protected $collection; /** * Store manager * * @var \Magento\Store\Model\StoreManagerInterface */ protected $_storeManager; public function __construct( \Magento\Store\Model\StoreManagerInterface $_storeManager, \Magento\Framework\Filesystem $fileSystem, \MageWorx\SeoXTemplates\Model\DataProviderCategoryFactory $dataProviderCategoryFactory ) { $this->_storeManager = $_storeManager; parent::__construct($fileSystem, $dataProviderCategoryFactory); } /** * Write to CSV file converted string from template code and retrieve file params * * @param \Magento\Framework\Data\Collection $collection * @param \MageWorx\SeoXTemplates\Model\AbstractTemplate $template * @param string|null $filenameParam * @param int|null $nestedStoreId * @return array */ public function write($collection, $template, $filenameParam = null, $nestedStoreId = null) { if (!$collection) { return false; } $this->collection = $collection; $dataProvider = $this->dataProviderCategoryFactory->create($template->getTypeId()); $data = $dataProvider->getData($collection, $template, $nestedStoreId); $filename = $filenameParam ? $filenameParam : 'export/' . hash('md5', microtime()) . '.csv'; $stream = $this->directory->openFile($filename, 'a+'); if (!$filenameParam) { $stream->writeCsv($this->_getHeaderData()); } $connect = $dataProvider->getCollectionIds(); $stream->lock(); foreach ($data as $attributeHash => $attributeData) { foreach ($attributeData as $multipleData) { list($attributeId, $attributeCode) = explode('#', $attributeHash); foreach ($multipleData as $entityId => $data) { $category = $this->collection->getItemById($connect[$entityId]); if (!$category) { continue; } if (empty($data['value'])) { continue; } if ($data['store_id'] == '0') { $storeName = __('Single-Store Mode'); } else { $storeId = $nestedStoreId ? $nestedStoreId : $this->collection->getStoreId(); $storeName = $this->_storeManager->getStore($storeId)->getName(); } $write = [ 'attribute_id' => $attributeId, 'attribute_code' => $attributeCode, 'category_id' => $connect[$entityId], 'category_name' => $this->collection->getItemById($connect[$entityId])->getName(), 'store_id' => $data['store_id'], 'store_name' => $storeName, 'current_value' => !empty($data['old_value']) ? $data['old_value'] : '', 'value' => $data['value'] ]; $stream->writeCsv($write); } } } $stream->unlock(); $stream->close(); return [ 'type' => 'filename', 'value' => $filename, 'rm' => true // can delete file after use ]; } /** * Retrieve header for report * * @return array */ protected function _getHeaderData() { return [ __('Attribute ID'), __('Attribute Code'), __('Category ID'), __('Category Name'), __('Store ID'), __('Store Name'), __('Current Store Value'), __('New Store Value') ]; } }