Файловый менеджер - Редактировать - /home/rowdyr7/vbln.supply/wp-content/plugins/woocommerce/vendor/automattic/jetpack-connection/src/class-partner.php
Назад
<?php /** * Jetpack Partner utilities. * * @package automattic/jetpack-connection */ namespace Automattic\Jetpack; /** * This class introduces functionality used by Jetpack hosting partners. * * @since partner-1.0.0 * @since 2.0.0 */ class Partner { /** * Affiliate code. */ const AFFILIATE_CODE = 'affiliate'; /** * Subsidiary id code. */ const SUBSIDIARY_CODE = 'subsidiary'; /** * Singleton instance. * * @since partner-1.0.0 * @since 2.0.0 * * @var Partner This class instance. */ private static $instance = null; /** * Partner constructor. */ private function __construct() { } /** * Initializes the class or returns the singleton. * * @since partner-1.0.0 * @since 2.0.0 * * @return Partner | false */ public static function init() { if ( self::$instance === null ) { self::$instance = new Partner(); add_filter( 'jetpack_build_authorize_url', array( self::$instance, 'add_subsidiary_id_as_query_arg' ) ); add_filter( 'jetpack_build_authorize_url', array( self::$instance, 'add_affiliate_code_as_query_arg' ) ); add_filter( 'jetpack_build_connection_url', array( self::$instance, 'add_subsidiary_id_as_query_arg' ) ); add_filter( 'jetpack_build_connection_url', array( self::$instance, 'add_affiliate_code_as_query_arg' ) ); add_filter( 'jetpack_register_request_body', array( self::$instance, 'add_subsidiary_id_to_params_array' ) ); add_filter( 'jetpack_register_request_body', array( self::$instance, 'add_affiliate_code_to_params_array' ) ); } return self::$instance; } /** * Adds the partner subsidiary code to the passed URL. * * @param string $url The URL. * * @return string */ public function add_subsidiary_id_as_query_arg( $url ) { return $this->add_code_as_query_arg( self::SUBSIDIARY_CODE, $url ); } /** * Adds the affiliate code to the passed URL. * * @param string $url The URL. * * @return string */ public function add_affiliate_code_as_query_arg( $url ) { return $this->add_code_as_query_arg( self::AFFILIATE_CODE, $url ); } /** * Adds the partner subsidiary code to the passed array. * * @since partner-1.5.0 * @since 2.0.0 * * @param array $params The parameters array. * * @return array */ public function add_subsidiary_id_to_params_array( $params ) { if ( ! is_array( $params ) ) { return $params; } return array_merge( $params, $this->get_code_as_array( self::SUBSIDIARY_CODE ) ); } /** * Adds the affiliate code to the passed array. * * @since partner-1.5.0 * @since 2.0.0 * * @param array $params The parameters array. * * @return array */ public function add_affiliate_code_to_params_array( $params ) { if ( ! is_array( $params ) ) { return $params; } return array_merge( $params, $this->get_code_as_array( self::AFFILIATE_CODE ) ); } /** * Returns the passed URL with the partner code added as a URL query arg. * * @since partner-1.0.0 * @since 2.0.0 * * @param string $type The partner code. * @param string $url The URL where the partner subsidiary id will be added. * * @return string The passed URL with the partner code added. */ public function add_code_as_query_arg( $type, $url ) { return add_query_arg( $this->get_code_as_array( $type ), $url ); } /** * Gets the partner code in an associative array format * * @since partner-1.5.0 * @since 2.0.0 * * @param string $type The partner code. * @return array */ private function get_code_as_array( $type ) { switch ( $type ) { case self::AFFILIATE_CODE: $query_arg_name = 'aff'; break; case self::SUBSIDIARY_CODE: $query_arg_name = 'subsidiaryId'; break; default: return array(); } $code = $this->get_partner_code( $type ); if ( '' === $code ) { return array(); } return array( $query_arg_name => $code ); } /** * Returns a partner code. * * @since partner-1.0.0 * @since 2.0.0 * * @param string $type This can be either 'affiliate' or 'subsidiary'. Returns empty string when code is unknown. * * @return string The partner code. */ public function get_partner_code( $type ) { switch ( $type ) { case self::AFFILIATE_CODE: /** * Allow to filter the affiliate code. * * @since partner-1.0.0 * @since-jetpack 6.9.0 * @since 2.0.0 * * @param string $affiliate_code The affiliate code, blank by default. */ return apply_filters( 'jetpack_affiliate_code', get_option( 'jetpack_affiliate_code', '' ) ); case self::SUBSIDIARY_CODE: /** * Allow to filter the partner subsidiary id. * * @since partner-1.0.0 * @since 2.0.0 * * @param string $subsidiary_id The partner subsidiary id, blank by default. */ return apply_filters( 'jetpack_partner_subsidiary_id', get_option( 'jetpack_partner_subsidiary_id', '' ) ); default: return ''; } } /** * Resets the singleton for testing purposes. */ public static function reset() { self::$instance = null; } }
| ver. 1.4 |
Github
|
.
| PHP 7.4.33 | Генерация страницы: 0 |
proxy
|
phpinfo
|
Настройка