er = self::_get_current_wp_user();
$plugin_ids = fs_request_get( 'plugin_ids', array() );
if ( ! is_array( $plugin_ids ) || empty( $plugin_ids ) ) {
self::shoot_ajax_failure();
}
$modules = array_merge(
array_values( self::maybe_get_entities_account_option( 'plugins', array() ) ),
array_values( self::maybe_get_entities_account_option( 'themes', array() ) )
);
foreach ( $modules as $key => $module ) {
if ( ! in_array( $module->id, $plugin_ids ) ) {
unset( $modules[ $key ] );
}
}
if ( empty( $modules ) ) {
self::shoot_ajax_failure();
}
$user_api = $this->get_api_user_scope_by_user( Freemius::_get_user_by_email( $current_wp_user->user_email ) );
foreach ( $modules as $module ) {
$user_api->call( "?plugin_id={$module->id}", 'put', array(
'is_marketing_allowed' => ( true == fs_request_get_bool( 'is_marketing_allowed' ) )
) );
}
FS_GDPR_Manager::instance()->remove_opt_in_notice();
require_once WP_FS__DIR_INCLUDES . '/class-fs-user-lock.php';
// 10-year lock.
FS_User_Lock::instance()->lock( 10 * 365 * WP_FS__TIME_24_HOURS_IN_SEC );
self::shoot_ajax_success();
}
/**
* Checks if the GDPR admin notice should be handled. By default, this logic is off, unless the integrator adds the special 'handle_gdpr_admin_notice' filter.
*
* @author Vova Feldman (@svovaf)
* @since 2.1.0
*
* @return bool
*/
private function should_handle_gdpr_admin_notice() {
return $this->apply_filters(
'handle_gdpr_admin_notice',
// Default to false.
false
);
}
#endregion
#----------------------------------------------------------------------------------
#region Marketing
#----------------------------------------------------------------------------------
/**
* Check if current user purchased any other plugins before.
*
* @author Vova Feldman (@svovaf)
* @since 1.0.9
*
* @return bool
*/
function has_purchased_before() {
// TODO: Implement has_purchased_before() method.
throw new Exception( 'not implemented' );
}
/**
* Check if current user classified as an agency.
*
* @author Vova Feldman (@svovaf)
* @since 1.0.9
*
* @return bool
*/
function is_agency() {
// TODO: Implement is_agency() method.
throw new Exception( 'not implemented' );
}
/**
* Check if current user classified as a developer.
*
* @author Vova Feldman (@svovaf)
* @since 1.0.9
*
* @return bool
*/
function is_developer() {
// TODO: Implement is_developer() method.
throw new Exception( 'not implemented' );
}
/**
* Check if current user classified as a business.
*
* @author Vova Feldman (@svovaf)
* @since 1.0.9
*
* @return bool
*/
function is_business() {
// TODO: Implement is_business() method.
throw new Exception( 'not implemented' );
}
#endregion
#----------------------------------------------------------------------------------
#region Helper
#----------------------------------------------------------------------------------
/**
* If running with a secret key, assume it's the developer and show pending plans as well.
*
* @author Vova Feldman (@svovaf)
* @since 2.1.2
*
* @param string $path
*
* @return string
*/
function add_show_pending( $path ) {
if ( ! $this->has_secret_key() ) {
return $path;
}
return $path . ( false !== strpos( $path, '?' ) ? '&' : '?' ) . 'show_pending=true';
}
#endregion
}