1
0

fix: authenticate per request (#2258)

Co-authored-by: Dominik Pschenitschni <mail@celement.de>
Reviewed-on: https://kolaente.dev/vikunja/frontend/pulls/2258
Reviewed-by: konrad <k@knt.li>
Co-authored-by: Dominik Pschenitschni <dpschen@noreply.kolaente.de>
Co-committed-by: Dominik Pschenitschni <dpschen@noreply.kolaente.de>
This commit is contained in:
Dominik Pschenitschni
2022-09-04 14:30:11 +00:00
committed by konrad
parent 3e770e11f1
commit 6e4a3ff199
3 changed files with 29 additions and 23 deletions

View File

@ -1,6 +1,5 @@
import axios from 'axios'
import {objectToSnakeCase} from '@/helpers/case'
import {getToken} from '@/helpers/auth'
import {AuthenticatedHTTPFactory} from '@/http-common'
function convertObject(o) {
if (o instanceof Date) {
@ -56,12 +55,7 @@ export default class AbstractService {
* @param [paths] An object with all paths. Default values are specified above.
*/
constructor(paths) {
this.http = axios.create({
baseURL: window.API_URL,
headers: {
'Content-Type': 'application/json',
},
})
this.http = AuthenticatedHTTPFactory()
// Set the interceptors to process every request
this.http.interceptors.request.use((config) => {
@ -88,12 +82,6 @@ export default class AbstractService {
return config
})
// Set the default auth header if we have a token
const token = getToken()
if (token !== null) {
this.http.defaults.headers.common['Authorization'] = `Bearer ${token}`
}
if (paths) {
this.paths = {
create: paths.create !== undefined ? paths.create : '',