connection = $connection; $this->config = $config; } /** * {@inheritdoc} */ public function getName() { return 'Repair language codes'; } /** * {@inheritdoc} */ public function run(IOutput $output) { $versionFromBeforeUpdate = $this->config->getSystemValueString('version', '0.0.0'); if (version_compare($versionFromBeforeUpdate, '12.0.0.13', '>')) { return; } $languages = [ 'bg_BG' => 'bg', 'cs_CZ' => 'cs', 'fi_FI' => 'fi', 'hu_HU' => 'hu', 'nb_NO' => 'nb', 'sk_SK' => 'sk', 'th_TH' => 'th', ]; foreach ($languages as $oldCode => $newCode) { $qb = $this->connection->getQueryBuilder(); $affectedRows = $qb->update('preferences') ->set('configvalue', $qb->createNamedParameter($newCode)) ->where($qb->expr()->eq('appid', $qb->createNamedParameter('core'))) ->andWhere($qb->expr()->eq('configkey', $qb->createNamedParameter('lang'))) ->andWhere($qb->expr()->eq('configvalue', $qb->createNamedParameter($oldCode), IQueryBuilder::PARAM_STR)) ->execute(); $output->info('Changed ' . $affectedRows . ' setting(s) from "' . $oldCode . '" to "' . $newCode . '" in preferences table.'); } } }