Commit | Line | Data |
---|---|---|
28abbcb0 | 1 | <?php |
2 | /* | |
3 | +--------------------------------------------------------------------+ | |
06b69b18 | 4 | | CiviCRM version 4.5 | |
28abbcb0 | 5 | +--------------------------------------------------------------------+ |
06b69b18 | 6 | | Copyright CiviCRM LLC (c) 2004-2014 | |
28abbcb0 | 7 | +--------------------------------------------------------------------+ |
8 | | This file is a part of CiviCRM. | | |
9 | | | | |
10 | | CiviCRM is free software; you can copy, modify, and distribute it | | |
11 | | under the terms of the GNU Affero General Public License | | |
12 | | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. | | |
13 | | | | |
14 | | CiviCRM is distributed in the hope that it will be useful, but | | |
15 | | WITHOUT ANY WARRANTY; without even the implied warranty of | | |
16 | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | | |
17 | | See the GNU Affero General Public License for more details. | | |
18 | | | | |
19 | | You should have received a copy of the GNU Affero General Public | | |
20 | | License and the CiviCRM Licensing Exception along | | |
21 | | with this program; if not, contact CiviCRM LLC | | |
22 | | at info[AT]civicrm[DOT]org. If you have questions about the | | |
23 | | GNU Affero General Public License or the licensing of CiviCRM, | | |
24 | | see the CiviCRM license FAQ at http://civicrm.org/licensing | | |
25 | +--------------------------------------------------------------------+ | |
26 | */ | |
27 | ||
28 | /** | |
29 | * | |
30 | * @package CRM | |
06b69b18 | 31 | * @copyright CiviCRM LLC (c) 2004-2014 |
28abbcb0 | 32 | * $Id$ |
33 | * | |
34 | */ | |
35 | class CRM_Member_BAO_MembershipPayment extends CRM_Member_DAO_MembershipPayment { | |
36 | ||
37 | ||
38 | /** | |
39 | * class constructor | |
40 | */ | |
41 | function __construct() { | |
42 | parent::__construct(); | |
43 | } | |
44 | /** | |
45 | * function to add the membership Payments | |
46 | * | |
47 | * @param array $params reference array contains the values submitted by the form | |
48 | * | |
49 | * @access public | |
50 | * @static | |
51 | * | |
52 | * @return object | |
53 | */ | |
99f71e5a | 54 | static function create($params) { |
28abbcb0 | 55 | $hook = empty($params['id']) ? 'create' : 'edit'; |
56 | CRM_Utils_Hook::pre($hook, 'MembershipPayment', CRM_Utils_Array::value('id', $params), $params); | |
57 | $dao = new CRM_Member_DAO_MembershipPayment(); | |
58 | $dao->copyValues($params); | |
59 | $dao->id = CRM_Utils_Array::value('id', $params); | |
99f71e5a EM |
60 | //Fixed for avoiding duplicate entry error when user goes |
61 | //back and forward during payment mode is notify | |
62 | if (!$dao->find(TRUE)) { | |
63 | $dao->save(); | |
64 | } | |
28abbcb0 | 65 | CRM_Utils_Hook::post($hook, 'MembershipPayment', $dao->id, $dao); |
99f71e5a EM |
66 | // CRM-14197 we are in the process on phasing out membershipPayment in favour of storing both contribution_id & entity_id (membership_id) on the line items |
67 | // table. However, at this stage we have both - there is still quite a bit of refactoring to do to set the line_iten entity_id right the first time | |
68 | // however, we can assume at this stage that any contribution id will have only one line item with that membership type in the line item table | |
69 | // OR the caller will have taken responsibility for updating the line items themselves so we will update using SQL here | |
70 | $membershipTypeID = civicrm_api3('membership', 'getvalue', array('id' => $dao->membership_id, 'return' => 'membership_type_id')); | |
71 | $sql = "UPDATE civicrm_line_item li | |
72 | LEFT JOIN civicrm_price_field_value pv ON pv.id = li.price_field_value_id | |
73 | SET entity_table = 'civicrm_membership', entity_id = %1 | |
74 | WHERE pv.membership_type_id = %2 | |
99f71e5a EM |
75 | AND contribution_id = %3"; |
76 | CRM_Core_DAO::executeQuery($sql, array(1 => array($dao->membership_id, 'Integer'), 2 => array($membershipTypeID, 'Integer'), 3 => array($dao->contribution_id, 'Integer'))); | |
28abbcb0 | 77 | return $dao; |
78 | } | |
79 | ||
80 | /** | |
81 | * Function to delete membership Payments | |
82 | * | |
83 | * @param int $id | |
77b97be7 EM |
84 | * |
85 | * @return bool | |
28abbcb0 | 86 | * @static |
87 | */ | |
88 | static function del($id) { | |
89 | $dao = new CRM_Member_DAO_MembershipPayment(); | |
90 | $dao->id = $id; | |
91 | $result = FALSE; | |
92 | if ($dao->find(TRUE)) { | |
93 | $dao->delete(); | |
94 | $result = TRUE; | |
95 | } | |
96 | return $result; | |
97 | } | |
98 | ||
99 | ||
100 | } | |
101 |