migration: Add shiftentry_edit_angeltype_supporter permission to angels
This commit is contained in:
parent
99126cab0c
commit
5a912a0f7e
|
@ -0,0 +1,67 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Engelsystem\Migrations;
|
||||||
|
|
||||||
|
use Engelsystem\Database\Migration\Migration;
|
||||||
|
|
||||||
|
class AddAngelSupporterPermissions extends Migration
|
||||||
|
{
|
||||||
|
/** @var string[] */
|
||||||
|
protected $data = [
|
||||||
|
'2-Engel',
|
||||||
|
'shiftentry_edit_angeltype_supporter',
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run the migration
|
||||||
|
*/
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
if (!$this->schema->hasTable('GroupPrivileges')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$db = $this->schema->getConnection();
|
||||||
|
if (!empty($db->select($this->getQuery('SELECT *'), $this->data))) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add permissions to angels to edit angels if they are angeltype supporters
|
||||||
|
$db->insert(
|
||||||
|
'
|
||||||
|
INSERT IGNORE INTO GroupPrivileges (group_id, privilege_id)
|
||||||
|
VALUES ((SELECT UID FROM `Groups` WHERE `name` = ?), (SELECT id FROM `Privileges` WHERE `name` = ?))
|
||||||
|
',
|
||||||
|
$this->data
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migration
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
if (!$this->schema->hasTable('GroupPrivileges')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove permission from angels
|
||||||
|
$this->schema->getConnection()->delete(
|
||||||
|
$this->getQuery('DELETE'),
|
||||||
|
$this->data
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $type
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getQuery($type)
|
||||||
|
{
|
||||||
|
return sprintf('
|
||||||
|
%s FROM GroupPrivileges
|
||||||
|
WHERE group_id = (SELECT UID FROM `Groups` WHERE `name` = ?)
|
||||||
|
AND privilege_id = (SELECT id FROM `Privileges` WHERE `name` = ?)
|
||||||
|
', $type);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue