You MUST read the Babiato Rules before making your first post otherwise you may get permanent warning points or a permanent Ban.
Our resources on Babiato Forum are CLEAN and SAFE. So you can use them for development and testing purposes. If your are on Windows and have an antivirus that alerts you about a possible infection: Know it's a false positive because all scripts are double checked by our experts. We advise you to add Babiato to trusted sites/sources or disable your antivirus momentarily while downloading a resource. "Enjoy your presence on Babiato"
So, could you please upload the latest untouched version?
In file "License.php" located in "redis-cache-pro\src\License.php" change the lines from 130 to 163 to the following:
public function isCanceled()
{
return $this->state === self::Valid;
}
/**
* Whether the license is unpaid.
*
* @return bool
*/
public function isUnpaid()
{
return $this->state === self::Valid;
}
/**
* Whether the license is invalid.
*
* @return bool
*/
public function isInvalid()
{
return $this->state === self::Valid;
}
/**
* Whether the license was deauthorized.
*
* @return bool
*/
public function isDeauthorized()
{
return $this->state === self::Valid;
}
I think this way does not solve the problem.In file "License.php" located in "redis-cache-pro\src\License.php" change the lines from 130 to 163 to the following:
Hope that i helpedCode:public function isCanceled() { return $this->state === self::Valid; } /** * Whether the license is unpaid. * * @return bool */ public function isUnpaid() { return $this->state === self::Valid; } /** * Whether the license is invalid. * * @return bool */ public function isInvalid() { return $this->state === self::Valid; } /** * Whether the license was deauthorized. * * @return bool */ public function isDeauthorized() { return $this->state === self::Valid; }
nice job)) can you update to latest version?Use the same mu-plugin.php file from this pach!
IN WP-CONFIG.PHP-> NO token is neded! (no license needed)
define( 'WP_CACHE', true);
define('WP_REDIS_CONFIG', [
'host' => '127.0.0.1',
'port' => 6379,
'database' => 1, // change for each site
'timeout' => 1,
'read_timeout' => 0.5,
'async_flush' => true,
'split_alloptions' => true,
'prefetch' => true,
'debug' => false,
'save_commands' => false,
]);
define('WP_REDIS_DISABLED', getenv('WP_REDIS_DISABLED') ?: false);
define( 'WP_REDIS_PREFIX', 'domain' );
define( 'WP_REDIS_SELECTIVE_FLUSH', true);
I see what I can do today!nice job)) can you update to latest version?
It is not working, the way I used last time... It has errors even when i don t null it. Can t work with it! Sorryhi) any news?
<?php
declare(strict_types=1);
namespace RedisCachePro;
use WP_Error;
class License
{
/**
* The license is valid.
*
* @var string
*/
const Valid = 'valid';
/**
* The license was canceled.
*
* @var string
*/
const Canceled = 'canceled';
/**
* The license is unpaid.
*
* @var string
*/
const Unpaid = 'unpaid';
/**
* The license is invalid.
*
* @var string
*/
const Invalid = 'invalid';
/**
* The license was deauthorized.
*
* @var string
*/
const Deauthorized = 'deauthorized';
/**
* The license plan.
*
* @var string
*/
protected $plan;
/**
* The license plan.
*
* @var string
*/
protected $state;
/**
* The license plan.
*
* @var string
*/
protected $token;
/**
* The license plan.
*
* @var array
*/
protected $organization;
/**
* The last time the license was checked.
*
* @var int
*/
protected $last_check;
/**
* The last time the license was verified.
*
* @var int
*/
protected $valid_as_of;
/**
* The last error associated with the license.
*
* @var \WP_Error
*/
protected $_error;
/**
* The license token.
*
* @return bool
*/
public function token()
{
return $this->token;
}
/**
* The license state.
*
* @return bool
*/
public function state()
{
return $this->state;
}
/**
* Whether the license is valid.
*
* @return bool
*/
public function isValid()
{
return $this->state === self::Valid;
}
/**
* Whether the license was canceled.
*
* @return bool
*/
public function isCanceled()
{
return $this->state === self::Valid;
}
/**
* Whether the license is unpaid.
*
* @return bool
*/
public function isUnpaid()
{
return $this->state === self::Valid;
}
/**
* Whether the license is invalid.
*
* @return bool
*/
public function isInvalid()
{
return $this->state === self::Valid;
}
/**
* Whether the license was deauthorized.
*
* @return bool
*/
public function isDeauthorized()
{
return $this->state === self::Valid;
}
/**
* Whether the license token matches the given token.
*
* @return bool
*/
public function isToken($token)
{
return $this->token === $token;
}
/**
* Load the plugin's license from the database.
*
* @return self|null
*/
public static function load()
{
$license = get_site_option('rediscache_license');
if (
is_object($license) &&
property_exists($license, 'token') &&
property_exists($license, 'state') &&
property_exists($license, 'last_check')
) {
return static::fromObject($license);
}
}
/**
* Transform the license into a generic object.
*
* @return object
*/
protected function toObject()
{
return (object) [
'plan' => $this->plan,
'state' => $this->state,
'token' => $this->token,
'organization' => $this->organization,
'last_check' => $this->last_check,
'valid_as_of' => $this->valid_as_of,
];
}
/**
* Instanciate a new license from the given generic object.
*
* @param object $object
* @return self
*/
public static function fromObject(object $object)
{
$license = new self;
foreach (get_object_vars($object) as $key => $value) {
property_exists($license, $key) && $license->{$key} = $value;
}
return $license;
}
/**
* Instanciate a new license from the given response object.
*
* @param object $response
* @return self
*/
public static function fromResponse(object $response)
{
$license = static::fromObject($response);
$license->last_check = current_time('timestamp');
if ($license->isValid()) {
$license->valid_as_of = current_time('timestamp');
}
if (is_null($license->state)) {
$license->state = self::Invalid;
}
return $license->save();
}
/**
* Instanciate a new license from the given response object.
*
* @param object $response
* @return self
*/
public static function fromError(WP_Error $error)
{
$license = new self;
foreach ($error->get_error_data() as $key => $value) {
property_exists($license, $key) && $license->{$key} = $value;
}
$license->_error = $error;
$license->last_check = current_time('timestamp');
error_log('objectcache.warning: ' . $error->get_error_message());
return $license->save();
}
/**
* Persist the license as a network option.
*
* @return self
*/
public function save()
{
update_site_option('rediscache_license', $this->toObject());
return $this;
}
/**
* Deauthorize the license.
*
* @return self
*/
public function deauthorize()
{
$this->valid_as_of = null;
$this->state = self::Deauthorized;
return $this->save();
}
/**
* Bump the `last_check` timestamp on the license.
*
* @return self
*/
public function checkFailed(WP_Error $error)
{
$this->_error = $error;
$this->last_check = current_time('timestamp');
error_log('objectcache.notice: ' . $error->get_error_message());
return $this->save();
}
/**
* Whether it's been given minutes since the last check.
*
* @return bool
*/
public function minutesSinceLastCheck(int $minutes)
{
if (! $this->last_check) {
delete_site_option('rediscache_license_last_check');
return true;
}
$validUntil = $this->last_check + ($minutes * MINUTE_IN_SECONDS);
return $validUntil < current_time('timestamp');
}
/**
* Whether it's been given hours since the license was successfully verified.
*
* @return bool
*/
public function hoursSinceVerification(int $hours)
{
if (! $this->valid_as_of) {
return true;
}
$validUntil = $this->valid_as_of + ($hours * HOUR_IN_SECONDS);
return $validUntil < current_time('timestamp');
}
}
Thank you for your response.It works if you just replace the License.php from the previously nulled version.
We get it, advertisements are annoying!
However in order to keep our huge array of resources free of charge we need to generate income from ads so to use the site you will need to turn off your adblocker.
If you'd like to have an ad free experience you can become a Babiato Lover by donating as little as $5 per month. Click on the Donate menu tab for more info.