123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- /*
- * @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('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));
- }
- };
|