Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 1695 | Rev 1697 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
797 stevensc 1
import axios from 'axios'
2
 
3
export class Request {
4
  #client
5
  #abortController
6
 
853 stevensc 7
  constructor() {
8
    this.#client = axios.create()
801 stevensc 9
 
10
    this.#client.interceptors.request.use(
11
      async (request) => {
12
        const token = window.localStorage.getItem('jwt')
13
 
14
        if (token) {
15
          request.headers.Authorization = 'Bearer ' + token
16
        }
17
 
1188 stevensc 18
        if (request.method === 'get') {
19
          request.headers['Content-Type'] = 'application/json'
20
          return request
21
        }
22
 
801 stevensc 23
        if (['post', 'put', 'delete'].includes(request.method)) {
24
          try {
807 stevensc 25
            const { data: responseData } = await this.#client.get('/csrf')
801 stevensc 26
            const { data, success } = responseData
27
 
28
            if (success) {
29
              request.headers['X-CSRF-TOKEN'] = data
30
              return request
31
            }
32
          } catch (err) {
33
            throw new Error(
34
              `Axios problem with request during pre-flight phase: ${err}.`
35
            )
36
          }
37
        }
38
 
39
        return request
40
      },
41
      (error) => {
42
        return Promise.reject(error)
43
      }
44
    )
45
 
808 stevensc 46
    this.#client.interceptors.response.use(
47
      async (response) => {
48
        const { fatal } = response.data
49
 
50
        if (fatal) {
51
          window.localStorage.removeItem('jwt')
52
          window.localStorage.removeItem('aes')
53
          window.location.reload()
1559 stevensc 54
 
1667 stevensc 55
          return { ...response, data: 'La sesión ha caducado' }
808 stevensc 56
        }
57
 
1667 stevensc 58
        return response
808 stevensc 59
      },
60
      (error) => {
61
        return Promise.reject(error)
62
      }
63
    )
64
 
797 stevensc 65
    this.#abortController = new AbortController()
66
  }
67
 
802 stevensc 68
  setBaseURL(baseURL = '') {
1180 stevensc 69
    if (typeof baseURL !== 'string') {
70
      throw new Error('baseURL must be a string')
71
    }
802 stevensc 72
    this.#client.defaults.baseURL = baseURL
73
  }
74
 
797 stevensc 75
  async MakeRequest(method = 'get', { endpoint, data, params }) {
76
    const config = { ...params }
77
    config.signal = this.#abortController.signal
78
 
79
    const response =
80
      method === 'get' || method === 'delete'
81
        ? await this.#client[method](endpoint, config)
82
        : await this.#client[method](endpoint, data, config)
83
 
805 stevensc 84
    return response
797 stevensc 85
  }
86
 
87
  async get(endpoint, params) {
1696 stevensc 88
    return await this.MakeRequest('get', { endpoint, params }).catch((err) => {
89
      if (axios.isCancel(err)) {
90
        console.log('Request canceled', err)
91
      } else {
92
        throw new Error(err.message)
93
      }
94
    })
797 stevensc 95
  }
96
 
97
  async delete(endpoint, params) {
98
    return await this.MakeRequest('delete', { endpoint, params })
99
  }
100
 
101
  async post(endpoint, data, params) {
102
    return await this.MakeRequest('post', { endpoint, data, params })
103
  }
104
 
105
  async put(endpoint, data, params) {
106
    return await this.MakeRequest('put', { endpoint, data, params })
107
  }
108
 
109
  cancelToken() {
110
    if (!this.#abortController.signal.aborted) {
111
      this.#abortController.abort()
112
    }
113
  }
114
}