PluginProbe ʕ •ᴥ•ʔ
GiveWP – Donation Plugin and Fundraising Platform / trunk
GiveWP – Donation Plugin and Fundraising Platform vtrunk
4.16.2 4.16.1 4.16.0 4.15.5 4.15.4 4.15.3 4.15.2 4.15.1 4.15.0 2.3.0 2.3.1 2.3.2 2.30.0 2.31.0 2.31.1 2.32.0 2.33.0 2.33.1 2.33.2 2.33.3 2.33.4 2.33.5 2.4.0 2.4.1 2.4.2 2.4.3 2.4.4 2.4.5 2.4.6 2.4.7 2.5.0 2.5.1 2.5.10 2.5.11 2.5.12 2.5.13 2.5.2 2.5.3 2.5.4 2.5.5 2.5.6 2.5.7 2.5.8 2.5.9 2.6.0 2.6.1 2.6.2 2.6.3 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.8.0 2.8.1 2.9.0 2.9.1 2.9.2 2.9.3 2.9.4 2.9.5 2.9.6 2.9.7 3.0.0 3.0.1 3.0.2 3.0.3 3.0.4 3.1.0 3.1.1 3.1.2 3.10.0 3.11.0 3.12.0 3.12.1 3.12.2 3.12.3 3.13.0 3.14.0 3.14.1 3.14.2 3.15.0 3.15.1 3.16.0 3.16.1 3.16.2 3.16.3 3.16.4 3.16.5 3.17.0 3.17.1 3.17.2 3.18.0 3.19.0 3.19.1 3.19.2 3.19.3 3.19.4 3.2.0 3.2.1 3.2.2 3.20.0 3.21.0 3.21.1 3.22.0 3.22.1 3.22.2 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.5.0 3.5.1 3.6.0 3.6.1 3.6.2 3.7.0 3.8.0 3.9.0 4.0.0 4.1.0 4.1.1 4.10.0 4.10.1 4.11.0 4.12.0 4.13.0 4.13.1 4.13.2 4.14.0 4.14.1 4.14.2 4.14.3 4.14.4 4.14.5 4.14.6 4.2.0 4.2.1 4.3.0 4.3.1 4.3.2 4.4.0 4.5.0 4.6.1 4.7.0 4.7.1 4.8.0 4.8.1 4.9.0 trunk 1.9.0 2.0.0 2.0.1 2.0.2 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7 2.1.0 2.1.1 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8 2.10.0 2.10.1 2.10.2 2.10.3 2.10.4 2.11.0 2.11.1 2.11.2 2.11.3 2.12.0 2.12.1 2.12.2 2.12.3 2.13.0 2.13.1 2.13.2 2.13.3 2.13.4 2.14.0 2.15.0 2.16.0 2.16.1 2.17.0 2.17.1 2.17.3 2.18.0 2.18.1 2.19.1 2.19.2 2.19.3 2.19.4 2.19.5 2.19.6 2.19.7 2.19.8 2.2.0 2.2.1 2.2.2 2.2.3 2.2.4 2.2.5 2.2.6 2.20.0 2.20.1 2.20.2 2.21.0 2.21.1 2.21.2 2.21.3 2.21.4 2.22.0 2.22.1 2.22.2 2.22.3 2.23.0 2.23.1 2.23.2 2.24.0 2.24.1 2.24.2 2.25.0 2.25.1 2.25.2 2.25.3 2.26.0 2.27.0 2.27.1 2.27.2 2.27.3 2.28.0 2.29.0 2.29.1 2.29.2
give / src / Subscriptions / Endpoints / ListSubscriptionStats.php
give / src / Subscriptions / Endpoints Last commit date
Endpoint.php 5 months ago ListSubscriptionStats.php 8 months ago ListSubscriptions.php 8 months ago SubscriptionActions.php 5 months ago SwitchSubscriptionView.php 3 years ago
ListSubscriptionStats.php
128 lines
1 <?php
2
3 namespace Give\Subscriptions\Endpoints;
4
5 use Give\Framework\Database\DB;
6 use Give\Donations\ValueObjects\DonationMetaKeys;
7 use WP_REST_Request;
8 use WP_REST_Response;
9
10 /**
11 * @since 4.12.0
12 */
13 class ListSubscriptionStats extends Endpoint
14 {
15 /**
16 * @var string
17 */
18 protected $endpoint = 'admin/subscriptions/stats';
19
20 /**
21 * @var WP_REST_Request
22 */
23 protected $request;
24
25 /**
26 * @since 4.12.0
27 */
28 public function registerRoute()
29 {
30 register_rest_route(
31 'give-api/v2',
32 $this->endpoint,
33 [
34 [
35 'methods' => 'GET',
36 'callback' => [$this, 'handleRequest'],
37 'permission_callback' => [$this, 'permissionsCheck'],
38 ],
39 'args' => [
40 'testMode' => [
41 'type' => 'boolean',
42 'required' => false,
43 'default' => give_is_test_mode(),
44 ],
45 ],
46 ]
47 );
48 }
49
50 /**
51 * @since 4.12.0
52 */
53 public function handleRequest(WP_REST_Request $request): WP_REST_Response
54 {
55 $this->request = $request;
56
57 $statistics = $this->getSubscriptionStatistics();
58
59 return new WP_REST_Response($statistics);
60 }
61
62 /**
63 * Get subscription statistics for total contributions and active subscriptions
64 *
65 * @since 4.12.0
66 */
67 public function getSubscriptionStatistics(): array
68 {
69 $testMode = $this->request->get_param('testMode');
70
71 $query = DB::table('posts')
72 ->where('post_type', 'give_payment')
73 ->whereIn('post_status', ['publish', 'give_subscription']);
74
75 $query->attachMeta(
76 'give_donationmeta',
77 'ID',
78 'donation_id',
79 [DonationMetaKeys::AMOUNT()->getValue(), DonationMetaKeys::AMOUNT()->getKeyAsCamelCase()],
80 [DonationMetaKeys::SUBSCRIPTION_ID()->getValue(), DonationMetaKeys::SUBSCRIPTION_ID()->getKeyAsCamelCase()],
81 [DonationMetaKeys::MODE()->getValue(), DonationMetaKeys::MODE()->getKeyAsCamelCase()]
82 );
83
84 if ($testMode) {
85 $query->where('give_donationmeta_attach_meta_mode.meta_value', 'test');
86 } else {
87 $query->where(function ($query) {
88 $query->whereIsNull('give_donationmeta_attach_meta_mode.meta_value')
89 ->orWhere('give_donationmeta_attach_meta_mode.meta_value', 'test', '<>');
90 });
91 }
92
93 $query->whereIsNotNull('give_donationmeta_attach_meta_subscriptionId.meta_value')
94 ->where('give_donationmeta_attach_meta_subscriptionId.meta_value', '', '!=')
95 ->where('give_donationmeta_attach_meta_subscriptionId.meta_value', '0', '!=');
96
97 $query->leftJoin(
98 'give_subscriptions',
99 'give_donationmeta_attach_meta_subscriptionId.meta_value',
100 's.id',
101 's'
102 );
103
104 $query->selectRaw('
105 SUM(give_donationmeta_attach_meta_amount.meta_value) as total_contributions,
106 COUNT(DISTINCT CASE WHEN s.status = "active" THEN s.id END) as active_subscriptions
107 ');
108
109 $result = $query->get();
110
111 if (!$result) {
112 return [
113 'activeSubscriptions' => 0,
114 'totalContributions' => 0,
115 ];
116 }
117
118 return [
119 'activeSubscriptions' => (int) $result->active_subscriptions,
120 'totalContributions' => (float) $result->total_contributions,
121 ];
122 }
123 }
124
125
126
127
128