Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/wordpres.../src/actions/wincher
File: wincher-account-action.php
<?php
[0] Fix | Delete
[1] Fix | Delete
namespace Yoast\WP\SEO\Actions\Wincher;
[2] Fix | Delete
[3] Fix | Delete
use Exception;
[4] Fix | Delete
use Yoast\WP\SEO\Config\Wincher_Client;
[5] Fix | Delete
use Yoast\WP\SEO\Helpers\Options_Helper;
[6] Fix | Delete
[7] Fix | Delete
/**
[8] Fix | Delete
* Class Wincher_Account_Action
[9] Fix | Delete
*/
[10] Fix | Delete
class Wincher_Account_Action {
[11] Fix | Delete
[12] Fix | Delete
public const ACCOUNT_URL = 'https://api.wincher.com/beta/account';
[13] Fix | Delete
public const UPGRADE_CAMPAIGN_URL = 'https://api.wincher.com/v1/yoast/upgrade-campaign';
[14] Fix | Delete
[15] Fix | Delete
/**
[16] Fix | Delete
* The Wincher_Client instance.
[17] Fix | Delete
*
[18] Fix | Delete
* @var Wincher_Client
[19] Fix | Delete
*/
[20] Fix | Delete
protected $client;
[21] Fix | Delete
[22] Fix | Delete
/**
[23] Fix | Delete
* The Options_Helper instance.
[24] Fix | Delete
*
[25] Fix | Delete
* @var Options_Helper
[26] Fix | Delete
*/
[27] Fix | Delete
protected $options_helper;
[28] Fix | Delete
[29] Fix | Delete
/**
[30] Fix | Delete
* Wincher_Account_Action constructor.
[31] Fix | Delete
*
[32] Fix | Delete
* @param Wincher_Client $client The API client.
[33] Fix | Delete
* @param Options_Helper $options_helper The options helper.
[34] Fix | Delete
*/
[35] Fix | Delete
public function __construct( Wincher_Client $client, Options_Helper $options_helper ) {
[36] Fix | Delete
$this->client = $client;
[37] Fix | Delete
$this->options_helper = $options_helper;
[38] Fix | Delete
}
[39] Fix | Delete
[40] Fix | Delete
/**
[41] Fix | Delete
* Checks the account limit for tracking keyphrases.
[42] Fix | Delete
*
[43] Fix | Delete
* @return object The response object.
[44] Fix | Delete
*/
[45] Fix | Delete
public function check_limit() {
[46] Fix | Delete
// Code has already been validated at this point. No need to do that again.
[47] Fix | Delete
try {
[48] Fix | Delete
$results = $this->client->get( self::ACCOUNT_URL );
[49] Fix | Delete
[50] Fix | Delete
$usage = $results['limits']['keywords']['usage'];
[51] Fix | Delete
$limit = $results['limits']['keywords']['limit'];
[52] Fix | Delete
$history = $results['limits']['history_days'];
[53] Fix | Delete
[54] Fix | Delete
return (object) [
[55] Fix | Delete
'canTrack' => \is_null( $limit ) || $usage < $limit,
[56] Fix | Delete
'limit' => $limit,
[57] Fix | Delete
'usage' => $usage,
[58] Fix | Delete
'historyDays' => $history,
[59] Fix | Delete
'status' => 200,
[60] Fix | Delete
];
[61] Fix | Delete
} catch ( Exception $e ) {
[62] Fix | Delete
return (object) [
[63] Fix | Delete
'status' => $e->getCode(),
[64] Fix | Delete
'error' => $e->getMessage(),
[65] Fix | Delete
];
[66] Fix | Delete
}
[67] Fix | Delete
}
[68] Fix | Delete
[69] Fix | Delete
/**
[70] Fix | Delete
* Gets the upgrade campaign.
[71] Fix | Delete
*
[72] Fix | Delete
* @return object The response object.
[73] Fix | Delete
*/
[74] Fix | Delete
public function get_upgrade_campaign() {
[75] Fix | Delete
try {
[76] Fix | Delete
$result = $this->client->get( self::UPGRADE_CAMPAIGN_URL );
[77] Fix | Delete
$type = ( $result['type'] ?? null );
[78] Fix | Delete
$months = ( $result['months'] ?? null );
[79] Fix | Delete
$discount = ( $result['value'] ?? null );
[80] Fix | Delete
[81] Fix | Delete
// We display upgrade discount only if it's a rate discount and positive months/discount.
[82] Fix | Delete
if ( $type === 'RATE' && $months && $discount ) {
[83] Fix | Delete
[84] Fix | Delete
return (object) [
[85] Fix | Delete
'discount' => $discount,
[86] Fix | Delete
'months' => $months,
[87] Fix | Delete
'status' => 200,
[88] Fix | Delete
];
[89] Fix | Delete
}
[90] Fix | Delete
[91] Fix | Delete
return (object) [
[92] Fix | Delete
'discount' => null,
[93] Fix | Delete
'months' => null,
[94] Fix | Delete
'status' => 200,
[95] Fix | Delete
];
[96] Fix | Delete
} catch ( Exception $e ) {
[97] Fix | Delete
return (object) [
[98] Fix | Delete
'status' => $e->getCode(),
[99] Fix | Delete
'error' => $e->getMessage(),
[100] Fix | Delete
];
[101] Fix | Delete
}
[102] Fix | Delete
}
[103] Fix | Delete
}
[104] Fix | Delete
[105] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function