DonateController.php
2 years ago
DonationConfirmationReceiptViewController.php
2 years ago
DonationFormViewController.php
2 years ago
DonateController.php
143 lines
| 1 | <?php |
| 2 | |
| 3 | namespace Give\DonationForms\Controllers; |
| 4 | |
| 5 | use Exception; |
| 6 | use Give\DonationForms\DataTransferObjects\DonateControllerData; |
| 7 | use Give\Donors\Models\Donor; |
| 8 | use Give\Framework\PaymentGateways\Controllers\GatewayPaymentController; |
| 9 | use Give\Framework\PaymentGateways\Controllers\GatewaySubscriptionController; |
| 10 | use Give\Framework\PaymentGateways\Exceptions\PaymentGatewayException; |
| 11 | use Give\Framework\PaymentGateways\PaymentGateway; |
| 12 | use Give\PaymentGateways\Actions\GetGatewayDataFromRequest; |
| 13 | use Give\Subscriptions\Models\Subscription; |
| 14 | |
| 15 | /** |
| 16 | * @since 3.0.0 |
| 17 | */ |
| 18 | class DonateController |
| 19 | { |
| 20 | /** |
| 21 | * First we create a donation and/or subscription, then move on to the gateway processing |
| 22 | * |
| 23 | * @since 3.0.0 |
| 24 | * |
| 25 | * @return void |
| 26 | * @throws Exception|PaymentGatewayException |
| 27 | */ |
| 28 | public function donate(DonateControllerData $formData, PaymentGateway $gateway) |
| 29 | { |
| 30 | $donor = $this->getOrCreateDonor( |
| 31 | $formData->wpUserId, |
| 32 | $formData->email, |
| 33 | $formData->firstName, |
| 34 | $formData->lastName |
| 35 | ); |
| 36 | |
| 37 | if ($formData->donationType->isSingle()) { |
| 38 | $donation = $formData->toDonation($donor->id); |
| 39 | $donation->save(); |
| 40 | |
| 41 | do_action('givewp_donate_controller_donation_created', $formData, $donation, null); |
| 42 | |
| 43 | $gatewayData = apply_filters( |
| 44 | "givewp_create_payment_gateway_data_{$gateway::id()}", |
| 45 | (new GetGatewayDataFromRequest)(), |
| 46 | $donation |
| 47 | ); |
| 48 | |
| 49 | $controller = new GatewayPaymentController($gateway); |
| 50 | $controller->create($donation, $gatewayData); |
| 51 | } |
| 52 | |
| 53 | if ($formData->donationType->isSubscription()) { |
| 54 | $this->validateGatewaySupportsSubscriptions($gateway); |
| 55 | |
| 56 | $subscription = $formData->toSubscription($donor->id); |
| 57 | $subscription->save(); |
| 58 | |
| 59 | $donation = $formData->toInitialSubscriptionDonation($donor->id, $subscription->id); |
| 60 | $donation->save(); |
| 61 | |
| 62 | do_action('givewp_donate_controller_donation_created', $formData, $donation, $subscription); |
| 63 | |
| 64 | do_action('givewp_donate_controller_subscription_created', $formData, $subscription, $donation); |
| 65 | |
| 66 | $gatewayData = apply_filters( |
| 67 | "givewp_create_subscription_gateway_data_{$gateway::id()}", |
| 68 | (new GetGatewayDataFromRequest)(), |
| 69 | $donation, |
| 70 | $subscription |
| 71 | ); |
| 72 | |
| 73 | $controller = new GatewaySubscriptionController($gateway); |
| 74 | $controller->create($donation, $subscription, $gatewayData); |
| 75 | } |
| 76 | } |
| 77 | |
| 78 | /** |
| 79 | * @since 3.0.0 |
| 80 | * |
| 81 | * @param int|null $userId |
| 82 | * @param string $donorEmail |
| 83 | * @param string $firstName |
| 84 | * @param string $lastName |
| 85 | * |
| 86 | * @return Donor |
| 87 | * @throws Exception |
| 88 | */ |
| 89 | private function getOrCreateDonor( |
| 90 | int $userId, |
| 91 | string $donorEmail, |
| 92 | string $firstName, |
| 93 | string $lastName |
| 94 | ): Donor { |
| 95 | // first check if donor exists as a user |
| 96 | $donor = Donor::whereUserId($userId); |
| 97 | |
| 98 | // If they exist as a donor & user then make sure they don't already own this email before adding to their additional emails list.. |
| 99 | if ($donor && !$donor->hasEmail($donorEmail)) { |
| 100 | $donor->additionalEmails = array_merge($donor->additionalEmails ?? [], [$donorEmail]); |
| 101 | $donor->save(); |
| 102 | } |
| 103 | |
| 104 | // if donor is not a user than check for any donor matching this email |
| 105 | if (!$donor) { |
| 106 | $donor = Donor::whereEmail($donorEmail); |
| 107 | } |
| 108 | |
| 109 | // if no donor exists then create a new one using their personal information from the form. |
| 110 | if (!$donor) { |
| 111 | $donor = Donor::create([ |
| 112 | 'name' => trim("$firstName $lastName"), |
| 113 | 'firstName' => $firstName, |
| 114 | 'lastName' => $lastName, |
| 115 | 'email' => $donorEmail, |
| 116 | 'userId' => $userId ?: null |
| 117 | ]); |
| 118 | } |
| 119 | |
| 120 | return $donor; |
| 121 | } |
| 122 | |
| 123 | /** |
| 124 | * @throws PaymentGatewayException |
| 125 | */ |
| 126 | private function validateGatewaySupportsSubscriptions(PaymentGateway $gateway) |
| 127 | { |
| 128 | if (!$gateway->supportsSubscriptions()) { |
| 129 | $gatewayName = $gateway->getName(); |
| 130 | |
| 131 | throw new PaymentGatewayException( |
| 132 | sprintf( |
| 133 | __( |
| 134 | "[%s] This payment gateway does not support recurring payments, please try selecting another payment gateway.", |
| 135 | 'give' |
| 136 | ), |
| 137 | $gatewayName |
| 138 | ) |
| 139 | ); |
| 140 | } |
| 141 | } |
| 142 | } |
| 143 |