hamzus-ui 0.0.226 → 0.0.228

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hamzus-ui",
3
- "version": "0.0.226",
3
+ "version": "0.0.228",
4
4
  "type": "module",
5
5
  "main": "index.js",
6
6
  "svelte": "index.js",
@@ -1,6 +1,8 @@
1
1
  import { getCookie } from "./clientCookie";
2
2
  import { config } from "./hamzus.config.js";
3
3
 
4
+ let on401Promise = null; // promesse partagée pendant que on401 tourne
5
+
4
6
  export function sendRequest(request) {
5
7
  return new Promise((resolve, reject) => {
6
8
  request = {
@@ -12,55 +14,62 @@ export function sendRequest(request) {
12
14
  ...request
13
15
  }
14
16
 
15
-
16
- const formData = new FormData();
17
-
18
- if (request.data) {
19
- for (const [key, value] of Object.entries(request.data)) {
20
- formData.append(key, value);
17
+ function buildFormData() {
18
+ const formData = new FormData();
19
+ if (request.data) {
20
+ for (const [key, value] of Object.entries(request.data)) {
21
+ formData.append(key, value);
22
+ }
21
23
  }
22
- }
23
- if (request.includeToken) {
24
- const myToken = getCookie(config['sessionTokenName']);
25
-
26
- formData.append(config['sessionTokenName'], myToken)
27
- }
28
-
29
- if (request.formData) {
30
- for (const [key, value] of request.formData.entries()) {
31
- formData.append(key, value);
24
+ if (request.includeToken) {
25
+ const myToken = getCookie(config['sessionTokenName']);
26
+ formData.append(config['sessionTokenName'], myToken)
32
27
  }
28
+ if (request.formData) {
29
+ for (const [key, value] of request.formData.entries()) {
30
+ formData.append(key, value);
31
+ }
32
+ }
33
+ return formData;
33
34
  }
34
35
 
35
- // Création de la requête XHR
36
- var scriptPath = request.url + request.path;
37
- const xhr = new XMLHttpRequest();
38
- xhr.open('POST', scriptPath, true);
39
- xhr.withCredentials = config.requestWithCredentials;
40
-
41
- xhr.onload = function () {
42
-
43
- if (xhr.status === 200) {
36
+ function executeRequest(isRetry = false) {
37
+ var scriptPath = request.url + request.path;
38
+ const xhr = new XMLHttpRequest();
39
+ xhr.open('POST', scriptPath, true);
40
+ xhr.withCredentials = config.requestWithCredentials;
44
41
 
45
-
46
- const response = JSON.parse(xhr.responseText)
47
- resolve(response)
48
- } else if (xhr.status === 400 || xhr.status === 409) {
49
- const response = JSON.parse(xhr.responseText)
50
- resolve(response)
51
- } else if (xhr.status === 401) {
52
- if (config.on401 !== null) {
53
- config.on401()
42
+ xhr.onload = function () {
43
+ if (xhr.status === 200) {
44
+ resolve(JSON.parse(xhr.responseText))
45
+ } else if (xhr.status === 400 || xhr.status === 409) {
46
+ resolve(JSON.parse(xhr.responseText))
47
+ } else if (xhr.status === 401) {
48
+ if (!isRetry && config.on401 != null) {
49
+ if (!on401Promise) {
50
+ // Personne d'autre ne tourne on401, on le lance
51
+ const result = config.on401();
52
+ on401Promise = (result instanceof Promise ? result : Promise.resolve())
53
+ .finally(() => { on401Promise = null; });
54
+ }
55
+ if (config.replayAfter401 === true) {
56
+ // On attend la fin du on401 (le nôtre ou celui d'un autre)
57
+ on401Promise.then(() => executeRequest(true));
58
+ return;
59
+ }
60
+ }
61
+ resolve(false);
54
62
  }
55
- }
63
+ };
56
64
 
57
- resolve(false)
58
- };
65
+ xhr.onerror = function () {
66
+ console.error('Erreur réseau.');
67
+ reject(new Error('Erreur réseau.'));
68
+ };
69
+
70
+ xhr.send(buildFormData());
71
+ }
59
72
 
60
- xhr.onerror = function () {
61
- console.error('Erreur réseau.');
62
- };
63
- // Envoi des données sous forme JSON
64
- xhr.send(formData);
73
+ executeRequest();
65
74
  })
66
75
  }