page-action-cache 2026.18.0 → 2026.20.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.
- package/dist/cache/preheater.d.ts +68 -0
- package/dist/cache/preheater.d.ts.map +1 -0
- package/dist/cache/preheater.js +159 -0
- package/dist/cache/preheater.js.map +1 -0
- package/dist/cache/token-tracker.d.ts +92 -0
- package/dist/cache/token-tracker.d.ts.map +1 -0
- package/dist/cache/token-tracker.js +205 -0
- package/dist/cache/token-tracker.js.map +1 -0
- package/dist/hooks/after-tool-call.d.ts.map +1 -1
- package/dist/hooks/after-tool-call.js +25 -0
- package/dist/hooks/after-tool-call.js.map +1 -1
- package/dist/hooks/before-tool-call.d.ts.map +1 -1
- package/dist/hooks/before-tool-call.js +7 -0
- package/dist/hooks/before-tool-call.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +26 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 缓存预热器
|
|
3
|
+
* 在页面加载时自动创建缓存条目,减少首次操作延迟
|
|
4
|
+
*/
|
|
5
|
+
import type { CacheEntry } from '../types/index.js';
|
|
6
|
+
/**
|
|
7
|
+
* 页面结构分析结果
|
|
8
|
+
*/
|
|
9
|
+
export interface PageStructure {
|
|
10
|
+
title?: string;
|
|
11
|
+
elementCount?: number;
|
|
12
|
+
formsCount?: number;
|
|
13
|
+
headingsCount?: number;
|
|
14
|
+
buttonsCount?: number;
|
|
15
|
+
linksCount?: number;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 预热结果
|
|
19
|
+
*/
|
|
20
|
+
export interface PreheatResult {
|
|
21
|
+
url: string;
|
|
22
|
+
cacheKey: string;
|
|
23
|
+
entry: CacheEntry;
|
|
24
|
+
preheatedAt: number;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 分析页面结构(基于snapshot结果)
|
|
28
|
+
*/
|
|
29
|
+
export declare function analyzePageStructure(snapshotData: unknown): PageStructure;
|
|
30
|
+
/**
|
|
31
|
+
* 检查URL是否应该被预热
|
|
32
|
+
*/
|
|
33
|
+
export declare function shouldPreheatUrl(url: string): boolean;
|
|
34
|
+
/**
|
|
35
|
+
* 预热单个URL
|
|
36
|
+
*/
|
|
37
|
+
export declare function preheatUrl(url: string, targetId: string, profile?: string, refs?: "role" | "aria", refsCount?: number): Promise<PreheatResult>;
|
|
38
|
+
/**
|
|
39
|
+
* 批量预热URL列表
|
|
40
|
+
*/
|
|
41
|
+
export declare function preheatUrls(urls: Array<{
|
|
42
|
+
url: string;
|
|
43
|
+
targetId: string;
|
|
44
|
+
profile?: string;
|
|
45
|
+
}>, refs?: "role" | "aria"): Promise<PreheatResult[]>;
|
|
46
|
+
/**
|
|
47
|
+
* 预测下一个可能访问的URL
|
|
48
|
+
*/
|
|
49
|
+
export declare function predictNextUrls(currentUrl: string, _structure: PageStructure): string[];
|
|
50
|
+
/**
|
|
51
|
+
* 根据页面结构调整缓存策略
|
|
52
|
+
*/
|
|
53
|
+
export declare function adjustCacheStrategy(structure: PageStructure): {
|
|
54
|
+
preferAiFormat: boolean;
|
|
55
|
+
expectedInteractions: number;
|
|
56
|
+
recommendedTTLMultiplier: number;
|
|
57
|
+
};
|
|
58
|
+
/**
|
|
59
|
+
* 获取预热统计信息
|
|
60
|
+
*/
|
|
61
|
+
export interface PreheatStats {
|
|
62
|
+
preheatedCount: number;
|
|
63
|
+
skippedCount: number;
|
|
64
|
+
failedCount: number;
|
|
65
|
+
lastPreheatTime: number;
|
|
66
|
+
}
|
|
67
|
+
export declare function getPreheatStats(): PreheatStats;
|
|
68
|
+
//# sourceMappingURL=preheater.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preheater.d.ts","sourceRoot":"","sources":["../../src/cache/preheater.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAKpD;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,UAAU,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,YAAY,EAAE,OAAO,GAAG,aAAa,CAsBzE;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAuBrD;AAED;;GAEG;AACH,wBAAsB,UAAU,CAC9B,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,MAAM,EAChB,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,EACtB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,aAAa,CAAC,CAWxB;AAED;;GAEG;AACH,wBAAsB,WAAW,CAC/B,IAAI,EAAE,KAAK,CAAC;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,EAChE,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,GACrB,OAAO,CAAC,aAAa,EAAE,CAAC,CAqB1B;AAED;;GAEG;AACH,wBAAgB,eAAe,CAC7B,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,aAAa,GACxB,MAAM,EAAE,CAqCV;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,aAAa,GAAG;IAC7D,cAAc,EAAE,OAAO,CAAC;IACxB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,wBAAwB,EAAE,MAAM,CAAC;CAClC,CA2BA;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,wBAAgB,eAAe,IAAI,YAAY,CAS9C"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 缓存预热器
|
|
3
|
+
* 在页面加载时自动创建缓存条目,减少首次操作延迟
|
|
4
|
+
*/
|
|
5
|
+
import { getConfig } from '../utils/config.js';
|
|
6
|
+
import { logInfo, logWarn } from '../utils/logger.js';
|
|
7
|
+
import { setCacheEntry } from './shared.js';
|
|
8
|
+
/**
|
|
9
|
+
* 分析页面结构(基于snapshot结果)
|
|
10
|
+
*/
|
|
11
|
+
export function analyzePageStructure(snapshotData) {
|
|
12
|
+
const structure = {};
|
|
13
|
+
if (typeof snapshotData === 'object' && snapshotData !== null) {
|
|
14
|
+
const data = snapshotData;
|
|
15
|
+
// 从snapshot数据中提取页面结构信息
|
|
16
|
+
// 这里简化处理,实际应该解析返回的HTML/DOM结构
|
|
17
|
+
if (typeof data.pageTitle === 'string') {
|
|
18
|
+
structure.title = data.pageTitle;
|
|
19
|
+
}
|
|
20
|
+
if (typeof data.elementCount === 'number') {
|
|
21
|
+
structure.elementCount = data.elementCount;
|
|
22
|
+
}
|
|
23
|
+
if (typeof data.refsCount === 'number') {
|
|
24
|
+
structure.elementCount = data.refsCount;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return structure;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* 检查URL是否应该被预热
|
|
31
|
+
*/
|
|
32
|
+
export function shouldPreheatUrl(url) {
|
|
33
|
+
const config = getConfig();
|
|
34
|
+
// 如果预热功能未启用,不预热
|
|
35
|
+
if (!config.strategy.enablePreheating) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
// 检查缓存模式
|
|
39
|
+
const shouldCache = config.strategy.cachePatterns.some(pattern => url.includes(pattern));
|
|
40
|
+
if (!shouldCache) {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
// 检查不缓存模式
|
|
44
|
+
const shouldNotCache = config.strategy.noCachePatterns.some(pattern => url.includes(pattern));
|
|
45
|
+
return !shouldNotCache;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* 预热单个URL
|
|
49
|
+
*/
|
|
50
|
+
export async function preheatUrl(url, targetId, profile, refs, refsCount) {
|
|
51
|
+
const { cacheKey, entry } = await setCacheEntry(url, targetId, profile, refs, refsCount);
|
|
52
|
+
logInfo(`Preheated cache for URL: ${url} (key: ${cacheKey})`);
|
|
53
|
+
return {
|
|
54
|
+
url,
|
|
55
|
+
cacheKey,
|
|
56
|
+
entry,
|
|
57
|
+
preheatedAt: Date.now(),
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* 批量预热URL列表
|
|
62
|
+
*/
|
|
63
|
+
export async function preheatUrls(urls, refs) {
|
|
64
|
+
const maxPreheats = getConfig().storage.maxSize;
|
|
65
|
+
// 限制预热数量
|
|
66
|
+
const urlsToPreheat = urls.slice(0, maxPreheats);
|
|
67
|
+
const results = [];
|
|
68
|
+
for (const item of urlsToPreheat) {
|
|
69
|
+
try {
|
|
70
|
+
if (shouldPreheatUrl(item.url)) {
|
|
71
|
+
const result = await preheatUrl(item.url, item.targetId, item.profile, refs);
|
|
72
|
+
results.push(result);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
logWarn(`Failed to preheat URL: ${item.url}`, error);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
logInfo(`Preheated ${results.length} URLs out of ${urls.length}`);
|
|
80
|
+
return results;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* 预测下一个可能访问的URL
|
|
84
|
+
*/
|
|
85
|
+
export function predictNextUrls(currentUrl, _structure) {
|
|
86
|
+
const predicted = [];
|
|
87
|
+
try {
|
|
88
|
+
const url = new URL(currentUrl);
|
|
89
|
+
// 预测1:相似路径(移除最后一个路径段)
|
|
90
|
+
const pathParts = url.pathname.split('/').filter(p => p);
|
|
91
|
+
if (pathParts.length > 1) {
|
|
92
|
+
const parentPath = pathParts.slice(0, -1).join('/');
|
|
93
|
+
const parentUrl = `${url.origin}${parentPath || '/'}`;
|
|
94
|
+
if (shouldPreheatUrl(parentUrl)) {
|
|
95
|
+
predicted.push(parentUrl);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
// 预测2:常见的管理页面路径
|
|
99
|
+
const commonPaths = [
|
|
100
|
+
'/dashboard',
|
|
101
|
+
'/settings',
|
|
102
|
+
'/admin',
|
|
103
|
+
'/profile',
|
|
104
|
+
'/account',
|
|
105
|
+
];
|
|
106
|
+
for (const path of commonPaths) {
|
|
107
|
+
const predictedUrl = `${url.origin}${path}`;
|
|
108
|
+
if (shouldPreheatUrl(predictedUrl)) {
|
|
109
|
+
predicted.push(predictedUrl);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
// 限制预测数量
|
|
113
|
+
return predicted.slice(0, 5);
|
|
114
|
+
}
|
|
115
|
+
catch {
|
|
116
|
+
return [];
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* 根据页面结构调整缓存策略
|
|
121
|
+
*/
|
|
122
|
+
export function adjustCacheStrategy(structure) {
|
|
123
|
+
// 基于页面结构元素数量调整策略
|
|
124
|
+
const elementCount = structure.elementCount || 0;
|
|
125
|
+
const buttonsCount = structure.buttonsCount || 0;
|
|
126
|
+
let preferAiFormat = false;
|
|
127
|
+
let expectedInteractions = 0;
|
|
128
|
+
let recommendedTTLMultiplier = 1.0;
|
|
129
|
+
// 大型页面(元素多)更适合AI格式
|
|
130
|
+
if (elementCount > 100) {
|
|
131
|
+
preferAiFormat = true;
|
|
132
|
+
expectedInteractions = Math.floor(buttonsCount * 0.8);
|
|
133
|
+
recommendedTTLMultiplier = 1.3; // 缓存更长时间
|
|
134
|
+
}
|
|
135
|
+
else if (elementCount > 50) {
|
|
136
|
+
expectedInteractions = Math.floor(buttonsCount * 0.6);
|
|
137
|
+
recommendedTTLMultiplier = 1.2;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
expectedInteractions = Math.floor(buttonsCount * 0.4);
|
|
141
|
+
recommendedTTLMultiplier = 1.0;
|
|
142
|
+
}
|
|
143
|
+
return {
|
|
144
|
+
preferAiFormat,
|
|
145
|
+
expectedInteractions,
|
|
146
|
+
recommendedTTLMultiplier,
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
export function getPreheatStats() {
|
|
150
|
+
// 这里应该从缓存中获取实际统计
|
|
151
|
+
// 简化实现,返回默认值
|
|
152
|
+
return {
|
|
153
|
+
preheatedCount: 0,
|
|
154
|
+
skippedCount: 0,
|
|
155
|
+
failedCount: 0,
|
|
156
|
+
lastPreheatTime: 0,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
//# sourceMappingURL=preheater.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preheater.js","sourceRoot":"","sources":["../../src/cache/preheater.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Token 追踪器
|
|
3
|
+
* 追踪 snapshot 的 token 使用量和缓存节省的 token
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Token 使用统计
|
|
7
|
+
*/
|
|
8
|
+
export interface TokenUsage {
|
|
9
|
+
snapshotTokens: number;
|
|
10
|
+
actionTokens: number;
|
|
11
|
+
cachedActionTokens: number;
|
|
12
|
+
totalTokens: number;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Token 节省统计
|
|
16
|
+
*/
|
|
17
|
+
export interface TokenSavings {
|
|
18
|
+
snapshots: number;
|
|
19
|
+
cachedActions: number;
|
|
20
|
+
totalSaved: number;
|
|
21
|
+
avgSavedPerAction: number;
|
|
22
|
+
efficiency: number;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Token 预算
|
|
26
|
+
*/
|
|
27
|
+
export interface TokenBudget {
|
|
28
|
+
dailyLimit: number;
|
|
29
|
+
currentUsage: number;
|
|
30
|
+
remaining: number;
|
|
31
|
+
resetTime: number;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Token 追踪器
|
|
35
|
+
*/
|
|
36
|
+
export declare class TokenTracker {
|
|
37
|
+
private usage;
|
|
38
|
+
private savings;
|
|
39
|
+
private startTime;
|
|
40
|
+
private reportInterval;
|
|
41
|
+
private lastReportTime;
|
|
42
|
+
constructor();
|
|
43
|
+
/**
|
|
44
|
+
* 记录 snapshot 的 token 使用
|
|
45
|
+
*/
|
|
46
|
+
recordSnapshot(tokens: number): void;
|
|
47
|
+
/**
|
|
48
|
+
* 记录浏览器操作的 token 使用
|
|
49
|
+
*/
|
|
50
|
+
recordAction(tokens: number, cached?: boolean): void;
|
|
51
|
+
/**
|
|
52
|
+
* 更新缓存效率
|
|
53
|
+
*/
|
|
54
|
+
private updateEfficiency;
|
|
55
|
+
/**
|
|
56
|
+
* 检查是否需要生成报告
|
|
57
|
+
*/
|
|
58
|
+
private checkReport;
|
|
59
|
+
/**
|
|
60
|
+
* 生成 token 使用报告
|
|
61
|
+
*/
|
|
62
|
+
generateReport(): string;
|
|
63
|
+
/**
|
|
64
|
+
* 获取当前 token 使用统计
|
|
65
|
+
*/
|
|
66
|
+
getUsage(): TokenUsage;
|
|
67
|
+
/**
|
|
68
|
+
* 获取 token 节省统计
|
|
69
|
+
*/
|
|
70
|
+
getSavings(): TokenSavings;
|
|
71
|
+
/**
|
|
72
|
+
* 重置统计
|
|
73
|
+
*/
|
|
74
|
+
reset(): void;
|
|
75
|
+
/**
|
|
76
|
+
* 获取 token 预算
|
|
77
|
+
*/
|
|
78
|
+
getBudget(dailyLimit: number): TokenBudget;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* 获取 token 追踪器实例
|
|
82
|
+
*/
|
|
83
|
+
export declare function getTokenTracker(): TokenTracker;
|
|
84
|
+
/**
|
|
85
|
+
* 估算 snapshot 的 token 使用
|
|
86
|
+
*/
|
|
87
|
+
export declare function estimateSnapshotTokens(elementCount: number, refsCount: number): number;
|
|
88
|
+
/**
|
|
89
|
+
* 估算操作节省的 token
|
|
90
|
+
*/
|
|
91
|
+
export declare function estimateSavedTokens(hasCache: boolean): number;
|
|
92
|
+
//# sourceMappingURL=token-tracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-tracker.d.ts","sourceRoot":"","sources":["../../src/cache/token-tracker.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAa;IAC1B,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAAS;;IAuB/B;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAQpC;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,GAAE,OAAe,GAAG,IAAI;IA0B3D;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAYxB;;OAEG;IACH,OAAO,CAAC,WAAW;IASnB;;OAEG;IACH,cAAc,IAAI,MAAM;IA8BxB;;OAEG;IACH,QAAQ,IAAI,UAAU;IAItB;;OAEG;IACH,UAAU,IAAI,YAAY;IAK1B;;OAEG;IACH,KAAK,IAAI,IAAI;IAsBb;;OAEG;IACH,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,WAAW;CAoB3C;AAOD;;GAEG;AACH,wBAAgB,eAAe,IAAI,YAAY,CAK9C;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,GAChB,MAAM,CAQR;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,OAAO,GAAG,MAAM,CAQ7D"}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Token 追踪器
|
|
3
|
+
* 追踪 snapshot 的 token 使用量和缓存节省的 token
|
|
4
|
+
*/
|
|
5
|
+
import { getConfig } from '../utils/config.js';
|
|
6
|
+
import { logInfo } from '../utils/logger.js';
|
|
7
|
+
/**
|
|
8
|
+
* Token 追踪器
|
|
9
|
+
*/
|
|
10
|
+
export class TokenTracker {
|
|
11
|
+
usage;
|
|
12
|
+
savings;
|
|
13
|
+
startTime;
|
|
14
|
+
reportInterval;
|
|
15
|
+
lastReportTime;
|
|
16
|
+
constructor() {
|
|
17
|
+
this.usage = {
|
|
18
|
+
snapshotTokens: 0,
|
|
19
|
+
actionTokens: 0,
|
|
20
|
+
cachedActionTokens: 0,
|
|
21
|
+
totalTokens: 0,
|
|
22
|
+
};
|
|
23
|
+
this.savings = {
|
|
24
|
+
snapshots: 0,
|
|
25
|
+
cachedActions: 0,
|
|
26
|
+
totalSaved: 0,
|
|
27
|
+
avgSavedPerAction: 0,
|
|
28
|
+
efficiency: 0,
|
|
29
|
+
};
|
|
30
|
+
this.startTime = Date.now();
|
|
31
|
+
this.reportInterval = getConfig().performance.reportInterval * 60 * 60 * 1000; // 转换为毫秒
|
|
32
|
+
this.lastReportTime = Date.now();
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* 记录 snapshot 的 token 使用
|
|
36
|
+
*/
|
|
37
|
+
recordSnapshot(tokens) {
|
|
38
|
+
this.usage.snapshotTokens += tokens;
|
|
39
|
+
this.usage.totalTokens += tokens;
|
|
40
|
+
this.savings.snapshots++;
|
|
41
|
+
logInfo(`Token usage: snapshot consumed ${tokens} tokens`);
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* 记录浏览器操作的 token 使用
|
|
45
|
+
*/
|
|
46
|
+
recordAction(tokens, cached = false) {
|
|
47
|
+
if (cached) {
|
|
48
|
+
// 缓存命中,记录节省的 token
|
|
49
|
+
const config = getConfig();
|
|
50
|
+
const avgTokens = config.performance.avgTokensPerSnapshot;
|
|
51
|
+
this.usage.cachedActionTokens += avgTokens;
|
|
52
|
+
this.savings.cachedActions++;
|
|
53
|
+
this.savings.totalSaved += avgTokens;
|
|
54
|
+
logInfo(`Token saved: cache hit saved ${avgTokens} tokens`);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
// 未命中,记录实际使用
|
|
58
|
+
this.usage.actionTokens += tokens;
|
|
59
|
+
this.usage.totalTokens += tokens;
|
|
60
|
+
logInfo(`Token usage: action consumed ${tokens} tokens`);
|
|
61
|
+
}
|
|
62
|
+
// 更新效率
|
|
63
|
+
this.updateEfficiency();
|
|
64
|
+
// 检查是否需要生成报告
|
|
65
|
+
this.checkReport();
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* 更新缓存效率
|
|
69
|
+
*/
|
|
70
|
+
updateEfficiency() {
|
|
71
|
+
const totalActions = this.savings.snapshots + this.savings.cachedActions;
|
|
72
|
+
if (totalActions > 0) {
|
|
73
|
+
this.savings.efficiency = this.savings.cachedActions / totalActions;
|
|
74
|
+
}
|
|
75
|
+
if (this.savings.cachedActions > 0) {
|
|
76
|
+
this.savings.avgSavedPerAction = this.savings.totalSaved / this.savings.cachedActions;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 检查是否需要生成报告
|
|
81
|
+
*/
|
|
82
|
+
checkReport() {
|
|
83
|
+
const now = Date.now();
|
|
84
|
+
if (now - this.lastReportTime >= this.reportInterval) {
|
|
85
|
+
this.generateReport();
|
|
86
|
+
this.lastReportTime = now;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* 生成 token 使用报告
|
|
91
|
+
*/
|
|
92
|
+
generateReport() {
|
|
93
|
+
const runtimeHours = (Date.now() - this.startTime) / (1000 * 60 * 60);
|
|
94
|
+
const efficiencyPercent = (this.savings.efficiency * 100).toFixed(2);
|
|
95
|
+
let report = '## Token Usage Report\n\n';
|
|
96
|
+
report += `**Runtime:** ${runtimeHours.toFixed(2)} hours\n\n`;
|
|
97
|
+
report += `### Token Usage\n`;
|
|
98
|
+
report += `- Snapshots: ${this.usage.snapshotTokens.toLocaleString()} tokens\n`;
|
|
99
|
+
report += `- Actions: ${this.usage.actionTokens.toLocaleString()} tokens\n`;
|
|
100
|
+
report += `- Cached Actions Saved: ${this.usage.cachedActionTokens.toLocaleString()} tokens\n`;
|
|
101
|
+
report += `- **Total:** ${this.usage.totalTokens.toLocaleString()} tokens\n\n`;
|
|
102
|
+
report += `### Cache Performance\n`;
|
|
103
|
+
report += `- Snapshots: ${this.savings.snapshots}\n`;
|
|
104
|
+
report += `- Cached Actions: ${this.savings.cachedActions}\n`;
|
|
105
|
+
report += `- Total Saved: ${this.savings.totalSaved.toLocaleString()} tokens\n`;
|
|
106
|
+
report += `- Avg Saved per Action: ${this.savings.avgSavedPerAction.toFixed(0)} tokens\n`;
|
|
107
|
+
report += `- **Efficiency:** ${efficiencyPercent}%\n\n`;
|
|
108
|
+
if (this.savings.totalSaved > 0) {
|
|
109
|
+
const savedHours = this.savings.totalSaved / 1000 / 60; // 假设 1K tokens = 1分钟
|
|
110
|
+
report += `### Cost Savings\n`;
|
|
111
|
+
report += `- Approximate Time Saved: ${savedHours.toFixed(2)} minutes\n`;
|
|
112
|
+
}
|
|
113
|
+
logInfo(report);
|
|
114
|
+
return report;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* 获取当前 token 使用统计
|
|
118
|
+
*/
|
|
119
|
+
getUsage() {
|
|
120
|
+
return { ...this.usage };
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* 获取 token 节省统计
|
|
124
|
+
*/
|
|
125
|
+
getSavings() {
|
|
126
|
+
this.updateEfficiency();
|
|
127
|
+
return { ...this.savings };
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* 重置统计
|
|
131
|
+
*/
|
|
132
|
+
reset() {
|
|
133
|
+
this.usage = {
|
|
134
|
+
snapshotTokens: 0,
|
|
135
|
+
actionTokens: 0,
|
|
136
|
+
cachedActionTokens: 0,
|
|
137
|
+
totalTokens: 0,
|
|
138
|
+
};
|
|
139
|
+
this.savings = {
|
|
140
|
+
snapshots: 0,
|
|
141
|
+
cachedActions: 0,
|
|
142
|
+
totalSaved: 0,
|
|
143
|
+
avgSavedPerAction: 0,
|
|
144
|
+
efficiency: 0,
|
|
145
|
+
};
|
|
146
|
+
this.startTime = Date.now();
|
|
147
|
+
this.lastReportTime = Date.now();
|
|
148
|
+
logInfo('Token tracker reset');
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* 获取 token 预算
|
|
152
|
+
*/
|
|
153
|
+
getBudget(dailyLimit) {
|
|
154
|
+
const now = Date.now();
|
|
155
|
+
const startOfDay = new Date(now);
|
|
156
|
+
startOfDay.setHours(0, 0, 0, 0);
|
|
157
|
+
const config = getConfig();
|
|
158
|
+
const avgTokensPerHour = config.performance.avgTokensPerSnapshot * 2; // 粗略估算
|
|
159
|
+
void avgTokensPerHour; // 使用该变量以避免"未使用"错误
|
|
160
|
+
const currentUsage = this.usage.totalTokens;
|
|
161
|
+
const remaining = Math.max(0, dailyLimit - currentUsage);
|
|
162
|
+
const resetTime = startOfDay.getTime() + 24 * 60 * 60 * 1000;
|
|
163
|
+
return {
|
|
164
|
+
dailyLimit,
|
|
165
|
+
currentUsage,
|
|
166
|
+
remaining,
|
|
167
|
+
resetTime,
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* 全局 token 追踪器实例
|
|
173
|
+
*/
|
|
174
|
+
let tracker = null;
|
|
175
|
+
/**
|
|
176
|
+
* 获取 token 追踪器实例
|
|
177
|
+
*/
|
|
178
|
+
export function getTokenTracker() {
|
|
179
|
+
if (!tracker) {
|
|
180
|
+
tracker = new TokenTracker();
|
|
181
|
+
}
|
|
182
|
+
return tracker;
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* 估算 snapshot 的 token 使用
|
|
186
|
+
*/
|
|
187
|
+
export function estimateSnapshotTokens(elementCount, refsCount) {
|
|
188
|
+
// 基于 AI 格式的 token 估算
|
|
189
|
+
// 假设:每个元素约 2 tokens,refs 约 1 token/个
|
|
190
|
+
const elementTokens = elementCount * 2;
|
|
191
|
+
const refsTokens = refsCount * 1;
|
|
192
|
+
const overhead = 100; // 固定开销
|
|
193
|
+
return elementTokens + refsTokens + overhead;
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* 估算操作节省的 token
|
|
197
|
+
*/
|
|
198
|
+
export function estimateSavedTokens(hasCache) {
|
|
199
|
+
const config = getConfig();
|
|
200
|
+
if (!hasCache) {
|
|
201
|
+
return 0;
|
|
202
|
+
}
|
|
203
|
+
return config.performance.avgTokensPerSnapshot;
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=token-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-tracker.js","sourceRoot":"","sources":["../../src/cache/token-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"after-tool-call.d.ts","sourceRoot":"","sources":["../../src/hooks/after-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"after-tool-call.d.ts","sourceRoot":"","sources":["../../src/hooks/after-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAc5D;;GAEG;AACH,wBAAsB,mBAAmB,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,CA2GlF;AAGD,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -6,6 +6,8 @@ import { logInfo, logError } from '../utils/logger.js';
|
|
|
6
6
|
import { hashUrl, extractDomain, shouldUseCacheUrl } from '../cache/url-normalizer.js';
|
|
7
7
|
import { getCacheKey, CACHE_TTL_MS, } from '../cache/shared.js';
|
|
8
8
|
import { getCacheManager } from '../cache/cache-manager.js';
|
|
9
|
+
import { analyzePageStructure, predictNextUrls } from '../cache/preheater.js';
|
|
10
|
+
import { getTokenTracker, estimateSnapshotTokens, } from '../cache/token-tracker.js';
|
|
9
11
|
/**
|
|
10
12
|
* 处理 after_tool_call hook
|
|
11
13
|
*/
|
|
@@ -74,6 +76,29 @@ export async function handleAfterToolCall(event) {
|
|
|
74
76
|
};
|
|
75
77
|
await manager.set(cacheKey, entry);
|
|
76
78
|
logInfo(`Cache entry created from snapshot (urlHash: ${urlHash}, refsCount: ${refsCount}, total entries: ${(await manager.getAll()).length})`);
|
|
79
|
+
// 记录 snapshot 的 token 使用
|
|
80
|
+
const tracker = getTokenTracker();
|
|
81
|
+
const estimatedTokens = estimateSnapshotTokens(refsCount || 0, refsCount || 0);
|
|
82
|
+
tracker.recordSnapshot(estimatedTokens);
|
|
83
|
+
// 可选:分析页面结构并预测下一个URL
|
|
84
|
+
try {
|
|
85
|
+
const structure = analyzePageStructure(result);
|
|
86
|
+
// 如果页面结构分析成功,可以记录或用于预热
|
|
87
|
+
if (structure.elementCount || structure.title) {
|
|
88
|
+
logInfo(`Page structure analyzed: ${structure.elementCount} elements, title: ${structure.title || 'N/A'}`);
|
|
89
|
+
// 预测下一个可能访问的URL(预热预留)
|
|
90
|
+
const predictedUrls = predictNextUrls(url, structure);
|
|
91
|
+
if (predictedUrls.length > 0) {
|
|
92
|
+
logInfo(`Predicted ${predictedUrls.length} potential next URLs for preheating`);
|
|
93
|
+
// 实际预热逻辑可以根据配置启用
|
|
94
|
+
// 这里只是记录预测结果
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
// 页面结构分析失败不影响缓存创建
|
|
100
|
+
logInfo('Page structure analysis failed, cache entry still created');
|
|
101
|
+
}
|
|
77
102
|
}
|
|
78
103
|
catch (error) {
|
|
79
104
|
logError('Error in after_tool_call handler', error);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"after-tool-call.js","sourceRoot":"","sources":["../../src/hooks/after-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AACvF,OAAO,EACL,WAAW,EACX,YAAY,GACb,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"after-tool-call.js","sourceRoot":"","sources":["../../src/hooks/after-tool-call.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"before-tool-call.d.ts","sourceRoot":"","sources":["../../src/hooks/before-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"before-tool-call.d.ts","sourceRoot":"","sources":["../../src/hooks/before-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAU7D;;GAEG;AACH,wBAAsB,oBAAoB,CAAC,KAAK,EAAE,mBAAmB,GAAG,OAAO,CAAC;IAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAAE,GAAG,SAAS,CAAC,CA0G/H"}
|
|
@@ -6,6 +6,7 @@ import { logInfo } from '../utils/logger.js';
|
|
|
6
6
|
import { hashUrl } from '../cache/url-normalizer.js';
|
|
7
7
|
import { getCacheKey } from '../cache/shared.js';
|
|
8
8
|
import { getCacheManager } from '../cache/cache-manager.js';
|
|
9
|
+
import { getTokenTracker, estimateSavedTokens, } from '../cache/token-tracker.js';
|
|
9
10
|
/**
|
|
10
11
|
* 处理 before_tool_call hook
|
|
11
12
|
*/
|
|
@@ -84,9 +85,15 @@ export async function handleBeforeToolCall(event) {
|
|
|
84
85
|
newParams.profile = cacheEntry.profile;
|
|
85
86
|
}
|
|
86
87
|
logInfo(`Cache hit found for ${action}: matchType=${matchType}, urlHash=${cacheEntry.urlHash}`);
|
|
88
|
+
// 记录 token 节省
|
|
89
|
+
const tracker = getTokenTracker();
|
|
90
|
+
tracker.recordAction(estimateSavedTokens(true), true);
|
|
87
91
|
return { params: newParams };
|
|
88
92
|
}
|
|
89
93
|
logInfo(`No cache hit for ${action}: url=${url || 'undefined'}, targetId=${targetId || 'undefined'}, profile=${profile || 'undefined'}`);
|
|
94
|
+
// 记录未命中的 token 使用(粗略估计)
|
|
95
|
+
const tracker = getTokenTracker();
|
|
96
|
+
tracker.recordAction(estimateSavedTokens(false), false);
|
|
90
97
|
return undefined;
|
|
91
98
|
}
|
|
92
99
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"before-tool-call.js","sourceRoot":"","sources":["../../src/hooks/before-tool-call.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"before-tool-call.js","sourceRoot":"","sources":["../../src/hooks/before-tool-call.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAyBH,UAAU,iBAAiB;IACzB,YAAY,CAAC,IAAI,EAAE;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,CAAC;QACd,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,EAAE,OAAO,CAAC;QACpB,OAAO,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;KACpE,GAAG,IAAI,CAAC;IACT,EAAE,CAAC,CAAC,SAAS,MAAM,EACjB,QAAQ,EAAE,CAAC,EACX,OAAO,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,KAAK,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,EACrE,IAAI,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE,GAC3B,IAAI,CAAC;CACT;AAED;;GAEG;AACH,wBAA8B,QAAQ,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,CA8Q5E"}
|
package/dist/index.js
CHANGED
|
@@ -11,6 +11,8 @@ import { handleAfterToolCall } from './hooks/after-tool-call.js';
|
|
|
11
11
|
import { getCacheStats, clearCache, setCacheEntry, getCacheEntry } from './hooks/after-tool-call.js';
|
|
12
12
|
// 导入缓存管理器初始化
|
|
13
13
|
import { initCacheManager } from './cache/cache-manager.js';
|
|
14
|
+
// 导入token追踪器
|
|
15
|
+
import { getTokenTracker } from './cache/token-tracker.js';
|
|
14
16
|
/**
|
|
15
17
|
* 主扩展入口
|
|
16
18
|
*/
|
|
@@ -205,6 +207,29 @@ export default async function register(api) {
|
|
|
205
207
|
};
|
|
206
208
|
}
|
|
207
209
|
});
|
|
210
|
+
// 注册token追踪工具
|
|
211
|
+
api.registerTool({
|
|
212
|
+
name: 'page_cache_tokens',
|
|
213
|
+
label: 'Token Usage Report',
|
|
214
|
+
description: 'View token usage and savings from cache',
|
|
215
|
+
parameters: {
|
|
216
|
+
type: 'object',
|
|
217
|
+
properties: {},
|
|
218
|
+
required: []
|
|
219
|
+
},
|
|
220
|
+
execute: async (toolCallId, _params) => {
|
|
221
|
+
logInfo(`Tool called: page_cache_tokens (callId: ${toolCallId})`);
|
|
222
|
+
const tracker = getTokenTracker();
|
|
223
|
+
const usage = tracker.getUsage();
|
|
224
|
+
const savings = tracker.getSavings();
|
|
225
|
+
const report = tracker.generateReport();
|
|
226
|
+
return {
|
|
227
|
+
text: report,
|
|
228
|
+
usage,
|
|
229
|
+
savings
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
});
|
|
208
233
|
// 安装 after_tool_call hook - 自动捕获 snapshot 结果并创建缓存条目
|
|
209
234
|
api.on('after_tool_call', async (event, _ctx) => {
|
|
210
235
|
await handleAfterToolCall(event);
|
|
@@ -214,6 +239,6 @@ export default async function register(api) {
|
|
|
214
239
|
return await handleBeforeToolCall(event);
|
|
215
240
|
});
|
|
216
241
|
logInfo('Page Action Cache plugin registration complete');
|
|
217
|
-
logInfo(`Registered
|
|
242
|
+
logInfo(`Registered 5 tools and 2 hooks: page_cache_stats, page_cache_clear, page_cache_set, page_cache_get, page_cache_tokens, before_tool_call, after_tool_call`);
|
|
218
243
|
}
|
|
219
244
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAQH,SAAS;AACT,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,cAAc;AACd,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE,WAAW;AACX,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAErG,aAAa;AACb,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|