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/m170303_140500_asset_field_source_settings.php
<?php

namespace craft\migrations;

use craft\db\Migration;
use craft\db\Query;
use craft\db\Table;
use craft\fields\Assets;
use craft\helpers\Json;

/**
 * m170303_140500_asset_field_source_settings migration.
 */
class m170303_140500_asset_field_source_settings extends Migration
{
    /**
     * @inheritdoc
     */
    public function safeUp()
    {

        echo "    > Converting the field setting format \n";
        // Convert the field setting from volume id to folder:XX
        $fields = (new Query())
            ->select(['id', 'settings'])
            ->from([Table::FIELDS])
            ->where(['type' => Assets::class])
            ->all($this->db);

        $getFolderPathFromVolumeId = function($volumeId) {
            if (empty($volumeId)) {
                return '';
            }

            $folderId = (new Query())
                ->select(['id'])
                ->from([Table::VOLUMEFOLDERS])
                ->where(['parentId' => null])
                ->andWhere(['volumeId' => $volumeId])
                ->scalar($this->db);

            // If the folder does not exist, set an invalid id to trigger field error when viewing
            return $folderId ? 'folder:' . $folderId : 'folder:0';
        };

        foreach ($fields as $field) {
            $settings = Json::decode($field['settings']);

            if (!empty($settings['defaultUploadLocationSource'])) {
                $settings['defaultUploadLocationSource'] = $getFolderPathFromVolumeId($settings['defaultUploadLocationSource']);
            }

            if (!empty($settings['singleUploadLocationSource'])) {
                $settings['singleUploadLocationSource'] = $getFolderPathFromVolumeId($settings['singleUploadLocationSource']);
            }

            $settings = Json::encode($settings);

            $this->update(Table::FIELDS, ['settings' => $settings], ['id' => $field['id']]);
        }

        return true;
    }

    /**
     * @inheritdoc
     */
    public function safeDown()
    {
        echo "m170303_140500_asset_field_source_settings cannot be reverted.\n";

        return false;
    }
}