import { debounce } from 'lodash'; import { getBackendSrv } from '@grafana/runtime'; import { updateNavIndex } from 'app/core/actions'; import { contextSrv } from 'app/core/core'; import { accessControlQueryParam } from 'app/core/utils/accessControl'; import { AccessControlAction, TeamMember, ThunkResult } from 'app/types'; import { buildNavModel } from './navModel'; import { teamGroupsLoaded, queryChanged, pageChanged, teamLoaded, teamMembersLoaded, teamsLoaded } from './reducers'; export function loadTeams(initial = false): ThunkResult { return async (dispatch, getState) => { const { query, page, perPage } = getState().teams; // Early return if the user cannot list teams if (!contextSrv.hasPermission(AccessControlAction.ActionTeamsRead)) { dispatch(teamsLoaded({ teams: [], totalCount: 0, page: 1, perPage, noTeams: true })); return; } const response = await getBackendSrv().get( '/api/teams/search', accessControlQueryParam({ query, page, perpage: perPage }) ); // We only want to check if there is no teams on the initial request. // A query that returns no teams should not render the empty list banner. let noTeams = false; if (initial) { noTeams = response.teams.length === 0; } dispatch(teamsLoaded({ noTeams, ...response })); }; } const loadTeamsWithDebounce = debounce((dispatch) => dispatch(loadTeams()), 500); export function loadTeam(id: number): ThunkResult { return async (dispatch) => { const response = await getBackendSrv().get(`/api/teams/${id}`, accessControlQueryParam()); dispatch(teamLoaded(response)); dispatch(updateNavIndex(buildNavModel(response))); }; } export function deleteTeam(id: number): ThunkResult { return async (dispatch) => { await getBackendSrv().delete(`/api/teams/${id}`); // Update users permissions in case they lost teams.read with the deletion await contextSrv.fetchUserPermissions(); dispatch(loadTeams()); }; } export function changeQuery(query: string): ThunkResult { return async (dispatch) => { dispatch(queryChanged(query)); loadTeamsWithDebounce(dispatch); }; } export function changePage(page: number): ThunkResult { return async (dispatch) => { dispatch(pageChanged(page)); dispatch(loadTeams()); }; } export function loadTeamMembers(): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; const response = await getBackendSrv().get(`/api/teams/${team.id}/members`); dispatch(teamMembersLoaded(response)); }; } export function addTeamMember(id: number): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; await getBackendSrv().post(`/api/teams/${team.id}/members`, { userId: id }); dispatch(loadTeamMembers()); }; } export function removeTeamMember(id: number): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; await getBackendSrv().delete(`/api/teams/${team.id}/members/${id}`); dispatch(loadTeamMembers()); }; } export function updateTeam(name: string, email: string): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; await getBackendSrv().put(`/api/teams/${team.id}`, { name, email }); dispatch(loadTeam(team.id)); }; } export function loadTeamGroups(): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; const response = await getBackendSrv().get(`/api/teams/${team.id}/groups`); dispatch(teamGroupsLoaded(response)); }; } export function addTeamGroup(groupId: string): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; await getBackendSrv().post(`/api/teams/${team.id}/groups`, { groupId: groupId }); dispatch(loadTeamGroups()); }; } export function removeTeamGroup(groupId: string): ThunkResult { return async (dispatch, getStore) => { const team = getStore().team.team; await getBackendSrv().delete(`/api/teams/${team.id}/groups/${encodeURIComponent(groupId)}`); dispatch(loadTeamGroups()); }; } export function updateTeamMember(member: TeamMember): ThunkResult { return async (dispatch) => { await getBackendSrv().put(`/api/teams/${member.teamId}/members/${member.userId}`, { permission: member.permission, }); dispatch(loadTeamMembers()); }; }