<?php

namespace Application\Migrations;

use Doctrine\DBAL\Schema\Schema;
use Wallabag\CoreBundle\Doctrine\WallabagMigration;

/**
 * Add missing entries in craue_config_setting.
 */
final class Version20190129120000 extends WallabagMigration
{
    private $settings = [
        [
            'name' => 'carrot',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'share_diaspora',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'diaspora_url',
            'value' => 'http://diasporapod.com',
            'section' => 'entry',
        ],
        [
            'name' => 'share_shaarli',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'shaarli_url',
            'value' => 'http://myshaarli.com',
            'section' => 'entry',
        ],
        [
            'name' => 'share_mail',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'share_twitter',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'show_printlink',
            'value' => '1',
            'section' => 'entry',
        ],
        [
            'name' => 'export_epub',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_mobi',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_pdf',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_csv',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_json',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_txt',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'export_xml',
            'value' => '1',
            'section' => 'export',
        ],
        [
            'name' => 'piwik_enabled',
            'value' => '0',
            'section' => 'analytics',
        ],
        [
            'name' => 'piwik_host',
            'value' => 'v2.wallabag.org',
            'section' => 'analytics',
        ],
        [
            'name' => 'piwik_site_id',
            'value' => '1',
            'section' => 'analytics',
        ],
        [
            'name' => 'demo_mode_enabled',
            'value' => '0',
            'section' => 'misc',
        ],
        [
            'name' => 'demo_mode_username',
            'value' => 'wallabag',
            'section' => 'misc',
        ],
        [
            'name' => 'wallabag_support_url',
            'value' => 'https://www.wallabag.org/pages/support.html',
            'section' => 'misc',
        ],
    ];

    public function up(Schema $schema)
    {
        foreach ($this->settings as $setting) {
            $settingEnabled = $this->container
                ->get('doctrine.orm.default_entity_manager')
                ->getConnection()
                ->fetchArray('SELECT * FROM ' . $this->getTable('craue_config_setting') . " WHERE name = '" . $setting['name'] . "'");

            if (false !== $settingEnabled) {
                continue;
            }

            $this->addSql('INSERT INTO ' . $this->getTable('craue_config_setting') . " (name, value, section) VALUES ('" . $setting['name'] . "', '" . $setting['value'] . "', '" . $setting['section'] . "');");
        }
    }

    public function down(Schema $schema)
    {
        $this->skipIf(true, 'These settings are required and should not be removed.');
    }
}