forked from Ivasoft/mattermost-mobile
* fix: handle NSMutableData * feat: integrate react-native-network-client * fix: typos * fix: semicolon * fix: rename to urlVersion * fix: add returnDataOnly arg * fix: configure network client * fix: headers * fix: handling of serverVersion * fix: rename requests to actions * fix: action imports * fix: no need to stringify body * fix: sso flow * fix: address PR feedback * fix: invalidate client on logout * fix: address PR feedback take 2 * fix: address PR feedback take 3 * fix: tsc issues * fix: get csrf token during client creation * fix: linter * fix: invalidate client onLogout * fix: event emitter * fix: unit tests * fix: apply linter fixes * fix lint * Modify actions to add / update database values * Rename clien4.d.ts to client.d.ts * fix empty & missing translations * cleanup api client * Cleanup init & squash some TODO's * Emit certificate errors in NetworkManager * cleanup user actions * Fix NetworkManager invalidate client * Invalidate client when server screen appears * Update kotlin to 1.4.30 required by network-client * patch react-native-keychain to remove cached credential * update react-native-network-client * Use app.db instead of default.db in native code * fix use of rnnc on Android * Init PushNotifications * No need to reset serverVersion on logout * fix logout action * fix deleteServerDatabase * fix schedule expired session notification * use safeParseJSON for db json fields * unsubscribe when database component unmounts * cleanup init * session type * pass launchprops to entire login flow * Properly remove third party cookies after SSO login * recreate network client if sso with redirect fails * add missing launch props from server screen * use query prefix for database queries * Add temporary logout function to channel screen Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
44 lines
1.3 KiB
TypeScript
44 lines
1.3 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {buildQueryString} from '@utils/helpers';
|
|
|
|
export interface ClientAppsMix {
|
|
executeAppCall: (call: AppCallRequest, type: AppCallType) => Promise<AppCallResponse>;
|
|
getAppsBindings: (userID: string, channelID: string, teamID: string) => Promise<AppBinding[]>;
|
|
}
|
|
|
|
const ClientApps = (superclass: any) => class extends superclass {
|
|
executeAppCall = async (call: AppCallRequest, type: AppCallType) => {
|
|
const callCopy = {
|
|
...call,
|
|
path: `${call.path}/${type}`,
|
|
context: {
|
|
...call.context,
|
|
user_agent: 'mobile',
|
|
},
|
|
};
|
|
|
|
return this.doFetch(
|
|
`${this.getAppsProxyRoute()}/api/v1/call`,
|
|
{method: 'post', body: callCopy},
|
|
);
|
|
}
|
|
|
|
getAppsBindings = async (userID: string, channelID: string, teamID: string) => {
|
|
const params = {
|
|
user_id: userID,
|
|
channel_id: channelID,
|
|
team_id: teamID,
|
|
user_agent: 'mobile',
|
|
};
|
|
|
|
return this.doFetch(
|
|
`${this.getAppsProxyRoute()}/api/v1/bindings${buildQueryString(params)}`,
|
|
{method: 'get'},
|
|
);
|
|
}
|
|
};
|
|
|
|
export default ClientApps;
|