Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 3
CRAP
0.00% covered (danger)
0.00%
0 / 41
merge_duplicate_bbcodes
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 3
72
0.00% covered (danger)
0.00%
0 / 41
 update_data
0.00% covered (danger)
0.00%
0 / 1
2
0.00% covered (danger)
0.00%
0 / 2
 update_bbcodes_table
0.00% covered (danger)
0.00%
0 / 1
30
0.00% covered (danger)
0.00%
0 / 16
 merge_bbcodes
0.00% covered (danger)
0.00%
0 / 1
6
0.00% covered (danger)
0.00%
0 / 23
<?php
/**
*
* This file is part of the phpBB Forum Software package.
*
* @copyright (c) phpBB Limited <https://www.phpbb.com>
* @license GNU General Public License, version 2 (GPL-2.0)
*
* For full copyright and license information, please see
* the docs/CREDITS.txt file.
*
*/
namespace phpbb\db\migration\data\v32x;
class merge_duplicate_bbcodes extends \phpbb\db\migration\container_aware_migration
{
    public function update_data()
    {
        return [
            ['custom', [[$this, 'update_bbcodes_table']]],
        ];
    }
    public function update_bbcodes_table()
    {
        $sql     = 'SELECT bbcode_id, bbcode_tag, bbcode_helpline, bbcode_match, bbcode_tpl FROM ' . BBCODES_TABLE;
        $result  = $this->sql_query($sql);
        $bbcodes = [];
        while ($row = $this->db->sql_fetchrow($result))
        {
            $variant = (substr($row['bbcode_tag'], -1) === '=') ? 'with': 'without';
            $bbcode_name = strtolower(rtrim($row['bbcode_tag'], '='));
            $bbcodes[$bbcode_name][$variant] = $row;
        }
        $this->db->sql_freeresult($result);
        foreach ($bbcodes as $bbcode_name => $variants)
        {
            if (count($variants) === 2)
            {
                $this->merge_bbcodes($variants['without'], $variants['with']);
            }
        }
    }
    protected function merge_bbcodes(array $without, array $with)
    {
        try
        {
            $merged = $this->container->get('text_formatter.s9e.bbcode_merger')->merge_bbcodes(
                [
                    'usage'    => $without['bbcode_match'],
                    'template' => $without['bbcode_tpl']
                ],
                [
                    'usage'    => $with['bbcode_match'],
                    'template' => $with['bbcode_tpl']
                ]
            );
        }
        catch (\Exception $e)
        {
            // Ignore the pair and move on. The BBCodes would have to be fixed manually
            return;
        }
        $bbcode_data = [
            'bbcode_tag'      => $without['bbcode_tag'],
            'bbcode_helpline' => $without['bbcode_helpline'] . ' | ' . $with['bbcode_helpline'],
            'bbcode_match'    => $merged['usage'],
            'bbcode_tpl'      => $merged['template']
        ];
        $sql = 'UPDATE ' . BBCODES_TABLE . '
            SET ' . $this->db->sql_build_array('UPDATE', $bbcode_data) . '
            WHERE bbcode_id = ' . (int) $without['bbcode_id'];
        $this->sql_query($sql);
        $sql = 'DELETE FROM ' . BBCODES_TABLE . '
            WHERE bbcode_id = ' . (int) $with['bbcode_id'];
        $this->sql_query($sql);
    }
}