Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Integrate react-native-network-client #5499

Merged
merged 56 commits into from
Jul 6, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
48f3b28
fix: handle NSMutableData
migbot Jun 25, 2021
15e0684
feat: integrate react-native-network-client
migbot Jun 29, 2021
00a8011
fix: typos
migbot Jun 29, 2021
e75abc8
Merge branch 'gekidou' into gekidou-network-clients
migbot Jun 29, 2021
fc13ce7
fix: semicolon
migbot Jun 29, 2021
483bd9e
fix: rename to urlVersion
migbot Jun 29, 2021
4d58d03
fix: add returnDataOnly arg
migbot Jun 29, 2021
50503e9
fix: configure network client
migbot Jun 29, 2021
7393f7b
fix: headers
migbot Jun 29, 2021
5d9adcb
fix: handling of serverVersion
migbot Jun 29, 2021
b193838
fix: rename requests to actions
migbot Jun 29, 2021
bb9f5cb
fix: action imports
migbot Jun 29, 2021
6c4935a
fix: no need to stringify body
migbot Jun 29, 2021
03be857
fix: sso flow
migbot Jun 29, 2021
864be4e
fix: address PR feedback
migbot Jul 1, 2021
4108154
fix: invalidate client on logout
migbot Jul 1, 2021
b488a18
fix: address PR feedback take 2
migbot Jul 1, 2021
47b115c
fix: address PR feedback take 3
migbot Jul 1, 2021
a9d6f9b
fix: tsc issues
migbot Jul 1, 2021
d8f4b2d
fix: get csrf token during client creation
migbot Jul 1, 2021
7fab95e
fix: linter
migbot Jul 1, 2021
aa4de0d
fix: invalidate client onLogout
migbot Jul 1, 2021
51372ce
fix: event emitter
migbot Jul 1, 2021
f68b0ee
fix: unit tests
migbot Jul 1, 2021
3eab409
fix: apply linter fixes
migbot Jul 1, 2021
d2724f4
fix lint
enahum Jul 1, 2021
f09b2c9
Modify actions to add / update database values
enahum Jul 1, 2021
29e9734
Rename clien4.d.ts to client.d.ts
enahum Jul 1, 2021
c5a823f
fix empty & missing translations
enahum Jul 1, 2021
8e4024f
cleanup api client
enahum Jul 1, 2021
340bcb5
Cleanup init & squash some TODO's
enahum Jul 1, 2021
e2a55ce
Emit certificate errors in NetworkManager
enahum Jul 2, 2021
cccc182
Merge branch 'gekidou' into gekidou-network-clients
enahum Jul 2, 2021
f839c80
cleanup user actions
enahum Jul 2, 2021
c77e2ca
Fix NetworkManager invalidate client
enahum Jul 2, 2021
be26b45
Invalidate client when server screen appears
enahum Jul 2, 2021
4b23310
Update kotlin to 1.4.30 required by network-client
enahum Jul 2, 2021
ce22a29
patch react-native-keychain to remove cached credential
enahum Jul 3, 2021
ba70408
update react-native-network-client
enahum Jul 3, 2021
181d65e
Use app.db instead of default.db in native code
enahum Jul 3, 2021
e98f55f
fix use of rnnc on Android
enahum Jul 3, 2021
beeac73
Init PushNotifications
enahum Jul 3, 2021
cd150ff
No need to reset serverVersion on logout
enahum Jul 3, 2021
e8bc57a
fix logout action
enahum Jul 3, 2021
b674ac3
fix deleteServerDatabase
enahum Jul 3, 2021
899048f
fix schedule expired session notification
enahum Jul 3, 2021
56fcd51
use safeParseJSON for db json fields
enahum Jul 3, 2021
a516413
unsubscribe when database component unmounts
enahum Jul 3, 2021
5bed596
cleanup init
enahum Jul 3, 2021
0f0cb39
session type
enahum Jul 3, 2021
efa867f
pass launchprops to entire login flow
enahum Jul 3, 2021
ef0469c
Properly remove third party cookies after SSO login
enahum Jul 3, 2021
2c3cb7b
recreate network client if sso with redirect fails
enahum Jul 3, 2021
81ca9db
add missing launch props from server screen
enahum Jul 3, 2021
d730ce9
use query prefix for database queries
enahum Jul 3, 2021
57017e6
Add temporary logout function to channel screen
enahum Jul 3, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Modify actions to add / update database values
  • Loading branch information
