You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

372 lines
11 KiB
PHP

<?php
// phpcs:ignoreFile Generic.Files.OneObjectStructurePerFile.MultipleFound
namespace WPForms {
/**
* The removed class helps prevent fatal errors for clients
* that use some of the classes we are about to remove.
* Use the class extending instead of class_alias function.
*
* @since 1.8.0
*/
class Removed {
/**
* List of removed classes in the next format:
* Fully-Qualified Class Name => version.
*
* @since 1.8.0
*/
const CLASSES = [
'WPForms\Pro\Admin\Entries\DefaultScreen' => '1.8.2'
];
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*/
public function __construct() {
self::trigger_error();
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $name Property name.
*/
public function __get( $name ) {
self::trigger_error( $name );
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $name Property name.
* @param mixed $value Property value.
*/
public function __set( $name, $value ) {
self::trigger_error( $name );
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $name Property name.
*/
public function __isset( $name ) {
self::trigger_error( $name );
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $name Method name.
* @param array $arguments List of arguments.
*/
public function __call( $name, $arguments ) {
self::trigger_error( $name );
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $name Method name.
* @param array $arguments List of arguments.
*/
public static function __callStatic( $name, $arguments ) {
self::trigger_error( $name );
}
/**
* Inform clients that the class is removed.
*
* @since 1.8.0
*
* @param string $element_name Property or method name.
*/
private static function trigger_error( $element_name = '' ) {
$current_class = static::class;
$removed_element = $current_class;
if ( $element_name ) {
$removed_element .= '::' . $element_name;
}
$version = ! empty( self::CLASSES[ $current_class ] ) ? self::CLASSES[ $current_class ] : WPFORMS_VERSION;
trigger_error(
sprintf(
'%1$s has been removed in %2$s of the WPForms plugin',
esc_html( $removed_element ),
esc_html( $version )
),
E_USER_WARNING
);
}
}
}
namespace WPForms\Forms {
use WPForms\Removed;
class Loader extends Removed {}
}
namespace {
/**
* To be compatible with both WP 4.9 (that can run on PHP 5.2+) and WP 5.3+ (PHP 5.6+)
* we need to rewrite some core WP classes and tweak our own skins to not use PHP 5.6 splat operator (...$args)
* that were introduced in WP 5.3 in \WP_Upgrader_Skin::feedback().
* This alias is a safeguard to those developers who decided to use our internal class WPForms_Install_Silent_Skin,
* which we deleted.
*
* @since 1.5.6.1
*/
class_alias( 'WPForms\Helpers\PluginSilentUpgraderSkin', 'WPForms_Install_Silent_Skin' );
/**
* Legacy `WPForms_Addons` class was refactored and moved to the new `WPForms\Pro\Admin\Pages\Addons` class.
* This alias is a safeguard to those developers who use our internal class WPForms_Addons,
* which we deleted.
*
* @since 1.6.7
*/
class_alias( wpforms()->is_pro() ? 'WPForms\Pro\Admin\Pages\Addons' : 'WPForms\Lite\Admin\Pages\Addons', 'WPForms_Addons' );
/**
* This alias is a safeguard to those developers who decided to use our internal class WPForms_Smart_Tags,
* which we deleted.
*
* @since 1.6.7
*/
class_alias( wpforms()->is_pro() ? 'WPForms\Pro\SmartTags\SmartTags' : 'WPForms\SmartTags\SmartTags', 'WPForms_Smart_Tags' );
/**
* This alias is a safeguard to those developers who decided to use our internal class \WPForms\Providers\Loader,
* which we deleted.
*
* @since 1.7.3
*/
class_alias( '\WPForms\Providers\Providers', '\WPForms\Providers\Loader' );
/**
* Legacy `\WPForms\Admin\Notifications` class was refactored and moved to the new `\WPForms\Admin\Notifications\Notifications` class.
* This alias is a safeguard to those developers who use our internal class \WPForms\Admin\Notifications,
* which we deleted.
*
* @since 1.7.5
*/
class_alias( '\WPForms\Admin\Notifications\Notifications', '\WPForms\Admin\Notifications' );
/**
* Legacy `\WPForms_Field_Payment_Checkbox` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentCheckbox\Field` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Checkbox,
* which we deleted.
*
* @since 1.8.2
*/
class_alias( '\WPForms\Forms\Fields\PaymentCheckbox\Field', '\WPForms_Field_Payment_Checkbox' );
/**
* Legacy `\WPForms_Field_Payment_Multiple` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentMultiple\Field` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Multiple,
* which we deleted.
*
* @since 1.8.2
*/
class_alias( '\WPForms\Forms\Fields\PaymentMultiple\Field', '\WPForms_Field_Payment_Multiple' );
/**
* Legacy `\WPForms_Field_Payment_Single` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentSingle\Field` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Single,
* which we deleted.
*
* @since 1.8.2
*/
class_alias( '\WPForms\Forms\Fields\PaymentSingle\Field', '\WPForms_Field_Payment_Single' );
/**
* Legacy `\WPForms_Field_Payment_Total` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentTotal\Field` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Total,
* which we deleted.
*
* @since 1.8.2
*/
class_alias( '\WPForms\Forms\Fields\PaymentTotal\Field', '\WPForms_Field_Payment_Total' );
/**
* Legacy `\WPForms_Field_Payment_Select` class was refactored and moved to the new `\WPForms\Forms\Fields\PaymentSelect\Field` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Field_Payment_Select,
* which we deleted.
*
* @since 1.8.2
*/
class_alias( '\WPForms\Forms\Fields\PaymentSelect\Field', '\WPForms_Field_Payment_Select' );
/**
* Legacy `\WPForms\Migrations` class was refactored and moved to the new `\WPForms\Migrations\Migrations` class.
* This alias is a safeguard to those developers who use our internal class \WPForms\Migrations, which we deleted.
*
* @since 1.7.5
*/
class_alias( '\WPForms\Migrations\Migrations', '\WPForms\Migrations' );
if ( wpforms()->is_pro() ) {
/**
* Legacy `\WPForms\Pro\Migrations` class was refactored and moved to the new `\WPForms\Pro\Migrations\Migrations` class.
* This alias is a safeguard to those developers who use our internal class \WPForms\Migrations, which we deleted.
*
* @since 1.7.5
*/
class_alias( '\WPForms\Pro\Migrations\Migrations', '\WPForms\Pro\Migrations' );
/**
* Legacy `\WPForms\Pro\Integrations\TranslationsPress\Translations` class was refactored and moved to the new
* `\WPForms\Pro\Integrations\Translations\Translations` class.
* This alias is a safeguard to those developers who use our internal class \WPForms\Pro\Integrations\TranslationsPress, which we deleted.
*
* @since 1.8.2.2
*/
class_alias( '\WPForms\Pro\Integrations\Translations\Translations', '\WPForms\Pro\Integrations\TranslationsPress\Translations' );
}
/**
* Legacy `\WPForms_Frontend` class was refactored and moved to the new `\WPForms\Frontend\Frontend` class.
* This alias is a safeguard to those developers who use our internal class \WPForms_Frontend, which we deleted.
*
* @since 1.8.1
*/
class_alias( '\WPForms\Frontend\Frontend', '\WPForms_Frontend' );
/**
* This adds backwards compatibility after scoping the stripe lib and using our own prefix `\WPForms\Vendor\Stripe`.
* This alias is a safeguard for the users who update core plugin to 1.8.5 but have older version of stripe pro addon.
* Fire this right before autoloading of legacy classes so that there is no conflict with other stripe libs when aliasing.
*
* @since 1.8.5
*/
spl_autoload_register(
static function ( $class_name ) {
static $stripe_check_done = false;
static $aliases = [
'\WPForms\Vendor\Stripe\Charge' => 'Stripe\Charge',
'\WPForms\Vendor\Stripe\Customer' => 'Stripe\Customer',
'\WPForms\Vendor\Stripe\Subscription' => 'Stripe\Subscription',
'\WPForms\Vendor\Stripe\Invoice' => 'Stripe\Invoice',
'\WPForms\Vendor\Stripe\Exception\CardException' => 'Stripe\Exception\CardException',
'\WPForms\Vendor\Stripe\Source' => 'Stripe\Source',
];
if ( $stripe_check_done ) {
return;
}
// If class not for aliasing, bail.
if ( ! in_array( $class_name, $aliases, true ) ) {
return;
}
$stripe_check_done = true;
// If no Stripe Pro addon bail.
if ( ! defined( 'WPFORMS_STRIPE_VERSION' ) ) {
return;
}
// Version 3.2.0 has prefixed lib.
// Versions 2.11.0 and below already have the lib bundled, so they don't require alias.
if (
version_compare( WPFORMS_STRIPE_VERSION, '3.2.0', '>=' ) ||
version_compare( WPFORMS_STRIPE_VERSION, '2.11.0', '<=' )
) {
return;
}
// We only need to alias if we are using the legacy API version.
if ( ! \WPFormsStripe\Helpers::is_legacy_api_version() ) {
return;
}
// If a lib is already loaded by a third party plugin,
// checking the CardException class here as a niche to make sure it is the correct library.
if ( class_exists( '\Stripe\Exception\CardException', false ) ) {
return;
}
foreach ( $aliases as $prefixed => $alias ) {
class_alias( $prefixed, '\\' . $alias );
}
}
);
/**
* Get notification state, whether it's opened or closed.
*
* @since 1.4.1
* @deprecated 1.4.8
*
* @param int $notification_id Notification ID.
*
* @param int $form_id Form ID.
*
* @return string
*/
function wpforms_builder_notification_get_state( $form_id, $notification_id ) {
_deprecated_function( __FUNCTION__, '1.4.8 of the WPForms addon', 'wpforms_builder_settings_block_get_state()' );
return wpforms_builder_settings_block_get_state( $form_id, $notification_id, 'notification' );
}
/**
* Convert bytes to megabytes (or in some cases KB).
*
* @since 1.0.0
* @deprecated 1.6.2
*
* @param int $bytes Bytes to convert to a readable format.
*
* @return string
*/
function wpforms_size_to_megabytes( $bytes ) {
_deprecated_function( __FUNCTION__, '1.6.2 of the WPForms plugin', 'size_format()' );
return size_format( $bytes );
}
}
namespace WPForms\Pro\Admin\Entries {
/**
* Default Entries screen showed a chart and the form entries stats.
* Replaced with "WPForms\Pro\Admin\Entries\Overview".
*
* @since 1.5.5
* @deprecated 1.8.2
*/
class DefaultScreen extends \WPForms\Removed {}
}