getConnection()->addColumn( $this->getTable('sales/quote'), 'global_currency_code', 'varchar(255) NULL AFTER `store_to_quote_rate`' ); $installer->getConnection()->addColumn( $this->getTable('sales/quote'), 'base_to_quote_rate', 'decimal(12,4) NULL AFTER `store_to_quote_rate`' ); $installer->getConnection()->addColumn( $this->getTable('sales/quote'), 'base_to_global_rate', 'decimal(12,4) NULL AFTER `store_to_quote_rate`' ); $installer->addAttribute('quote', 'global_currency_code', array('type'=>'static')); $installer->addAttribute('quote', 'base_to_global_rate', array('type'=>'static')); $installer->addAttribute('quote', 'base_to_quote_rate', array('type'=>'static')); $installer->addAttribute('order', 'global_currency_code', array('type'=>'varchar')); $installer->addAttribute('order', 'base_to_global_rate', array('type'=>'decimal')); $installer->addAttribute('order', 'base_to_order_rate', array('type'=>'decimal')); $installer->addAttribute('invoice', 'global_currency_code', array('type'=>'varchar')); $installer->addAttribute('invoice', 'base_to_global_rate', array('type'=>'decimal')); $installer->addAttribute('invoice', 'base_to_order_rate', array('type'=>'decimal')); $installer->addAttribute('creditmemo', 'global_currency_code', array('type'=>'varchar')); $installer->addAttribute('creditmemo', 'base_to_global_rate', array('type'=>'decimal')); $installer->addAttribute('creditmemo', 'base_to_order_rate', array('type'=>'decimal')); /* * getting all base currency codes and placing them in newly created attribute */ $orderEntityType = $installer->getEntityType('order'); $orderEntityType['entity_table'] = 'sales_order'; $invoiceEntityType = $installer->getEntityType('invoice'); $invoiceEntityType['entity_table'] = 'sales_order_entity'; $creditmemoEntityType = $installer->getEntityType('creditmemo'); $creditmemoEntityType['entity_table'] = 'sales_order_entity'; $entityTypes = array($orderEntityType['entity_type_id'] => $orderEntityType, $invoiceEntityType['entity_type_id'] => $invoiceEntityType, $creditmemoEntityType['entity_type_id'] => $creditmemoEntityType); try { $installer->getConnection()->beginTransaction(); foreach ($entityTypes as $typeId => $entity) { $globalCurrencyCode = $installer->getAttribute($typeId, 'global_currency_code'); if ($globalCurrencyCode['backend_type'] == 'static') { $globalCurrencyCodeTable = $this->getTable($entity['entity_table']); } else { $globalCurrencyCodeTable = $this->getTable($entity['entity_table']) . '_' . $globalCurrencyCode['backend_type']; } $baseCurrencyCode = $installer->getAttribute($typeId, 'base_currency_code'); if ($baseCurrencyCode['backend_type'] == 'static') { $baseCurrencyCodeTable = $this->getTable($entity['entity_table']); } else { $baseCurrencyCodeTable = $this->getTable($entity['entity_table']) . '_' . $baseCurrencyCode['backend_type']; } $storeCurrencyCode = $installer->getAttribute($typeId, 'store_currency_code'); if ($storeCurrencyCode['backend_type'] == 'static') { $storeCurrencyCodeTable = $this->getTable($entity['entity_table']); } else { $storeCurrencyCodeTable = $this->getTable($entity['entity_table']) . '_' . $storeCurrencyCode['backend_type']; } $baseToGlobalRate = $installer->getAttribute($typeId, 'base_to_global_rate'); if ($baseToGlobalRate['backend_type'] == 'static') { $baseToGlobalRateTable = $this->getTable($entity['entity_table']); } else { $baseToGlobalRateTable = $this->getTable($entity['entity_table']) . '_' . $baseToGlobalRate['backend_type']; } $storeToBaseRate = $installer->getAttribute($typeId, 'store_to_base_rate'); if ($storeToBaseRate['backend_type'] == 'static') { $storeToBaseRateTable = $this->getTable($entity['entity_table']); } else { $storeToBaseRateTable = $this->getTable($entity['entity_table']) . '_' . $storeToBaseRate['backend_type']; } $baseToOrderRate = $installer->getAttribute($typeId, 'base_to_order_rate'); if ($baseToOrderRate['backend_type'] == 'static') { $baseToOrderRateTable = $this->getTable($entity['entity_table']); } else { $baseToOrderRateTable = $this->getTable($entity['entity_table']) . '_' . $baseToOrderRate['backend_type']; } $storeToOrderRate = $installer->getAttribute($typeId, 'store_to_order_rate'); if ($storeToOrderRate['backend_type'] == 'static') { $storeToOrderRateTable = $this->getTable($entity['entity_table']); } else { $storeToOrderRateTable = $this->getTable($entity['entity_table']) . '_' . $storeToOrderRate['backend_type']; } //////////////////////////////////////////////////////////////////////////////////////////////////////////////// //copy data from base_currency_code into global_currency_code $query = 'INSERT INTO `' . $globalCurrencyCodeTable . '` (`entity_type_id`, `attribute_id`, `entity_id`, `value`) SELECT `entity_type_id`, "' . $globalCurrencyCode['attribute_id'] . '" as `attribute_id`, `entity_id`, `value` FROM `' . $baseCurrencyCodeTable . '` WHERE `attribute_id` = ' . $baseCurrencyCode['attribute_id'] . ';'; //echo $query . "
"; $installer->getConnection()->query($query); //delete old data in base_currency_code $query = 'DELETE FROM `' . $baseCurrencyCodeTable . '` WHERE `attribute_id` = ' . $baseCurrencyCode['attribute_id'] . ';'; //echo $query . "
"; $installer->getConnection()->query($query); //copy data from store_currency_code into base_currency_code $query = 'INSERT INTO `' . $baseCurrencyCodeTable . '` (`entity_type_id`, `attribute_id`, `entity_id`, `value`) SELECT `entity_type_id`, "' . $baseCurrencyCode['attribute_id'] . '" as `attribute_id`, `entity_id`, `value` FROM `' . $storeCurrencyCodeTable . '` WHERE `attribute_id` = ' . $storeCurrencyCode['attribute_id'] . ';'; //echo $query . "
"; $installer->getConnection()->query($query); //copy data from store_to_base_rate into base_to_global_rate $query = 'INSERT INTO `' . $baseToGlobalRateTable . '` (`entity_type_id`, `attribute_id`, `entity_id`, `value`) SELECT `entity_type_id`, "' . $baseToGlobalRate['attribute_id'] . '" as `attribute_id`, `entity_id`, `value` FROM `' . $storeToBaseRateTable . '` WHERE `attribute_id` = ' . $storeToBaseRate['attribute_id'] . ';'; //echo $query . "
"; $installer->getConnection()->query($query); //copy data from store_to_order_rate into base_to_order_rate $query = 'INSERT INTO `' . $baseToOrderRateTable . '` (`entity_type_id`, `attribute_id`, `entity_id`, `value`) SELECT `entity_type_id`, "' . $baseToOrderRate['attribute_id'] . '" as `attribute_id`, `entity_id`, `value` FROM `' . $storeToOrderRateTable . '` WHERE `attribute_id` = ' . $storeToOrderRate['attribute_id'] . ';'; //echo $query . "
"; $installer->getConnection()->query($query); } $installer->getConnection()->commit(); } catch(Exception $e) { $installer->getConnection()->rollBack(); throw $e; }