PluginProbe ʕ •ᴥ•ʔ
GiveWP – Donation Plugin and Fundraising Platform / 2.24.2
GiveWP – Donation Plugin and Fundraising Platform v2.24.2
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 / includes / install.php
give / includes Last commit date
admin 3 years ago api 3 years ago database 5 years ago deprecated 3 years ago donors 3 years ago emails 3 years ago forms 3 years ago frontend 6 years ago gateways 3 years ago libraries 4 years ago payments 4 years ago actions.php 5 years ago ajax-functions.php 4 years ago class-give-async-process.php 6 years ago class-give-background-updater.php 6 years ago class-give-cache-setting.php 4 years ago class-give-cache.php 3 years ago class-give-cli-commands.php 3 years ago class-give-comment.php 6 years ago class-give-cron.php 6 years ago class-give-donate-form.php 4 years ago class-give-donor.php 3 years ago class-give-email-access.php 5 years ago class-give-license-handler.php 4 years ago class-give-logging.php 5 years ago class-give-readme-parser.php 4 years ago class-give-roles.php 6 years ago class-give-scripts.php 4 years ago class-give-session.php 5 years ago class-give-stats.php 6 years ago class-give-template-loader.php 6 years ago class-give-tooltips.php 6 years ago class-give-translation.php 4 years ago class-notices.php 4 years ago country-functions.php 5 years ago currencies-list.php 4 years ago currency-functions.php 3 years ago error-tracking.php 6 years ago filters.php 3 years ago formatting.php 3 years ago install.php 4 years ago login-register.php 4 years ago misc-functions.php 4 years ago plugin-compatibility.php 6 years ago post-types.php 5 years ago price-functions.php 6 years ago process-donation.php 4 years ago setting-functions.php 6 years ago shortcodes.php 3 years ago template-functions.php 4 years ago user-functions.php 3 years ago
install.php
545 lines
1 <?php
2
3 use Give\Form\Migrations\MoveOptionsToVisualAppearanceSection;
4 use Give\Framework\Migrations\Exceptions\DatabaseMigrationException;
5 use Give\Log\Migrations\MigrateExistingLogs;
6 use Give\MigrationLog\Migrations\CreateMigrationsTable;
7 use Give\Revenue\Migrations\AddPastDonationsToRevenueTable;
8
9 /**
10 * Install Function
11 *
12 * @package Give
13 * @since 1.0
14 * @copyright Copyright (c) 2016, GiveWP
15 * @license https://opensource.org/licenses/gpl-license GNU Public License
16 * @subpackage Functions/Install
17 */
18
19 // Exit if accessed directly.
20 if (!defined('ABSPATH')) {
21 exit;
22 }
23
24 /**
25 * Install
26 *
27 * Runs on plugin install by setting up the post types, custom taxonomies, flushing rewrite rules to initiate the new
28 * 'donations' slug and also creates the plugin and populates the settings fields for those plugin pages. After
29 * successful install, the user is redirected to the Give Onboarding Wizard.
30 *
31 * @since 1.0
32 *
33 * @param bool $network_wide
34 *
35 * @return void
36 * @global $wpdb
37 */
38 function give_install($network_wide = false)
39 {
40 global $wpdb;
41
42 if (is_multisite() && $network_wide) {
43 foreach ($wpdb->get_col("SELECT blog_id FROM $wpdb->blogs LIMIT 100") as $blog_id) {
44 switch_to_blog($blog_id);
45 give_run_install();
46 restore_current_blog();
47 }
48 } else {
49 give_run_install();
50 }
51 }
52
53 /**
54 * Run the Give Install process.
55 *
56 * @since 1.5
57 * @return void
58 */
59 function give_run_install()
60 {
61 $give_options = give_get_settings();
62
63 // Setup the Give Custom Post Types.
64 give_setup_post_types();
65
66 // Add Upgraded From Option.
67 $current_version = get_option('give_version');
68 if ($current_version) {
69 update_option('give_version_upgraded_from', $current_version, false);
70 }
71
72 // Setup some default options.
73 $options = [];
74
75 // Fresh Install? Setup Test Mode, Base Country (US), Test Gateway, Currency.
76 if (empty($current_version)) {
77 $options = array_merge($options, give_get_default_settings());
78 } else {
79 // Otherwise, disable the Onboarding experience
80 $options = [
81 'setup_page_enabled' => 'disabled',
82 ];
83 }
84
85 // Populate the default values.
86 update_option('give_settings', array_merge($give_options, $options), false);
87
88 // Create Give roles.
89 $roles = new Give_Roles();
90 $roles->add_roles();
91 $roles->add_caps();
92
93 // Set api version, end point and refresh permalink.
94 $api = new Give_API();
95 $api->add_endpoint();
96 update_option('give_default_api_version', 'v' . $api->get_version(), false);
97
98 // Create databases.
99 __give_register_tables();
100
101 // Add a temporary option to note that Give pages have been created.
102 Give_Cache::set('_give_installed', $options, 30, true);
103
104 /**
105 * Run plugin upgrades.
106 *
107 * @since 1.8
108 */
109 do_action('give_upgrades');
110
111 if (GIVE_VERSION !== get_option('give_version')) {
112 update_option('give_version', GIVE_VERSION, false);
113 }
114
115 if (!$current_version) {
116 require_once GIVE_PLUGIN_DIR . 'includes/admin/upgrades/upgrade-functions.php';
117
118 // When new upgrade routines are added, mark them as complete on fresh install.
119 $upgrade_routines = [
120 'upgrade_give_user_caps_cleanup',
121 'upgrade_give_payment_customer_id',
122 'upgrade_give_offline_status',
123 'v18_upgrades_core_setting',
124 'v18_upgrades_form_metadata',
125 'v189_upgrades_levels_post_meta',
126 'v1812_update_amount_values',
127 'v1812_update_donor_purchase_values',
128 'v1813_update_user_roles',
129 'v1813_update_donor_user_roles',
130 'v1817_update_donation_iranian_currency_code',
131 'v1817_cleanup_user_roles',
132 'v1818_assign_custom_amount_set_donation',
133 'v1818_give_worker_role_cleanup',
134 'v20_upgrades_form_metadata',
135 'v20_logs_upgrades',
136 'v20_move_metadata_into_new_table',
137 'v20_rename_donor_tables',
138 'v20_upgrades_donor_name',
139 'v20_upgrades_user_address',
140 'v20_upgrades_payment_metadata',
141 'v201_upgrades_payment_metadata',
142 'v201_add_missing_donors',
143 'v201_move_metadata_into_new_table',
144 'v201_logs_upgrades',
145 'v210_verify_form_status_upgrades',
146 'v213_delete_donation_meta',
147 'v215_update_donor_user_roles',
148 'v220_rename_donation_meta_type',
149 'v224_update_donor_meta',
150 'v224_update_donor_meta_forms_id',
151 'v230_move_donor_note',
152 'v230_move_donation_note',
153 'v230_delete_donor_wall_related_donor_data',
154 'v230_delete_donor_wall_related_comment_data',
155 'v240_update_form_goal_progress',
156 'v241_remove_sale_logs',
157 'v270_store_stripe_account_for_donation',
158 AddPastDonationsToRevenueTable::id(),
159 MigrateExistingLogs::id()
160 ];
161
162 foreach ($upgrade_routines as $upgrade) {
163 give_set_upgrade_complete($upgrade);
164 }
165 }
166
167 // Bail if activating from network, or bulk.
168 if (is_network_admin() || isset($_GET['activate-multi'])) {
169 return;
170 }
171
172 // Setup embed form route on fresh install or plugin activation.
173 Give()->routeForm->setBasePrefix();
174 Give()->routeForm->addRule();
175
176 // Flush rewrite rules.
177 flush_rewrite_rules();
178
179 // Add the transient to redirect.
180 Give_Cache::set('_give_activation_redirect', true, 30, true);
181 }
182
183 /**
184 * Network Activated New Site Setup.
185 *
186 * When a new site is created when Give is network activated this function runs the appropriate install function to set
187 * up the site for Give.
188 *
189 * @since 1.3.5
190 *
191 * @param int $blog_id The Blog ID created.
192 * @param int $user_id The User ID set as the admin.
193 * @param string $domain The URL.
194 * @param string $path Site Path.
195 * @param int $site_id The Site ID.
196 * @param array $meta Blog Meta.
197 */
198 function give_on_create_blog($blog_id, $user_id, $domain, $path, $site_id, $meta)
199 {
200 if (is_plugin_active_for_network(GIVE_PLUGIN_BASENAME)) {
201 switch_to_blog($blog_id);
202 give_install();
203 restore_current_blog();
204 }
205 }
206
207 add_action('wpmu_new_blog', 'give_on_create_blog', 10, 6);
208
209
210 /**
211 * Drop Give's custom tables when a mu site is deleted.
212 *
213 * @since 1.4.3
214 *
215 * @param array $tables The tables to drop.
216 * @param int $blog_id The Blog ID being deleted.
217 *
218 * @return array The tables to drop.
219 */
220 function give_wpmu_drop_tables($tables, $blog_id)
221 {
222 switch_to_blog($blog_id);
223 $custom_tables = __give_get_tables();
224
225 /* @var Give_DB $table */
226 foreach ($custom_tables as $table) {
227 if ($table->installed()) {
228 $tables[] = $table->table_name;
229 }
230 }
231
232 restore_current_blog();
233
234 return $tables;
235 }
236
237 add_filter('wpmu_drop_tables', 'give_wpmu_drop_tables', 10, 2);
238
239 /**
240 * Post-installation
241 *
242 * Runs just after plugin installation and exposes the give_after_install hook.
243 *
244 * @since 1.0
245 * @return void
246 */
247 function give_after_install()
248 {
249 if (!is_admin()) {
250 return;
251 }
252
253 $give_options = Give_Cache::get('_give_installed', true);
254 $give_table_check = get_option('_give_table_check', false);
255
256 if (false === $give_table_check || current_time('timestamp') > $give_table_check) {
257 if (!@Give()->donor_meta->installed()) {
258 // Create the donor meta database.
259 // (this ensures it creates it on multisite instances where it is network activated).
260 @Give()->donor_meta->create_table();
261 }
262
263 if (!@Give()->donors->installed()) {
264 // Create the donor database.
265 // (this ensures it creates it on multisite instances where it is network activated).
266 @Give()->donors->create_table();
267 }
268
269 /**
270 * Fires after plugin installation.
271 *
272 * @since 1.0
273 *
274 * @param array $give_options Give plugin options.
275 */
276 do_action('give_after_install', $give_options);
277
278 update_option('_give_table_check', (current_time('timestamp') + WEEK_IN_SECONDS), false);
279 }
280
281 // Delete the transient
282 if (false !== $give_options) {
283 Give_Cache::delete(Give_Cache::get_key('_give_installed'));
284 }
285 }
286
287 add_action('admin_init', 'give_after_install');
288
289
290 /**
291 * Install user roles on sub-sites of a network
292 *
293 * Roles do not get created when Give is network activation so we need to create them during admin_init
294 *
295 * @since 1.0
296 * @return void
297 */
298 function give_install_roles_on_network()
299 {
300 global $wp_roles;
301
302 if (!is_object($wp_roles)) {
303 return;
304 }
305
306 if (!array_key_exists('give_manager', $wp_roles->roles)) {
307 // Create Give plugin roles
308 $roles = new Give_Roles();
309 $roles->add_roles();
310 $roles->add_caps();
311 }
312 }
313
314 add_action('admin_init', 'give_install_roles_on_network');
315
316 /**
317 * Default core setting values.
318 *
319 * @since 1.8
320 * @return array
321 */
322 function give_get_default_settings()
323 {
324 $options = [
325 // General.
326 'base_country' => 'US',
327 'test_mode' => 'enabled',
328 'currency' => 'USD',
329 'currency_position' => 'before',
330 'session_lifetime' => '604800',
331 'email_access' => 'enabled',
332 'thousands_separator' => ',',
333 'decimal_separator' => '.',
334 'number_decimals' => 2,
335 'sequential-ordering_status' => 'enabled',
336
337 // Display options.
338 'css' => 'enabled',
339 'floatlabels' => 'disabled',
340 'company_field' => 'disabled',
341 'name_title_prefix' => 'disabled',
342 'forms_singular' => 'enabled',
343 'forms_archives' => 'enabled',
344 'forms_excerpt' => 'enabled',
345 'form_featured_img' => 'enabled',
346 'form_sidebar' => 'enabled',
347 'categories' => 'disabled',
348 'tags' => 'disabled',
349 'terms' => 'disabled',
350 'admin_notices' => 'enabled',
351 'cache' => 'enabled',
352 'uninstall_on_delete' => 'disabled',
353 'the_content_filter' => 'enabled',
354 'scripts_footer' => 'disabled',
355 'agree_to_terms_label' => __('Agree to Terms?', 'give'),
356 'agreement_text' => give_get_default_agreement_text(),
357 'babel_polyfill_script' => 'enabled',
358
359 // Default is manual gateway.
360 'gateways' => [
361 'manual' => 1,
362 'offline' => 1,
363 ],
364 'default_gateway' => 'manual',
365
366 // Offline gateway setup.
367 'global_offline_donation_content' => give_get_default_offline_donation_content(),
368 'global_offline_donation_email' => give_get_default_offline_donation_content(),
369
370 // Billing address.
371 'give_offline_donation_enable_billing_fields' => 'disabled',
372
373 // Default donation notification email.
374 'donation_notification' => give_get_default_donation_notification_email(),
375
376 // Default email receipt message.
377 'donation_receipt' => give_get_default_donation_receipt_email(),
378
379 'donor_default_user_role' => 'give_donor',
380 Give()->routeForm->getOptionName() => 'give',
381
382 // Stripe accounts.
383 '_give_stripe_get_all_accounts' => [],
384
385 // Onboarding
386 'setup_page_enabled' => 'enabled',
387
388 // Advanced settings
389 'usage_tracking' => 'disabled',
390 ];
391
392 return $options;
393 }
394
395 /**
396 * Default terms and conditions.
397 */
398 function give_get_default_agreement_text()
399 {
400 $org_name = get_bloginfo('name');
401
402 $agreement = sprintf(
403 '<p>Acceptance of any contribution, gift or grant is at the discretion of the %1$s. The %1$s will not accept any gift unless it can be used or expended consistently with the purpose and mission of the %1$s.</p>
404 <p>No irrevocable gift, whether outright or life-income in character, will be accepted if under any reasonable set of circumstances the gift would jeopardize the donor’s financial security.</p>
405 <p>The %1$s will refrain from providing advice about the tax or other treatment of gifts and will encourage donors to seek guidance from their own professional advisers to assist them in the process of making their donation.</p>
406 <p>The %1$s will accept donations of cash or publicly traded securities. Gifts of in-kind services will be accepted at the discretion of the %1$s.</p>
407 <p>Certain other gifts, real property, personal property, in-kind gifts, non-liquid securities, and contributions whose sources are not transparent or whose use is restricted in some manner, must be reviewed prior to acceptance due to the special obligations raised or liabilities they may pose for %1$s.</p>
408 <p>The %1$s will provide acknowledgments to donors meeting tax requirements for property received by the charity as a gift. However, except for gifts of cash and publicly traded securities, no value shall be ascribed to any receipt or other form of substantiation of a gift received by %1$s.</p>
409 <p>The %1$s will respect the intent of the donor relating to gifts for restricted purposes and those relating to the desire to remain anonymous. With respect to anonymous gifts, the %1$s will restrict information about the donor to only those staff members with a need to know.</p>
410 <p>The %1$s will not compensate, whether through commissions, finders\' fees, or other means, any third party for directing a gift or a donor to the %1$s.</p>',
411 $org_name
412 );
413
414 return apply_filters('give_get_default_agreement_text', $agreement, $org_name);
415 }
416
417
418 /**
419 * This function will install give related page which is not created already.
420 *
421 * @since 1.8.11
422 *
423 * @return void
424 */
425 function give_create_pages()
426 {
427 // Bailout if pages already created.
428 if (Give_Cache_Setting::get_option('give_install_pages_created')) {
429 return;
430 }
431
432 $options = [];
433
434 // Checks if the Success Page option exists AND that the page exists.
435 if (!get_post(give_get_option('success_page'))) {
436 // Donation Confirmation (Success) Page
437 $success = wp_insert_post(
438 [
439 'post_title' => esc_html__('Donation Confirmation', 'give'),
440 'post_content' => '[give_receipt]',
441 'post_status' => 'publish',
442 'post_author' => 1,
443 'post_type' => 'page',
444 'comment_status' => 'closed',
445 ]
446 );
447
448 // Store our page IDs
449 $options['success_page'] = $success;
450 }
451
452 // Checks if the Failure Page option exists AND that the page exists.
453 if (!get_post(give_get_option('failure_page'))) {
454 // Failed Donation Page
455 $failed = wp_insert_post(
456 [
457 'post_title' => esc_html__('Donation Failed', 'give'),
458 'post_content' => esc_html__(
459 'We\'re sorry, your donation failed to process. Please try again or contact site support.',
460 'give'
461 ),
462 'post_status' => 'publish',
463 'post_author' => 1,
464 'post_type' => 'page',
465 'comment_status' => 'closed',
466 ]
467 );
468
469 $options['failure_page'] = $failed;
470 }
471
472 if (!empty($options)) {
473 update_option('give_settings', array_merge(give_get_settings(), $options), false);
474 }
475
476 add_option('give_install_pages_created', 1, '', false);
477 }
478
479 // @TODO we can add this hook only when plugin activate instead of every admin page load.
480 // @see known issue https://github.com/impress-org/give/issues/1848
481 add_action('admin_init', 'give_create_pages', -1);
482
483
484 /**
485 * Install tables on plugin update if missing
486 * Note: only for internal use
487 *
488 * @since 2.4.1
489 *
490 * @param string $old_version
491 */
492 function give_install_tables_on_plugin_update($old_version)
493 {
494 update_option('give_version_upgraded_from', $old_version, false);
495 __give_register_tables();
496 }
497
498 add_action('update_option_give_version', 'give_install_tables_on_plugin_update', 0, 2);
499
500
501 /**
502 * Get array of table class objects
503 *
504 * Note: only for internal purpose use
505 *
506 * @sice 2.3.1
507 */
508 function __give_get_tables()
509 {
510 $tables = [
511 'donors_db' => new Give_DB_Donors(),
512 'donor_meta_db' => new Give_DB_Donor_Meta(),
513 'comment_db' => new Give_DB_Comments(),
514 'comment_db_meta' => new Give_DB_Comment_Meta(),
515 'give_session' => new Give_DB_Sessions(),
516 'formmeta_db' => new Give_DB_Form_Meta(),
517 'sequential_db' => new Give_DB_Sequential_Ordering(),
518 'donation_meta' => new Give_DB_Payment_Meta(),
519 ];
520
521 return $tables;
522 }
523
524 /**
525 * Register classes
526 * Note: only for internal purpose use
527 *
528 * @since 2.21.0 Install migration table on fresh install because this table is required to run migrations.
529 * @since 2.3.1
530 * @throws DatabaseMigrationException
531 */
532 function __give_register_tables()
533 {
534 $tables = __give_get_tables();
535
536 /* @var Give_DB $table */
537 foreach ($tables as $table) {
538 if (!$table->installed()) {
539 $table->register_table();
540 }
541 }
542
543 give(CreateMigrationsTable::class)->run();
544 }
545