enahum committed Jul 1, 2021
commit f09b2c9556beee00aafac7ac7bbe9603b350a7ce
24 changes: 0 additions & 24 deletions app/actions/local/systems.ts

This file was deleted.

31 changes: 29 additions & 2 deletions app/actions/remote/general.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.

import NetworkManager from '@app/init/network_manager';
import {SYSTEM_IDENTIFIERS} from '@constants/database';
import DatabaseManager from '@database/manager';
import {getServerCredentials} from '@init/credentials';
import NetworkManager from '@init/network_manager';

import type {ClientResponse} from '@mattermost/react-native-network-client';

import type {RawSystem} from '@typings/database/database';

export const doPing = async (serverUrl: string) => {
const client = await NetworkManager.createClient(serverUrl);

Expand All @@ -25,6 +30,7 @@ export const doPing = async (serverUrl: string) => {
if (response.code === 401) {
// Don't invalidate the client since we want to eventually
// import a certificate with client.importClientP12()
// if for some reason cert is not imported do invalidate the client then.
return {error: {intl: certificateError}};
}

Expand All @@ -49,11 +55,32 @@ export const fetchConfigAndLicense = async (serverUrl: string) => {
}

try {
const [config, license] = await Promise.all<any, any>([
const [config, license] = await Promise.all<ClientConfig, ClientLicense>([
client.getClientConfigOld(),
client.getClientLicenseOld(),
]);

// If we have credentials for this server then update the values in the database
const credentials = await getServerCredentials(serverUrl);
const operator = DatabaseManager.serverDatabases[serverUrl]?.operator;
if (credentials && operator) {
const systems: RawSystem[] = [{
id: SYSTEM_IDENTIFIERS.CONFIG,
name: SYSTEM_IDENTIFIERS.CONFIG,
value: JSON.stringify(config),
}, {
id: SYSTEM_IDENTIFIERS.LICENSE,
name: SYSTEM_IDENTIFIERS.LICENSE,
value: JSON.stringify(license),
}];

operator.handleSystem({systems, prepareRecordsOnly: false}).
catch((error) => {
// eslint-disable-next-line no-console
console.log('An error ocurred while saving config & license', error);
});
}

return {config, license};
} catch (error) {
return {error};
Expand Down
28 changes: 13 additions & 15 deletions app/actions/remote/push_notification.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,8 @@ import PushNotifications from '@init/push_notifications';
import {getCommonSystemValues} from '@app/queries/servers/system';
import {getSessions} from '@actions/remote/user';
import {Config} from '@typings/database/models/servers/config';
import {isMinimumServerVersion} from '@utils/helpers';

const MAJOR_VERSION = 5;
const MINOR_VERSION = 24;

const sortByNewest = (a: any, b: any) => {
const sortByNewest = (a: Session, b: Session) => {
if (a.create_at > b.create_at) {
return -1;
}
Expand All @@ -26,28 +22,29 @@ export const scheduleExpiredNotification = async (serverUrl: string, intl: IntlS
const database = DatabaseManager.serverDatabases[serverUrl].database;
const {currentUserId, config}: {currentUserId: string, config: Partial<Config>} = await getCommonSystemValues(database);

if (isMinimumServerVersion(config.Version!, MAJOR_VERSION, MINOR_VERSION) && config.ExtendSessionLengthWithActivity === 'true') {
if (config.ExtendSessionLengthWithActivity === 'true') {
PushNotifications.cancelAllLocalNotifications();
return null;
}

const timeOut = setTimeout(async () => {
clearTimeout(timeOut);
let sessions: any;
let sessions: Session[]|undefined;

try {
sessions = await getSessions(serverUrl, currentUserId);
} catch (e) {
// console.warn('Failed to get current session', e);
// eslint-disable-next-line no-console
console.warn('Failed to get user sessions', e);
return;
}

if (!Array.isArray(sessions?.data)) {
if (!Array.isArray(sessions)) {
return;
}

const session = sessions.data.sort(sortByNewest)[0];
const expiresAt = session?.expires_at || 0; //eslint-disable-line camelcase
const session = sessions.sort(sortByNewest)[0];
const expiresAt = session?.expires_at || 0;
const expiresInDays = parseInt(String(Math.ceil(Math.abs(moment.duration(moment().diff(expiresAt)).asDays()))), 10);

const message = intl.formatMessage(
Expand All @@ -61,13 +58,14 @@ export const scheduleExpiredNotification = async (serverUrl: string, intl: IntlS
);

if (expiresAt) {
//@ts-expect-error: Does not need to set all Notification properties
PushNotifications.scheduleNotification({
fireDate: expiresAt,
body: message,
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
userInfo: {
local: true,
payload: {
userInfo: {
local: true,
},
},
});
}
Expand Down
6 changes: 3 additions & 3 deletions app/actions/remote/role.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
// See LICENSE.txt for license information.

import DatabaseManager from '@database/manager';
import NetworkManager from '@app/init/network_manager';
import {getRoles} from '@app/queries/servers/role';
import NetworkManager from '@init/network_manager';
import {getRoles} from '@queries/servers/role';

export const loadRolesIfNeeded = async (serverUrl: string, updatedRoles: string[]) => {
let client;
Expand All @@ -15,7 +15,7 @@ export const loadRolesIfNeeded = async (serverUrl: string, updatedRoles: string[

const database = DatabaseManager.serverDatabases[serverUrl].database;
const operator = DatabaseManager.serverDatabases[serverUrl].operator;
const existingRoles = ((await getRoles(database)) as unknown) as Role[];
const existingRoles = await getRoles(database);

const roleNames = existingRoles.map((role) => {
return role.name;
Expand Down
23 changes: 20 additions & 3 deletions app/actions/remote/systems.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.

import NetworkManager from '@app/init/network_manager';
import {logError} from '@actions/remote/error';
import {forceLogoutIfNecessary} from '@actions/remote/user';
import {SYSTEM_IDENTIFIERS} from '@constants/database';
import DatabaseManager from '@database/manager';
import NetworkManager from '@init/network_manager';

import type {RawSystem} from '@typings/database/database';

export const getDataRetentionPolicy = async (serverUrl: string) => {
let client;
Expand All @@ -19,11 +23,24 @@ export const getDataRetentionPolicy = async (serverUrl: string) => {
} catch (error) {
forceLogoutIfNecessary(serverUrl, error);

//fixme: do we care for the below line ? It seems that the `error` object is never read ??
// dispatch(batchActions([{type: GeneralTypes.RECEIVED_DATA_RETENTION_POLICY, error,},]));
logError(error);
return {error};
}

const operator = DatabaseManager.serverDatabases[serverUrl]?.operator;
if (operator) {
const systems: RawSystem[] = [{
id: SYSTEM_IDENTIFIERS.DATA_RETENTION_POLICIES,
name: SYSTEM_IDENTIFIERS.DATA_RETENTION_POLICIES,
value: JSON.stringify(data),
}];

operator.handleSystem({systems, prepareRecordsOnly: false}).
catch((error) => {
// eslint-disable-next-line no-console
console.log('An error ocurred while saving data retention policies', error);
});
}

return data;
};
Loading