mirror of
https://codeberg.org/timelimit/timelimit-server.git
synced 2025-10-03 09:49:32 +02:00
46 lines
1.7 KiB
TypeScript
46 lines
1.7 KiB
TypeScript
/*
|
|
* server component for the TimeLimit App
|
|
* Copyright (C) 2019 Jonas Lochmann
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, version 3 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { QueryInterface, Sequelize, Transaction } from 'sequelize'
|
|
import { attributesVersion7 } from '../../device'
|
|
|
|
export async function up (queryInterface: QueryInterface, sequelize: Sequelize) {
|
|
await sequelize.transaction({
|
|
type: Transaction.TYPES.EXCLUSIVE
|
|
}, async (transaction) => {
|
|
await queryInterface.addColumn('Devices', 'currentOverlayPermission', {
|
|
...attributesVersion7.currentOverlayPermission
|
|
}, {
|
|
transaction
|
|
})
|
|
|
|
await queryInterface.addColumn('Devices', 'highestOverlayPermission', {
|
|
...attributesVersion7.highestOverlayPermission
|
|
}, {
|
|
transaction
|
|
})
|
|
})
|
|
}
|
|
|
|
export async function down (queryInterface: QueryInterface, sequelize: Sequelize) {
|
|
await sequelize.transaction({
|
|
type: Transaction.TYPES.EXCLUSIVE
|
|
}, async (transaction) => {
|
|
await queryInterface.removeColumn('Devices', 'currentOverlayPermission', { transaction })
|
|
await queryInterface.removeColumn('Devices', 'highestOverlayPermission', { transaction })
|
|
})
|
|
}
|