Edit File by line
/home/zeestwma/ceyloniy.../wp-conte.../plugins/extendif.../app/Shared/Services
File: VersionMigrator.php
<?php
[0] Fix | Delete
[1] Fix | Delete
/**
[2] Fix | Delete
* Class specifically to update/migrate database values
[3] Fix | Delete
* that may have changed over time. Use the version of
[4] Fix | Delete
* the plugin that we are migrating from, not the
[5] Fix | Delete
* version of the plugin that we are migrating to.
[6] Fix | Delete
*/
[7] Fix | Delete
[8] Fix | Delete
namespace Extendify\Shared\Services;
[9] Fix | Delete
[10] Fix | Delete
defined('ABSPATH') || die('No direct access.');
[11] Fix | Delete
[12] Fix | Delete
/**
[13] Fix | Delete
* Migration class.
[14] Fix | Delete
*/
[15] Fix | Delete
[16] Fix | Delete
class VersionMigrator
[17] Fix | Delete
{
[18] Fix | Delete
/**
[19] Fix | Delete
* Initialize the class.
[20] Fix | Delete
*
[21] Fix | Delete
* @return void
[22] Fix | Delete
*/
[23] Fix | Delete
public function __construct()
[24] Fix | Delete
{
[25] Fix | Delete
$targetVersion = $this->getVersion();
[26] Fix | Delete
$migrationMethods = $this->getMigrationMethods();
[27] Fix | Delete
$previousMigrations = get_option('extendify_run_migrations', []);
[28] Fix | Delete
[29] Fix | Delete
foreach ($migrationMethods as $method) {
[30] Fix | Delete
$version = $this->extractVersion($method);
[31] Fix | Delete
[32] Fix | Delete
// Stop if we've reached a version beyond our target.
[33] Fix | Delete
if (version_compare($version, $targetVersion) > 0) {
[34] Fix | Delete
break;
[35] Fix | Delete
}
[36] Fix | Delete
[37] Fix | Delete
// Skip if this migration has already been run.
[38] Fix | Delete
if (isset($previousMigrations[$version])) {
[39] Fix | Delete
continue;
[40] Fix | Delete
}
[41] Fix | Delete
[42] Fix | Delete
$this->$method();
[43] Fix | Delete
$previousMigrations[$version] = true;
[44] Fix | Delete
update_option('extendify_run_migrations', $previousMigrations);
[45] Fix | Delete
}//end foreach
[46] Fix | Delete
}
[47] Fix | Delete
[48] Fix | Delete
/**
[49] Fix | Delete
* This method fixes a math bug in the usage data in the database.
[50] Fix | Delete
*
[51] Fix | Delete
* @return void
[52] Fix | Delete
*/
[53] Fix | Delete
private function migrate_1_14_2_fixUsageMathBug() // phpcs:ignore
[54] Fix | Delete
{
[55] Fix | Delete
$normalizeMathBug = function ($number) {
[56] Fix | Delete
if (is_int($number)) {
[57] Fix | Delete
return $number;
[58] Fix | Delete
}
[59] Fix | Delete
[60] Fix | Delete
$count = substr_count((string) $number, '1');
[61] Fix | Delete
$subNumbers = substr($number, 0, -$count);
[62] Fix | Delete
return ((int) $subNumbers + $count);
[63] Fix | Delete
};
[64] Fix | Delete
[65] Fix | Delete
$librarySiteData = get_option('extendify_library_site_data', []);
[66] Fix | Delete
$state = ($librarySiteData['state'] ?? []);
[67] Fix | Delete
if (!empty($state['totalImports'])) {
[68] Fix | Delete
$state['totalImports'] = $normalizeMathBug($state['totalImports']);
[69] Fix | Delete
$librarySiteData['state'] = $state;
[70] Fix | Delete
update_option('extendify_library_site_data', Sanitizer::sanitizeArray($librarySiteData));
[71] Fix | Delete
}
[72] Fix | Delete
[73] Fix | Delete
$toursData = get_option('extendify_assist_tour_progress', []);
[74] Fix | Delete
$state = ($toursData['state']['progress'] ?? null);
[75] Fix | Delete
if ($state) {
[76] Fix | Delete
$state = array_map(function ($progress) use ($normalizeMathBug) {
[77] Fix | Delete
$progress['openedCount'] = $normalizeMathBug($progress['openedCount']);
[78] Fix | Delete
$progress['closedManuallyCount'] = $normalizeMathBug($progress['closedManuallyCount']);
[79] Fix | Delete
$progress['completedCount'] = $normalizeMathBug($progress['completedCount']);
[80] Fix | Delete
return $progress;
[81] Fix | Delete
}, $state);
[82] Fix | Delete
[83] Fix | Delete
$toursData['state']['progress'] = $state;
[84] Fix | Delete
update_option('extendify_assist_tour_progress', Sanitizer::sanitizeArray($toursData));
[85] Fix | Delete
}
[86] Fix | Delete
[87] Fix | Delete
// The following all have a property 'count'.
[88] Fix | Delete
$normalizeCount = function ($viewed) use ($normalizeMathBug) {
[89] Fix | Delete
$viewed['count'] = $normalizeMathBug($viewed['count']);
[90] Fix | Delete
return $viewed;
[91] Fix | Delete
};
[92] Fix | Delete
[93] Fix | Delete
$kbData = get_option('extendify_assist_support_articles', []);
[94] Fix | Delete
$state = ($kbData['state']['viewedArticles'] ?? null);
[95] Fix | Delete
if ($state) {
[96] Fix | Delete
$kbData['state']['viewedArticles'] = array_map($normalizeCount, $state);
[97] Fix | Delete
update_option('extendify_assist_support_articles', Sanitizer::sanitizeArray($kbData));
[98] Fix | Delete
}
[99] Fix | Delete
[100] Fix | Delete
// Each of the routers have the same signature.
[101] Fix | Delete
foreach (['assist', 'help_center', 'draft'] as $key) {
[102] Fix | Delete
$router = get_option("extendify_{$key}_router", []);
[103] Fix | Delete
$state = ($router['state']['viewedPages'] ?? null);
[104] Fix | Delete
if ($state) {
[105] Fix | Delete
$router['state']['viewedPages'] = array_map($normalizeCount, $state);
[106] Fix | Delete
update_option("extendify_{$key}_router", Sanitizer::sanitizeArray($router));
[107] Fix | Delete
}
[108] Fix | Delete
}
[109] Fix | Delete
}
[110] Fix | Delete
[111] Fix | Delete
/**
[112] Fix | Delete
* Get the plugin version.
[113] Fix | Delete
*
[114] Fix | Delete
* @return string
[115] Fix | Delete
*/
[116] Fix | Delete
private function getVersion()
[117] Fix | Delete
{
[118] Fix | Delete
// phpcs:ignore WordPress.WP.AlternativeFunctions.file_get_contents_file_get_contents
[119] Fix | Delete
$readme = file_get_contents(EXTENDIFY_PATH . 'readme.txt');
[120] Fix | Delete
preg_match('/Stable tag: ([0-9.:]+)/', $readme, $matches);
[121] Fix | Delete
return ($matches[1] ?? '0.0.0');
[122] Fix | Delete
}
[123] Fix | Delete
[124] Fix | Delete
/**
[125] Fix | Delete
* Get migration methods.
[126] Fix | Delete
*
[127] Fix | Delete
* @return array
[128] Fix | Delete
*/
[129] Fix | Delete
private function getMigrationMethods(): array
[130] Fix | Delete
{
[131] Fix | Delete
$methods = get_class_methods($this);
[132] Fix | Delete
$migrationMethods = array_filter($methods, function ($method) {
[133] Fix | Delete
return strpos($method, 'migrate_') === 0;
[134] Fix | Delete
});
[135] Fix | Delete
sort($migrationMethods);
[136] Fix | Delete
[137] Fix | Delete
return $migrationMethods;
[138] Fix | Delete
}
[139] Fix | Delete
[140] Fix | Delete
/**
[141] Fix | Delete
* Extract version from the method name.
[142] Fix | Delete
*
[143] Fix | Delete
* @param string $method The method name.
[144] Fix | Delete
* @return string
[145] Fix | Delete
*/
[146] Fix | Delete
private function extractVersion($method)
[147] Fix | Delete
{
[148] Fix | Delete
preg_match('/^migrate_(\d+)_(\d+)_(\d+)/', $method, $matches);
[149] Fix | Delete
return $matches ? "{$matches[1]}.{$matches[2]}.{$matches[3]}" : '0.0.0';
[150] Fix | Delete
}
[151] Fix | Delete
}
[152] Fix | Delete
[153] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function