I am creating an Open Source Extension for Magento. Its in very early stages. I am struggling with cancel orders problem. I found some solution here
Magento - How can I run code when my order is canceled or refunded.
But whenever I cancel an order it calls neither void (in case of only Authorize payment action) nor refund (in case of authorize-capture payment action).
When I use capture-refund, It says the order cannot be cancelled.
When I use authorize-void, It say's the order have been cancelled. But the Void() function wasn't called at all. I kept some Mage::Log() functions inside. Which are not shown in Log file.
I don't understand what is wrong.
Here is the code. This is payment method model
<?php
class Package_Cashondelivery_Model_Createorder extends Mage_Payment_Model_Method_Abstract
{
protected $_code = 'cashondelivery';
protected $_canCapture = true;
protected $_canUseCheckout = true;
protected $_canFetchTransactionInfo = true;
protected $_isGateway = true;
protected $_canUseInternal = true;
protected $_canVoid = true;
protected $_canRefund = true;
public function validate()
{
$paymentInfo = $this->getInfoInstance();
if ($paymentInfo instanceof Mage_Sales_Model_Order_Payment) {
$postCode = $paymentInfo->getOrder()->getBillingAddress()->getPostcode();
}
else {
$postCode = $paymentInfo->getQuote()->getBillingAddress()->getPostcode();
}
$res=Api->validatePostCode($postCode);
$r = $res=='false'? FALSE : TRUE;
if (!$r) {
Mage::throwException($this->_getHelper()->__('Sorry ! Service is not available in your area'));
}
return $this;
}
public function authorize(Varien_Object $payment, $amount)
{
-------------------------------
-------------------------------
-------------------------------
#This is working fine
$transactionId = Api->someCall();
$payment->setTransactionId();
-------------------------------
-------------------------------
-------------------------------
-------------------------------
-------------------------------
-------------------------------
return $this;
}
public function void(Varien_Object $payment)
{
if (!$this->canVoid($payment)) {
Mage::throwException($this->_getHelper()->__('Void action is not available.'));
}
-------------------------------
-------------------------------
-------------------------------
-------------------------------
Mage::Log('Starting Void here....');
$transactionId = $Payment->getTransactionId();
Api->cancelOrder($transactionId);
return $this;
-------------------------------
-------------------------------
-------------------------------
}
}
?>
Here is config file.
<?xml version="1.0"?>
<config>
<modules>
<Package_Cashondelivery>
<!-- declare module's version information for database updates -->
<version>0.1.0</version>
</Package_Cashondelivery>
</modules>
<global>
<!-- declare model group for new module -->
<models>
<!-- model group alias to be used in Mage::getModel('newmodule/...') -->
<cashondelivery>
<!-- base class name for the model group -->
<class>Package_Cashondelivery_Model</class>
</cashondelivery>
</models>
<helpers>
<cashondelivery>
<class>Package_Cashondelivery_Helper</class>
</cashondelivery>
</helpers>
<!-- declare resource setup for new module -->
<resources>
<!-- resource identifier -->
<cashondelivery_setup>
<!-- specify that this resource is a setup resource and used for upgrades -->
<setup>
<!-- which module to look for install/upgrade files in -->
<module>Package_Cashondelivery</module>
</setup>
<!-- specify database connection for this resource -->
<connection>
<!-- do not create new connection, use predefined core setup connection -->
<use>core_setup</use>
</connection>
</cashondelivery_setup>
<cashondelivery_write>
<connection>
<use>core_write</use>
</connection>
</cashondelivery_write>
<cashondelivery_read>
<connection>
<use>core_read</use>
</connection>
</cashondelivery_read>
</resources>
</global>
<!-- declare default configuration values for this module -->
<default>
<payment>
<cashondelivery>
<active>1</active>
<model>cashondelivery/createorder</model>
<order_status>Processing</order_status>
<payment_action>authorize</payment_action>
<title>Cash On Delivery</title>
<example_uri>services.example.com</example_uri>
</cashondelivery>
</payment>
</default>
</config>
Anybody has any idea why this happens and how to resolve.