MOON
Server: Apache
System: Linux res.emeff.ca 3.10.0-962.3.2.lve1.5.24.10.el7.x86_64 #1 SMP Wed Mar 20 07:36:02 EDT 2019 x86_64
User: accemeff (1004)
PHP: 7.0.33
Disabled: NONE
Upload Files
File: /home/accemeff/vendor/craftcms/cms/src/migrations/m180328_115523_new_license_key_statuses.php
<?php

namespace craft\migrations;

use craft\db\Migration;
use craft\db\Table;

/**
 * m180328_115523_new_license_key_statuses migration.
 */
class m180328_115523_new_license_key_statuses extends Migration
{
    /**
     * @inheritdoc
     */
    public function safeUp()
    {
        $values = ['valid', 'invalid', 'mismatched', 'astray', 'unknown'];
        if ($this->db->getIsPgsql()) {
            // Manually construct the SQL for Postgres
            $check = '[[licenseKeyStatus]] in (';
            foreach ($values as $i => $value) {
                if ($i != 0) {
                    $check .= ',';
                }
                $check .= $this->db->quoteValue($value);
            }
            $check .= ')';
            $this->execute("alter table {{%plugins}} drop constraint {{%plugins_licenseKeyStatus_check}}, add check ({$check})");
        } else {
            $this->alterColumn(Table::PLUGINS, 'licenseKeyStatus', $this->enum('licenseKeyStatus', $values)->notNull()->defaultValue('unknown'));
        }
    }

    /**
     * @inheritdoc
     */
    public function safeDown()
    {
        echo "m180328_115523_new_license_key_statuses cannot be reverted.\n";
        return false;
    }
}