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:
parent
3e770e11f1
commit
6e4a3ff199
3 changed files with 29 additions and 23 deletions
|
@ -2,17 +2,35 @@ import axios from 'axios'
|
|||
import {getToken} from '@/helpers/auth'
|
||||
|
||||
export function HTTPFactory() {
|
||||
return axios.create({
|
||||
baseURL: window.API_URL,
|
||||
const instance = axios.create({baseURL: window.API_URL})
|
||||
|
||||
instance.interceptors.request.use((config) => {
|
||||
// by setting the baseURL fresh for every request
|
||||
// we make sure that it is never outdated in case it is updated
|
||||
config.baseURL = window.API_URL
|
||||
|
||||
return config
|
||||
})
|
||||
|
||||
return instance
|
||||
}
|
||||
|
||||
export function AuthenticatedHTTPFactory(token = getToken()) {
|
||||
return axios.create({
|
||||
baseURL: window.API_URL,
|
||||
headers: {
|
||||
Authorization: `Bearer ${token}`,
|
||||
export function AuthenticatedHTTPFactory() {
|
||||
const instance = HTTPFactory()
|
||||
|
||||
instance.interceptors.request.use((config) => {
|
||||
config.headers = {
|
||||
...config.headers,
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
}
|
||||
|
||||
// Set the default auth header if we have a token
|
||||
const token = getToken()
|
||||
if (token !== null) {
|
||||
config.headers['Authorization'] = `Bearer ${token}`
|
||||
}
|
||||
return config
|
||||
})
|
||||
|
||||
return instance
|
||||
}
|
||||
|
|
|
@ -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 : '',
|
||||
|
|
|
@ -215,7 +215,7 @@ export default {
|
|||
return
|
||||
}
|
||||
|
||||
const HTTP = AuthenticatedHTTPFactory(jwt)
|
||||
const HTTP = AuthenticatedHTTPFactory()
|
||||
try {
|
||||
const response = await HTTP.get('user')
|
||||
const info = new UserModel(response.data)
|
||||
|
|
Loading…
Reference in a new issue