123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework\EntityManager\Db;
- use Magento\Framework\EntityManager\MetadataPool;
- use Magento\Framework\EntityManager\EntityMetadataInterface;
- use Magento\Framework\DB\Adapter\AdapterInterface;
- use Magento\Framework\App\ResourceConnection;
- /**
- * Class UpdateRow
- */
- class UpdateRow
- {
- /**
- * @var MetadataPool
- */
- private $metadataPool;
- /**
- * @var ResourceConnection
- */
- private $resourceConnection;
- /**
- * CreateRow constructor.
- *
- * @param MetadataPool $metadataPool
- * @param ResourceConnection $resourceConnection
- */
- public function __construct(
- MetadataPool $metadataPool,
- ResourceConnection $resourceConnection
- ) {
- $this->metadataPool = $metadataPool;
- $this->resourceConnection = $resourceConnection;
- }
- /**
- * @param EntityMetadataInterface $metadata
- * @param AdapterInterface $connection
- * @param array $data
- * @return array
- */
- protected function prepareData(EntityMetadataInterface $metadata, AdapterInterface $connection, $data)
- {
- $output = [];
- foreach ($connection->describeTable($metadata->getEntityTable()) as $column) {
- $columnName = strtolower($column['COLUMN_NAME']);
- if ($this->canNotSetTimeStamp($columnName, $column, $data) || $column['IDENTITY']) {
- continue;
- }
- if (isset($data[$columnName])) {
- $output[strtolower($column['COLUMN_NAME'])] = $data[strtolower($column['COLUMN_NAME'])];
- } elseif (!empty($column['NULLABLE'])) {
- $output[strtolower($column['COLUMN_NAME'])] = null;
- }
- }
- if (empty($data[$metadata->getIdentifierField()])) {
- $output[$metadata->getIdentifierField()] = $metadata->generateIdentifier();
- }
- return $output;
- }
- /**
- * Prepares SQL conditions for an update request.
- *
- * @param EntityMetadataInterface $metadata
- * @param AdapterInterface $connection
- * @param array $data
- *
- * @return array
- */
- private function prepareUpdateConditions(
- EntityMetadataInterface $metadata,
- AdapterInterface $connection,
- $data
- ) {
- $conditions = [];
- $indexList = $connection->getIndexList($metadata->getEntityTable());
- $primaryKeyName = $connection->getPrimaryKeyName($metadata->getEntityTable());
- foreach ($indexList[$primaryKeyName]['COLUMNS_LIST'] as $linkField) {
- if (isset($data[$linkField])) {
- $conditions[$linkField . ' = ?'] = $data[$linkField];
- }
- }
- return $conditions;
- }
- /**
- * @param string $columnName
- * @param string $column
- * @param array $data
- * @return bool
- */
- private function canNotSetTimeStamp($columnName, $column, array $data)
- {
- return $column['DEFAULT'] == 'CURRENT_TIMESTAMP' && !isset($data[$columnName])
- && empty($column['NULLABLE']);
- }
- /**
- * @param string $entityType
- * @param array $data
- * @return array
- */
- public function execute($entityType, $data)
- {
- $metadata = $this->metadataPool->getMetadata($entityType);
- $connection = $this->resourceConnection->getConnectionByName(
- $metadata->getEntityConnectionName()
- );
- $connection->update(
- $metadata->getEntityTable(),
- $this->prepareData($metadata, $connection, $data),
- $this->prepareUpdateConditions($metadata, $connection, $data)
- );
- return $data;
- }
- }
|