* @license GNU General Public License, version 2 (GPL-2.0) */ namespace phpbbstudio\dice\migrations; /** * phpBB Studio's Dice Migration: Install permission roles. */ class install_roles extends \phpbb\db\migration\migration { /** * Assign migration file dependencies for this migration. * * @return array Array of migration files * @access public * @static */ static public function depends_on() { return [ '\phpbb\db\migration\data\v32x\v325', '\phpbbstudio\dice\migrations\install_permissions', ]; } /** * Add the dice extension permissions to the database. * * @return array Array of permissions * @access public */ public function update_data() { $data = []; /* Forum User permissions */ if ($this->role_exists('ROLE_FORUM_STANDARD')) { $data[] = ['permission.permission_set', ['ROLE_FORUM_STANDARD', 'f_dice_roll']]; $data[] = ['permission.permission_set', ['ROLE_FORUM_STANDARD', 'f_dice_edit']]; $data[] = ['permission.permission_set', ['ROLE_FORUM_STANDARD', 'f_dice_delete']]; $data[] = ['permission.permission_unset', ['ROLE_FORUM_STANDARD', 'f_dice_no_limit']]; $data[] = ['permission.permission_set', ['ROLE_FORUM_STANDARD', 'f_dice_view']]; } /* Forum Moderator permissions */ if ($this->role_exists('ROLE_FORUM_FULL')) { $data[] = ['permission.permission_set', ['ROLE_FORUM_FULL', 'f_mod_dice_add']]; $data[] = ['permission.permission_set', ['ROLE_FORUM_FULL', 'f_mod_dice_edit']]; $data[] = ['permission.permission_set', ['ROLE_FORUM_FULL', 'f_mod_dice_delete']]; } /* Admin Group permissions */ if ($this->role_exists('ROLE_ADMIN_FULL')) { $data[] = ['permission.permission_set', ['ROLE_ADMIN_FULL', 'a_dice_admin']]; } /* Registered user Group permissions */ if ($this->role_exists('ROLE_USER_STANDARD')) { $data[] = ['permission.permission_set', ['ROLE_USER_STANDARD', 'u_dice_use_ucp']]; $data[] = ['permission.permission_set', ['ROLE_USER_STANDARD', 'u_dice_test']]; $data[] = ['permission.permission_set', ['ROLE_USER_STANDARD', 'u_dice_skin']]; } return $data; } /** * Checks whether the given role does exist or not. * * @param string $role The name of the role * @return bool true if the role exists, false otherwise * @access protected */ protected function role_exists($role) { $sql = 'SELECT role_id FROM ' . $this->table_prefix . "acl_roles WHERE role_name = '" . $this->db->sql_escape($role) . "'"; $result = $this->db->sql_query_limit($sql, 1); $role_id = $this->db->sql_fetchfield('role_id'); $this->db->sql_freeresult($result); return (bool) $role_id; } }