![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/migrations/ |
<?php declare(strict_types=1); namespace Mautic\Migrations; use Doctrine\DBAL\Schema\Schema; use Mautic\CoreBundle\Doctrine\AbstractMauticMigration; final class Version20231110103625 extends AbstractMauticMigration { protected static string $tableName = 'roles'; public function up(Schema $schema): void { $sql = sprintf('SELECT id, readable_permissions FROM %s WHERE is_admin != 1', $this->getPrefixedTableName()); $results = $this->connection->executeQuery($sql)->fetchAllAssociative(); $updatedRecords = 0; $addPermissions = []; foreach ($results as $row) { $permissionsArray = unserialize($row['readable_permissions']); // Add permissions if not exists $permissionsToAdd = ['lead:export', 'form:export', 'report:export']; foreach ($permissionsToAdd as $permission) { if (!isset($permissionsArray[$permission])) { $permissionsArray[$permission] = ['enable']; $addPermissions[$row['id']][$permission] = 1024; } } $permissionsString = serialize($permissionsArray); $updateSql = sprintf('UPDATE %s SET readable_permissions = :permissions WHERE id = :id', $this->getPrefixedTableName()); $stmt = $this->connection->prepare($updateSql); $stmt->bindValue('permissions', $permissionsString, \PDO::PARAM_STR); $stmt->bindValue('id', $row['id'], \PDO::PARAM_INT); $updatedRecords += $stmt->executeStatement(); foreach ($addPermissions as $roleId => $permissionsToAdd) { foreach ($permissionsToAdd as $permissionToAdd => $bitwise) { $sql = sprintf('INSERT IGNORE INTO %s (role_id, bundle, name, bitwise) VALUES (:role_id, :bundle, :name, :bitwise)', $this->prefix.'permissions'); $stmt = $this->connection->prepare($sql); $permissionArray = explode(':', $permissionToAdd); $stmt->bindValue('role_id', $row['id'], \PDO::PARAM_INT); $stmt->bindValue('bundle', $permissionArray[0], \PDO::PARAM_STR); $stmt->bindValue('name', $permissionArray[1], \PDO::PARAM_STR); $stmt->bindValue('bitwise', $bitwise, \PDO::PARAM_INT); $stmt->executeStatement(); } } } $this->write(sprintf('<comment>%s record(s) have been updated successfully.</comment>', $updatedRecords)); } private function getPrefixedTableName(): string { return $this->prefix.self::$tableName; } }