Во время разработки модуля я писал плагин, который изменяет коллекцию параметров продукта до его загрузки (добавляет поле описания). Вот:
и т.д. / di.xml
<type name="Magento\Catalog\Model\ResourceModel\Product\Option\Collection">
<plugin name="addOptionDescription" type="Vendor\Module\Plugin\Product\Option\Collection" sortOrder="10" disabled="false"/>
</type>
Код:
<?php
namespace Vendor\Module\Plugin\Product\Option;
use Vendor\Module\Model\OptionDescription;
use Magento\Catalog\Model\ResourceModel\Product\Option\Collection as OptionCollection;
class Collection
{
/**
* @var \Vendor\Module\Helper\Data
*/
protected $helper;
public function __construct(
\Vendor\Module\Helper\Data $helper
) {
$this->helper = $helper;
}
/**
* @param OptionCollection $subject
* @param bool $printQuery
* @param bool $logQuery
* @return array
*/
public function beforeLoad($subject, $printQuery = false, $logQuery = false)
{
if (!$subject->isLoaded()) {
$this->addDescriptionToResult($subject);
}
return [$printQuery, $logQuery];
}
/**
* Add description to result
*
* If yo get error message "Warning: Illegal string offset 'is_in_stock' ... "
* @see http://devdocs.magento.com/guides/v2.0/install-gde/trouble/php/tshoot_opcache.html
*
* @param OptionCollection $collection
* @return OptionCollection $collection
*/
private function addDescriptionToResult($collection)
{
$tableName = OptionDescription::TABLE_NAME;
$joinDescriptionExpr = 'main_table.unique_option_id = option_description.unique_option_id AND option_description.store_id = 0';
$collection->getSelect()->joinLeft(
['option_description' => $tableName],
$joinDescriptionExpr,
['description' => 'description']
);
return $collection;
}
/**
* Resolve current store id
*
* @return int
*/
protected function getStoreId()
{
return $this->helper->resolveCurrentStoreId();
}
}
Кажется, все в порядке, но ... Когда я пытаюсь загрузить существующую страницу редактирования продукта (на сервере), я вижу следующую ошибку:
Предупреждение: недопустимое смещение строки 'is_in_stock' в [...] / vendor / magento / module-catalog-inventory / Ui / DataProvider / Product / Form / Modifier / AdvancedInventory.php в строке 87
В случае, если я внесу изменения, как указано в документации (установить opcache.save_comments = 1
в моем конфиге php-fpm), все работает отлично. Но я не могу понять, какой код вызывает ошибку выше и как я могу предотвратить ее без изменений конфигурации?