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