mirror of
https://codeberg.org/timelimit/timelimit-server.git
synced 2025-10-05 02:39:48 +02:00
Remove saving Apps in the legacy format
This commit is contained in:
parent
f5198c7c0b
commit
89e9b85bda
8 changed files with 40 additions and 205 deletions
|
@ -17,8 +17,6 @@
|
||||||
|
|
||||||
import * as Sequelize from 'sequelize'
|
import * as Sequelize from 'sequelize'
|
||||||
import { AddDeviceTokenModelStatic, createAddDeviceTokenModel } from './adddevicetoken'
|
import { AddDeviceTokenModelStatic, createAddDeviceTokenModel } from './adddevicetoken'
|
||||||
import { AppModelStatic, createAppModel } from './app'
|
|
||||||
import { AppActivityModelStatic, createAppActivityModel } from './appactivity'
|
|
||||||
import { AuthTokenModelStatic, createAuthtokenModel } from './authtoken'
|
import { AuthTokenModelStatic, createAuthtokenModel } from './authtoken'
|
||||||
import { CategoryModelStatic, createCategoryModel } from './category'
|
import { CategoryModelStatic, createCategoryModel } from './category'
|
||||||
import { CategoryAppModelStatic, createCategoryAppModel } from './categoryapp'
|
import { CategoryAppModelStatic, createCategoryAppModel } from './categoryapp'
|
||||||
|
@ -49,8 +47,6 @@ export type Transaction = Sequelize.Transaction
|
||||||
export interface Database {
|
export interface Database {
|
||||||
addDeviceToken: AddDeviceTokenModelStatic
|
addDeviceToken: AddDeviceTokenModelStatic
|
||||||
authtoken: AuthTokenModelStatic
|
authtoken: AuthTokenModelStatic
|
||||||
app: AppModelStatic
|
|
||||||
appActivity: AppActivityModelStatic
|
|
||||||
category: CategoryModelStatic
|
category: CategoryModelStatic
|
||||||
categoryApp: CategoryAppModelStatic
|
categoryApp: CategoryAppModelStatic
|
||||||
categoryNetworkId: CategoryNetworkIdModelStatic
|
categoryNetworkId: CategoryNetworkIdModelStatic
|
||||||
|
@ -87,8 +83,6 @@ interface TransactionOptions {
|
||||||
const createDatabase = (sequelize: Sequelize.Sequelize): Database => ({
|
const createDatabase = (sequelize: Sequelize.Sequelize): Database => ({
|
||||||
addDeviceToken: createAddDeviceTokenModel(sequelize),
|
addDeviceToken: createAddDeviceTokenModel(sequelize),
|
||||||
authtoken: createAuthtokenModel(sequelize),
|
authtoken: createAuthtokenModel(sequelize),
|
||||||
app: createAppModel(sequelize),
|
|
||||||
appActivity: createAppActivityModel(sequelize),
|
|
||||||
category: createCategoryModel(sequelize),
|
category: createCategoryModel(sequelize),
|
||||||
categoryApp: createCategoryAppModel(sequelize),
|
categoryApp: createCategoryAppModel(sequelize),
|
||||||
childTask: createChildTaskModel(sequelize),
|
childTask: createChildTaskModel(sequelize),
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
/*
|
||||||
|
* server component for the TimeLimit App
|
||||||
|
* Copyright (C) 2019 - 2022 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'
|
||||||
|
|
||||||
|
export async function up (queryInterface: QueryInterface, sequelize: Sequelize) {
|
||||||
|
await sequelize.transaction({
|
||||||
|
type: Transaction.TYPES.EXCLUSIVE
|
||||||
|
}, async (transaction) => {
|
||||||
|
await queryInterface.dropTable('Apps', { transaction })
|
||||||
|
await queryInterface.dropTable('AppActivities', { transaction })
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function down() {
|
||||||
|
throw new Error('not possible')
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* server component for the TimeLimit App
|
* server component for the TimeLimit App
|
||||||
* Copyright (C) 2019 - 2020 Jonas Lochmann
|
* Copyright (C) 2019 - 2022 Jonas Lochmann
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Affero General Public License as
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
@ -29,26 +29,6 @@ export async function deleteFamilies ({ database, familiyIds }: {
|
||||||
}
|
}
|
||||||
|
|
||||||
await database.transaction(async (transaction) => {
|
await database.transaction(async (transaction) => {
|
||||||
// app
|
|
||||||
await database.app.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: {
|
|
||||||
[Sequelize.Op.in]: familiyIds
|
|
||||||
}
|
|
||||||
},
|
|
||||||
transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
// app activity
|
|
||||||
await database.appActivity.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: {
|
|
||||||
[Sequelize.Op.in]: familiyIds
|
|
||||||
}
|
|
||||||
},
|
|
||||||
transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
// category
|
// category
|
||||||
await database.category.destroy({
|
await database.category.destroy({
|
||||||
where: {
|
where: {
|
||||||
|
|
|
@ -40,23 +40,6 @@ export async function removeDevice ({ database, familyId, deviceId, websocket, t
|
||||||
throw new Conflict()
|
throw new Conflict()
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove app entries
|
|
||||||
await database.app.destroy({
|
|
||||||
where: {
|
|
||||||
familyId,
|
|
||||||
deviceId
|
|
||||||
},
|
|
||||||
transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
await database.appActivity.destroy({
|
|
||||||
where: {
|
|
||||||
familyId,
|
|
||||||
deviceId
|
|
||||||
},
|
|
||||||
transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
// remove as current device
|
// remove as current device
|
||||||
await database.user.update({
|
await database.user.update({
|
||||||
currentDevice: ''
|
currentDevice: ''
|
||||||
|
|
|
@ -15,49 +15,13 @@
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import * as Sequelize from 'sequelize'
|
|
||||||
import { AddInstalledAppsAction } from '../../../../action'
|
import { AddInstalledAppsAction } from '../../../../action'
|
||||||
import { AppAttributes, maxPackageNameLength } from '../../../../database/app'
|
|
||||||
import { Cache } from '../cache'
|
import { Cache } from '../cache'
|
||||||
import { ApplyActionException } from '../exception'
|
|
||||||
|
|
||||||
export async function dispatchAddInstalledApps ({ deviceId, action, cache }: {
|
export async function dispatchAddInstalledApps (_: {
|
||||||
deviceId: string
|
deviceId: string
|
||||||
action: AddInstalledAppsAction
|
action: AddInstalledAppsAction
|
||||||
cache: Cache
|
cache: Cache
|
||||||
}) {
|
}) {
|
||||||
action.apps.forEach((app) => {
|
// do nothing
|
||||||
if (app.packageName.length > maxPackageNameLength) {
|
|
||||||
throw new ApplyActionException({
|
|
||||||
staticMessage: 'package name too long',
|
|
||||||
dynamicMessage: 'package name too long: ' + app.packageName
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
await cache.database.app.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
packageName: {
|
|
||||||
[Sequelize.Op.in]: action.apps.map((app) => app.packageName)
|
|
||||||
}
|
|
||||||
},
|
|
||||||
transaction: cache.transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
await cache.database.app.bulkCreate(
|
|
||||||
action.apps.map((app): AppAttributes => ({
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
packageName: app.packageName,
|
|
||||||
title: app.title,
|
|
||||||
isLaunchable: app.isLaunchable,
|
|
||||||
recommendation: app.recommendation
|
|
||||||
})),
|
|
||||||
{ transaction: cache.transaction }
|
|
||||||
)
|
|
||||||
|
|
||||||
cache.devicesWithModifiedInstalledApps.add(deviceId)
|
|
||||||
cache.incrementTriggeredSyncLevel(1)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,26 +15,13 @@
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import * as Sequelize from 'sequelize'
|
|
||||||
import { RemoveInstalledAppsAction } from '../../../../action'
|
import { RemoveInstalledAppsAction } from '../../../../action'
|
||||||
import { Cache } from '../cache'
|
import { Cache } from '../cache'
|
||||||
|
|
||||||
export async function dispatchRemoveInstalledApps ({ deviceId, action, cache }: {
|
export async function dispatchRemoveInstalledApps (_: {
|
||||||
deviceId: string
|
deviceId: string
|
||||||
action: RemoveInstalledAppsAction
|
action: RemoveInstalledAppsAction
|
||||||
cache: Cache
|
cache: Cache
|
||||||
}) {
|
}) {
|
||||||
await cache.database.app.destroy({
|
// do nothing
|
||||||
where: {
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
packageName: {
|
|
||||||
[Sequelize.Op.in]: action.packageNames
|
|
||||||
}
|
|
||||||
},
|
|
||||||
transaction: cache.transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
cache.devicesWithModifiedInstalledApps.add(deviceId)
|
|
||||||
cache.incrementTriggeredSyncLevel(1)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,85 +15,13 @@
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { chunk } from 'lodash'
|
|
||||||
import * as Sequelize from 'sequelize'
|
|
||||||
import { UpdateAppActivitiesAction } from '../../../../action'
|
import { UpdateAppActivitiesAction } from '../../../../action'
|
||||||
import { AppActivityAttributes, maxActivityNameLength, maxPackageNameLength } from '../../../../database/appactivity'
|
|
||||||
import { Cache } from '../cache'
|
import { Cache } from '../cache'
|
||||||
import { ApplyActionException } from '../exception'
|
|
||||||
|
|
||||||
export async function dispatchUpdateAppActivities ({ deviceId, action, cache }: {
|
export async function dispatchUpdateAppActivities (_: {
|
||||||
deviceId: string
|
deviceId: string
|
||||||
action: UpdateAppActivitiesAction
|
action: UpdateAppActivitiesAction
|
||||||
cache: Cache
|
cache: Cache
|
||||||
}) {
|
}) {
|
||||||
action.updatedOrAdded.forEach((app) => {
|
// do nothing
|
||||||
if (app.packageName.length > maxPackageNameLength) {
|
|
||||||
throw new ApplyActionException({
|
|
||||||
staticMessage: 'package name too long',
|
|
||||||
dynamicMessage: 'package name too long: ' + app.packageName
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if (app.activityName.length > maxActivityNameLength) {
|
|
||||||
throw new ApplyActionException({
|
|
||||||
staticMessage: 'activity name too long',
|
|
||||||
dynamicMessage: 'activity name too long: ' + app.activityName
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
if (action.updatedOrAdded.length > 0) {
|
|
||||||
const chuncks = chunk(action.updatedOrAdded, 500)
|
|
||||||
|
|
||||||
for (const items of chuncks) {
|
|
||||||
await cache.database.appActivity.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
[Sequelize.Op.or]: (
|
|
||||||
items.map((item) => ({
|
|
||||||
packageName: item.packageName,
|
|
||||||
activityName: item.activityName
|
|
||||||
}))
|
|
||||||
)
|
|
||||||
},
|
|
||||||
transaction: cache.transaction
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
await cache.database.appActivity.bulkCreate(
|
|
||||||
action.updatedOrAdded.map((item): AppActivityAttributes => ({
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
packageName: item.packageName,
|
|
||||||
activityName: item.activityName,
|
|
||||||
title: item.title
|
|
||||||
})),
|
|
||||||
{ transaction: cache.transaction }
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (action.removed.length > 0) {
|
|
||||||
const chunks = chunk(action.removed, 500)
|
|
||||||
|
|
||||||
for (const items of chunks) {
|
|
||||||
await cache.database.appActivity.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
[Sequelize.Op.or]: (
|
|
||||||
items.map((item) => ({
|
|
||||||
packageName: item.packageName,
|
|
||||||
activityName: item.activityName
|
|
||||||
}))
|
|
||||||
)
|
|
||||||
},
|
|
||||||
transaction: cache.transaction
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cache.devicesWithModifiedInstalledApps.add(deviceId)
|
|
||||||
cache.incrementTriggeredSyncLevel(1)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,44 +16,12 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { UpdateInstalledAppsAction } from '../../../../action'
|
import { UpdateInstalledAppsAction } from '../../../../action'
|
||||||
import { types } from '../../../../database/encryptedapplist'
|
|
||||||
import { generateVersionId } from '../../../../util/token'
|
|
||||||
import { Cache } from '../cache'
|
import { Cache } from '../cache'
|
||||||
|
|
||||||
export async function dispatchUpdateInstalledApps ({ deviceId, action, cache }: {
|
export async function dispatchUpdateInstalledApps (_: {
|
||||||
deviceId: string
|
deviceId: string
|
||||||
action: UpdateInstalledAppsAction
|
action: UpdateInstalledAppsAction
|
||||||
cache: Cache
|
cache: Cache
|
||||||
}) {
|
}) {
|
||||||
async function upsert({ type, data }: { type: number, data: Buffer }) {
|
// do nothing
|
||||||
await cache.database.encryptedAppList.upsert({
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId,
|
|
||||||
type,
|
|
||||||
version: generateVersionId(),
|
|
||||||
data
|
|
||||||
}, { transaction: cache.transaction })
|
|
||||||
}
|
|
||||||
|
|
||||||
if (action.base) {
|
|
||||||
await upsert({ type: types.base, data: action.base })
|
|
||||||
}
|
|
||||||
|
|
||||||
if (action.diff) {
|
|
||||||
await upsert({ type: types.diff, data: action.diff })
|
|
||||||
}
|
|
||||||
|
|
||||||
if (action.wipe) {
|
|
||||||
await cache.database.app.destroy({
|
|
||||||
where: {
|
|
||||||
familyId: cache.familyId,
|
|
||||||
deviceId
|
|
||||||
},
|
|
||||||
transaction: cache.transaction
|
|
||||||
})
|
|
||||||
|
|
||||||
cache.devicesWithModifiedInstalledApps.add(deviceId)
|
|
||||||
}
|
|
||||||
|
|
||||||
cache.incrementTriggeredSyncLevel(1)
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue