oasis-chat 0.1.3 → 0.1.5

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/dist/sw.js CHANGED
@@ -2,10 +2,17 @@
2
2
  // 이 파일은 빌드 시 자동으로 TARGET_API가 주입됩니다
3
3
  const TARGET_API = 'https://oasis-dev.haiqv.ai';
4
4
 
5
- self.addEventListener('install', () => {
5
+ self.addEventListener('install', (event) => {
6
+ // 즉시 활성화하고 이전 Service Worker를 대체
6
7
  self.skipWaiting();
7
8
  });
8
9
 
10
+ self.addEventListener('message', (event) => {
11
+ if (event.data && event.data.type === 'SKIP_WAITING') {
12
+ self.skipWaiting();
13
+ }
14
+ });
15
+
9
16
  self.addEventListener('activate', (event) => {
10
17
  event.waitUntil(self.clients.claim());
11
18
  });
@@ -18,13 +25,23 @@ self.addEventListener('fetch', (event) => {
18
25
  // /oasis/... -> /api/...로 변환하여 실제 API 서버에 요청
19
26
  const apiPath = url.pathname.replace('/oasis', '/api');
20
27
 
21
- // 요청을 새로 생성하여 프록시 (body 처리 이슈 방지)
22
- const requestInit = {
23
- method: event.request.method,
24
- headers: event.request.headers,
25
- credentials: 'include',
26
- mode: 'cors',
27
- };
28
+ // 허용된 헤더만 추출 (CORS 관련 문제 방지)
29
+ const headers = new Headers();
30
+ const allowedHeaders = [
31
+ 'accept',
32
+ 'content-type',
33
+ 'authorization',
34
+ 'cookie', // 쿠키 헤더 추가
35
+ 'current-workspace-id',
36
+ 'current-workspace-uuid',
37
+ ];
38
+
39
+ event.request.headers.forEach((value, key) => {
40
+ const lowerKey = key.toLowerCase();
41
+ if (allowedHeaders.includes(lowerKey)) {
42
+ headers.set(key, value);
43
+ }
44
+ });
28
45
 
29
46
  // body가 있는 요청인 경우 (GET, HEAD가 아닌 경우)
30
47
  const hasBody =
@@ -40,13 +57,23 @@ self.addEventListener('fetch', (event) => {
40
57
  .arrayBuffer()
41
58
  .then((body) => {
42
59
  return fetch(`${TARGET_API}${apiPath}${url.search}`, {
43
- ...requestInit,
60
+ method: event.request.method,
61
+ headers: headers,
62
+ credentials: 'include',
63
+ mode: 'cors',
44
64
  body: body.byteLength > 0 ? body : undefined,
45
65
  });
46
66
  })
47
67
  );
48
68
  } else {
49
- event.respondWith(fetch(`${TARGET_API}${apiPath}${url.search}`, requestInit));
69
+ event.respondWith(
70
+ fetch(`${TARGET_API}${apiPath}${url.search}`, {
71
+ method: event.request.method,
72
+ headers: headers,
73
+ credentials: 'include',
74
+ mode: 'cors',
75
+ })
76
+ );
50
77
  }
51
78
  }
52
79
  });