PluginProbe ʕ •ᴥ•ʔ
GiveWP – Donation Plugin and Fundraising Platform / 2.21.1
GiveWP – Donation Plugin and Fundraising Platform v2.21.1
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 / give.php
give Last commit date
assets 4 years ago blocks 4 years ago includes 4 years ago languages 4 years ago sample-data 6 years ago src 4 years ago templates 4 years ago vendor 4 years ago .phpstorm.meta.php 4 years ago changelog.txt 5 years ago give.php 4 years ago license.txt 6 years ago readme.txt 4 years ago uninstall.php 5 years ago wpml-config.xml 6 years ago
give.php
517 lines
1 <?php
2
3 /**
4 * Plugin Name: Give - Donation Plugin
5 * Plugin URI: https://givewp.com
6 * Description: The most robust, flexible, and intuitive way to accept donations on WordPress.
7 * Author: GiveWP
8 * Author URI: https://givewp.com/
9 * Version: 2.21.1
10 * Requires at least: 5.0
11 * Requires PHP: 7.0
12 * Text Domain: give
13 * Domain Path: /languages
14 *
15 * Give is free software: you can redistribute it and/or modify
16 * it under the terms of the GNU General Public License as published by
17 * the Free Software Foundation, either version 3 of the License, or
18 * any later version.
19 *
20 * Give is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
24 *
25 * You should have received a copy of the GNU General Public License
26 * along with Give. If not, see <https://www.gnu.org/licenses/>.
27 *
28 * A Tribute to Open Source:
29 *
30 * "Open source software is software that can be freely used, changed, and shared (in modified or unmodified form) by
31 * anyone. Open source software is made by many people, and distributed under licenses that comply with the Open Source
32 * Definition."
33 *
34 * -- The Open Source Initiative
35 *
36 * Give is a tribute to the spirit and philosophy of Open Source. We at GiveWP gladly embrace the Open Source
37 * philosophy both in how Give itself was developed, and how we hope to see others build more from our code base.
38 *
39 * Give would not have been possible without the tireless efforts of WordPress and the surrounding Open Source projects
40 * and their talented developers. Thank you all for your contribution to WordPress.
41 *
42 * - The GiveWP Team
43 */
44
45 use Give\Container\Container;
46 use Give\DonationForms\Repositories\DonationFormsRepository;
47 use Give\DonationForms\ServiceProvider as DonationFormsServiceProvider;
48 use Give\Donations\Repositories\DonationRepository;
49 use Give\Donations\ServiceProvider as DonationServiceProvider;
50 use Give\DonationSummary\ServiceProvider as DonationSummaryServiceProvider;
51 use Give\DonorDashboards\ServiceProvider as DonorDashboardsServiceProvider;
52 use Give\Donors\Repositories\DonorRepositoryProxy;
53 use Give\Donors\ServiceProvider as DonorsServiceProvider;
54 use Give\Form\LegacyConsumer\ServiceProvider as FormLegacyConsumerServiceProvider;
55 use Give\Form\Templates;
56 use Give\Framework\Exceptions\UncaughtExceptionLogger;
57 use Give\Framework\Migrations\MigrationsServiceProvider;
58 use Give\Framework\PaymentGateways\PaymentGatewayRegister;
59 use Give\Framework\WordPressShims\ServiceProvider as WordPressShimsServiceProvider;
60 use Give\LegacySubscriptions\ServiceProvider as LegacySubscriptionsServiceProvider;
61 use Give\License\LicenseServiceProvider;
62 use Give\Log\LogServiceProvider;
63 use Give\MigrationLog\MigrationLogServiceProvider;
64 use Give\MultiFormGoals\ServiceProvider as MultiFormGoalsServiceProvider;
65 use Give\PaymentGateways\ServiceProvider as PaymentGatewaysServiceProvider;
66 use Give\Promotions\ServiceProvider as PromotionsServiceProvider;
67 use Give\Revenue\RevenueServiceProvider;
68 use Give\Route\Form as FormRoute;
69 use Give\ServiceProviders\LegacyServiceProvider;
70 use Give\ServiceProviders\Onboarding;
71 use Give\ServiceProviders\PaymentGateways;
72 use Give\ServiceProviders\RestAPI;
73 use Give\ServiceProviders\Routes;
74 use Give\ServiceProviders\ServiceProvider;
75 use Give\Subscriptions\Repositories\SubscriptionRepository;
76 use Give\Subscriptions\ServiceProvider as SubscriptionServiceProvider;
77 use Give\TestData\ServiceProvider as TestDataServiceProvider;
78 use Give\Tracking\TrackingServiceProvider;
79
80 // Exit if accessed directly.
81 if (!defined('ABSPATH')) {
82 exit;
83 }
84
85 /**
86 * Main Give Class
87 *
88 * @since 2.21.0 Remove php dependency validation logic and constant
89 * @since 2.19.6 add $donations, $subscriptions, and replace $donors class with DonorRepositoryProxy
90 * @since 2.8.0 build in a service container
91 * @since 1.0
92 *
93 * @property-read Give_API $api
94 * @property-read Give_Async_Process $async_process
95 * @property-read Give_Comment $comment
96 * @property-read Give_DB_Donor_Meta $donor_meta
97 * @property-read Give_Emails $emails
98 * @property-read Give_Email_Template_Tags $email_tags
99 * @property-read Give_DB_Form_Meta $form_meta
100 * @property-read Give_Admin_Settings $give_settings
101 * @property-read Give_HTML_Elements $html
102 * @property-read Give_Logging $logs
103 * @property-read Give_Notices $notices
104 * @property-read Give_DB_Payment_Meta $payment_meta
105 * @property-read Give_Roles $roles
106 * @property-read FormRoute $routeForm
107 * @property-read Templates $templates
108 * @property-read Give_Scripts $scripts
109 * @property-read Give_DB_Sequential_Ordering $sequential_donation_db
110 * @property-read Give_Sequential_Donation_Number $seq_donation_number
111 * @property-read Give_Session $session
112 * @property-read Give_DB_Sessions $session_db
113 * @property-read Give_Tooltips $tooltips
114 * @property-read PaymentGatewayRegister $gateways
115 * @property-read DonationRepository $donations
116 * @property-read DonorRepositoryProxy $donors
117 * @property-read SubscriptionRepository $subscriptions
118 * @property-read DonationFormsRepository $donationFormsRepository
119 * @property-read Give_Recurring_DB_Subscription_Meta $subscription_meta
120 *
121 * @mixin Container
122 */
123 final class Give
124 {
125 /**
126 * Give Template Loader Object
127 *
128 * @since 1.0
129 * @access public
130 *
131 * @var Give_Template_Loader object
132 */
133 public $template_loader;
134
135 /**
136 * Give No Login Object
137 *
138 * @since 1.0
139 * @access public
140 *
141 * @var Give_Email_Access object
142 */
143 public $email_access;
144
145 /**
146 * Give_Stripe Object.
147 *
148 * @since 2.5.0
149 * @access public
150 *
151 * @var Give_Stripe
152 */
153 public $stripe;
154
155 /**
156 * @since 2.8.0
157 *
158 * @var Container
159 */
160 private $container;
161
162 /**
163 * @since 2.19.6 added Donors, Donations, and Subscriptions
164 * @since 2.8.0
165 *
166 * @var array Array of Service Providers to load
167 */
168 private $serviceProviders = [
169 LegacyServiceProvider::class,
170 RestAPI::class,
171 Routes::class,
172 PaymentGateways::class,
173 Onboarding::class,
174 MigrationsServiceProvider::class,
175 RevenueServiceProvider::class,
176 MultiFormGoalsServiceProvider::class,
177 DonorDashboardsServiceProvider::class,
178 TrackingServiceProvider::class,
179 TestDataServiceProvider::class,
180 MigrationLogServiceProvider::class,
181 LogServiceProvider::class,
182 FormLegacyConsumerServiceProvider::class,
183 LicenseServiceProvider::class,
184 Give\Email\ServiceProvider::class,
185 DonationSummaryServiceProvider::class,
186 PaymentGatewaysServiceProvider::class,
187 DonationServiceProvider::class,
188 DonorsServiceProvider::class,
189 SubscriptionServiceProvider::class,
190 DonationFormsServiceProvider::class,
191 PromotionsServiceProvider::class,
192 LegacySubscriptionsServiceProvider::class,
193 WordPressShimsServiceProvider::class,
194 ];
195
196 /**
197 * @since 2.8.0
198 *
199 * @var bool Make sure the providers are loaded only once
200 */
201 private $providersLoaded = false;
202
203 /**
204 * Give constructor.
205 *
206 * Sets up the Container to be used for managing all other instances and data
207 *
208 * @since 2.8.0
209 */
210 public function __construct()
211 {
212 $this->container = new Container();
213 }
214
215 /**
216 * Bootstraps the Give Plugin
217 *
218 * @since 2.8.0
219 */
220 public function boot()
221 {
222 $this->setup_constants();
223
224 // Add compatibility notice for recurring and stripe support with Give 2.5.0.
225 add_action('admin_notices', [$this, 'display_old_recurring_compatibility_notice']);
226
227 add_action('plugins_loaded', [$this, 'init'], 0);
228
229 register_activation_hook(GIVE_PLUGIN_FILE, [$this, 'install']);
230
231 do_action('give_loaded');
232 }
233
234 /**
235 * Init Give when WordPress Initializes.
236 *
237 * @since 1.8.9
238 */
239 public function init()
240 {
241 /**
242 * Fires before the Give core is initialized.
243 *
244 * @since 1.8.9
245 */
246 do_action('before_give_init');
247
248 // Set up localization.
249 $this->load_textdomain();
250
251 $this->bindClasses();
252
253 $this->setupExceptionHandler();
254
255 $this->loadServiceProviders();
256
257 // Load form template
258 $this->templates->load();
259
260 // Load routes.
261 $this->routeForm->init();
262
263 /**
264 * Fire the action after Give core loads.
265 *
266 * @since 1.8.7
267 *
268 * @param Give class instance.
269 *
270 */
271 do_action('give_init', $this);
272 }
273
274 /**
275 * Binds the initial classes to the service provider.
276 *
277 * @since 2.8.0
278 */
279 private function bindClasses()
280 {
281 $this->container->singleton('templates', Templates::class);
282 $this->container->singleton('routeForm', FormRoute::class);
283 }
284
285 /**
286 * Setup plugin constants
287 *
288 * @since 1.0
289 * @access private
290 *
291 * @return void
292 */
293 private function setup_constants()
294 {
295 // Plugin version.
296 if (!defined('GIVE_VERSION')) {
297 define('GIVE_VERSION', '2.21.1');
298 }
299
300 // Plugin Root File.
301 if (!defined('GIVE_PLUGIN_FILE')) {
302 define('GIVE_PLUGIN_FILE', __FILE__);
303 }
304
305 // Plugin Folder Path.
306 if (!defined('GIVE_PLUGIN_DIR')) {
307 define('GIVE_PLUGIN_DIR', plugin_dir_path(GIVE_PLUGIN_FILE));
308 }
309
310 // Plugin Folder URL.
311 if (!defined('GIVE_PLUGIN_URL')) {
312 define('GIVE_PLUGIN_URL', plugin_dir_url(GIVE_PLUGIN_FILE));
313 }
314
315 // Plugin Basename aka: "give/give.php".
316 if (!defined('GIVE_PLUGIN_BASENAME')) {
317 define('GIVE_PLUGIN_BASENAME', plugin_basename(GIVE_PLUGIN_FILE));
318 }
319
320 // Make sure CAL_GREGORIAN is defined.
321 if (!defined('CAL_GREGORIAN')) {
322 define('CAL_GREGORIAN', 1);
323 }
324 }
325
326 /**
327 * Loads the plugin language files.
328 *
329 * @since 1.0
330 * @access public
331 *
332 * @return void
333 */
334 public function load_textdomain()
335 {
336 // Set filter for Give's languages directory
337 $give_lang_dir = dirname(plugin_basename(GIVE_PLUGIN_FILE)) . '/languages/';
338 $give_lang_dir = apply_filters('give_languages_directory', $give_lang_dir);
339
340 // Traditional WordPress plugin locale filter.
341 $locale = is_admin() && function_exists('get_user_locale') ? get_user_locale() : get_locale();
342 $locale = apply_filters('plugin_locale', $locale, 'give');
343
344 unload_textdomain('give');
345 load_textdomain('give', WP_LANG_DIR . '/give/give-' . $locale . '.mo');
346 load_plugin_textdomain('give', false, $give_lang_dir);
347 }
348
349 /**
350 * Display compatibility notice for Give 2.5.0 and Recurring 1.8.13 when Stripe premium is not active.
351 *
352 * @since 2.5.0
353 *
354 * @return void
355 */
356 public function display_old_recurring_compatibility_notice()
357 {
358 // Show notice, if incompatibility found.
359 if (
360 defined('GIVE_RECURRING_VERSION')
361 && version_compare(GIVE_RECURRING_VERSION, '1.9.0', '<')
362 && defined('GIVE_STRIPE_VERSION')
363 && version_compare(GIVE_STRIPE_VERSION, '2.2.0', '<')
364 ) {
365 $message = sprintf(
366 __(
367 '<strong>Attention:</strong> GiveWP 2.5.0+ requires the latest version of the Recurring Donations add-on to process payments properly with Stripe. Please update to the latest version add-on to resolve compatibility issues. If your license is active, you should see the update available in WordPress. Otherwise, you can access the latest version by <a href="%1$s" target="_blank">logging into your account</a> and visiting <a href="%1$s" target="_blank">your downloads</a> page on the GiveWP website.',
368 'give'
369 ),
370 esc_url('https://givewp.com/wp-login.php'),
371 esc_url('https://givewp.com/my-account/#tab_downloads')
372 );
373
374 Give()->notices->register_notice(
375 [
376 'id' => 'give-compatibility-with-old-recurring',
377 'description' => $message,
378 'dismissible_type' => 'user',
379 'dismiss_interval' => 'shortly',
380 ]
381 );
382 }
383 }
384
385 public function install()
386 {
387 $this->loadServiceProviders();
388 give_install();
389 }
390
391 /**
392 * Load all the service providers to bootstrap the various parts of the application.
393 *
394 * @since 2.8.0
395 */
396 private function loadServiceProviders()
397 {
398 if ($this->providersLoaded) {
399 return;
400 }
401
402 $providers = [];
403
404 foreach ($this->serviceProviders as $serviceProvider) {
405 if (!is_subclass_of($serviceProvider, ServiceProvider::class)) {
406 throw new InvalidArgumentException(
407 "$serviceProvider class must implement the ServiceProvider interface"
408 );
409 }
410
411 /** @var ServiceProvider $serviceProvider */
412 $serviceProvider = new $serviceProvider();
413
414 $serviceProvider->register();
415
416 $providers[] = $serviceProvider;
417 }
418
419 foreach ($providers as $serviceProvider) {
420 $serviceProvider->boot();
421 }
422
423 $this->providersLoaded = true;
424 }
425
426 /**
427 * Register a Service Provider for bootstrapping
428 *
429 * @since 2.8.0
430 *
431 * @param string $serviceProvider
432 */
433 public function registerServiceProvider($serviceProvider)
434 {
435 $this->serviceProviders[] = $serviceProvider;
436 }
437
438 /**
439 * Magic properties are passed to the service container to retrieve the data.
440 *
441 * @since 2.8.0 retrieve from the service container
442 * @since 2.7.0
443 *
444 * @param string $propertyName
445 *
446 * @return mixed
447 * @throws Exception
448 */
449 public function __get($propertyName)
450 {
451 return $this->container->get($propertyName);
452 }
453
454 /**
455 * Magic methods are passed to the service container.
456 *
457 * @since 2.8.0
458 *
459 * @param $arguments
460 *
461 * @param $name
462 *
463 * @return mixed
464 */
465 public function __call($name, $arguments)
466 {
467 return call_user_func_array([$this->container, $name], $arguments);
468 }
469
470 /**
471 * Sets up the Exception Handler to catch and handle uncaught exceptions
472 *
473 * @since 2.11.1
474 */
475 private function setupExceptionHandler()
476 {
477 $handler = new UncaughtExceptionLogger();
478 $handler->setupExceptionHandler();
479 }
480 }
481
482 /**
483 * Start Give
484 *
485 * The main function responsible for returning the one true Give instance to functions everywhere.
486 *
487 * Use this function like you would a global variable, except without needing
488 * to declare the global.
489 *
490 * Example: <?php $give = Give(); ?>
491 *
492 * @since 2.8.0 add parameter for quick retrieval from container
493 * @since 1.0
494 *
495 * @param null $abstract Selector for data to retrieve from the service container
496 *
497 * @return object|Give
498 */
499 function give($abstract = null)
500 {
501 static $instance = null;
502
503 if ($instance === null) {
504 $instance = new Give();
505 }
506
507 if ($abstract !== null) {
508 return $instance->make($abstract);
509 }
510
511 return $instance;
512 }
513
514 require __DIR__ . '/vendor/autoload.php';
515
516 give()->boot();
517