From d2e63cd31a559eabf2e16b2df9d0d8772b5d2ed3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julius=20H=C3=A4rtl?= Date: Wed, 16 Dec 2020 10:41:41 +0100 Subject: [PATCH] Cancel user search requests to avoid duplicate results being added MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- apps/settings/src/store/api.js | 4 ++-- apps/settings/src/store/users.js | 28 ++++++++++++++++++++++++---- 2 files changed, 26 insertions(+), 6 deletions(-) diff --git a/apps/settings/src/store/api.js b/apps/settings/src/store/api.js index ef2a51b2a1..9a03fe68ef 100644 --- a/apps/settings/src/store/api.js +++ b/apps/settings/src/store/api.js @@ -63,8 +63,8 @@ export default { requireAdmin() { return confirmPassword() }, - get(url) { - return axios.get(sanitize(url)) + get(url, options) { + return axios.get(sanitize(url), options) }, post(url, data) { return axios.post(sanitize(url), data) diff --git a/apps/settings/src/store/users.js b/apps/settings/src/store/users.js index e24996305a..3f87f5b004 100644 --- a/apps/settings/src/store/users.js +++ b/apps/settings/src/store/users.js @@ -21,6 +21,7 @@ */ import api from './api' +import axios from '@nextcloud/axios' import { generateOcsUrl } from '@nextcloud/router' const orderGroups = function(groups, orderBy) { @@ -189,6 +190,9 @@ const getters = { }, } +const CancelToken = axios.CancelToken +let searchRequestCancelSource = null + const actions = { /** @@ -203,10 +207,16 @@ const actions = { * @returns {Promise} */ getUsers(context, { offset, limit, search, group }) { + if (searchRequestCancelSource) { + searchRequestCancelSource.cancel('Operation canceled by another search request.') + } + searchRequestCancelSource = CancelToken.source() search = typeof search === 'string' ? search : '' group = typeof group === 'string' ? group : '' if (group !== '') { - return api.get(generateOcsUrl(`cloud/groups/${encodeURIComponent(encodeURIComponent(group))}/users/details?offset=${offset}&limit=${limit}&search=${search}`, 2)) + return api.get(generateOcsUrl(`cloud/groups/${encodeURIComponent(encodeURIComponent(group))}/users/details?offset=${offset}&limit=${limit}&search=${search}`, 2), { + cancelToken: searchRequestCancelSource.token, + }) .then((response) => { if (Object.keys(response.data.ocs.data.users).length > 0) { context.commit('appendUsers', response.data.ocs.data.users) @@ -214,10 +224,16 @@ const actions = { } return false }) - .catch((error) => context.commit('API_FAILURE', error)) + .catch((error) => { + if (!axios.isCancel(error)) { + context.commit('API_FAILURE', error) + } + }) } - return api.get(generateOcsUrl(`cloud/users/details?offset=${offset}&limit=${limit}&search=${search}`, 2)) + return api.get(generateOcsUrl(`cloud/users/details?offset=${offset}&limit=${limit}&search=${search}`, 2), { + cancelToken: searchRequestCancelSource.token, + }) .then((response) => { if (Object.keys(response.data.ocs.data.users).length > 0) { context.commit('appendUsers', response.data.ocs.data.users) @@ -225,7 +241,11 @@ const actions = { } return false }) - .catch((error) => context.commit('API_FAILURE', error)) + .catch((error) => { + if (!axios.isCancel(error)) { + context.commit('API_FAILURE', error) + } + }) }, getGroups(context, { offset, limit, search }) {