@omnistreamai/data-adapter-webdav 0.1.0

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.
@@ -0,0 +1,59 @@
1
+ import { AdapterType, PaginatedResult, QueryOptions, RemoteAdapter, ServiceConfig } from "@omnistreamai/data-core";
2
+
3
+ //#region src/webdav-adapter.d.ts
4
+
5
+ /**
6
+ * WebDAV adapter implementation
7
+ */
8
+ declare class WebDAVAdapter implements RemoteAdapter {
9
+ readonly type = AdapterType.Remote;
10
+ readonly name = "WebDAVAdapter";
11
+ private service;
12
+ /**
13
+ * Set service configuration
14
+ */
15
+ setService(service: ServiceConfig): void;
16
+ /**
17
+ * Get request headers
18
+ */
19
+ private getHeaders;
20
+ /**
21
+ * Build URL
22
+ */
23
+ private buildUrl;
24
+ /**
25
+ * Send request
26
+ */
27
+ private request;
28
+ /**
29
+ * Initialize store
30
+ */
31
+ initStore(storeName: string, _indexes?: string[], _idKey?: string): Promise<void>;
32
+ /**
33
+ * Add data
34
+ */
35
+ add<T extends Record<string, unknown>>(storeName: string, data: T, idKey?: string): Promise<T>;
36
+ /**
37
+ * Update data
38
+ */
39
+ update<T extends Record<string, unknown>>(storeName: string, id: string, data: Partial<T>, idKey?: string): Promise<T>;
40
+ /**
41
+ * Delete data
42
+ */
43
+ delete(storeName: string, id: string, _idKey?: string): Promise<void>;
44
+ /**
45
+ * Get data by ID
46
+ */
47
+ getData<T extends Record<string, unknown>>(storeName: string, id: string, _idKey?: string): Promise<T | null>;
48
+ /**
49
+ * Get list data (with pagination support)
50
+ */
51
+ getList<T extends Record<string, unknown>>(storeName: string, options?: QueryOptions<T>, _idKey?: string): Promise<PaginatedResult<T>>;
52
+ /**
53
+ * Clear store
54
+ */
55
+ clear(storeName: string): Promise<void>;
56
+ }
57
+ //#endregion
58
+ export { WebDAVAdapter };
59
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../src/webdav-adapter.ts"],"sourcesContent":[],"mappings":";;;;;;AAYA;AACe,cADF,aAAA,YAAyB,aACvB,CAAA;EAQO,SAAA,IAAA,GARP,WAAA,CAAA,MAAA;EA4GV,SAAA,IAAA,GAAA,eAAA;EAkBiB,QAAA,OAAA;EAEZ;;;EAiBe,UAAA,CAAA,OAAA,EAzIH,aAyIG,CAAA,EAAA,IAAA;EAGP;;;EAEb,QAAA,UAAA;EAsBiE;;;EAejE,QAAA,QAAA;EAWqB;;;EAIG,QAAA,OAAA;EAAhB;;;EA3MyB,SAAA,CAAA,SAAA,EAAA,MAAA,EAAA,QAAA,CAAA,EAAA,MAAA,EAAA,EAAA,MAAA,CAAA,EAAA,MAAA,CAAA,EA6GjC,OA7GiC,CAAA,IAAA,CAAA;EAAa;;;gBA+H7B,kDAEZ,oBAEL,QAAQ;;;;mBAeY,8DAGf,QAAQ,qBAEb,QAAQ;;;;0DAsByD;;;;oBAW5C,0EAIrB,QAAQ;;;;oBAWa,sDAEb,aAAa,sBAErB,QAAQ,gBAAgB;;;;4BAoDK"}
package/dist/index.mjs ADDED
@@ -0,0 +1,162 @@
1
+ import { AdapterType, AuthType } from "@omnistreamai/data-core";
2
+
3
+ //#region src/webdav-adapter.ts
4
+ /**
5
+ * WebDAV adapter implementation
6
+ */
7
+ var WebDAVAdapter = class {
8
+ type = AdapterType.Remote;
9
+ name = "WebDAVAdapter";
10
+ service = null;
11
+ /**
12
+ * Set service configuration
13
+ */
14
+ setService(service) {
15
+ this.service = service;
16
+ }
17
+ /**
18
+ * Get request headers
19
+ */
20
+ getHeaders() {
21
+ const headers = { "Content-Type": "application/json" };
22
+ if (!this.service?.authentication) return headers;
23
+ const { authentication } = this.service;
24
+ switch (authentication.authType) {
25
+ case AuthType.Token:
26
+ if (authentication.token) headers["Authorization"] = `${authentication.token.token_type} ${authentication.token.access_token}`;
27
+ break;
28
+ case AuthType.Bearer:
29
+ if (authentication.bearer) headers["Authorization"] = `Bearer ${authentication.bearer}`;
30
+ break;
31
+ case AuthType.Basic:
32
+ if (authentication.username && authentication.password) headers["Authorization"] = `Basic ${btoa(`${authentication.username}:${authentication.password}`)}`;
33
+ break;
34
+ }
35
+ return headers;
36
+ }
37
+ /**
38
+ * Build URL
39
+ */
40
+ buildUrl(storeName, id) {
41
+ if (!this.service) throw new Error("Service not configured. Call setService() first.");
42
+ const baseUrl = this.service.endpoint.replace(/\/$/, "");
43
+ const storePath = `/${storeName}`;
44
+ if (id) return `${baseUrl}${storePath}/${id}`;
45
+ return `${baseUrl}${storePath}`;
46
+ }
47
+ /**
48
+ * Send request
49
+ */
50
+ async request(url, options = {}) {
51
+ const response = await fetch(url, {
52
+ ...options,
53
+ headers: {
54
+ ...this.getHeaders(),
55
+ ...options.headers
56
+ }
57
+ });
58
+ if (!response.ok) {
59
+ if (response.status === 404) return null;
60
+ throw new Error(`HTTP error! status: ${response.status}`);
61
+ }
62
+ const text = await response.text();
63
+ if (!text) return null;
64
+ try {
65
+ return JSON.parse(text);
66
+ } catch {
67
+ return null;
68
+ }
69
+ }
70
+ /**
71
+ * Initialize store
72
+ */
73
+ async initStore(storeName, _indexes = [], _idKey = "id") {
74
+ const url = this.buildUrl(storeName);
75
+ const response = await fetch(url, {
76
+ method: "MKCOL",
77
+ headers: this.getHeaders()
78
+ });
79
+ if (!response.ok && response.status !== 409) throw new Error(`Failed to create store: ${response.statusText}`);
80
+ }
81
+ /**
82
+ * Add data
83
+ */
84
+ async add(storeName, data, idKey = "id") {
85
+ const id = String(data[idKey]);
86
+ const url = this.buildUrl(storeName, id);
87
+ return await this.request(url, {
88
+ method: "PUT",
89
+ body: JSON.stringify(data)
90
+ }) ?? data;
91
+ }
92
+ /**
93
+ * Update data
94
+ */
95
+ async update(storeName, id, data, idKey = "id") {
96
+ const existing = await this.getData(storeName, id, idKey);
97
+ if (!existing) throw new Error(`Data with id ${id} not found`);
98
+ const updated = {
99
+ ...existing,
100
+ ...data
101
+ };
102
+ const url = this.buildUrl(storeName, id);
103
+ return await this.request(url, {
104
+ method: "PUT",
105
+ body: JSON.stringify(updated)
106
+ }) ?? updated;
107
+ }
108
+ /**
109
+ * Delete data
110
+ */
111
+ async delete(storeName, id, _idKey = "id") {
112
+ const url = this.buildUrl(storeName, id);
113
+ await this.request(url, { method: "DELETE" });
114
+ }
115
+ /**
116
+ * Get data by ID
117
+ */
118
+ async getData(storeName, id, _idKey = "id") {
119
+ const url = this.buildUrl(storeName, id);
120
+ return await this.request(url, { method: "GET" });
121
+ }
122
+ /**
123
+ * Get list data (with pagination support)
124
+ */
125
+ async getList(storeName, options = {}, _idKey = "id") {
126
+ const url = this.buildUrl(storeName);
127
+ const params = new URLSearchParams();
128
+ if (options.page !== void 0) params.append("page", String(options.page));
129
+ if (options.limit !== void 0) params.append("limit", String(options.limit));
130
+ if (options.where) params.append("where", JSON.stringify(options.where));
131
+ const queryString = params.toString();
132
+ const fullUrl = queryString ? `${url}?${queryString}` : url;
133
+ const result = await this.request(fullUrl, { method: "GET" });
134
+ if (result && "data" in result) return result;
135
+ if (Array.isArray(result)) {
136
+ const dataArray = result;
137
+ return {
138
+ data: dataArray,
139
+ totalCount: dataArray.length,
140
+ page: options.page ?? 1,
141
+ limit: options.limit ?? dataArray.length
142
+ };
143
+ }
144
+ return {
145
+ data: [],
146
+ totalCount: 0,
147
+ page: options.page ?? 1,
148
+ limit: options.limit ?? 10
149
+ };
150
+ }
151
+ /**
152
+ * Clear store
153
+ */
154
+ async clear(storeName) {
155
+ const url = this.buildUrl(storeName);
156
+ await this.request(url, { method: "DELETE" });
157
+ }
158
+ };
159
+
160
+ //#endregion
161
+ export { WebDAVAdapter };
162
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":["headers: Record<string, string>"],"sources":["../src/webdav-adapter.ts"],"sourcesContent":["import {\n AdapterType,\n type RemoteAdapter,\n type QueryOptions,\n type PaginatedResult,\n type ServiceConfig,\n AuthType,\n} from '@omnistreamai/data-core';\n\n/**\n * WebDAV adapter implementation\n */\nexport class WebDAVAdapter implements RemoteAdapter {\n readonly type = AdapterType.Remote;\n readonly name = 'WebDAVAdapter';\n\n private service: ServiceConfig | null = null;\n\n /**\n * Set service configuration\n */\n setService(service: ServiceConfig): void {\n this.service = service;\n }\n\n /**\n * Get request headers\n */\n private getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n if (!this.service?.authentication) {\n return headers;\n }\n\n const { authentication } = this.service;\n\n switch (authentication.authType) {\n case AuthType.Token:\n if (authentication.token) {\n headers['Authorization'] = `${authentication.token.token_type} ${authentication.token.access_token}`;\n }\n break;\n case AuthType.Bearer:\n if (authentication.bearer) {\n headers['Authorization'] = `Bearer ${authentication.bearer}`;\n }\n break;\n case AuthType.Basic:\n if (authentication.username && authentication.password) {\n const credentials = btoa(`${authentication.username}:${authentication.password}`);\n headers['Authorization'] = `Basic ${credentials}`;\n }\n break;\n }\n\n return headers;\n }\n\n /**\n * Build URL\n */\n private buildUrl(storeName: string, id?: string): string {\n if (!this.service) {\n throw new Error('Service not configured. Call setService() first.');\n }\n\n const baseUrl = this.service.endpoint.replace(/\\/$/, '');\n const storePath = `/${storeName}`;\n \n if (id) {\n return `${baseUrl}${storePath}/${id}`;\n }\n \n return `${baseUrl}${storePath}`;\n }\n\n /**\n * Send request\n */\n private async request<T>(\n url: string,\n options: RequestInit = {}\n ): Promise<T> {\n const response = await fetch(url, {\n ...options,\n headers: {\n ...this.getHeaders(),\n ...options.headers,\n },\n });\n\n if (!response.ok) {\n if (response.status === 404) {\n return null as T;\n }\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n // If response is empty, return null\n const text = await response.text();\n if (!text) {\n return null as T;\n }\n\n try {\n return JSON.parse(text) as T;\n } catch {\n return null as T;\n }\n }\n\n /**\n * Initialize store\n */\n async initStore(\n storeName: string,\n _indexes: string[] = [],\n _idKey: string = 'id'\n ): Promise<void> {\n const url = this.buildUrl(storeName);\n \n // Try to create directory (using MKCOL method)\n const response = await fetch(url, {\n method: 'MKCOL',\n headers: this.getHeaders(),\n });\n\n // If directory already exists (409 Conflict), ignore error\n if (!response.ok && response.status !== 409) {\n throw new Error(`Failed to create store: ${response.statusText}`);\n }\n }\n\n /**\n * Add data\n */\n async add<T extends Record<string, unknown>>(\n storeName: string,\n data: T,\n idKey: string = 'id'\n ): Promise<T> {\n const id = String(data[idKey]);\n const url = this.buildUrl(storeName, id);\n\n const result = await this.request<T>(url, {\n method: 'PUT',\n body: JSON.stringify(data),\n });\n\n return result ?? data;\n }\n\n /**\n * Update data\n */\n async update<T extends Record<string, unknown>>(\n storeName: string,\n id: string,\n data: Partial<T>,\n idKey: string = 'id'\n ): Promise<T> {\n // First get existing data\n const existing = await this.getData<T>(storeName, id, idKey);\n if (!existing) {\n throw new Error(`Data with id ${id} not found`);\n }\n\n // Merge data\n const updated = { ...existing, ...data };\n const url = this.buildUrl(storeName, id);\n\n const result = await this.request<T>(url, {\n method: 'PUT',\n body: JSON.stringify(updated),\n });\n\n return result ?? updated;\n }\n\n /**\n * Delete data\n */\n async delete(storeName: string, id: string, _idKey: string = 'id'): Promise<void> {\n const url = this.buildUrl(storeName, id);\n\n await this.request(url, {\n method: 'DELETE',\n });\n }\n\n /**\n * Get data by ID\n */\n async getData<T extends Record<string, unknown>>(\n storeName: string,\n id: string,\n _idKey: string = 'id'\n ): Promise<T | null> {\n const url = this.buildUrl(storeName, id);\n\n return await this.request<T | null>(url, {\n method: 'GET',\n });\n }\n\n /**\n * Get list data (with pagination support)\n */\n async getList<T extends Record<string, unknown>>(\n storeName: string,\n options: QueryOptions<T> = {},\n _idKey: string = 'id'\n ): Promise<PaginatedResult<T>> {\n const url = this.buildUrl(storeName);\n \n // Build query parameters\n const params = new URLSearchParams();\n if (options.page !== undefined) {\n params.append('page', String(options.page));\n }\n if (options.limit !== undefined) {\n params.append('limit', String(options.limit));\n }\n if (options.where) {\n params.append('where', JSON.stringify(options.where));\n }\n\n const queryString = params.toString();\n const fullUrl = queryString ? `${url}?${queryString}` : url;\n\n const result = await this.request<PaginatedResult<T>>(fullUrl, {\n method: 'GET',\n });\n\n // If server returns non-paginated format, convert to paginated format\n if (result && 'data' in result) {\n return result;\n }\n\n // If return is an array, convert to paginated format\n if (Array.isArray(result)) {\n const dataArray = result as T[];\n return {\n data: dataArray,\n totalCount: dataArray.length,\n page: options.page ?? 1,\n limit: options.limit ?? dataArray.length,\n };\n }\n\n // Default return empty result\n return {\n data: [],\n totalCount: 0,\n page: options.page ?? 1,\n limit: options.limit ?? 10,\n };\n }\n\n\n\n /**\n * Clear store\n */\n async clear(storeName: string): Promise<void> {\n const url = this.buildUrl(storeName);\n\n await this.request(url, {\n method: 'DELETE',\n });\n }\n}\n\n\n"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,21 @@
1
+ {
2
+ "name": "@omnistreamai/data-adapter-webdav",
3
+ "version": "0.1.0",
4
+ "type": "module",
5
+ "main": "./dist/index.js",
6
+ "types": "./dist/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "types": "./dist/index.d.ts",
10
+ "import": "./dist/index.js"
11
+ }
12
+ },
13
+ "dependencies": {
14
+ "@omnistreamai/data-core": "0.1.0"
15
+ },
16
+ "scripts": {
17
+ "build": "tsdown",
18
+ "test": "vitest run",
19
+ "type-check": "tsc --noEmit"
20
+ }
21
+ }
package/src/index.ts ADDED
@@ -0,0 +1,3 @@
1
+ export * from './webdav-adapter.js';
2
+
3
+
@@ -0,0 +1,301 @@
1
+ import { describe, it, expect, beforeEach, vi } from 'vitest';
2
+ import { WebDAVAdapter } from './webdav-adapter.js';
3
+ import { AdapterType, AuthType, type ServiceConfig } from '@omnistreamai/data-core';
4
+
5
+ // Mock fetch
6
+ global.fetch = vi.fn();
7
+
8
+ describe('WebDAVAdapter', () => {
9
+ let adapter: WebDAVAdapter;
10
+ const storeName = 'test-store';
11
+
12
+ beforeEach(() => {
13
+ adapter = new WebDAVAdapter();
14
+ vi.clearAllMocks();
15
+ });
16
+
17
+ describe('基本属性', () => {
18
+ it('应该是远程适配器', () => {
19
+ expect(adapter.type).toBe(AdapterType.Remote);
20
+ expect(adapter.name).toBe('WebDAVAdapter');
21
+ });
22
+ });
23
+
24
+ describe('setService', () => {
25
+ it('应该能够设置服务配置', () => {
26
+ const service: ServiceConfig = {
27
+ endpoint: 'https://webdav.example.com/data',
28
+ authentication: {
29
+ authType: AuthType.Token,
30
+ token: {
31
+ access_token: 'test-token',
32
+ token_type: 'Bearer',
33
+ },
34
+ },
35
+ };
36
+
37
+ adapter.setService(service);
38
+ expect(adapter).toBeDefined();
39
+ });
40
+ });
41
+
42
+ describe('initStore', () => {
43
+ it('应该能够初始化存储', async () => {
44
+ const service: ServiceConfig = {
45
+ endpoint: 'https://webdav.example.com/data',
46
+ };
47
+ adapter.setService(service);
48
+
49
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
50
+ ok: true,
51
+ status: 201,
52
+ } as Response);
53
+
54
+ await adapter.initStore(storeName, ['username'], 'id');
55
+ expect(global.fetch).toHaveBeenCalled();
56
+ });
57
+ });
58
+
59
+ describe('add', () => {
60
+ it('应该能够添加数据', async () => {
61
+ const service: ServiceConfig = {
62
+ endpoint: 'https://webdav.example.com/data',
63
+ authentication: {
64
+ authType: AuthType.Token,
65
+ token: {
66
+ access_token: 'test-token',
67
+ token_type: 'Bearer',
68
+ },
69
+ },
70
+ };
71
+ adapter.setService(service);
72
+
73
+ const data = {
74
+ id: '1',
75
+ username: 'test-user',
76
+ email: 'test@example.com',
77
+ };
78
+
79
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
80
+ ok: true,
81
+ status: 201,
82
+ text: async () => JSON.stringify(data),
83
+ json: async () => data,
84
+ } as unknown as Response);
85
+
86
+ const result = await adapter.add(storeName, data, 'id');
87
+ expect(result).toEqual(data);
88
+ expect(global.fetch).toHaveBeenCalled();
89
+ });
90
+ });
91
+
92
+ describe('getData', () => {
93
+ it('应该能够根据 ID 获取数据', async () => {
94
+ const service: ServiceConfig = {
95
+ endpoint: 'https://webdav.example.com/data',
96
+ };
97
+ adapter.setService(service);
98
+
99
+ const data = {
100
+ id: '1',
101
+ username: 'test-user',
102
+ email: 'test@example.com',
103
+ };
104
+
105
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
106
+ ok: true,
107
+ status: 200,
108
+ text: async () => JSON.stringify(data),
109
+ json: async () => data,
110
+ } as unknown as Response);
111
+
112
+ const result = await adapter.getData(storeName, '1', 'id');
113
+ expect(result).toEqual(data);
114
+ });
115
+
116
+ it('当数据不存在时应该返回 null', async () => {
117
+ const service: ServiceConfig = {
118
+ endpoint: 'https://webdav.example.com/data',
119
+ };
120
+ adapter.setService(service);
121
+
122
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
123
+ ok: false,
124
+ status: 404,
125
+ text: async () => '',
126
+ } as unknown as Response);
127
+
128
+ const result = await adapter.getData(storeName, 'non-existent', 'id');
129
+ expect(result).toBeNull();
130
+ });
131
+ });
132
+
133
+ describe('getList', () => {
134
+ it('应该能够获取列表数据并返回分页结果', async () => {
135
+ const service: ServiceConfig = {
136
+ endpoint: 'https://webdav.example.com/data',
137
+ };
138
+ adapter.setService(service);
139
+
140
+ const data = [
141
+ { id: '1', username: 'user1' },
142
+ { id: '2', username: 'user2' },
143
+ ];
144
+
145
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
146
+ ok: true,
147
+ status: 200,
148
+ text: async () => JSON.stringify({
149
+ data,
150
+ totalCount: 2,
151
+ page: 1,
152
+ limit: 10,
153
+ }),
154
+ json: async () => ({
155
+ data,
156
+ totalCount: 2,
157
+ page: 1,
158
+ limit: 10,
159
+ }),
160
+ } as unknown as Response);
161
+
162
+ const result = await adapter.getList(storeName, undefined, 'id');
163
+ expect(result.data).toEqual(data);
164
+ expect(result.totalCount).toBe(2);
165
+ expect(result.page).toBe(1);
166
+ expect(result.limit).toBe(10);
167
+ });
168
+
169
+ it('应该支持分页查询', async () => {
170
+ const service: ServiceConfig = {
171
+ endpoint: 'https://webdav.example.com/data',
172
+ };
173
+ adapter.setService(service);
174
+
175
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
176
+ ok: true,
177
+ status: 200,
178
+ text: async () => JSON.stringify({
179
+ data: [],
180
+ totalCount: 100,
181
+ page: 2,
182
+ limit: 10,
183
+ }),
184
+ json: async () => ({
185
+ data: [],
186
+ totalCount: 100,
187
+ page: 2,
188
+ limit: 10,
189
+ }),
190
+ } as unknown as Response);
191
+
192
+ const result = await adapter.getList(storeName, { page: 2, limit: 10 }, 'id');
193
+ expect(result.page).toBe(2);
194
+ expect(result.limit).toBe(10);
195
+ expect(result.totalCount).toBe(100);
196
+ });
197
+
198
+ it('应该支持条件查询', async () => {
199
+ const service: ServiceConfig = {
200
+ endpoint: 'https://webdav.example.com/data',
201
+ };
202
+ adapter.setService(service);
203
+
204
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
205
+ ok: true,
206
+ status: 200,
207
+ text: async () => JSON.stringify({
208
+ data: [{ id: '1', username: 'user1' }],
209
+ totalCount: 1,
210
+ page: 1,
211
+ limit: 10,
212
+ }),
213
+ json: async () => ({
214
+ data: [{ id: '1', username: 'user1' }],
215
+ totalCount: 1,
216
+ page: 1,
217
+ limit: 10,
218
+ }),
219
+ } as unknown as Response);
220
+
221
+ const result = await adapter.getList(storeName, { where: { username: 'user1' } }, 'id');
222
+ expect(result.data).toHaveLength(1);
223
+ expect(result.data[0]?.username).toBe('user1');
224
+ });
225
+ });
226
+
227
+ describe('update', () => {
228
+ it('应该能够更新数据', async () => {
229
+ const service: ServiceConfig = {
230
+ endpoint: 'https://webdav.example.com/data',
231
+ };
232
+ adapter.setService(service);
233
+
234
+ const existingData = {
235
+ id: '1',
236
+ username: 'test-user',
237
+ email: 'test@example.com',
238
+ };
239
+
240
+ const updatedData = {
241
+ id: '1',
242
+ username: 'test-user',
243
+ email: 'updated@example.com',
244
+ };
245
+
246
+ (global.fetch as ReturnType<typeof vi.fn>)
247
+ .mockResolvedValueOnce({
248
+ ok: true,
249
+ status: 200,
250
+ text: async () => JSON.stringify(existingData),
251
+ json: async () => existingData,
252
+ } as unknown as Response)
253
+ .mockResolvedValueOnce({
254
+ ok: true,
255
+ status: 200,
256
+ text: async () => JSON.stringify(updatedData),
257
+ json: async () => updatedData,
258
+ } as unknown as Response);
259
+
260
+ const result = await adapter.update(storeName, '1', { email: 'updated@example.com' }, 'id');
261
+ expect(result.email).toBe('updated@example.com');
262
+ });
263
+ });
264
+
265
+ describe('delete', () => {
266
+ it('应该能够删除数据', async () => {
267
+ const service: ServiceConfig = {
268
+ endpoint: 'https://webdav.example.com/data',
269
+ };
270
+ adapter.setService(service);
271
+
272
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
273
+ ok: true,
274
+ status: 200,
275
+ text: async () => '',
276
+ } as unknown as Response);
277
+
278
+ await adapter.delete(storeName, '1', 'id');
279
+ expect(global.fetch).toHaveBeenCalled();
280
+ });
281
+ });
282
+
283
+ describe('clear', () => {
284
+ it('应该能够清空存储', async () => {
285
+ const service: ServiceConfig = {
286
+ endpoint: 'https://webdav.example.com/data',
287
+ };
288
+ adapter.setService(service);
289
+
290
+ (global.fetch as ReturnType<typeof vi.fn>).mockResolvedValueOnce({
291
+ ok: true,
292
+ status: 200,
293
+ text: async () => '',
294
+ } as unknown as Response);
295
+
296
+ await adapter.clear(storeName);
297
+ expect(global.fetch).toHaveBeenCalled();
298
+ });
299
+ });
300
+ });
301
+
@@ -0,0 +1,277 @@
1
+ import {
2
+ AdapterType,
3
+ type RemoteAdapter,
4
+ type QueryOptions,
5
+ type PaginatedResult,
6
+ type ServiceConfig,
7
+ AuthType,
8
+ } from '@omnistreamai/data-core';
9
+
10
+ /**
11
+ * WebDAV adapter implementation
12
+ */
13
+ export class WebDAVAdapter implements RemoteAdapter {
14
+ readonly type = AdapterType.Remote;
15
+ readonly name = 'WebDAVAdapter';
16
+
17
+ private service: ServiceConfig | null = null;
18
+
19
+ /**
20
+ * Set service configuration
21
+ */
22
+ setService(service: ServiceConfig): void {
23
+ this.service = service;
24
+ }
25
+
26
+ /**
27
+ * Get request headers
28
+ */
29
+ private getHeaders(): Record<string, string> {
30
+ const headers: Record<string, string> = {
31
+ 'Content-Type': 'application/json',
32
+ };
33
+
34
+ if (!this.service?.authentication) {
35
+ return headers;
36
+ }
37
+
38
+ const { authentication } = this.service;
39
+
40
+ switch (authentication.authType) {
41
+ case AuthType.Token:
42
+ if (authentication.token) {
43
+ headers['Authorization'] = `${authentication.token.token_type} ${authentication.token.access_token}`;
44
+ }
45
+ break;
46
+ case AuthType.Bearer:
47
+ if (authentication.bearer) {
48
+ headers['Authorization'] = `Bearer ${authentication.bearer}`;
49
+ }
50
+ break;
51
+ case AuthType.Basic:
52
+ if (authentication.username && authentication.password) {
53
+ const credentials = btoa(`${authentication.username}:${authentication.password}`);
54
+ headers['Authorization'] = `Basic ${credentials}`;
55
+ }
56
+ break;
57
+ }
58
+
59
+ return headers;
60
+ }
61
+
62
+ /**
63
+ * Build URL
64
+ */
65
+ private buildUrl(storeName: string, id?: string): string {
66
+ if (!this.service) {
67
+ throw new Error('Service not configured. Call setService() first.');
68
+ }
69
+
70
+ const baseUrl = this.service.endpoint.replace(/\/$/, '');
71
+ const storePath = `/${storeName}`;
72
+
73
+ if (id) {
74
+ return `${baseUrl}${storePath}/${id}`;
75
+ }
76
+
77
+ return `${baseUrl}${storePath}`;
78
+ }
79
+
80
+ /**
81
+ * Send request
82
+ */
83
+ private async request<T>(
84
+ url: string,
85
+ options: RequestInit = {}
86
+ ): Promise<T> {
87
+ const response = await fetch(url, {
88
+ ...options,
89
+ headers: {
90
+ ...this.getHeaders(),
91
+ ...options.headers,
92
+ },
93
+ });
94
+
95
+ if (!response.ok) {
96
+ if (response.status === 404) {
97
+ return null as T;
98
+ }
99
+ throw new Error(`HTTP error! status: ${response.status}`);
100
+ }
101
+
102
+ // If response is empty, return null
103
+ const text = await response.text();
104
+ if (!text) {
105
+ return null as T;
106
+ }
107
+
108
+ try {
109
+ return JSON.parse(text) as T;
110
+ } catch {
111
+ return null as T;
112
+ }
113
+ }
114
+
115
+ /**
116
+ * Initialize store
117
+ */
118
+ async initStore(
119
+ storeName: string,
120
+ _indexes: string[] = [],
121
+ _idKey: string = 'id'
122
+ ): Promise<void> {
123
+ const url = this.buildUrl(storeName);
124
+
125
+ // Try to create directory (using MKCOL method)
126
+ const response = await fetch(url, {
127
+ method: 'MKCOL',
128
+ headers: this.getHeaders(),
129
+ });
130
+
131
+ // If directory already exists (409 Conflict), ignore error
132
+ if (!response.ok && response.status !== 409) {
133
+ throw new Error(`Failed to create store: ${response.statusText}`);
134
+ }
135
+ }
136
+
137
+ /**
138
+ * Add data
139
+ */
140
+ async add<T extends Record<string, unknown>>(
141
+ storeName: string,
142
+ data: T,
143
+ idKey: string = 'id'
144
+ ): Promise<T> {
145
+ const id = String(data[idKey]);
146
+ const url = this.buildUrl(storeName, id);
147
+
148
+ const result = await this.request<T>(url, {
149
+ method: 'PUT',
150
+ body: JSON.stringify(data),
151
+ });
152
+
153
+ return result ?? data;
154
+ }
155
+
156
+ /**
157
+ * Update data
158
+ */
159
+ async update<T extends Record<string, unknown>>(
160
+ storeName: string,
161
+ id: string,
162
+ data: Partial<T>,
163
+ idKey: string = 'id'
164
+ ): Promise<T> {
165
+ // First get existing data
166
+ const existing = await this.getData<T>(storeName, id, idKey);
167
+ if (!existing) {
168
+ throw new Error(`Data with id ${id} not found`);
169
+ }
170
+
171
+ // Merge data
172
+ const updated = { ...existing, ...data };
173
+ const url = this.buildUrl(storeName, id);
174
+
175
+ const result = await this.request<T>(url, {
176
+ method: 'PUT',
177
+ body: JSON.stringify(updated),
178
+ });
179
+
180
+ return result ?? updated;
181
+ }
182
+
183
+ /**
184
+ * Delete data
185
+ */
186
+ async delete(storeName: string, id: string, _idKey: string = 'id'): Promise<void> {
187
+ const url = this.buildUrl(storeName, id);
188
+
189
+ await this.request(url, {
190
+ method: 'DELETE',
191
+ });
192
+ }
193
+
194
+ /**
195
+ * Get data by ID
196
+ */
197
+ async getData<T extends Record<string, unknown>>(
198
+ storeName: string,
199
+ id: string,
200
+ _idKey: string = 'id'
201
+ ): Promise<T | null> {
202
+ const url = this.buildUrl(storeName, id);
203
+
204
+ return await this.request<T | null>(url, {
205
+ method: 'GET',
206
+ });
207
+ }
208
+
209
+ /**
210
+ * Get list data (with pagination support)
211
+ */
212
+ async getList<T extends Record<string, unknown>>(
213
+ storeName: string,
214
+ options: QueryOptions<T> = {},
215
+ _idKey: string = 'id'
216
+ ): Promise<PaginatedResult<T>> {
217
+ const url = this.buildUrl(storeName);
218
+
219
+ // Build query parameters
220
+ const params = new URLSearchParams();
221
+ if (options.page !== undefined) {
222
+ params.append('page', String(options.page));
223
+ }
224
+ if (options.limit !== undefined) {
225
+ params.append('limit', String(options.limit));
226
+ }
227
+ if (options.where) {
228
+ params.append('where', JSON.stringify(options.where));
229
+ }
230
+
231
+ const queryString = params.toString();
232
+ const fullUrl = queryString ? `${url}?${queryString}` : url;
233
+
234
+ const result = await this.request<PaginatedResult<T>>(fullUrl, {
235
+ method: 'GET',
236
+ });
237
+
238
+ // If server returns non-paginated format, convert to paginated format
239
+ if (result && 'data' in result) {
240
+ return result;
241
+ }
242
+
243
+ // If return is an array, convert to paginated format
244
+ if (Array.isArray(result)) {
245
+ const dataArray = result as T[];
246
+ return {
247
+ data: dataArray,
248
+ totalCount: dataArray.length,
249
+ page: options.page ?? 1,
250
+ limit: options.limit ?? dataArray.length,
251
+ };
252
+ }
253
+
254
+ // Default return empty result
255
+ return {
256
+ data: [],
257
+ totalCount: 0,
258
+ page: options.page ?? 1,
259
+ limit: options.limit ?? 10,
260
+ };
261
+ }
262
+
263
+
264
+
265
+ /**
266
+ * Clear store
267
+ */
268
+ async clear(storeName: string): Promise<void> {
269
+ const url = this.buildUrl(storeName);
270
+
271
+ await this.request(url, {
272
+ method: 'DELETE',
273
+ });
274
+ }
275
+ }
276
+
277
+
package/tsconfig.json ADDED
@@ -0,0 +1,16 @@
1
+ {
2
+ "extends": "../../tsconfig.json",
3
+ "compilerOptions": {
4
+ "outDir": "./dist",
5
+ "rootDir": "./src"
6
+ },
7
+ "references": [
8
+ {
9
+ "path": "../core"
10
+ }
11
+ ],
12
+ "include": ["src/**/*"],
13
+ "exclude": ["node_modules", "dist", "**/*.test.ts"]
14
+ }
15
+
16
+
@@ -0,0 +1 @@
1
+ {"fileNames":["../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.core.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.collection.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.generator.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.iterable.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.proxy.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.reflect.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.array.include.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.date.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.regexp.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.array.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.symbol.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.bigint.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.date.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.number.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.weakref.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.array.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.error.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.regexp.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.legacy.d.ts","../core/dist/index.d.mts","./src/webdav-adapter.ts","./src/index.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/compatibility/disposable.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/compatibility/indexable.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/compatibility/iterators.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/compatibility/index.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/globals.typedarray.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/buffer.buffer.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/globals.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/abortcontroller.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/domexception.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/events.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/header.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/readable.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/file.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/fetch.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/formdata.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/connector.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/client.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/errors.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/dispatcher.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-dispatcher.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-origin.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool-stats.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/handlers.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/balanced-pool.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/agent.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-interceptor.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-agent.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-client.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-pool.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-errors.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/proxy-agent.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/env-http-proxy-agent.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-handler.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-agent.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/api.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/interceptors.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/util.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cookies.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/patch.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/websocket.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/eventsource.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/filereader.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/diagnostics-channel.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/content-type.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cache.d.ts","../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/index.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/fetch.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/navigator.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/web-globals/storage.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/assert.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/assert/strict.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/async_hooks.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/buffer.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/child_process.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/cluster.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/console.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/constants.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/crypto.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/dgram.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/diagnostics_channel.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/dns.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/dns/promises.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/domain.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/events.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/fs.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/fs/promises.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/http.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/http2.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/https.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/inspector.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/inspector.generated.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/module.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/net.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/os.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/path.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/perf_hooks.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/process.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/punycode.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/querystring.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/readline.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/readline/promises.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/repl.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/sea.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/sqlite.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/stream.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/stream/promises.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/stream/consumers.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/stream/web.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/string_decoder.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/test.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/timers.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/timers/promises.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/tls.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/trace_events.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/tty.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/url.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/util.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/v8.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/vm.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/wasi.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/worker_threads.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/zlib.d.ts","../../node_modules/.pnpm/@types+node@22.19.3/node_modules/@types/node/index.d.ts"],"fileIdsList":[[66,111,112,114,131,132],[66,113,114,131,132],[114,131,132],[66,114,119,131,132,149],[66,114,115,120,125,131,132,134,146,157],[66,114,115,116,125,131,132,134],[66,114,131,132],[61,62,63,66,114,131,132],[66,114,117,131,132,158],[66,114,118,119,126,131,132,135],[66,114,119,131,132,146,154],[66,114,120,122,125,131,132,134],[66,113,114,121,131,132],[66,114,122,123,131,132],[66,114,124,125,131,132],[66,113,114,125,131,132],[66,114,125,126,127,131,132,146,157],[66,114,125,126,127,131,132,141,146,149],[66,107,114,122,125,128,131,132,134,146,157],[66,114,125,126,128,129,131,132,134,146,154,157],[66,114,128,130,131,132,146,154,157],[64,65,66,67,68,69,70,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163],[66,114,125,131,132],[66,114,131,132,133,157],[66,114,122,125,131,132,134,146],[66,114,131,132,135],[66,114,131,132,136],[66,113,114,131,132,137],[66,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163],[66,114,131,132,139],[66,114,131,132,140],[66,114,125,131,132,141,142],[66,114,131,132,141,143,158,160],[66,114,126,131,132],[66,114,125,131,132,146,147,149],[66,114,131,132,148,149],[66,114,131,132,146,147],[66,114,131,132,149],[66,114,131,132,150],[66,111,114,131,132,146,151],[66,114,125,131,132,152,153],[66,114,131,132,152,153],[66,114,119,131,132,134,146,154],[66,114,131,132,155],[66,114,131,132,134,156],[66,114,128,131,132,140,157],[66,114,119,131,132,158],[66,114,131,132,146,159],[66,114,131,132,133,160],[66,114,131,132,161],[66,107,114,131,132],[66,107,114,125,127,131,132,137,146,149,157,159,160,162],[66,114,131,132,146,163],[66,79,83,114,131,132,157],[66,79,114,131,132,146,157],[66,74,114,131,132],[66,76,79,114,131,132,154,157],[66,114,131,132,134,154],[66,114,131,132,164],[66,74,114,131,132,164],[66,76,79,114,131,132,134,157],[66,71,72,75,78,114,125,131,132,146,157],[66,79,86,114,131,132],[66,71,77,114,131,132],[66,79,100,101,114,131,132],[66,75,79,114,131,132,149,157,164],[66,100,114,131,132,164],[66,73,74,114,131,132,164],[66,79,114,131,132],[66,73,74,75,76,77,78,79,80,81,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,101,102,103,104,105,106,114,131,132],[66,79,94,114,131,132],[66,79,86,87,114,131,132],[66,77,79,87,88,114,131,132],[66,78,114,131,132],[66,71,74,79,114,131,132],[66,79,83,87,88,114,131,132],[66,83,114,131,132],[66,77,79,82,114,131,132,157],[66,71,76,79,86,114,131,132],[66,114,131,132,146],[66,74,79,100,114,131,132,162,164],[59,66,114,131,132],[58,66,114,131,132]],"fileInfos":[{"version":"c430d44666289dae81f30fa7b2edebf186ecc91a2d4c71266ea6ae76388792e1","affectsGlobalScope":true,"impliedFormat":1},{"version":"45b7ab580deca34ae9729e97c13cfd999df04416a79116c3bfb483804f85ded4","impliedFormat":1},{"version":"3facaf05f0c5fc569c5649dd359892c98a85557e3e0c847964caeb67076f4d75","impliedFormat":1},{"version":"e44bb8bbac7f10ecc786703fe0a6a4b952189f908707980ba8f3c8975a760962","impliedFormat":1},{"version":"5e1c4c362065a6b95ff952c0eab010f04dcd2c3494e813b493ecfd4fcb9fc0d8","impliedFormat":1},{"version":"68d73b4a11549f9c0b7d352d10e91e5dca8faa3322bfb77b661839c42b1ddec7","impliedFormat":1},{"version":"5efce4fc3c29ea84e8928f97adec086e3dc876365e0982cc8479a07954a3efd4","impliedFormat":1},{"version":"feecb1be483ed332fad555aff858affd90a48ab19ba7272ee084704eb7167569","impliedFormat":1},{"version":"ee7bad0c15b58988daa84371e0b89d313b762ab83cb5b31b8a2d1162e8eb41c2","impliedFormat":1},{"version":"c57796738e7f83dbc4b8e65132f11a377649c00dd3eee333f672b8f0a6bea671","affectsGlobalScope":true,"impliedFormat":1},{"version":"dc2df20b1bcdc8c2d34af4926e2c3ab15ffe1160a63e58b7e09833f616efff44","affectsGlobalScope":true,"impliedFormat":1},{"version":"515d0b7b9bea2e31ea4ec968e9edd2c39d3eebf4a2d5cbd04e88639819ae3b71","affectsGlobalScope":true,"impliedFormat":1},{"version":"0559b1f683ac7505ae451f9a96ce4c3c92bdc71411651ca6ddb0e88baaaad6a3","affectsGlobalScope":true,"impliedFormat":1},{"version":"0dc1e7ceda9b8b9b455c3a2d67b0412feab00bd2f66656cd8850e8831b08b537","affectsGlobalScope":true,"impliedFormat":1},{"version":"ce691fb9e5c64efb9547083e4a34091bcbe5bdb41027e310ebba8f7d96a98671","affectsGlobalScope":true,"impliedFormat":1},{"version":"8d697a2a929a5fcb38b7a65594020fcef05ec1630804a33748829c5ff53640d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ff2a353abf8a80ee399af572debb8faab2d33ad38c4b4474cff7f26e7653b8d","affectsGlobalScope":true,"impliedFormat":1},{"version":"fb0f136d372979348d59b3f5020b4cdb81b5504192b1cacff5d1fbba29378aa1","affectsGlobalScope":true,"impliedFormat":1},{"version":"d15bea3d62cbbdb9797079416b8ac375ae99162a7fba5de2c6c505446486ac0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"68d18b664c9d32a7336a70235958b8997ebc1c3b8505f4f1ae2b7e7753b87618","affectsGlobalScope":true,"impliedFormat":1},{"version":"eb3d66c8327153d8fa7dd03f9c58d351107fe824c79e9b56b462935176cdf12a","affectsGlobalScope":true,"impliedFormat":1},{"version":"38f0219c9e23c915ef9790ab1d680440d95419ad264816fa15009a8851e79119","affectsGlobalScope":true,"impliedFormat":1},{"version":"69ab18c3b76cd9b1be3d188eaf8bba06112ebbe2f47f6c322b5105a6fbc45a2e","affectsGlobalScope":true,"impliedFormat":1},{"version":"a680117f487a4d2f30ea46f1b4b7f58bef1480456e18ba53ee85c2746eeca012","affectsGlobalScope":true,"impliedFormat":1},{"version":"2f11ff796926e0832f9ae148008138ad583bd181899ab7dd768a2666700b1893","affectsGlobalScope":true,"impliedFormat":1},{"version":"4de680d5bb41c17f7f68e0419412ca23c98d5749dcaaea1896172f06435891fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"954296b30da6d508a104a3a0b5d96b76495c709785c1d11610908e63481ee667","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac9538681b19688c8eae65811b329d3744af679e0bdfa5d842d0e32524c73e1c","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a969edff4bd52585473d24995c5ef223f6652d6ef46193309b3921d65dd4376","affectsGlobalScope":true,"impliedFormat":1},{"version":"9e9fbd7030c440b33d021da145d3232984c8bb7916f277e8ffd3dc2e3eae2bdb","affectsGlobalScope":true,"impliedFormat":1},{"version":"811ec78f7fefcabbda4bfa93b3eb67d9ae166ef95f9bff989d964061cbf81a0c","affectsGlobalScope":true,"impliedFormat":1},{"version":"717937616a17072082152a2ef351cb51f98802fb4b2fdabd32399843875974ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"d7e7d9b7b50e5f22c915b525acc5a49a7a6584cf8f62d0569e557c5cfc4b2ac2","affectsGlobalScope":true,"impliedFormat":1},{"version":"71c37f4c9543f31dfced6c7840e068c5a5aacb7b89111a4364b1d5276b852557","affectsGlobalScope":true,"impliedFormat":1},{"version":"576711e016cf4f1804676043e6a0a5414252560eb57de9faceee34d79798c850","affectsGlobalScope":true,"impliedFormat":1},{"version":"89c1b1281ba7b8a96efc676b11b264de7a8374c5ea1e6617f11880a13fc56dc6","affectsGlobalScope":true,"impliedFormat":1},{"version":"74f7fa2d027d5b33eb0471c8e82a6c87216223181ec31247c357a3e8e2fddc5b","affectsGlobalScope":true,"impliedFormat":1},{"version":"d6d7ae4d1f1f3772e2a3cde568ed08991a8ae34a080ff1151af28b7f798e22ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"063600664504610fe3e99b717a1223f8b1900087fab0b4cad1496a114744f8df","affectsGlobalScope":true,"impliedFormat":1},{"version":"934019d7e3c81950f9a8426d093458b65d5aff2c7c1511233c0fd5b941e608ab","affectsGlobalScope":true,"impliedFormat":1},{"version":"52ada8e0b6e0482b728070b7639ee42e83a9b1c22d205992756fe020fd9f4a47","affectsGlobalScope":true,"impliedFormat":1},{"version":"3bdefe1bfd4d6dee0e26f928f93ccc128f1b64d5d501ff4a8cf3c6371200e5e6","affectsGlobalScope":true,"impliedFormat":1},{"version":"59fb2c069260b4ba00b5643b907ef5d5341b167e7d1dbf58dfd895658bda2867","affectsGlobalScope":true,"impliedFormat":1},{"version":"639e512c0dfc3fad96a84caad71b8834d66329a1f28dc95e3946c9b58176c73a","affectsGlobalScope":true,"impliedFormat":1},{"version":"368af93f74c9c932edd84c58883e736c9e3d53cec1fe24c0b0ff451f529ceab1","affectsGlobalScope":true,"impliedFormat":1},{"version":"af3dd424cf267428f30ccfc376f47a2c0114546b55c44d8c0f1d57d841e28d74","affectsGlobalScope":true,"impliedFormat":1},{"version":"995c005ab91a498455ea8dfb63aa9f83fa2ea793c3d8aa344be4a1678d06d399","affectsGlobalScope":true,"impliedFormat":1},{"version":"959d36cddf5e7d572a65045b876f2956c973a586da58e5d26cde519184fd9b8a","affectsGlobalScope":true,"impliedFormat":1},{"version":"965f36eae237dd74e6cca203a43e9ca801ce38824ead814728a2807b1910117d","affectsGlobalScope":true,"impliedFormat":1},{"version":"3925a6c820dcb1a06506c90b1577db1fdbf7705d65b62b99dce4be75c637e26b","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a3d63ef2b853447ec4f749d3f368ce642264246e02911fcb1590d8c161b8005","affectsGlobalScope":true,"impliedFormat":1},{"version":"8cdf8847677ac7d20486e54dd3fcf09eda95812ac8ace44b4418da1bbbab6eb8","affectsGlobalScope":true,"impliedFormat":1},{"version":"8444af78980e3b20b49324f4a16ba35024fef3ee069a0eb67616ea6ca821c47a","affectsGlobalScope":true,"impliedFormat":1},{"version":"3287d9d085fbd618c3971944b65b4be57859f5415f495b33a6adc994edd2f004","affectsGlobalScope":true,"impliedFormat":1},{"version":"b4b67b1a91182421f5df999988c690f14d813b9850b40acd06ed44691f6727ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e7f8264d0fb4c5339605a15daadb037bf238c10b654bb3eee14208f860a32ea","affectsGlobalScope":true,"impliedFormat":1},{"version":"782dec38049b92d4e85c1585fbea5474a219c6984a35b004963b00beb1aab538","affectsGlobalScope":true,"impliedFormat":1},{"version":"2d4971f983508c7eb69730d2a1d3b8c6e0b52ad188822cc8546047542844b72b","impliedFormat":99},{"version":"ac6f3709655c1bd440c52e3436653dfe32341419385307e1577dfd7692c45a60","signature":"708755a3b32d19c67b7c6790d48485cb44b96c35ae62532ca3b061c0e79c38e5"},{"version":"befe9fa472895b2a88678c9509194d671b2cf62defef9e7f633232f14cbd3fd5","signature":"f78e02bd4998b55c2bed7ed3fb8e8551814a61cec2aef478f592814224dae437"},{"version":"6c7176368037af28cb72f2392010fa1cef295d6d6744bca8cfb54985f3a18c3e","affectsGlobalScope":true,"impliedFormat":1},{"version":"ab41ef1f2cdafb8df48be20cd969d875602483859dc194e9c97c8a576892c052","affectsGlobalScope":true,"impliedFormat":1},{"version":"437e20f2ba32abaeb7985e0afe0002de1917bc74e949ba585e49feba65da6ca1","affectsGlobalScope":true,"impliedFormat":1},{"version":"21d819c173c0cf7cc3ce57c3276e77fd9a8a01d35a06ad87158781515c9a438a","impliedFormat":1},{"version":"98cffbf06d6bab333473c70a893770dbe990783904002c4f1a960447b4b53dca","affectsGlobalScope":true,"impliedFormat":1},{"version":"3af97acf03cc97de58a3a4bc91f8f616408099bc4233f6d0852e72a8ffb91ac9","affectsGlobalScope":true,"impliedFormat":1},{"version":"808069bba06b6768b62fd22429b53362e7af342da4a236ed2d2e1c89fcca3b4a","affectsGlobalScope":true,"impliedFormat":1},{"version":"1db0b7dca579049ca4193d034d835f6bfe73096c73663e5ef9a0b5779939f3d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"9798340ffb0d067d69b1ae5b32faa17ab31b82466a3fc00d8f2f2df0c8554aaa","affectsGlobalScope":true,"impliedFormat":1},{"version":"f26b11d8d8e4b8028f1c7d618b22274c892e4b0ef5b3678a8ccbad85419aef43","affectsGlobalScope":true,"impliedFormat":1},{"version":"5929864ce17fba74232584d90cb721a89b7ad277220627cc97054ba15a98ea8f","impliedFormat":1},{"version":"763fe0f42b3d79b440a9b6e51e9ba3f3f91352469c1e4b3b67bfa4ff6352f3f4","impliedFormat":1},{"version":"25c8056edf4314820382a5fdb4bb7816999acdcb929c8f75e3f39473b87e85bc","impliedFormat":1},{"version":"c464d66b20788266e5353b48dc4aa6bc0dc4a707276df1e7152ab0c9ae21fad8","impliedFormat":1},{"version":"78d0d27c130d35c60b5e5566c9f1e5be77caf39804636bc1a40133919a949f21","impliedFormat":1},{"version":"c6fd2c5a395f2432786c9cb8deb870b9b0e8ff7e22c029954fabdd692bff6195","impliedFormat":1},{"version":"1d6e127068ea8e104a912e42fc0a110e2aa5a66a356a917a163e8cf9a65e4a75","impliedFormat":1},{"version":"5ded6427296cdf3b9542de4471d2aa8d3983671d4cac0f4bf9c637208d1ced43","impliedFormat":1},{"version":"7f182617db458e98fc18dfb272d40aa2fff3a353c44a89b2c0ccb3937709bfb5","impliedFormat":1},{"version":"cadc8aced301244057c4e7e73fbcae534b0f5b12a37b150d80e5a45aa4bebcbd","impliedFormat":1},{"version":"385aab901643aa54e1c36f5ef3107913b10d1b5bb8cbcd933d4263b80a0d7f20","impliedFormat":1},{"version":"9670d44354bab9d9982eca21945686b5c24a3f893db73c0dae0fd74217a4c219","impliedFormat":1},{"version":"0b8a9268adaf4da35e7fa830c8981cfa22adbbe5b3f6f5ab91f6658899e657a7","impliedFormat":1},{"version":"11396ed8a44c02ab9798b7dca436009f866e8dae3c9c25e8c1fbc396880bf1bb","impliedFormat":1},{"version":"ba7bc87d01492633cb5a0e5da8a4a42a1c86270e7b3d2dea5d156828a84e4882","impliedFormat":1},{"version":"4893a895ea92c85345017a04ed427cbd6a1710453338df26881a6019432febdd","impliedFormat":1},{"version":"c21dc52e277bcfc75fac0436ccb75c204f9e1b3fa5e12729670910639f27343e","impliedFormat":1},{"version":"13f6f39e12b1518c6650bbb220c8985999020fe0f21d818e28f512b7771d00f9","impliedFormat":1},{"version":"9b5369969f6e7175740bf51223112ff209f94ba43ecd3bb09eefff9fd675624a","impliedFormat":1},{"version":"4fe9e626e7164748e8769bbf74b538e09607f07ed17c2f20af8d680ee49fc1da","impliedFormat":1},{"version":"24515859bc0b836719105bb6cc3d68255042a9f02a6022b3187948b204946bd2","impliedFormat":1},{"version":"ea0148f897b45a76544ae179784c95af1bd6721b8610af9ffa467a518a086a43","impliedFormat":1},{"version":"24c6a117721e606c9984335f71711877293a9651e44f59f3d21c1ea0856f9cc9","impliedFormat":1},{"version":"dd3273ead9fbde62a72949c97dbec2247ea08e0c6952e701a483d74ef92d6a17","impliedFormat":1},{"version":"405822be75ad3e4d162e07439bac80c6bcc6dbae1929e179cf467ec0b9ee4e2e","impliedFormat":1},{"version":"0db18c6e78ea846316c012478888f33c11ffadab9efd1cc8bcc12daded7a60b6","impliedFormat":1},{"version":"e61be3f894b41b7baa1fbd6a66893f2579bfad01d208b4ff61daef21493ef0a8","impliedFormat":1},{"version":"bd0532fd6556073727d28da0edfd1736417a3f9f394877b6d5ef6ad88fba1d1a","impliedFormat":1},{"version":"89167d696a849fce5ca508032aabfe901c0868f833a8625d5a9c6e861ef935d2","impliedFormat":1},{"version":"615ba88d0128ed16bf83ef8ccbb6aff05c3ee2db1cc0f89ab50a4939bfc1943f","impliedFormat":1},{"version":"a4d551dbf8746780194d550c88f26cf937caf8d56f102969a110cfaed4b06656","impliedFormat":1},{"version":"8bd86b8e8f6a6aa6c49b71e14c4ffe1211a0e97c80f08d2c8cc98838006e4b88","impliedFormat":1},{"version":"317e63deeb21ac07f3992f5b50cdca8338f10acd4fbb7257ebf56735bf52ab00","impliedFormat":1},{"version":"4732aec92b20fb28c5fe9ad99521fb59974289ed1e45aecb282616202184064f","impliedFormat":1},{"version":"2e85db9e6fd73cfa3d7f28e0ab6b55417ea18931423bd47b409a96e4a169e8e6","impliedFormat":1},{"version":"c46e079fe54c76f95c67fb89081b3e399da2c7d109e7dca8e4b58d83e332e605","impliedFormat":1},{"version":"bf67d53d168abc1298888693338cb82854bdb2e69ef83f8a0092093c2d562107","impliedFormat":1},{"version":"2cbe0621042e2a68c7cbce5dfed3906a1862a16a7d496010636cdbdb91341c0f","affectsGlobalScope":true,"impliedFormat":1},{"version":"f9501cc13ce624c72b61f12b3963e84fad210fbdf0ffbc4590e08460a3f04eba","affectsGlobalScope":true,"impliedFormat":1},{"version":"e7721c4f69f93c91360c26a0a84ee885997d748237ef78ef665b153e622b36c1","affectsGlobalScope":true,"impliedFormat":1},{"version":"0fa06ada475b910e2106c98c68b10483dc8811d0c14a8a8dd36efb2672485b29","impliedFormat":1},{"version":"33e5e9aba62c3193d10d1d33ae1fa75c46a1171cf76fef750777377d53b0303f","impliedFormat":1},{"version":"2b06b93fd01bcd49d1a6bd1f9b65ddcae6480b9a86e9061634d6f8e354c1468f","impliedFormat":1},{"version":"6a0cd27e5dc2cfbe039e731cf879d12b0e2dded06d1b1dedad07f7712de0d7f4","affectsGlobalScope":true,"impliedFormat":1},{"version":"13f5c844119c43e51ce777c509267f14d6aaf31eafb2c2b002ca35584cd13b29","impliedFormat":1},{"version":"e60477649d6ad21542bd2dc7e3d9ff6853d0797ba9f689ba2f6653818999c264","impliedFormat":1},{"version":"c2510f124c0293ab80b1777c44d80f812b75612f297b9857406468c0f4dafe29","affectsGlobalScope":true,"impliedFormat":1},{"version":"5524481e56c48ff486f42926778c0a3cce1cc85dc46683b92b1271865bcf015a","impliedFormat":1},{"version":"4c829ab315f57c5442c6667b53769975acbf92003a66aef19bce151987675bd1","affectsGlobalScope":true,"impliedFormat":1},{"version":"b2ade7657e2db96d18315694789eff2ddd3d8aea7215b181f8a0b303277cc579","impliedFormat":1},{"version":"9855e02d837744303391e5623a531734443a5f8e6e8755e018c41d63ad797db2","impliedFormat":1},{"version":"4d631b81fa2f07a0e63a9a143d6a82c25c5f051298651a9b69176ba28930756d","impliedFormat":1},{"version":"836a356aae992ff3c28a0212e3eabcb76dd4b0cc06bcb9607aeef560661b860d","impliedFormat":1},{"version":"1e0d1f8b0adfa0b0330e028c7941b5a98c08b600efe7f14d2d2a00854fb2f393","impliedFormat":1},{"version":"41670ee38943d9cbb4924e436f56fc19ee94232bc96108562de1a734af20dc2c","affectsGlobalScope":true,"impliedFormat":1},{"version":"c906fb15bd2aabc9ed1e3f44eb6a8661199d6c320b3aa196b826121552cb3695","impliedFormat":1},{"version":"22295e8103f1d6d8ea4b5d6211e43421fe4564e34d0dd8e09e520e452d89e659","impliedFormat":1},{"version":"bb45cd435da536500f1d9692a9b49d0c570b763ccbf00473248b777f5c1f353b","impliedFormat":1},{"version":"6b4e081d55ac24fc8a4631d5dd77fe249fa25900abd7d046abb87d90e3b45645","impliedFormat":1},{"version":"a10f0e1854f3316d7ee437b79649e5a6ae3ae14ffe6322b02d4987071a95362e","impliedFormat":1},{"version":"e208f73ef6a980104304b0d2ca5f6bf1b85de6009d2c7e404028b875020fa8f2","impliedFormat":1},{"version":"d163b6bc2372b4f07260747cbc6c0a6405ab3fbcea3852305e98ac43ca59f5bc","impliedFormat":1},{"version":"e6fa9ad47c5f71ff733744a029d1dc472c618de53804eae08ffc243b936f87ff","affectsGlobalScope":true,"impliedFormat":1},{"version":"83e63d6ccf8ec004a3bb6d58b9bb0104f60e002754b1e968024b320730cc5311","impliedFormat":1},{"version":"24826ed94a78d5c64bd857570fdbd96229ad41b5cb654c08d75a9845e3ab7dde","impliedFormat":1},{"version":"8b479a130ccb62e98f11f136d3ac80f2984fdc07616516d29881f3061f2dd472","impliedFormat":1},{"version":"928af3d90454bf656a52a48679f199f64c1435247d6189d1caf4c68f2eaf921f","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac39df6dfb9e284bb0c205b15f4d9a2b260f5bab5c85bf2fb97d0cdd509c06ea","affectsGlobalScope":true,"impliedFormat":1},{"version":"3f16a7e4deafa527ed9995a772bb380eb7d3c2c0fd4ae178c5263ed18394db2c","impliedFormat":1},{"version":"933921f0bb0ec12ef45d1062a1fc0f27635318f4d294e4d99de9a5493e618ca2","impliedFormat":1},{"version":"71a0f3ad612c123b57239a7749770017ecfe6b66411488000aba83e4546fde25","impliedFormat":1},{"version":"77fbe5eecb6fac4b6242bbf6eebfc43e98ce5ccba8fa44e0ef6a95c945ff4d98","impliedFormat":1},{"version":"4f9d8ca0c417b67b69eeb54c7ca1bedd7b56034bb9bfd27c5d4f3bc4692daca7","impliedFormat":1},{"version":"814118df420c4e38fe5ae1b9a3bafb6e9c2aa40838e528cde908381867be6466","impliedFormat":1},{"version":"a3fc63c0d7b031693f665f5494412ba4b551fe644ededccc0ab5922401079c95","impliedFormat":1},{"version":"f27524f4bef4b6519c604bdb23bf4465bddcccbf3f003abb901acbd0d7404d99","impliedFormat":1},{"version":"37ba7b45141a45ce6e80e66f2a96c8a5ab1bcef0fc2d0f56bb58df96ec67e972","impliedFormat":1},{"version":"45650f47bfb376c8a8ed39d4bcda5902ab899a3150029684ee4c10676d9fbaee","impliedFormat":1},{"version":"dba28a419aec76ed864ef43e5f577a5c99a010c32e5949fe4e17a4d57c58dd11","affectsGlobalScope":true,"impliedFormat":1},{"version":"18fd40412d102c5564136f29735e5d1c3b455b8a37f920da79561f1fde068208","impliedFormat":1},{"version":"c959a391a75be9789b43c8468f71e3fa06488b4d691d5729dde1416dcd38225b","impliedFormat":1},{"version":"f0be1b8078cd549d91f37c30c222c2a187ac1cf981d994fb476a1adc61387b14","affectsGlobalScope":true,"impliedFormat":1},{"version":"0aaed1d72199b01234152f7a60046bc947f1f37d78d182e9ae09c4289e06a592","impliedFormat":1},{"version":"5ebe6f4cc3b803cbfc962bae0d954f9c80e5078ca41eb3f1de41d92e7193ef37","impliedFormat":1},{"version":"66ba1b2c3e3a3644a1011cd530fb444a96b1b2dfe2f5e837a002d41a1a799e60","impliedFormat":1},{"version":"7e514f5b852fdbc166b539fdd1f4e9114f29911592a5eb10a94bb3a13ccac3c4","impliedFormat":1},{"version":"5b7aa3c4c1a5d81b411e8cb302b45507fea9358d3569196b27eb1a27ae3a90ef","affectsGlobalScope":true,"impliedFormat":1},{"version":"5987a903da92c7462e0b35704ce7da94d7fdc4b89a984871c0e2b87a8aae9e69","affectsGlobalScope":true,"impliedFormat":1},{"version":"ea08a0345023ade2b47fbff5a76d0d0ed8bff10bc9d22b83f40858a8e941501c","impliedFormat":1},{"version":"47613031a5a31510831304405af561b0ffaedb734437c595256bb61a90f9311b","impliedFormat":1},{"version":"ae062ce7d9510060c5d7e7952ae379224fb3f8f2dd74e88959878af2057c143b","impliedFormat":1},{"version":"8a1a0d0a4a06a8d278947fcb66bf684f117bf147f89b06e50662d79a53be3e9f","affectsGlobalScope":true,"impliedFormat":1},{"version":"9f663c2f91127ef7024e8ca4b3b4383ff2770e5f826696005de382282794b127","impliedFormat":1},{"version":"9f55299850d4f0921e79b6bf344b47c420ce0f507b9dcf593e532b09ea7eeea1","impliedFormat":1}],"root":[59,60],"options":{"composite":true,"declaration":true,"declarationMap":true,"esModuleInterop":true,"module":99,"noFallthroughCasesInSwitch":true,"noImplicitReturns":true,"noUncheckedIndexedAccess":true,"noUnusedLocals":true,"noUnusedParameters":true,"outDir":"./dist","rootDir":"./src","skipLibCheck":true,"sourceMap":true,"strict":true,"target":9},"referencedMap":[[111,1],[112,1],[113,2],[66,3],[114,4],[115,5],[116,6],[61,7],[64,8],[62,7],[63,7],[117,9],[118,10],[119,11],[120,12],[121,13],[122,14],[123,14],[124,15],[125,16],[126,17],[127,18],[67,7],[65,7],[128,19],[129,20],[130,21],[164,22],[131,23],[132,7],[133,24],[134,25],[135,26],[136,27],[137,28],[138,29],[139,30],[140,31],[141,32],[142,32],[143,33],[144,7],[145,34],[146,35],[148,36],[147,37],[149,38],[150,39],[151,40],[152,41],[153,42],[154,43],[155,44],[156,45],[157,46],[158,47],[159,48],[160,49],[161,50],[68,7],[69,7],[70,7],[108,51],[109,7],[110,7],[162,52],[163,53],[56,7],[57,7],[11,7],[10,7],[2,7],[12,7],[13,7],[14,7],[15,7],[16,7],[17,7],[18,7],[19,7],[3,7],[20,7],[21,7],[4,7],[22,7],[26,7],[23,7],[24,7],[25,7],[27,7],[28,7],[29,7],[5,7],[30,7],[31,7],[32,7],[33,7],[6,7],[37,7],[34,7],[35,7],[36,7],[38,7],[7,7],[39,7],[44,7],[45,7],[40,7],[41,7],[42,7],[43,7],[8,7],[49,7],[46,7],[47,7],[48,7],[50,7],[9,7],[51,7],[52,7],[53,7],[55,7],[54,7],[1,7],[86,54],[96,55],[85,54],[106,56],[77,57],[76,58],[105,59],[99,60],[104,61],[79,62],[93,63],[78,64],[102,65],[74,66],[73,59],[103,67],[75,68],[80,69],[81,7],[84,69],[71,7],[107,70],[97,71],[88,72],[89,73],[91,74],[87,75],[90,76],[100,59],[82,77],[83,78],[92,79],[72,80],[95,71],[94,69],[98,7],[101,81],[60,82],[59,83],[58,7]],"affectedFilesPendingEmit":[[60,51],[59,51]],"emitSignatures":[59,60],"version":"5.9.3"}
@@ -0,0 +1,11 @@
1
+ import { defineConfig } from 'tsdown';
2
+
3
+ export default defineConfig({
4
+ entry: ['src/index.ts'],
5
+ format: ['esm'],
6
+ dts: true,
7
+ clean: true,
8
+ sourcemap: true,
9
+ });
10
+
11
+
@@ -0,0 +1,10 @@
1
+ import { defineConfig } from 'vitest/config';
2
+
3
+ export default defineConfig({
4
+ test: {
5
+ globals: true,
6
+ environment: 'node',
7
+ },
8
+ });
9
+
10
+