Files
san-reymoros/ext/phpbbstudio/ass/migrations/v111_update_permissions.php
2020-04-04 18:27:27 +02:00

73 lines
1.7 KiB
PHP

<?php
/**
*
* phpBB Studio - Advanced Shop System. An extension for the phpBB Forum Software package.
*
* @copyright (c) 2019, phpBB Studio, https://www.phpbbstudio.com
* @license GNU General Public License, version 2 (GPL-2.0)
*
*/
namespace phpbbstudio\ass\migrations;
/**
* phpBB Studio - Advanced Shop System: v1.1.1 Permissions update migration
*/
class v111_update_permissions 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 ['\phpbbstudio\ass\migrations\install_permissions'];
}
/**
* Update the ASS extension permissions to the database.
*
* @return array Array of permissions
* @access public
*/
public function update_data()
{
$data = [
['permission.add', ['u_ass_can_stack']],
];
if ($this->role_exists('ROLE_USER_STANDARD'))
{
$data[] = ['permission.permission_set', ['ROLE_USER_STANDARD', 'u_ass_can_stack']];
}
if ($this->role_exists('ROLE_USER_FULL'))
{
$data[] = ['permission.permission_set', ['ROLE_USER_FULL', 'u_ass_can_stack']];
}
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
*/
private 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;
}
}