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

namespace craft\migrations;

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

/**
 * m171107_000000_assign_group_permissions migration.
 */
class m171107_000000_assign_group_permissions extends Migration
{
    /**
     * @inheritdoc
     */
    public function safeUp()
    {
        // See which users & groups already have the "assignUserPermissions" permission
        $userIds = (new Query())
            ->select(['up_u.userId'])
            ->from(['{{%userpermissions_users}} up_u'])
            ->innerJoin('{{%userpermissions}} up', '[[up.id]] = [[up_u.permissionId]]')
            ->where(['up.name' => 'assignuserpermissions'])
            ->column($this->db);

        $groupIds = (new Query())
            ->select(['up_ug.groupId'])
            ->from(['{{%userpermissions_usergroups}} up_ug'])
            ->innerJoin('{{%userpermissions}} up', '[[up.id]] = [[up_ug.permissionId]]')
            ->where(['up.name' => 'assignuserpermissions'])
            ->column($this->db);

        if (empty($userIds) && empty($groupIds)) {
            return;
        }

        // Get the user group IDs
        $allGroupIds = (new Query())
            ->select(['id'])
            ->from([Table::USERGROUPS])
            ->column();

        // Create the new permissions
        $permissionIds = [];

        $this->insert(Table::USERPERMISSIONS, ['name' => 'assignusergroups']);
        $permissionIds[] = $this->db->getLastInsertID(Table::USERPERMISSIONS);

        foreach ($allGroupIds as $groupId) {
            $this->insert(Table::USERPERMISSIONS, ['name' => 'assignusergroup:' . $groupId]);
            $permissionIds[] = $this->db->getLastInsertID(Table::USERPERMISSIONS);
        }

        // Assign the new permissions to the users
        if (!empty($userIds)) {
            $data = [];
            foreach ($userIds as $userId) {
                foreach ($permissionIds as $permissionId) {
                    $data[] = [$permissionId, $userId];
                }
            }
            $this->batchInsert(Table::USERPERMISSIONS_USERS, ['permissionId', 'userId'], $data);
        }

        // Assign the new permissions to the groups
        if (!empty($groupIds)) {
            $data = [];
            foreach ($groupIds as $groupId) {
                foreach ($permissionIds as $permissionId) {
                    $data[] = [$permissionId, $groupId];
                }
            }
            $this->batchInsert(Table::USERPERMISSIONS_USERGROUPS, ['permissionId', 'groupId'], $data);
        }
    }

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