*/
protected $subscriptionDetails = [];
+ /**
+ * Is the form being accessed by a front end user to update their own recurring.
+ *
+ * @var bool
+ */
+ protected $selfService;
+
/**
* Explicitly declare the entity api name.
*/
}
$this->_paymentProcessorObj = $this->_paymentProcessor['object'];
}
+ elseif ($this->_mid) {
+ $this->_paymentProcessorObj = CRM_Financial_BAO_PaymentProcessor::getProcessorForEntity($this->_mid, 'membership', 'obj');
+ $this->_paymentProcessor = $this->_paymentProcessorObj->getPaymentProcessor();
+ }
}
/**
elseif ($this->_coid) {
$this->subscriptionDetails = $this->_subscriptionDetails = CRM_Contribute_BAO_ContributionRecur::getSubscriptionDetails($this->_coid, 'contribution');
}
+ elseif ($this->_mid) {
+ $this->subscriptionDetails = CRM_Contribute_BAO_ContributionRecur::getSubscriptionDetails($this->_mid, 'membership');
+ }
+ // This is being set temporarily - we should eventually just use the getter fn.
+ $this->_subscriptionDetails = $this->subscriptionDetails;
}
/**
return isset($sub->contact_id) ? $sub->contact_id : FALSE;
}
+ /**
+ * Is this being used by a front end user to update their own recurring.
+ *
+ * @return bool
+ */
+ protected function isSelfService() {
+ if (!is_null($this->selfService)) {
+ return $this->selfService;
+ }
+ $this->selfService = FALSE;
+ if (!CRM_Core_Permission::check('edit contributions')) {
+ if ($this->_subscriptionDetails->contact_id != $this->getContactID()) {
+ CRM_Core_Error::statusBounce(ts('You do not have permission to cancel this recurring contribution.'));
+ }
+ $this->selfService = TRUE;
+ }
+ return $this->selfService;
+ }
+
}