summaryrefslogtreecommitdiffstats
path: root/src/services
diff options
context:
space:
mode:
authorJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2018-11-10 10:06:01 +0100
committerJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2018-11-12 22:38:05 +0100
commit6822a6d6c232ad138ffd866d54b7204938c222a1 (patch)
tree3d78ca6b013a19b3fa9b94ed09e7f5e10f719206 /src/services
parentfaf4e4adea598aafafd36265922e865d8afe260a (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.js127
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))
-
- }
-}