diff options
author | Jessica <jessica@Absolventas-MacBook-Pro.local> | 2018-08-13 19:24:27 +0200 |
---|---|---|
committer | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-08-28 15:33:46 +0200 |
commit | 8505db5262f11033534ad8e7c4feecf5fe36271d (patch) | |
tree | 8f9cd9ded8e76984644a3d1ea78a0a9758fcf967 /src/services | |
parent | 5e1a74a21cc71b53d51eb6836f12cb078fd53307 (diff) |
added group to sharee so to distinguish groups and users and decide which icon to display
Diffstat (limited to 'src/services')
-rw-r--r-- | src/services/api.js.orig | 130 |
1 files changed, 0 insertions, 130 deletions
diff --git a/src/services/api.js.orig b/src/services/api.js.orig deleted file mode 100644 index 511e5321..00000000 --- a/src/services/api.js.orig +++ /dev/null @@ -1,130 +0,0 @@ -/* - * @copyright Copyright (c) 2018 John Molakvoæ <skjnldsv@protonmail.com> - * - * @author John Molakvoæ <skjnldsv@protonmail.com> - * - * @license GNU AGPL version 3 or any later version - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU Affero General Public License as - * published by the Free Software Foundation, either version 3 of the - * License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Affero General Public License for more details. - * - * You should have received a copy of the GNU Affero General Public License - * along with this program. If not, see <http://www.gnu.org/licenses/>. - * - */ - -import axios from 'axios' - -const requestToken = document.getElementsByTagName('head')[0].getAttribute('data-requesttoken') -const tokenHeaders = { headers: { requesttoken: requestToken } } - -const sanitize = function(url) { - return url.replace(/\/$/, '') // Remove last url slash -} - -export default { - - /** - * This Promise is used to chain a request that require an admin password confirmation - * Since chaining Promise have a very precise behavior concerning catch and then, - * you'll need to be careful when using it. - * e.g - * // store - * action(context) { - * return api.requireAdmin().then((response) => { - * return api.get('url') - * .then((response) => {API success}) - * .catch((error) => {API failure}); - * }).catch((error) => {requireAdmin failure}); - * } - * // vue - * this.$store.dispatch('action').then(() => {always executed}) - * - * Since Promise.then().catch().then() will always execute the last then - * this.$store.dispatch('action').then will always be executed - * - * If you want requireAdmin failure to also catch the API request failure - * you will need to throw a new error in the api.get.catch() - * - * e.g - * api.requireAdmin().then((response) => { - * api.get('url') - * .then((response) => {API success}) - * .catch((error) => {throw error;}); - * }).catch((error) => {requireAdmin OR API failure}); - * - * @returns {Promise} - */ - requireAdmin() { - return new Promise(function(resolve, reject) { - // TODO: migrate the OC.dialog to Vue and avoid this mess - // wait for password confirmation - let passwordTimeout - let waitForpassword = function() { - if (OC.PasswordConfirmation.requiresPasswordConfirmation()) { - passwordTimeout = setTimeout(waitForpassword, 500) - return - } - clearTimeout(passwordTimeout) - clearTimeout(promiseTimeout) - resolve() - } - - // automatically reject after 5s if not resolved - let promiseTimeout = setTimeout(() => { - clearTimeout(passwordTimeout) - // close dialog - if (document.getElementsByClassName('oc-dialog-close').length > 0) { - document.getElementsByClassName('oc-dialog-close')[0].click() - } - OC.Notification.showTemporary(t('settings', 'You did not enter the password in time')) - reject(new Error('Password request cancelled')) - }, 7000) - - // request password - OC.PasswordConfirmation.requirePasswordConfirmation() - waitForpassword() - }) - }, - get(url) { - return axios.get(sanitize(url), tokenHeaders) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - }, - post(url, data) { - return axios.post(sanitize(url), data, tokenHeaders) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - }, - patch(url, data) { - return axios.patch(sanitize(url), data, tokenHeaders) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - }, - put(url, data) { - return axios.put(sanitize(url), data, tokenHeaders) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - }, - delete(url, data) { - return axios.delete(sanitize(url), { data: data, headers: tokenHeaders.headers }) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) -<<<<<<< HEAD - }, - all(promises) { - return axios.all(promises) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - -======= ->>>>>>> added api.js with axios and worked on getting the matching users and groups based on input - } -} |