opencode-antigravity-autopilot 2.1.0 → 2.1.3
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/manager.d.ts +1 -0
- package/dist/manager.d.ts.map +1 -1
- package/dist/manager.js +56 -4
- package/dist/manager.js.map +1 -1
- package/dist/plugin-tools.d.ts.map +1 -1
- package/dist/plugin-tools.js +11 -2
- package/dist/plugin-tools.js.map +1 -1
- package/dist/plugin.d.ts +25 -14
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +177 -35
- package/dist/plugin.js.map +1 -1
- package/dist/quota/ApiQuotaPoller.d.ts.map +1 -1
- package/dist/quota/ApiQuotaPoller.js +14 -9
- package/dist/quota/ApiQuotaPoller.js.map +1 -1
- package/dist/quota/QuotaCacheUpdater.d.ts +11 -6
- package/dist/quota/QuotaCacheUpdater.d.ts.map +1 -1
- package/dist/quota/QuotaCacheUpdater.js +98 -71
- package/dist/quota/QuotaCacheUpdater.js.map +1 -1
- package/dist/rotation/HardLimitDetector.d.ts +1 -0
- package/dist/rotation/HardLimitDetector.d.ts.map +1 -1
- package/dist/rotation/HardLimitDetector.js +85 -5
- package/dist/rotation/HardLimitDetector.js.map +1 -1
- package/dist/rotation/ModelSelector.d.ts +1 -0
- package/dist/rotation/ModelSelector.d.ts.map +1 -1
- package/dist/rotation/ModelSelector.js +19 -0
- package/dist/rotation/ModelSelector.js.map +1 -1
- package/dist/rotation/QuotaTracker.d.ts +1 -0
- package/dist/rotation/QuotaTracker.d.ts.map +1 -1
- package/dist/rotation/QuotaTracker.js +39 -3
- package/dist/rotation/QuotaTracker.js.map +1 -1
- package/dist/rotation/reproduce_crash.d.ts +2 -0
- package/dist/rotation/reproduce_crash.d.ts.map +1 -0
- package/dist/rotation/reproduce_crash.js +10 -0
- package/dist/rotation/reproduce_crash.js.map +1 -0
- package/dist/utils/logger.d.ts +39 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +147 -0
- package/dist/utils/logger.js.map +1 -0
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ModelSelector.d.ts","sourceRoot":"","sources":["../../src/rotation/ModelSelector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"ModelSelector.d.ts","sourceRoot":"","sources":["../../src/rotation/ModelSelector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AAGjD,qBAAa,aAAa;IACxB,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,QAAQ,CAAyB;IACzC,OAAO,CAAC,MAAM,CAAe;gBAEjB,YAAY,EAAE,YAAY,EAAE,QAAQ,EAAE,qBAAqB;IAevE,WAAW,IAAI,MAAM,GAAG,IAAI;IA8B5B,cAAc,CAAC,QAAQ,EAAE,OAAO,CAAC,qBAAqB,CAAC,GAAG,IAAI;IAI9D,WAAW,IAAI,qBAAqB;IAIpC,cAAc;CAGf"}
|
|
@@ -9,20 +9,39 @@ var __assign = (this && this.__assign) || function () {
|
|
|
9
9
|
};
|
|
10
10
|
return __assign.apply(this, arguments);
|
|
11
11
|
};
|
|
12
|
+
import { getLogger } from '../utils/logger';
|
|
12
13
|
var ModelSelector = (function () {
|
|
13
14
|
function ModelSelector(quotaTracker, strategy) {
|
|
15
|
+
this.logger = getLogger();
|
|
14
16
|
if (!(this instanceof ModelSelector)) {
|
|
15
17
|
return new ModelSelector(quotaTracker, strategy);
|
|
16
18
|
}
|
|
17
19
|
this.quotaTracker = quotaTracker;
|
|
18
20
|
this.strategy = strategy;
|
|
21
|
+
this.logger.info('ModelSelector', 'Initialized', {
|
|
22
|
+
preferredModelsCount: strategy.preferredModels.length,
|
|
23
|
+
fallbackModelsCount: strategy.fallbackModels.length,
|
|
24
|
+
quotaThreshold: strategy.quotaThreshold,
|
|
25
|
+
});
|
|
19
26
|
}
|
|
20
27
|
ModelSelector.prototype.selectModel = function () {
|
|
28
|
+
this.logger.debug('ModelSelector', 'Selecting model', {
|
|
29
|
+
preferredModels: this.strategy.preferredModels,
|
|
30
|
+
fallbackModels: this.strategy.fallbackModels,
|
|
31
|
+
});
|
|
21
32
|
var preferredModel = this.quotaTracker.getBestAvailableModel(this.strategy.preferredModels);
|
|
22
33
|
if (preferredModel) {
|
|
34
|
+
this.logger.info('ModelSelector', 'Selected preferred model', { model: preferredModel });
|
|
23
35
|
return preferredModel;
|
|
24
36
|
}
|
|
37
|
+
this.logger.warn('ModelSelector', 'No preferred model available, trying fallbacks');
|
|
25
38
|
var fallbackModel = this.quotaTracker.getBestAvailableModel(this.strategy.fallbackModels);
|
|
39
|
+
if (fallbackModel) {
|
|
40
|
+
this.logger.info('ModelSelector', 'Selected fallback model', { model: fallbackModel });
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.logger.error('ModelSelector', 'No suitable model found (all exhausted or below threshold)');
|
|
44
|
+
}
|
|
26
45
|
return fallbackModel;
|
|
27
46
|
};
|
|
28
47
|
ModelSelector.prototype.updateStrategy = function (strategy) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ModelSelector.js","sourceRoot":"","sources":["../../src/rotation/ModelSelector.ts"],"names":[],"mappings":";;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"ModelSelector.js","sourceRoot":"","sources":["../../src/rotation/ModelSelector.ts"],"names":[],"mappings":";;;;;;;;;;;AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C;IAKE,uBAAY,YAA0B,EAAE,QAA+B;QAF/D,WAAM,GAAG,SAAS,EAAE,CAAC;QAG3B,IAAI,CAAC,CAAC,IAAI,YAAY,aAAa,CAAC,EAAE,CAAC;YAErC,OAAO,IAAI,aAAa,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAEzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,EAAE;YAC/C,oBAAoB,EAAE,QAAQ,CAAC,eAAe,CAAC,MAAM;YACrD,mBAAmB,EAAE,QAAQ,CAAC,cAAc,CAAC,MAAM;YACnD,cAAc,EAAE,QAAQ,CAAC,cAAc;SACxC,CAAC,CAAC;IACL,CAAC;IAED,mCAAW,GAAX;QACE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE,iBAAiB,EAAE;YACpD,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,eAAe;YAC9C,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,cAAc;SAC7C,CAAC,CAAC;QAEH,IAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAC5D,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC9B,CAAC;QAEF,IAAI,cAAc,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,0BAA0B,EAAE,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAC;YACzF,OAAO,cAAc,CAAC;QACxB,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,gDAAgD,CAAC,CAAC;QAEpF,IAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAC3D,IAAI,CAAC,QAAQ,CAAC,cAAc,CAC7B,CAAC;QAEF,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,yBAAyB,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;QACzF,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE,4DAA4D,CAAC,CAAC;QACnG,CAAC;QAED,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,sCAAc,GAAd,UAAe,QAAwC;QACrD,IAAI,CAAC,QAAQ,yBAAQ,IAAI,CAAC,QAAQ,GAAK,QAAQ,CAAE,CAAC;IACpD,CAAC;IAED,mCAAW,GAAX;QACE,oBAAY,IAAI,CAAC,QAAQ,EAAG;IAC9B,CAAC;IAED,sCAAc,GAAd;QACE,OAAO,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,CAAC;IAC/C,CAAC;IACH,oBAAC;AAAD,CAAC,AA7DD,IA6DC"}
|
|
@@ -2,6 +2,7 @@ import { QuotaInfo, ModelQuotaState } from '../types';
|
|
|
2
2
|
export declare class QuotaTracker {
|
|
3
3
|
private quotaState;
|
|
4
4
|
private quotaThreshold;
|
|
5
|
+
private logger;
|
|
5
6
|
constructor(quotaThreshold?: number);
|
|
6
7
|
updateQuota(model: string, quota: QuotaInfo): void;
|
|
7
8
|
getQuotaForModel(model: string): ModelQuotaState | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuotaTracker.d.ts","sourceRoot":"","sources":["../../src/rotation/QuotaTracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"QuotaTracker.d.ts","sourceRoot":"","sources":["../../src/rotation/QuotaTracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAGtD,qBAAa,YAAY;IACvB,OAAO,CAAC,UAAU,CAAgC;IAClD,OAAO,CAAC,cAAc,CAAU;IAChC,OAAO,CAAC,MAAM,CAAe;gBAEjB,cAAc,GAAE,MAAa;IAczC,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI;IAqBlD,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,eAAe,GAAG,IAAI;IAIvD,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAWxC,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI;IAuC1D,iBAAiB,IAAI,eAAe,EAAE;IAItC,cAAc,CAAC,QAAQ,GAAE,MAAe,GAAG,IAAI;IAS/C,QAAQ,IAAI,IAAI;CAKjB"}
|
|
@@ -25,21 +25,37 @@ var __read = (this && this.__read) || function (o, n) {
|
|
|
25
25
|
}
|
|
26
26
|
return ar;
|
|
27
27
|
};
|
|
28
|
+
import { getLogger } from '../utils/logger';
|
|
28
29
|
var QuotaTracker = (function () {
|
|
29
30
|
function QuotaTracker(quotaThreshold) {
|
|
30
|
-
if (quotaThreshold === void 0) { quotaThreshold = 0.
|
|
31
|
+
if (quotaThreshold === void 0) { quotaThreshold = 0.02; }
|
|
32
|
+
this.logger = getLogger();
|
|
31
33
|
if (!(this instanceof QuotaTracker)) {
|
|
32
34
|
return new QuotaTracker(quotaThreshold);
|
|
33
35
|
}
|
|
34
36
|
this.quotaState = new Map();
|
|
35
37
|
this.quotaThreshold = quotaThreshold;
|
|
38
|
+
this.logger.info('QuotaTracker', 'Initialized', {
|
|
39
|
+
quotaThreshold: quotaThreshold,
|
|
40
|
+
thresholdPercentage: "".concat((quotaThreshold * 100).toFixed(1), "%"),
|
|
41
|
+
});
|
|
36
42
|
}
|
|
37
43
|
QuotaTracker.prototype.updateQuota = function (model, quota) {
|
|
38
|
-
this.quotaState.
|
|
44
|
+
var previousState = this.quotaState.get(model);
|
|
45
|
+
var newState = {
|
|
39
46
|
model: model,
|
|
40
47
|
quotaFraction: quota.remainingFraction,
|
|
41
48
|
lastChecked: Date.now(),
|
|
42
49
|
resetTime: quota.resetTime,
|
|
50
|
+
};
|
|
51
|
+
this.quotaState.set(model, newState);
|
|
52
|
+
this.logger.debug('QuotaTracker', 'Quota updated', {
|
|
53
|
+
model: model,
|
|
54
|
+
previousFraction: previousState === null || previousState === void 0 ? void 0 : previousState.quotaFraction,
|
|
55
|
+
newFraction: quota.remainingFraction,
|
|
56
|
+
quotaPercentage: "".concat((quota.remainingFraction * 100).toFixed(1), "%"),
|
|
57
|
+
threshold: "".concat((this.quotaThreshold * 100).toFixed(1), "%"),
|
|
58
|
+
isAboveThreshold: quota.remainingFraction >= this.quotaThreshold,
|
|
43
59
|
});
|
|
44
60
|
};
|
|
45
61
|
QuotaTracker.prototype.getQuotaForModel = function (model) {
|
|
@@ -57,13 +73,19 @@ var QuotaTracker = (function () {
|
|
|
57
73
|
QuotaTracker.prototype.getBestAvailableModel = function (candidates) {
|
|
58
74
|
var e_1, _a;
|
|
59
75
|
var _b;
|
|
76
|
+
this.logger.debug('QuotaTracker', 'Finding best available model', {
|
|
77
|
+
candidatesCount: candidates.length,
|
|
78
|
+
candidates: candidates,
|
|
79
|
+
});
|
|
60
80
|
var bestModel = null;
|
|
61
81
|
var bestQuota = -1;
|
|
62
82
|
try {
|
|
63
83
|
for (var candidates_1 = __values(candidates), candidates_1_1 = candidates_1.next(); !candidates_1_1.done; candidates_1_1 = candidates_1.next()) {
|
|
64
84
|
var model = candidates_1_1.value;
|
|
65
|
-
if (!this.isModelAvailable(model))
|
|
85
|
+
if (!this.isModelAvailable(model)) {
|
|
86
|
+
this.logger.debug('QuotaTracker', 'Model unavailable (below threshold)', { model: model });
|
|
66
87
|
continue;
|
|
88
|
+
}
|
|
67
89
|
var state = this.quotaState.get(model);
|
|
68
90
|
var quota = (_b = state === null || state === void 0 ? void 0 : state.quotaFraction) !== null && _b !== void 0 ? _b : 1.0;
|
|
69
91
|
if (quota > bestQuota) {
|
|
@@ -79,6 +101,18 @@ var QuotaTracker = (function () {
|
|
|
79
101
|
}
|
|
80
102
|
finally { if (e_1) throw e_1.error; }
|
|
81
103
|
}
|
|
104
|
+
if (bestModel) {
|
|
105
|
+
this.logger.info('QuotaTracker', 'Best model found', {
|
|
106
|
+
model: bestModel,
|
|
107
|
+
quotaFraction: bestQuota,
|
|
108
|
+
quotaPercentage: "".concat((bestQuota * 100).toFixed(1), "%"),
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.logger.warn('QuotaTracker', 'No available model found among candidates', {
|
|
113
|
+
candidatesCount: candidates.length,
|
|
114
|
+
});
|
|
115
|
+
}
|
|
82
116
|
return bestModel;
|
|
83
117
|
};
|
|
84
118
|
QuotaTracker.prototype.getAllQuotaStates = function () {
|
|
@@ -105,7 +139,9 @@ var QuotaTracker = (function () {
|
|
|
105
139
|
}
|
|
106
140
|
};
|
|
107
141
|
QuotaTracker.prototype.clearAll = function () {
|
|
142
|
+
var count = this.quotaState.size;
|
|
108
143
|
this.quotaState.clear();
|
|
144
|
+
this.logger.info('QuotaTracker', 'Cleared all quota states', { clearedCount: count });
|
|
109
145
|
};
|
|
110
146
|
return QuotaTracker;
|
|
111
147
|
}());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuotaTracker.js","sourceRoot":"","sources":["../../src/rotation/QuotaTracker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"QuotaTracker.js","sourceRoot":"","sources":["../../src/rotation/QuotaTracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reproduce_crash.d.ts","sourceRoot":"","sources":["../../src/rotation/reproduce_crash.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { HardLimitDetector } from './HardLimitDetector';
|
|
2
|
+
console.log('Attempting to call HardLimitDetector without new...');
|
|
3
|
+
try {
|
|
4
|
+
var instance = HardLimitDetector();
|
|
5
|
+
console.log('Successfully created instance via function call');
|
|
6
|
+
}
|
|
7
|
+
catch (error) {
|
|
8
|
+
console.error('Caught error:', error);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=reproduce_crash.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reproduce_crash.js","sourceRoot":"","sources":["../../src/rotation/reproduce_crash.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC;AAEnE,IAAI,CAAC;IAED,IAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAC;IACrC,OAAO,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAC;AACnE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACb,OAAO,CAAC,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export type LogLevel = 'debug' | 'info' | 'warn' | 'error';
|
|
2
|
+
export interface LogEntry {
|
|
3
|
+
timestamp: string;
|
|
4
|
+
level: LogLevel;
|
|
5
|
+
component: string;
|
|
6
|
+
message: string;
|
|
7
|
+
data?: any;
|
|
8
|
+
}
|
|
9
|
+
export declare class AutopilotLogger {
|
|
10
|
+
private logFilePath;
|
|
11
|
+
private enabled;
|
|
12
|
+
private minLevel;
|
|
13
|
+
private levelPriority;
|
|
14
|
+
constructor(options?: {
|
|
15
|
+
logDir?: string;
|
|
16
|
+
filename?: string;
|
|
17
|
+
enabled?: boolean;
|
|
18
|
+
minLevel?: LogLevel;
|
|
19
|
+
});
|
|
20
|
+
private getDateString;
|
|
21
|
+
private ensureLogDirectory;
|
|
22
|
+
private logRotation;
|
|
23
|
+
private shouldLog;
|
|
24
|
+
private formatLogEntry;
|
|
25
|
+
private writeLog;
|
|
26
|
+
debug(component: string, message: string, data?: any): void;
|
|
27
|
+
info(component: string, message: string, data?: any): void;
|
|
28
|
+
warn(component: string, message: string, data?: any): void;
|
|
29
|
+
error(component: string, message: string, data?: any): void;
|
|
30
|
+
getLogFilePath(): string;
|
|
31
|
+
}
|
|
32
|
+
export declare function getLogger(options?: {
|
|
33
|
+
logDir?: string;
|
|
34
|
+
filename?: string;
|
|
35
|
+
enabled?: boolean;
|
|
36
|
+
minLevel?: LogLevel;
|
|
37
|
+
}): AutopilotLogger;
|
|
38
|
+
export declare function setLogger(logger: AutopilotLogger): void;
|
|
39
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3D,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,QAAQ,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,GAAG,CAAC;CACZ;AAED,qBAAa,eAAe;IAC1B,OAAO,CAAC,WAAW,CAAS;IAC5B,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,aAAa,CAKnB;gBAEU,OAAO,CAAC,EAAE;QACpB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,QAAQ,CAAC;KACrB;IAaD,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,kBAAkB;IAO1B,OAAO,CAAC,WAAW;IAqBnB,OAAO,CAAC,SAAS;IAKjB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,QAAQ;IAehB,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAU3D,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAU1D,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAU1D,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAU3D,cAAc,IAAI,MAAM;CAGzB;AAID,wBAAgB,SAAS,CAAC,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,OAAO,CAAC;IAAC,QAAQ,CAAC,EAAE,QAAQ,CAAA;CAAE,GAAG,eAAe,CAKnI;AAED,wBAAgB,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI,CAEvD"}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
var __values = (this && this.__values) || function(o) {
|
|
2
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
3
|
+
if (m) return m.call(o);
|
|
4
|
+
if (o && typeof o.length === "number") return {
|
|
5
|
+
next: function () {
|
|
6
|
+
if (o && i >= o.length) o = void 0;
|
|
7
|
+
return { value: o && o[i++], done: !o };
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
11
|
+
};
|
|
12
|
+
import fs from 'fs';
|
|
13
|
+
import path from 'path';
|
|
14
|
+
var AutopilotLogger = (function () {
|
|
15
|
+
function AutopilotLogger(options) {
|
|
16
|
+
var _a;
|
|
17
|
+
this.levelPriority = {
|
|
18
|
+
debug: 0,
|
|
19
|
+
info: 1,
|
|
20
|
+
warn: 2,
|
|
21
|
+
error: 3,
|
|
22
|
+
};
|
|
23
|
+
var logDir = (options === null || options === void 0 ? void 0 : options.logDir) || '/tmp';
|
|
24
|
+
var filename = (options === null || options === void 0 ? void 0 : options.filename) || "autopilot-".concat(this.getDateString(), ".log");
|
|
25
|
+
this.logFilePath = path.join(logDir, filename);
|
|
26
|
+
this.enabled = (_a = options === null || options === void 0 ? void 0 : options.enabled) !== null && _a !== void 0 ? _a : true;
|
|
27
|
+
this.minLevel = (options === null || options === void 0 ? void 0 : options.minLevel) || 'debug';
|
|
28
|
+
if (this.enabled) {
|
|
29
|
+
this.ensureLogDirectory();
|
|
30
|
+
this.logRotation();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
AutopilotLogger.prototype.getDateString = function () {
|
|
34
|
+
var now = new Date();
|
|
35
|
+
return now.toISOString().split('T')[0];
|
|
36
|
+
};
|
|
37
|
+
AutopilotLogger.prototype.ensureLogDirectory = function () {
|
|
38
|
+
var dir = path.dirname(this.logFilePath);
|
|
39
|
+
if (!fs.existsSync(dir)) {
|
|
40
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
AutopilotLogger.prototype.logRotation = function () {
|
|
44
|
+
var e_1, _a;
|
|
45
|
+
try {
|
|
46
|
+
var dir = path.dirname(this.logFilePath);
|
|
47
|
+
var files = fs.readdirSync(dir);
|
|
48
|
+
var autopilotLogs = files.filter(function (f) { return f.startsWith('autopilot-') && f.endsWith('.log'); });
|
|
49
|
+
var now = Date.now();
|
|
50
|
+
var sevenDaysAgo = now - (7 * 24 * 60 * 60 * 1000);
|
|
51
|
+
try {
|
|
52
|
+
for (var autopilotLogs_1 = __values(autopilotLogs), autopilotLogs_1_1 = autopilotLogs_1.next(); !autopilotLogs_1_1.done; autopilotLogs_1_1 = autopilotLogs_1.next()) {
|
|
53
|
+
var file = autopilotLogs_1_1.value;
|
|
54
|
+
var filePath = path.join(dir, file);
|
|
55
|
+
var stats = fs.statSync(filePath);
|
|
56
|
+
if (stats.mtimeMs < sevenDaysAgo) {
|
|
57
|
+
fs.unlinkSync(filePath);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
62
|
+
finally {
|
|
63
|
+
try {
|
|
64
|
+
if (autopilotLogs_1_1 && !autopilotLogs_1_1.done && (_a = autopilotLogs_1.return)) _a.call(autopilotLogs_1);
|
|
65
|
+
}
|
|
66
|
+
finally { if (e_1) throw e_1.error; }
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
AutopilotLogger.prototype.shouldLog = function (level) {
|
|
73
|
+
if (!this.enabled)
|
|
74
|
+
return false;
|
|
75
|
+
return this.levelPriority[level] >= this.levelPriority[this.minLevel];
|
|
76
|
+
};
|
|
77
|
+
AutopilotLogger.prototype.formatLogEntry = function (entry) {
|
|
78
|
+
var dataStr = entry.data ? " | ".concat(JSON.stringify(entry.data)) : '';
|
|
79
|
+
return "[".concat(entry.timestamp, "] [").concat(entry.level.toUpperCase(), "] [").concat(entry.component, "] ").concat(entry.message).concat(dataStr, "\n");
|
|
80
|
+
};
|
|
81
|
+
AutopilotLogger.prototype.writeLog = function (entry) {
|
|
82
|
+
if (!this.shouldLog(entry.level))
|
|
83
|
+
return;
|
|
84
|
+
try {
|
|
85
|
+
var formatted = this.formatLogEntry(entry);
|
|
86
|
+
fs.appendFileSync(this.logFilePath, formatted, 'utf-8');
|
|
87
|
+
var consoleMethod = entry.level === 'error' ? console.error :
|
|
88
|
+
entry.level === 'warn' ? console.warn : console.log;
|
|
89
|
+
consoleMethod("[AUTOPILOT] ".concat(formatted.trim()));
|
|
90
|
+
}
|
|
91
|
+
catch (error) {
|
|
92
|
+
console.error('Failed to write log:', error);
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
AutopilotLogger.prototype.debug = function (component, message, data) {
|
|
96
|
+
this.writeLog({
|
|
97
|
+
timestamp: new Date().toISOString(),
|
|
98
|
+
level: 'debug',
|
|
99
|
+
component: component,
|
|
100
|
+
message: message,
|
|
101
|
+
data: data,
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
AutopilotLogger.prototype.info = function (component, message, data) {
|
|
105
|
+
this.writeLog({
|
|
106
|
+
timestamp: new Date().toISOString(),
|
|
107
|
+
level: 'info',
|
|
108
|
+
component: component,
|
|
109
|
+
message: message,
|
|
110
|
+
data: data,
|
|
111
|
+
});
|
|
112
|
+
};
|
|
113
|
+
AutopilotLogger.prototype.warn = function (component, message, data) {
|
|
114
|
+
this.writeLog({
|
|
115
|
+
timestamp: new Date().toISOString(),
|
|
116
|
+
level: 'warn',
|
|
117
|
+
component: component,
|
|
118
|
+
message: message,
|
|
119
|
+
data: data,
|
|
120
|
+
});
|
|
121
|
+
};
|
|
122
|
+
AutopilotLogger.prototype.error = function (component, message, data) {
|
|
123
|
+
this.writeLog({
|
|
124
|
+
timestamp: new Date().toISOString(),
|
|
125
|
+
level: 'error',
|
|
126
|
+
component: component,
|
|
127
|
+
message: message,
|
|
128
|
+
data: data,
|
|
129
|
+
});
|
|
130
|
+
};
|
|
131
|
+
AutopilotLogger.prototype.getLogFilePath = function () {
|
|
132
|
+
return this.logFilePath;
|
|
133
|
+
};
|
|
134
|
+
return AutopilotLogger;
|
|
135
|
+
}());
|
|
136
|
+
export { AutopilotLogger };
|
|
137
|
+
var globalLogger = null;
|
|
138
|
+
export function getLogger(options) {
|
|
139
|
+
if (!globalLogger) {
|
|
140
|
+
globalLogger = new AutopilotLogger(options);
|
|
141
|
+
}
|
|
142
|
+
return globalLogger;
|
|
143
|
+
}
|
|
144
|
+
export function setLogger(logger) {
|
|
145
|
+
globalLogger = logger;
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "opencode-antigravity-autopilot",
|
|
3
|
-
"version": "2.1.
|
|
3
|
+
"version": "2.1.3",
|
|
4
4
|
"description": "Intelligent quota monitoring and model auto-switching for OpenCode with Antigravity. Plugin-based, zero source modifications required.",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -60,4 +60,4 @@
|
|
|
60
60
|
"peerDependencies": {
|
|
61
61
|
"opencode-antigravity-auth": "^1.2.8"
|
|
62
62
|
}
|
|
63
|
-
}
|
|
63
|
+
}
|