forked from Ivasoft/mattermost-mobile
* Adapt websocket client * Add Websocket Manager * Address feedback * Start websockets on init and login, and invalidate on logout * Add temporal logging and bug fixing * Working WS * Add reconnect actions and periodic updates * Address feedback * Add missing change * Several improvements on websocket reconnect and channel handling * fix gekidou package-lock.json * update Podfile.lock * Address feedback * Address feedback * Address feedback * Fix update channel delete at * Catch errors on batchRecords * Update app/queries/servers/channel.ts Co-authored-by: Elias Nahum <nahumhbl@gmail.com> Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
168 lines
5.3 KiB
TypeScript
168 lines
5.3 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {buildQueryString} from '@utils/helpers';
|
|
|
|
import {PER_PAGE_DEFAULT} from './constants';
|
|
|
|
export interface ClientTeamsMix {
|
|
createTeam: (team: Team) => Promise<Team>;
|
|
deleteTeam: (teamId: string) => Promise<any>;
|
|
updateTeam: (team: Team) => Promise<Team>;
|
|
patchTeam: (team: Partial<Team> & {id: string}) => Promise<Team>;
|
|
getTeams: (page?: number, perPage?: number, includeTotalCount?: boolean) => Promise<Team[]>;
|
|
getTeam: (teamId: string) => Promise<Team>;
|
|
getTeamByName: (teamName: string) => Promise<Team>;
|
|
getMyTeams: () => Promise<Team[]>;
|
|
getTeamsForUser: (userId: string) => Promise<Team[]>;
|
|
getMyTeamMembers: () => Promise<TeamMembership[]>;
|
|
getTeamMembers: (teamId: string, page?: number, perPage?: number) => Promise<TeamMembership[]>;
|
|
getTeamMember: (teamId: string, userId: string) => Promise<TeamMembership>;
|
|
addToTeam: (teamId: string, userId: string) => Promise<TeamMembership>;
|
|
joinTeam: (inviteId: string) => Promise<TeamMembership>;
|
|
removeFromTeam: (teamId: string, userId: string) => Promise<any>;
|
|
getTeamStats: (teamId: string) => Promise<any>;
|
|
getTeamIconUrl: (teamId: string, lastTeamIconUpdate: number) => string;
|
|
}
|
|
|
|
const ClientTeams = (superclass: any) => class extends superclass {
|
|
createTeam = async (team: Team) => {
|
|
this.analytics.trackAPI('api_teams_create');
|
|
|
|
return this.doFetch(
|
|
`${this.getTeamsRoute()}`,
|
|
{method: 'post', body: team},
|
|
);
|
|
};
|
|
|
|
deleteTeam = async (teamId: string) => {
|
|
this.analytics.trackAPI('api_teams_delete');
|
|
|
|
return this.doFetch(
|
|
`${this.getTeamRoute(teamId)}`,
|
|
{method: 'delete'},
|
|
);
|
|
};
|
|
|
|
updateTeam = async (team: Team) => {
|
|
this.analytics.trackAPI('api_teams_update_name', {team_id: team.id});
|
|
|
|
return this.doFetch(
|
|
`${this.getTeamRoute(team.id)}`,
|
|
{method: 'put', body: team},
|
|
);
|
|
};
|
|
|
|
patchTeam = async (team: Partial<Team> & {id: string}) => {
|
|
this.analytics.trackAPI('api_teams_patch_name', {team_id: team.id});
|
|
|
|
return this.doFetch(
|
|
`${this.getTeamRoute(team.id)}/patch`,
|
|
{method: 'put', body: team},
|
|
);
|
|
};
|
|
|
|
getTeams = async (page = 0, perPage = PER_PAGE_DEFAULT, includeTotalCount = false) => {
|
|
return this.doFetch(
|
|
`${this.getTeamsRoute()}${buildQueryString({page, per_page: perPage, include_total_count: includeTotalCount})}`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeam = async (teamId: string) => {
|
|
return this.doFetch(
|
|
this.getTeamRoute(teamId),
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeamByName = async (teamName: string) => {
|
|
this.analytics.trackAPI('api_teams_get_team_by_name');
|
|
|
|
return this.doFetch(
|
|
this.getTeamNameRoute(teamName),
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getMyTeams = async () => {
|
|
return this.doFetch(
|
|
`${this.getUserRoute('me')}/teams`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeamsForUser = async (userId: string) => {
|
|
return this.doFetch(
|
|
`${this.getUserRoute(userId)}/teams`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getMyTeamMembers = async () => {
|
|
return this.doFetch(
|
|
`${this.getUserRoute('me')}/teams/members`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeamMembers = async (teamId: string, page = 0, perPage = PER_PAGE_DEFAULT) => {
|
|
return this.doFetch(
|
|
`${this.getTeamMembersRoute(teamId)}${buildQueryString({page, per_page: perPage})}`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeamMember = async (teamId: string, userId: string) => {
|
|
return this.doFetch(
|
|
`${this.getTeamMemberRoute(teamId, userId)}`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
addToTeam = async (teamId: string, userId: string) => {
|
|
this.analytics.trackAPI('api_teams_invite_members', {team_id: teamId});
|
|
|
|
const member = {user_id: userId, team_id: teamId};
|
|
return this.doFetch(
|
|
`${this.getTeamMembersRoute(teamId)}`,
|
|
{method: 'post', body: member},
|
|
);
|
|
};
|
|
|
|
joinTeam = async (inviteId: string) => {
|
|
const query = buildQueryString({invite_id: inviteId});
|
|
return this.doFetch(
|
|
`${this.getTeamsRoute()}/members/invite${query}`,
|
|
{method: 'post'},
|
|
);
|
|
};
|
|
|
|
removeFromTeam = async (teamId: string, userId: string) => {
|
|
this.analytics.trackAPI('api_teams_remove_members', {team_id: teamId});
|
|
|
|
return this.doFetch(
|
|
`${this.getTeamMemberRoute(teamId, userId)}`,
|
|
{method: 'delete'},
|
|
);
|
|
};
|
|
|
|
getTeamStats = async (teamId: string) => {
|
|
return this.doFetch(
|
|
`${this.getTeamRoute(teamId)}/stats`,
|
|
{method: 'get'},
|
|
);
|
|
};
|
|
|
|
getTeamIconUrl = (teamId: string, lastTeamIconUpdate: number) => {
|
|
const params: any = {};
|
|
if (lastTeamIconUpdate) {
|
|
params._ = lastTeamIconUpdate;
|
|
}
|
|
|
|
return `${this.getTeamRoute(teamId)}/image${buildQueryString(params)}`;
|
|
};
|
|
};
|
|
|
|
export default ClientTeams;
|