Files
mattermost-mobile/app/queries/servers/entry.ts
Elias Nahum d61fbd3180 Various fixes (#7161)
* Save message draft when post input is unmounted

* Fix switch CRT on/off

* Handle iPad on Stage Manager

* iOS Share Extension to use LRU cache instead of file cache

* Support building android as aab

* use handleReconnect instead of appEntry on handleCRTToggled

* show skin tone selector tutorial after running all interactions

* Update app/actions/remote/preference.ts

Co-authored-by: Daniel Espino García <larkox@gmail.com>

* fix lint

---------

Co-authored-by: Daniel Espino García <larkox@gmail.com>
2023-02-24 13:02:05 +02:00

118 lines
4.2 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import {MM_TABLES} from '@constants/database';
import DatabaseManager from '@database/manager';
import {prepareCategoriesAndCategoriesChannels} from './categories';
import {prepareDeleteChannel, prepareMyChannelsForTeam} from './channel';
import {prepareMyPreferences} from './preference';
import {resetWebSocketLastDisconnected} from './system';
import {prepareDeleteTeam, prepareMyTeams} from './team';
import {prepareUsers} from './user';
import type {MyChannelsRequest} from '@actions/remote/channel';
import type {MyPreferencesRequest} from '@actions/remote/preference';
import type {MyTeamsRequest} from '@actions/remote/team';
import type {MyUserRequest} from '@actions/remote/user';
import type ServerDataOperator from '@database/operator/server_data_operator';
import type {Model} from '@nozbe/watermelondb';
import type ChannelModel from '@typings/database/models/servers/channel';
import type TeamModel from '@typings/database/models/servers/team';
type PrepareModelsArgs = {
operator: ServerDataOperator;
initialTeamId?: string;
removeTeams?: TeamModel[];
removeChannels?: ChannelModel[];
teamData?: MyTeamsRequest;
chData?: MyChannelsRequest;
prefData?: MyPreferencesRequest;
meData?: MyUserRequest;
isCRTEnabled?: boolean;
}
const {
POST,
POSTS_IN_CHANNEL,
POSTS_IN_THREAD,
THREAD,
THREADS_IN_TEAM,
THREAD_PARTICIPANT,
TEAM_THREADS_SYNC,
MY_CHANNEL,
} = MM_TABLES.SERVER;
export async function prepareModels({operator, initialTeamId, removeTeams, removeChannels, teamData, chData, prefData, meData, isCRTEnabled}: PrepareModelsArgs, isGraphQL = false): Promise<Array<Promise<Model[]>>> {
const modelPromises: Array<Promise<Model[]>> = [];
if (removeTeams?.length) {
removeTeams.forEach((team) => {
modelPromises.push(prepareDeleteTeam(team));
});
}
if (removeChannels?.length) {
removeChannels.forEach((channel) => {
modelPromises.push(prepareDeleteChannel(channel));
});
}
if (teamData?.teams?.length && teamData.memberships?.length) {
modelPromises.push(...prepareMyTeams(operator, teamData.teams, teamData.memberships));
}
if (chData?.categories?.length) {
modelPromises.push(prepareCategoriesAndCategoriesChannels(operator, chData.categories, true));
}
if (chData?.channels?.length && chData.memberships?.length) {
if (isGraphQL) {
modelPromises.push(...await prepareMyChannelsForTeam(operator, '', chData.channels, chData.memberships, isCRTEnabled, true));
} else if (initialTeamId) {
modelPromises.push(...await prepareMyChannelsForTeam(operator, initialTeamId, chData.channels, chData.memberships, isCRTEnabled, false));
}
}
if (prefData?.preferences?.length) {
modelPromises.push(prepareMyPreferences(operator, prefData.preferences, true));
}
if (meData?.user) {
modelPromises.push(prepareUsers(operator, [meData.user]));
}
return modelPromises;
}
export async function truncateCrtRelatedTables(serverUrl: string): Promise<{error: any}> {
const {database, operator} = DatabaseManager.getServerDatabaseAndOperator(serverUrl);
try {
await database.write(() => {
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
return database.adapter.unsafeExecute({
sqls: [
[`DELETE FROM ${POST}`, []],
[`DELETE FROM ${POSTS_IN_CHANNEL}`, []],
[`DELETE FROM ${POSTS_IN_THREAD}`, []],
[`DELETE FROM ${THREAD}`, []],
[`DELETE FROM ${THREADS_IN_TEAM}`, []],
[`DELETE FROM ${THREAD_PARTICIPANT}`, []],
[`DELETE FROM ${TEAM_THREADS_SYNC}`, []],
[`DELETE FROM ${MY_CHANNEL}`, []],
],
});
});
await resetWebSocketLastDisconnected(operator);
} catch (error) {
if (__DEV__) {
throw error;
}
return {error};
}
return {error: false};
}