diff options
author | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-11-10 10:06:01 +0100 |
---|---|---|
committer | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-11-12 22:38:05 +0100 |
commit | 6822a6d6c232ad138ffd866d54b7204938c222a1 (patch) | |
tree | 3d78ca6b013a19b3fa9b94ed09e7f5e10f719206 /src/services | |
parent | faf4e4adea598aafafd36265922e865d8afe260a (diff) |
Cleanup code with Property Mixin
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'src/services')
-rw-r--r-- | src/services/api.js | 127 |
1 files changed, 0 insertions, 127 deletions
diff --git a/src/services/api.js b/src/services/api.js deleted file mode 100644 index ac881b4a..00000000 --- a/src/services/api.js +++ /dev/null @@ -1,127 +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)) - }, - all(promises) { - return axios.all(promises) - .then((response) => Promise.resolve(response)) - .catch((error) => Promise.reject(error)) - - } -} |