opencode-antigravity-autopilot 2.1.0 → 2.1.2
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/quota/ApiQuotaPoller.d.ts.map +1 -1
- package/dist/quota/ApiQuotaPoller.js +3 -4
- package/dist/quota/ApiQuotaPoller.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/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 +1 -1
package/dist/manager.d.ts
CHANGED
package/dist/manager.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../src/manager.ts"],"names":[],"mappings":"AAGA,OAAO,EAAe,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../src/manager.ts"],"names":[],"mappings":"AAGA,OAAO,EAAe,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAI9D,qBAAa,YAAY;IACvB,OAAO,CAAC,WAAW,CAAsB;IACzC,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,aAAa,CAAwB;IAC7C,OAAO,CAAC,UAAU,CAA2D;IAC7E,OAAO,CAAC,iBAAiB,CAAiB;IAC1C,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,CAAC,EAAE,YAAY;IAmC3B,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B,QAAQ,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAKlC,QAAQ,IAAI,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAqBrC,cAAc,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAmD1E,kBAAkB,CAAC,OAAO,SAAI,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAmChE,aAAa,CAAC,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAWzD,eAAe,IAAI,MAAM,GAAG,IAAI;IAWhC,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI;IAI1D,eAAe,IAAI,YAAY;IAI/B,wBAAwB,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;CAQhE;AAED,wBAAsB,QAAQ,CAAC,MAAM,CAAC,EAAE,YAAY;gBAK9B,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;gBAItB,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;qBAIpB,OAAO,CAAC,IAAI,CAAC;uBAIjB,MAAM,GAAG,IAAI;+BAIL,MAAM,SAAS,SAAS,GAAG,IAAI;uBAIvC,YAAY;uCAII,qBAAqB,GAAG,IAAI;GAIlE"}
|
package/dist/manager.js
CHANGED
|
@@ -42,8 +42,11 @@ import { ApiQuotaPoller, AuthenticationError } from './quota/ApiQuotaPoller';
|
|
|
42
42
|
import { QuotaTracker } from './rotation/QuotaTracker';
|
|
43
43
|
import { ModelSelector } from './rotation/ModelSelector';
|
|
44
44
|
import { writeQuotaToCache } from './quota/QuotaCacheUpdater';
|
|
45
|
+
import { getLogger } from './utils/logger';
|
|
45
46
|
var QuotaManager = (function () {
|
|
46
47
|
function QuotaManager(config) {
|
|
48
|
+
var _a;
|
|
49
|
+
this.logger = getLogger();
|
|
47
50
|
if (!(this instanceof QuotaManager)) {
|
|
48
51
|
return new QuotaManager(config);
|
|
49
52
|
}
|
|
@@ -57,12 +60,18 @@ var QuotaManager = (function () {
|
|
|
57
60
|
this.lspFinder = new LSPFinder();
|
|
58
61
|
this.poller = new QuotaPoller();
|
|
59
62
|
this.apiPoller = new ApiQuotaPoller();
|
|
60
|
-
this.quotaTracker = new QuotaTracker((config === null || config === void 0 ? void 0 : config.quotaThreshold) || 0.
|
|
63
|
+
this.quotaTracker = new QuotaTracker((config === null || config === void 0 ? void 0 : config.quotaThreshold) || 0.02);
|
|
64
|
+
this.logger.info('QuotaManager', 'Initialized', {
|
|
65
|
+
quotaThreshold: (config === null || config === void 0 ? void 0 : config.quotaThreshold) || 0.02,
|
|
66
|
+
accountsCount: accounts.length,
|
|
67
|
+
activeIndex: activeIndex,
|
|
68
|
+
preferredModelsCount: ((_a = config === null || config === void 0 ? void 0 : config.preferredModels) === null || _a === void 0 ? void 0 : _a.length) || 0,
|
|
69
|
+
});
|
|
61
70
|
if (config === null || config === void 0 ? void 0 : config.preferredModels) {
|
|
62
71
|
var strategy = {
|
|
63
72
|
preferredModels: config.preferredModels,
|
|
64
73
|
fallbackModels: [],
|
|
65
|
-
quotaThreshold: config.quotaThreshold || 0.
|
|
74
|
+
quotaThreshold: config.quotaThreshold || 0.02,
|
|
66
75
|
};
|
|
67
76
|
this.modelSelector = new ModelSelector(this.quotaTracker, strategy);
|
|
68
77
|
}
|
|
@@ -127,28 +136,43 @@ var QuotaManager = (function () {
|
|
|
127
136
|
case 0:
|
|
128
137
|
account = this.rotator.getCurrentAccount();
|
|
129
138
|
if (!account) {
|
|
139
|
+
this.logger.warn('QuotaManager', 'No account available for quota fetch');
|
|
130
140
|
return [2, null];
|
|
131
141
|
}
|
|
142
|
+
this.logger.debug('QuotaManager', 'Fetching quota via API', {
|
|
143
|
+
modelName: modelName || this.lastSelectedModel || 'all',
|
|
144
|
+
accountEmail: account.email,
|
|
145
|
+
retriesLeft: retries,
|
|
146
|
+
});
|
|
132
147
|
_a.label = 1;
|
|
133
148
|
case 1:
|
|
134
149
|
_a.trys.push([1, 8, , 11]);
|
|
135
150
|
result = null;
|
|
136
151
|
targetModel = modelName || this.lastSelectedModel;
|
|
137
152
|
if (!targetModel) return [3, 3];
|
|
153
|
+
this.logger.debug('QuotaManager', 'Fetching quota for specific model', { model: targetModel });
|
|
138
154
|
return [4, this.apiPoller.checkQuotaForModel(account, targetModel)];
|
|
139
155
|
case 2:
|
|
140
156
|
result = _a.sent();
|
|
141
157
|
return [3, 5];
|
|
142
|
-
case 3:
|
|
158
|
+
case 3:
|
|
159
|
+
this.logger.debug('QuotaManager', 'Fetching all quotas');
|
|
160
|
+
return [4, this.apiPoller.getAllQuotas(account)];
|
|
143
161
|
case 4:
|
|
144
162
|
quotas = _a.sent();
|
|
145
163
|
if (quotas.size === 0) {
|
|
164
|
+
this.logger.warn('QuotaManager', 'No quotas returned from API');
|
|
146
165
|
return [2, null];
|
|
147
166
|
}
|
|
148
167
|
result = quotas.values().next().value || null;
|
|
149
168
|
_a.label = 5;
|
|
150
169
|
case 5:
|
|
151
170
|
if (!result) return [3, 7];
|
|
171
|
+
this.logger.info('QuotaManager', 'Quota fetched successfully', {
|
|
172
|
+
model: result.model,
|
|
173
|
+
remainingFraction: result.remainingFraction,
|
|
174
|
+
quotaPercentage: "".concat((result.remainingFraction * 100).toFixed(1), "%"),
|
|
175
|
+
});
|
|
152
176
|
return [4, writeQuotaToCache(result)];
|
|
153
177
|
case 6:
|
|
154
178
|
_a.sent();
|
|
@@ -156,7 +180,9 @@ var QuotaManager = (function () {
|
|
|
156
180
|
case 7: return [2, result];
|
|
157
181
|
case 8:
|
|
158
182
|
error_1 = _a.sent();
|
|
183
|
+
this.logger.error('QuotaManager', 'Error fetching quota', { error: error_1, retriesLeft: retries });
|
|
159
184
|
if (!(error_1 instanceof AuthenticationError && retries > 0)) return [3, 10];
|
|
185
|
+
this.logger.info('QuotaManager', 'Authentication failed, rotating account', { retriesLeft: retries - 1 });
|
|
160
186
|
return [4, this.rotateAccount()];
|
|
161
187
|
case 9:
|
|
162
188
|
_a.sent();
|
|
@@ -175,14 +201,23 @@ var QuotaManager = (function () {
|
|
|
175
201
|
switch (_a.label) {
|
|
176
202
|
case 0:
|
|
177
203
|
account = this.rotator.getCurrentAccount();
|
|
178
|
-
if (!account)
|
|
204
|
+
if (!account) {
|
|
205
|
+
this.logger.warn('QuotaManager', 'No account available for getAllQuotas');
|
|
179
206
|
return [2, new Map()];
|
|
207
|
+
}
|
|
208
|
+
this.logger.debug('QuotaManager', 'Fetching all quotas via API', {
|
|
209
|
+
accountEmail: account.email,
|
|
210
|
+
retriesLeft: retries,
|
|
211
|
+
});
|
|
180
212
|
_a.label = 1;
|
|
181
213
|
case 1:
|
|
182
214
|
_a.trys.push([1, 5, , 8]);
|
|
183
215
|
return [4, this.apiPoller.getAllQuotas(account)];
|
|
184
216
|
case 2:
|
|
185
217
|
quotas = _a.sent();
|
|
218
|
+
this.logger.info('QuotaManager', 'All quotas fetched successfully', {
|
|
219
|
+
modelsCount: quotas.size,
|
|
220
|
+
});
|
|
186
221
|
first = quotas.values().next().value;
|
|
187
222
|
if (!first) return [3, 4];
|
|
188
223
|
return [4, writeQuotaToCache(first)];
|
|
@@ -192,7 +227,9 @@ var QuotaManager = (function () {
|
|
|
192
227
|
case 4: return [2, quotas];
|
|
193
228
|
case 5:
|
|
194
229
|
error_2 = _a.sent();
|
|
230
|
+
this.logger.error('QuotaManager', 'Error fetching all quotas', { error: error_2, retriesLeft: retries });
|
|
195
231
|
if (!(error_2 instanceof AuthenticationError && retries > 0)) return [3, 7];
|
|
232
|
+
this.logger.info('QuotaManager', 'Authentication failed, rotating account', { retriesLeft: retries - 1 });
|
|
196
233
|
return [4, this.rotateAccount()];
|
|
197
234
|
case 6:
|
|
198
235
|
_a.sent();
|
|
@@ -205,9 +242,15 @@ var QuotaManager = (function () {
|
|
|
205
242
|
};
|
|
206
243
|
QuotaManager.prototype.rotateAccount = function (resetTimeISO) {
|
|
207
244
|
return __awaiter(this, void 0, void 0, function () {
|
|
245
|
+
var newAccount;
|
|
208
246
|
return __generator(this, function (_a) {
|
|
247
|
+
this.logger.info('QuotaManager', 'Rotating account', { resetTimeISO: resetTimeISO });
|
|
209
248
|
this.rotator.markCurrentExhausted(undefined, resetTimeISO);
|
|
210
249
|
this.quotaTracker.clearAll();
|
|
250
|
+
newAccount = this.rotator.getCurrentAccount();
|
|
251
|
+
this.logger.info('QuotaManager', 'Account rotated', {
|
|
252
|
+
newAccountEmail: newAccount === null || newAccount === void 0 ? void 0 : newAccount.email,
|
|
253
|
+
});
|
|
211
254
|
return [2];
|
|
212
255
|
});
|
|
213
256
|
});
|
|
@@ -216,8 +259,12 @@ var QuotaManager = (function () {
|
|
|
216
259
|
var _a;
|
|
217
260
|
var model = ((_a = this.modelSelector) === null || _a === void 0 ? void 0 : _a.selectModel()) || null;
|
|
218
261
|
if (model) {
|
|
262
|
+
this.logger.info('QuotaManager', 'Best model selected', { model: model });
|
|
219
263
|
this.lastSelectedModel = model;
|
|
220
264
|
}
|
|
265
|
+
else {
|
|
266
|
+
this.logger.warn('QuotaManager', 'No suitable model found');
|
|
267
|
+
}
|
|
221
268
|
return model;
|
|
222
269
|
};
|
|
223
270
|
QuotaManager.prototype.updateQuotaForModel = function (model, quota) {
|
|
@@ -227,6 +274,11 @@ var QuotaManager = (function () {
|
|
|
227
274
|
return this.quotaTracker;
|
|
228
275
|
};
|
|
229
276
|
QuotaManager.prototype.setModelRotationStrategy = function (strategy) {
|
|
277
|
+
this.logger.info('QuotaManager', 'Setting model rotation strategy', {
|
|
278
|
+
preferredModels: strategy.preferredModels,
|
|
279
|
+
fallbackModels: strategy.fallbackModels,
|
|
280
|
+
quotaThreshold: strategy.quotaThreshold,
|
|
281
|
+
});
|
|
230
282
|
this.modelSelector = new ModelSelector(this.quotaTracker, strategy);
|
|
231
283
|
};
|
|
232
284
|
return QuotaManager;
|
package/dist/manager.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../src/manager.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAa,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../src/manager.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAa,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;IAYE,sBAAY,MAAqB;;QAFzB,WAAM,GAAG,SAAS,EAAE,CAAC;QAG3B,IAAI,CAAC,CAAC,IAAI,YAAY,YAAY,CAAC,EAAE,CAAC;YAEpC,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAC5C,IAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;QAChD,IAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;QAEtD,IAAI,CAAC,OAAO,GAAG,IAAI,cAAc,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;QACzD,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;QACjC,IAAI,CAAC,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,EAAE,CAAC;QACtC,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,KAAI,IAAI,CAAC,CAAC;QAErE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,aAAa,EAAE;YAC9C,cAAc,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,KAAI,IAAI;YAC9C,aAAa,EAAE,QAAQ,CAAC,MAAM;YAC9B,WAAW,aAAA;YACX,oBAAoB,EAAE,CAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,eAAe,0CAAE,MAAM,KAAI,CAAC;SAC3D,CAAC,CAAC;QAEH,IAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,eAAe,EAAE,CAAC;YAC5B,IAAM,QAAQ,GAA0B;gBACtC,eAAe,EAAE,MAAM,CAAC,eAAe;gBACvC,cAAc,EAAE,EAAE;gBAClB,cAAc,EAAE,MAAM,CAAC,cAAc,IAAI,IAAI;aAC9C,CAAC;YACF,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACtE,CAAC;IACH,CAAC;IAEK,iCAAU,GAAhB;;;;;;wBACE,KAAA,IAAI,CAAA;wBAAc,WAAM,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,EAAA;;wBAApD,GAAK,UAAU,GAAG,SAAkC,CAAC;;;;;KACtD;IAEK,+BAAQ,GAAd;;;;gBACQ,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;gBACjD,WAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAC;;;KAC9C;IAEK,+BAAQ,GAAd;;;;;;6BACM,CAAC,IAAI,CAAC,UAAU,EAAhB,cAAgB;wBAClB,KAAA,IAAI,CAAA;wBAAc,WAAM,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,EAAA;;wBAApD,GAAK,UAAU,GAAG,SAAkC,CAAC;;;wBAGvD,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;4BACrB,WAAO,IAAI,EAAC;wBACd,CAAC;wBAEa,WAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CACxC,IAAI,CAAC,UAAU,CAAC,IAAI,EACpB,IAAI,CAAC,UAAU,CAAC,SAAS,CAC1B,EAAA;;wBAHK,KAAK,GAAG,SAGb;wBAED,IAAI,CAAC,KAAK,EAAE,CAAC;4BACX,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;wBACzB,CAAC;wBAED,WAAO,KAAK,EAAC;;;;KACd;IAEK,qCAAc,GAApB;4DAAqB,SAAkB,EAAE,OAAW;;YAAX,wBAAA,EAAA,WAAW;;;;wBAC5C,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACjD,IAAI,CAAC,OAAO,EAAE,CAAC;4BACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,sCAAsC,CAAC,CAAC;4BACzE,WAAO,IAAI,EAAC;wBACd,CAAC;wBAED,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,wBAAwB,EAAE;4BAC1D,SAAS,EAAE,SAAS,IAAI,IAAI,CAAC,iBAAiB,IAAI,KAAK;4BACvD,YAAY,EAAE,OAAO,CAAC,KAAK;4BAC3B,WAAW,EAAE,OAAO;yBACrB,CAAC,CAAC;;;;wBAGG,MAAM,GAAqB,IAAI,CAAC;wBAC9B,WAAW,GAAG,SAAS,IAAI,IAAI,CAAC,iBAAiB,CAAC;6BAEpD,WAAW,EAAX,cAAW;wBACb,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,mCAAmC,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;wBACtF,WAAM,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,OAAO,EAAE,WAAW,CAAC,EAAA;;wBAAtE,MAAM,GAAG,SAA6D,CAAC;;;wBAEvE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,qBAAqB,CAAC,CAAC;wBAC1C,WAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,EAAA;;wBAAnD,MAAM,GAAG,SAA0C;wBACzD,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;4BACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,6BAA6B,CAAC,CAAC;4BAChE,WAAO,IAAI,EAAC;wBACd,CAAC;wBACD,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,IAAI,CAAC;;;6BAG5C,MAAM,EAAN,cAAM;wBACR,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,4BAA4B,EAAE;4BAC7D,KAAK,EAAE,MAAM,CAAC,KAAK;4BACnB,iBAAiB,EAAE,MAAM,CAAC,iBAAiB;4BAC3C,eAAe,EAAE,UAAG,CAAC,MAAM,CAAC,iBAAiB,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAG;yBACnE,CAAC,CAAC;wBACH,WAAM,iBAAiB,CAAC,MAAM,CAAC,EAAA;;wBAA/B,SAA+B,CAAC;;4BAElC,WAAO,MAAM,EAAC;;;wBAGd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,sBAAsB,EAAE,EAAE,KAAK,SAAA,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC;6BACvF,CAAA,OAAK,YAAY,mBAAmB,IAAI,OAAO,GAAG,CAAC,CAAA,EAAnD,eAAmD;wBACrD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,yCAAyC,EAAE,EAAE,WAAW,EAAE,OAAO,GAAG,CAAC,EAAE,CAAC,CAAC;wBAC1G,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wBAA1B,SAA0B,CAAC;wBAC3B,WAAO,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,GAAG,CAAC,CAAC,EAAC;6BAErD,MAAM,OAAK,CAAC;;;;;KAEf;IAEK,yCAAkB,GAAxB;4DAAyB,OAAW;;YAAX,wBAAA,EAAA,WAAW;;;;wBAC5B,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;wBACjD,IAAI,CAAC,OAAO,EAAE,CAAC;4BACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,uCAAuC,CAAC,CAAC;4BAC1E,WAAO,IAAI,GAAG,EAAE,EAAC;wBACnB,CAAC;wBAED,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,6BAA6B,EAAE;4BAC/D,YAAY,EAAE,OAAO,CAAC,KAAK;4BAC3B,WAAW,EAAE,OAAO;yBACrB,CAAC,CAAC;;;;wBAGc,WAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,EAAA;;wBAAnD,MAAM,GAAG,SAA0C;wBAEzD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,iCAAiC,EAAE;4BAClE,WAAW,EAAE,MAAM,CAAC,IAAI;yBACzB,CAAC,CAAC;wBAEG,KAAK,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;6BACvC,KAAK,EAAL,cAAK;wBACP,WAAM,iBAAiB,CAAC,KAAK,CAAC,EAAA;;wBAA9B,SAA8B,CAAC;;4BAEjC,WAAO,MAAM,EAAC;;;wBAEd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,EAAE,2BAA2B,EAAE,EAAE,KAAK,SAAA,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC;6BAC5F,CAAA,OAAK,YAAY,mBAAmB,IAAI,OAAO,GAAG,CAAC,CAAA,EAAnD,cAAmD;wBACrD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,yCAAyC,EAAE,EAAE,WAAW,EAAE,OAAO,GAAG,CAAC,EAAE,CAAC,CAAC;wBAC1G,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wBAA1B,SAA0B,CAAC;wBAC3B,WAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,GAAG,CAAC,CAAC,EAAC;4BAE9C,MAAM,OAAK,CAAC;;;;;KAEf;IAEK,oCAAa,GAAnB,UAAoB,YAAqB;;;;gBACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,kBAAkB,EAAE,EAAE,YAAY,cAAA,EAAE,CAAC,CAAC;gBACvE,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;gBAC3D,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;gBAEvB,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;gBACpD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,iBAAiB,EAAE;oBAClD,eAAe,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,KAAK;iBACnC,CAAC,CAAC;;;;KACJ;IAED,sCAAe,GAAf;;QACE,IAAM,KAAK,GAAG,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,WAAW,EAAE,KAAI,IAAI,CAAC;QACxD,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,qBAAqB,EAAE,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC;YACnE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,yBAAyB,CAAC,CAAC;QAC9D,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,0CAAmB,GAAnB,UAAoB,KAAa,EAAE,KAAgB;QACjD,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,sCAAe,GAAf;QACE,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,+CAAwB,GAAxB,UAAyB,QAA+B;QACtD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,iCAAiC,EAAE;YAClE,eAAe,EAAE,QAAQ,CAAC,eAAe;YACzC,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,cAAc,EAAE,QAAQ,CAAC,cAAc;SACxC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;IACtE,CAAC;IACH,mBAAC;AAAD,CAAC,AAzMD,IAyMC;;AAED,MAAM,UAAgB,QAAQ,CAAC,MAAqB;;;;;;oBAC5C,OAAO,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;oBACzC,WAAM,OAAO,CAAC,UAAU,EAAE,EAAA;;oBAA1B,SAA0B,CAAC;oBAE3B,WAAO;4BACC,QAAQ;;;wCACZ,WAAO,OAAO,CAAC,QAAQ,EAAE,EAAC;;;6BAC3B;4BAEK,QAAQ;;;wCACZ,WAAO,OAAO,CAAC,QAAQ,EAAE,EAAC;;;6BAC3B;4BAEK,aAAa;;;wCACjB,WAAO,OAAO,CAAC,aAAa,EAAE,EAAC;;;6BAChC;4BAED,eAAe;gCACb,OAAO,OAAO,CAAC,eAAe,EAAE,CAAC;4BACnC,CAAC;4BAED,mBAAmB,YAAC,KAAa,EAAE,KAAgB;gCACjD,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;4BAC5C,CAAC;4BAED,eAAe;gCACb,OAAO,OAAO,CAAC,eAAe,EAAE,CAAC;4BACnC,CAAC;4BAED,wBAAwB,YAAC,QAA+B;gCACtD,OAAO,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;4BAC7C,CAAC;yBACF,EAAC;;;;CACH"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-tools.d.ts","sourceRoot":"","sources":["../src/plugin-tools.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"plugin-tools.d.ts","sourceRoot":"","sources":["../src/plugin-tools.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAG5C,wBAAgB,gBAAgB,CAAC,MAAM,CAAC,EAAE,YAAY;;;;uBAS5B;YAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;SAAE,QAAa,GAAG;;;;;sBA4EtC;YAAE,KAAK,EAAE,MAAM,CAAA;SAAE,QAAQ,GAAG;;;;;uBAuC3B;YAAE,YAAY,CAAC,EAAE,MAAM,CAAA;SAAE,QAAQ,GAAG;;EAgB9D"}
|
package/dist/plugin-tools.js
CHANGED
|
@@ -63,9 +63,11 @@ var __values = (this && this.__values) || function(o) {
|
|
|
63
63
|
};
|
|
64
64
|
import { QuotaManager } from './manager';
|
|
65
65
|
import { HardLimitDetector } from './rotation/HardLimitDetector';
|
|
66
|
+
import { getLogger } from './utils/logger';
|
|
66
67
|
export function createQuotaTools(config) {
|
|
67
68
|
var manager = new QuotaManager(config);
|
|
68
69
|
var detector = new HardLimitDetector(config);
|
|
70
|
+
var logger = getLogger();
|
|
69
71
|
return {
|
|
70
72
|
quota_status: {
|
|
71
73
|
description: 'Check current quota status for Antigravity models. Use detailed=true for all models.',
|
|
@@ -77,7 +79,9 @@ export function createQuotaTools(config) {
|
|
|
77
79
|
if (args === void 0) { args = {}; }
|
|
78
80
|
return __generator(this, function (_c) {
|
|
79
81
|
switch (_c.label) {
|
|
80
|
-
case 0:
|
|
82
|
+
case 0:
|
|
83
|
+
logger.info('PluginTools', 'quota_status invoked', { detailed: args.detailed });
|
|
84
|
+
return [4, manager.initialize()];
|
|
81
85
|
case 1:
|
|
82
86
|
_c.sent();
|
|
83
87
|
return [4, manager.getQuotaViaApi()];
|
|
@@ -86,6 +90,7 @@ export function createQuotaTools(config) {
|
|
|
86
90
|
accounts = manager['tokenReader'].getAccounts();
|
|
87
91
|
activeIndex = manager['tokenReader'].getActiveIndex();
|
|
88
92
|
if (!currentQuota) {
|
|
93
|
+
logger.error('PluginTools', 'quota_status: could not fetch quota');
|
|
89
94
|
return [2, 'Could not fetch quota information. Ensure opencode-antigravity-auth is configured.'];
|
|
90
95
|
}
|
|
91
96
|
percentage = Math.round(currentQuota.remainingFraction * 100);
|
|
@@ -168,7 +173,9 @@ export function createQuotaTools(config) {
|
|
|
168
173
|
return __generator(this, function (_a) {
|
|
169
174
|
switch (_a.label) {
|
|
170
175
|
case 0:
|
|
176
|
+
logger.info('PluginTools', 'quota_check_model invoked', { model: args.model });
|
|
171
177
|
if (!args.model) {
|
|
178
|
+
logger.error('PluginTools', 'quota_check_model: missing model argument');
|
|
172
179
|
return [2, 'Error: model argument is required. Example: quota_check_model({model: "gemini-3-pro"})'];
|
|
173
180
|
}
|
|
174
181
|
return [4, detector.checkHardLimit(args.model)];
|
|
@@ -209,7 +216,9 @@ export function createQuotaTools(config) {
|
|
|
209
216
|
var resetDate, now, minutesUntilReset;
|
|
210
217
|
return __generator(this, function (_a) {
|
|
211
218
|
switch (_a.label) {
|
|
212
|
-
case 0:
|
|
219
|
+
case 0:
|
|
220
|
+
logger.info('PluginTools', 'quota_rotate_account invoked', { resetTimeISO: args === null || args === void 0 ? void 0 : args.resetTimeISO });
|
|
221
|
+
return [4, manager.rotateAccount(args === null || args === void 0 ? void 0 : args.resetTimeISO)];
|
|
213
222
|
case 1:
|
|
214
223
|
_a.sent();
|
|
215
224
|
if (args === null || args === void 0 ? void 0 : args.resetTimeISO) {
|
package/dist/plugin-tools.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-tools.js","sourceRoot":"","sources":["../src/plugin-tools.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"plugin-tools.js","sourceRoot":"","sources":["../src/plugin-tools.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ApiQuotaPoller.d.ts","sourceRoot":"","sources":["../../src/quota/ApiQuotaPoller.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAoClD,MAAM,WAAW,SAAS;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;
|
|
1
|
+
{"version":3,"file":"ApiQuotaPoller.d.ts","sourceRoot":"","sources":["../../src/quota/ApiQuotaPoller.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAoClD,MAAM,WAAW,SAAS;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAYD,qBAAa,mBAAoB,SAAQ,KAAK;gBAChC,OAAO,EAAE,MAAM;CAI5B;AAID,qBAAa,cAAc;;YAQX,kBAAkB;YAuClB,cAAc;IA4B5B,OAAO,CAAC,gBAAgB;YASV,oBAAoB;IAgC5B,UAAU,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IAuDjE,kBAAkB,CAAC,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAwB5F,YAAY,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAqBhF"}
|
|
@@ -81,10 +81,9 @@ var ANTIGRAVITY_CLIENT_SECRET = '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';
|
|
|
81
81
|
var GOOGLE_TOKEN_URL = 'https://oauth2.googleapis.com/token';
|
|
82
82
|
var CLOUDCODE_BASE_URL = 'https://cloudcode-pa.googleapis.com';
|
|
83
83
|
var CLOUDCODE_METADATA = {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
ideName: 'vscode',
|
|
84
|
+
ideType: 'ANTIGRAVITY',
|
|
85
|
+
platform: 'PLATFORM_UNSPECIFIED',
|
|
86
|
+
pluginType: 'GEMINI',
|
|
88
87
|
};
|
|
89
88
|
var AuthenticationError = (function (_super) {
|
|
90
89
|
__extends(AuthenticationError, _super);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ApiQuotaPoller.js","sourceRoot":"","sources":["../../src/quota/ApiQuotaPoller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkDA,IAAM,qBAAqB,GAAG,2EAA2E,CAAC;AAC1G,IAAM,yBAAyB,GAAG,qCAAqC,CAAC;AACxE,IAAM,gBAAgB,GAAG,qCAAqC,CAAC;AAC/D,IAAM,kBAAkB,GAAG,qCAAqC,CAAC;AACjE,IAAM,kBAAkB,GAAG;IACzB,
|
|
1
|
+
{"version":3,"file":"ApiQuotaPoller.js","sourceRoot":"","sources":["../../src/quota/ApiQuotaPoller.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,6 +13,7 @@ export declare class HardLimitDetector {
|
|
|
13
13
|
private quotaTracker;
|
|
14
14
|
private modelSelector;
|
|
15
15
|
private quotaThreshold;
|
|
16
|
+
private logger;
|
|
16
17
|
constructor(config?: PluginConfig);
|
|
17
18
|
checkHardLimit(currentModel: string): Promise<HardLimitCheckResult>;
|
|
18
19
|
updateAllQuotas(): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HardLimitDetector.d.ts","sourceRoot":"","sources":["../../src/rotation/HardLimitDetector.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAa,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"HardLimitDetector.d.ts","sourceRoot":"","sources":["../../src/rotation/HardLimitDetector.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAa,MAAM,UAAU,CAAC;AAG1E,MAAM,WAAW,oBAAoB;IACnC,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,WAAW,CAAsB;IACzC,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,aAAa,CAAwB;IAC7C,OAAO,CAAC,cAAc,CAAU;IAChC,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,CAAC,EAAE,YAAY;IAiC3B,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IA0HnE,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IA0BtC,wBAAwB,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAS/D,eAAe,IAAI,YAAY;IAIzB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAKrC"}
|
|
@@ -66,8 +66,10 @@ import { AccountRotator } from '../auth/AccountRotator';
|
|
|
66
66
|
import { ApiQuotaPoller } from '../quota/ApiQuotaPoller';
|
|
67
67
|
import { QuotaTracker } from '../rotation/QuotaTracker';
|
|
68
68
|
import { ModelSelector } from '../rotation/ModelSelector';
|
|
69
|
+
import { getLogger } from '../utils/logger';
|
|
69
70
|
var HardLimitDetector = (function () {
|
|
70
71
|
function HardLimitDetector(config) {
|
|
72
|
+
this.logger = getLogger();
|
|
71
73
|
if (!(this instanceof HardLimitDetector)) {
|
|
72
74
|
return new HardLimitDetector(config);
|
|
73
75
|
}
|
|
@@ -76,9 +78,15 @@ var HardLimitDetector = (function () {
|
|
|
76
78
|
var activeIndex = this.tokenReader.getActiveIndex();
|
|
77
79
|
this.rotator = new AccountRotator(accounts, activeIndex);
|
|
78
80
|
this.apiPoller = new ApiQuotaPoller();
|
|
79
|
-
this.quotaThreshold = (config === null || config === void 0 ? void 0 : config.quotaThreshold) || 0.
|
|
81
|
+
this.quotaThreshold = (config === null || config === void 0 ? void 0 : config.quotaThreshold) || 0.02;
|
|
80
82
|
this.quotaTracker = new QuotaTracker(this.quotaThreshold);
|
|
81
83
|
this.modelSelector = null;
|
|
84
|
+
this.logger.info('HardLimitDetector', 'Initialized', {
|
|
85
|
+
quotaThreshold: this.quotaThreshold,
|
|
86
|
+
thresholdPercentage: "".concat((this.quotaThreshold * 100).toFixed(1), "%"),
|
|
87
|
+
accountsCount: accounts.length,
|
|
88
|
+
activeIndex: activeIndex,
|
|
89
|
+
});
|
|
82
90
|
if (config === null || config === void 0 ? void 0 : config.preferredModels) {
|
|
83
91
|
var strategy = {
|
|
84
92
|
preferredModels: config.preferredModels,
|
|
@@ -90,33 +98,54 @@ var HardLimitDetector = (function () {
|
|
|
90
98
|
}
|
|
91
99
|
HardLimitDetector.prototype.checkHardLimit = function (currentModel) {
|
|
92
100
|
return __awaiter(this, void 0, void 0, function () {
|
|
93
|
-
var account, quota, nextModel, nextModel;
|
|
101
|
+
var account, quota, quotaPercentage, nextModel, nextModel;
|
|
94
102
|
var _a, _b;
|
|
95
103
|
return __generator(this, function (_c) {
|
|
96
104
|
switch (_c.label) {
|
|
97
105
|
case 0:
|
|
106
|
+
this.logger.debug('HardLimitDetector', 'Starting hard limit check', { currentModel: currentModel });
|
|
98
107
|
account = this.rotator.getCurrentAccount();
|
|
99
108
|
if (!account) {
|
|
109
|
+
this.logger.warn('HardLimitDetector', 'No active account found');
|
|
100
110
|
return [2, {
|
|
101
111
|
isExhausted: false,
|
|
102
112
|
shouldRotate: false,
|
|
103
113
|
message: 'No active account found',
|
|
104
114
|
}];
|
|
105
115
|
}
|
|
116
|
+
this.logger.debug('HardLimitDetector', 'Fetching quota from API', {
|
|
117
|
+
model: currentModel,
|
|
118
|
+
accountEmail: account.email,
|
|
119
|
+
});
|
|
106
120
|
return [4, this.apiPoller.checkQuotaForModel(account, currentModel)];
|
|
107
121
|
case 1:
|
|
108
122
|
quota = _c.sent();
|
|
109
123
|
if (!quota) {
|
|
124
|
+
this.logger.error('HardLimitDetector', 'Failed to fetch quota information', { currentModel: currentModel });
|
|
110
125
|
return [2, {
|
|
111
126
|
isExhausted: false,
|
|
112
127
|
shouldRotate: false,
|
|
113
128
|
message: 'Could not fetch quota information',
|
|
114
129
|
}];
|
|
115
130
|
}
|
|
131
|
+
quotaPercentage = (quota.remainingFraction * 100).toFixed(1);
|
|
132
|
+
this.logger.info('HardLimitDetector', 'Quota fetched successfully', {
|
|
133
|
+
model: currentModel,
|
|
134
|
+
remainingFraction: quota.remainingFraction,
|
|
135
|
+
quotaPercentage: "".concat(quotaPercentage, "%"),
|
|
136
|
+
resetTime: quota.resetTime,
|
|
137
|
+
});
|
|
116
138
|
this.quotaTracker.updateQuota(currentModel, quota);
|
|
117
139
|
if (quota.remainingFraction <= 0) {
|
|
140
|
+
this.logger.warn('HardLimitDetector', 'Model quota exhausted (0%)', {
|
|
141
|
+
model: currentModel,
|
|
142
|
+
resetTime: quota.resetTime,
|
|
143
|
+
});
|
|
118
144
|
nextModel = (_a = this.modelSelector) === null || _a === void 0 ? void 0 : _a.selectModel();
|
|
119
145
|
if (!nextModel) {
|
|
146
|
+
this.logger.info('HardLimitDetector', 'No alternative model available, rotating account', {
|
|
147
|
+
currentModel: currentModel,
|
|
148
|
+
});
|
|
120
149
|
this.rotator.markCurrentExhausted(undefined, quota.resetTime);
|
|
121
150
|
return [2, {
|
|
122
151
|
isExhausted: true,
|
|
@@ -124,6 +153,11 @@ var HardLimitDetector = (function () {
|
|
|
124
153
|
message: "Model ".concat(currentModel, " exhausted (0% quota). Rotated to next account."),
|
|
125
154
|
}];
|
|
126
155
|
}
|
|
156
|
+
this.logger.info('HardLimitDetector', 'Switching to alternative model (exhausted)', {
|
|
157
|
+
fromModel: currentModel,
|
|
158
|
+
toModel: nextModel,
|
|
159
|
+
reason: 'Model exhausted',
|
|
160
|
+
});
|
|
127
161
|
return [2, {
|
|
128
162
|
isExhausted: true,
|
|
129
163
|
shouldRotate: true,
|
|
@@ -132,20 +166,48 @@ var HardLimitDetector = (function () {
|
|
|
132
166
|
}];
|
|
133
167
|
}
|
|
134
168
|
if (quota.remainingFraction < this.quotaThreshold) {
|
|
169
|
+
this.logger.warn('HardLimitDetector', 'Model below threshold', {
|
|
170
|
+
model: currentModel,
|
|
171
|
+
remainingFraction: quota.remainingFraction,
|
|
172
|
+
quotaPercentage: "".concat(quotaPercentage, "%"),
|
|
173
|
+
threshold: this.quotaThreshold,
|
|
174
|
+
thresholdPercentage: "".concat((this.quotaThreshold * 100).toFixed(1), "%"),
|
|
175
|
+
});
|
|
135
176
|
nextModel = (_b = this.modelSelector) === null || _b === void 0 ? void 0 : _b.selectModel();
|
|
136
177
|
if (nextModel && nextModel !== currentModel) {
|
|
178
|
+
this.logger.info('HardLimitDetector', 'Triggering model switch (below threshold)', {
|
|
179
|
+
fromModel: currentModel,
|
|
180
|
+
toModel: nextModel,
|
|
181
|
+
currentQuota: "".concat(quotaPercentage, "%"),
|
|
182
|
+
threshold: "".concat((this.quotaThreshold * 100).toFixed(1), "%"),
|
|
183
|
+
reason: 'Below threshold',
|
|
184
|
+
});
|
|
137
185
|
return [2, {
|
|
138
186
|
isExhausted: false,
|
|
139
187
|
shouldRotate: true,
|
|
140
188
|
nextModel: nextModel,
|
|
141
|
-
message: "Model ".concat(currentModel, " below threshold (").concat(
|
|
189
|
+
message: "Model ".concat(currentModel, " below threshold (").concat(quotaPercentage, "%). Switching to ").concat(nextModel, "."),
|
|
142
190
|
}];
|
|
143
191
|
}
|
|
192
|
+
else {
|
|
193
|
+
this.logger.warn('HardLimitDetector', 'Below threshold but no alternative model', {
|
|
194
|
+
model: currentModel,
|
|
195
|
+
quotaPercentage: "".concat(quotaPercentage, "%"),
|
|
196
|
+
nextModel: nextModel,
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
this.logger.debug('HardLimitDetector', 'Model quota healthy', {
|
|
202
|
+
model: currentModel,
|
|
203
|
+
quotaPercentage: "".concat(quotaPercentage, "%"),
|
|
204
|
+
threshold: "".concat((this.quotaThreshold * 100).toFixed(1), "%"),
|
|
205
|
+
});
|
|
144
206
|
}
|
|
145
207
|
return [2, {
|
|
146
208
|
isExhausted: false,
|
|
147
209
|
shouldRotate: false,
|
|
148
|
-
message: "Model ".concat(currentModel, " has ").concat(
|
|
210
|
+
message: "Model ".concat(currentModel, " has ").concat(quotaPercentage, "% quota remaining."),
|
|
149
211
|
}];
|
|
150
212
|
}
|
|
151
213
|
});
|
|
@@ -158,16 +220,28 @@ var HardLimitDetector = (function () {
|
|
|
158
220
|
return __generator(this, function (_e) {
|
|
159
221
|
switch (_e.label) {
|
|
160
222
|
case 0:
|
|
223
|
+
this.logger.debug('HardLimitDetector', 'Updating all quotas');
|
|
161
224
|
account = this.rotator.getCurrentAccount();
|
|
162
|
-
if (!account)
|
|
225
|
+
if (!account) {
|
|
226
|
+
this.logger.warn('HardLimitDetector', 'Cannot update quotas: no account available');
|
|
163
227
|
return [2];
|
|
228
|
+
}
|
|
164
229
|
return [4, this.apiPoller.getAllQuotas(account)];
|
|
165
230
|
case 1:
|
|
166
231
|
quotas = _e.sent();
|
|
232
|
+
this.logger.info('HardLimitDetector', 'Fetched all quotas', {
|
|
233
|
+
accountEmail: account.email,
|
|
234
|
+
modelsCount: quotas.size,
|
|
235
|
+
});
|
|
167
236
|
try {
|
|
168
237
|
for (_a = __values(quotas.entries()), _b = _a.next(); !_b.done; _b = _a.next()) {
|
|
169
238
|
_c = __read(_b.value, 2), model = _c[0], quota = _c[1];
|
|
170
239
|
this.quotaTracker.updateQuota(model, quota);
|
|
240
|
+
this.logger.debug('HardLimitDetector', 'Updated quota for model', {
|
|
241
|
+
model: model,
|
|
242
|
+
remainingFraction: quota.remainingFraction,
|
|
243
|
+
quotaPercentage: "".concat((quota.remainingFraction * 100).toFixed(1), "%"),
|
|
244
|
+
});
|
|
171
245
|
}
|
|
172
246
|
}
|
|
173
247
|
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
@@ -183,6 +257,11 @@ var HardLimitDetector = (function () {
|
|
|
183
257
|
});
|
|
184
258
|
};
|
|
185
259
|
HardLimitDetector.prototype.setModelRotationStrategy = function (strategy) {
|
|
260
|
+
this.logger.info('HardLimitDetector', 'Setting model rotation strategy', {
|
|
261
|
+
preferredModels: strategy.preferredModels,
|
|
262
|
+
fallbackModels: strategy.fallbackModels,
|
|
263
|
+
quotaThreshold: strategy.quotaThreshold,
|
|
264
|
+
});
|
|
186
265
|
this.modelSelector = new ModelSelector(this.quotaTracker, strategy);
|
|
187
266
|
};
|
|
188
267
|
HardLimitDetector.prototype.getQuotaTracker = function () {
|
|
@@ -191,6 +270,7 @@ var HardLimitDetector = (function () {
|
|
|
191
270
|
HardLimitDetector.prototype.rotateAccount = function () {
|
|
192
271
|
return __awaiter(this, void 0, void 0, function () {
|
|
193
272
|
return __generator(this, function (_a) {
|
|
273
|
+
this.logger.info('HardLimitDetector', 'Manually rotating account');
|
|
194
274
|
this.rotator.markCurrentExhausted();
|
|
195
275
|
this.quotaTracker.clearAll();
|
|
196
276
|
return [2];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HardLimitDetector.js","sourceRoot":"","sources":["../../src/rotation/HardLimitDetector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"HardLimitDetector.js","sourceRoot":"","sources":["../../src/rotation/HardLimitDetector.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,6 +3,7 @@ import { ModelRotationStrategy } from '../types';
|
|
|
3
3
|
export declare class ModelSelector {
|
|
4
4
|
private quotaTracker;
|
|
5
5
|
private strategy;
|
|
6
|
+
private logger;
|
|
6
7
|
constructor(quotaTracker: QuotaTracker, strategy: ModelRotationStrategy);
|
|
7
8
|
selectModel(): string | null;
|
|
8
9
|
updateStrategy(strategy: Partial<ModelRotationStrategy>): void;
|
|
@@ -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,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.2",
|
|
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",
|