Files
admin 875c7f9b91 feat: Complete zCode CLI X with Telegram bot integration
- Add full Telegram bot functionality with Z.AI API integration
- Implement 4 tools: Bash, FileEdit, WebSearch, Git
- Add 3 agents: Code Reviewer, Architect, DevOps Engineer
- Add 6 skills for common coding tasks
- Add systemd service file for 24/7 operation
- Add nginx configuration for HTTPS webhook
- Add comprehensive documentation
- Implement WebSocket server for real-time updates
- Add logging system with Winston
- Add environment validation

🤖 zCode CLI X - Agentic coder with Z.AI + Telegram integration
2026-05-05 09:01:26 +00:00

114 lines
4.3 KiB
JavaScript

/*
* Copyright The OpenTelemetry Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
import { AggregatorKind, } from './types';
import { DataPointType, } from '../export/MetricData';
var SumAccumulation = /** @class */ (function () {
function SumAccumulation(startTime, monotonic, _current, reset) {
if (_current === void 0) { _current = 0; }
if (reset === void 0) { reset = false; }
this.startTime = startTime;
this.monotonic = monotonic;
this._current = _current;
this.reset = reset;
}
SumAccumulation.prototype.record = function (value) {
if (this.monotonic && value < 0) {
return;
}
this._current += value;
};
SumAccumulation.prototype.setStartTime = function (startTime) {
this.startTime = startTime;
};
SumAccumulation.prototype.toPointValue = function () {
return this._current;
};
return SumAccumulation;
}());
export { SumAccumulation };
/** Basic aggregator which calculates a Sum from individual measurements. */
var SumAggregator = /** @class */ (function () {
function SumAggregator(monotonic) {
this.monotonic = monotonic;
this.kind = AggregatorKind.SUM;
}
SumAggregator.prototype.createAccumulation = function (startTime) {
return new SumAccumulation(startTime, this.monotonic);
};
/**
* Returns the result of the merge of the given accumulations.
*/
SumAggregator.prototype.merge = function (previous, delta) {
var prevPv = previous.toPointValue();
var deltaPv = delta.toPointValue();
if (delta.reset) {
return new SumAccumulation(delta.startTime, this.monotonic, deltaPv, delta.reset);
}
return new SumAccumulation(previous.startTime, this.monotonic, prevPv + deltaPv);
};
/**
* Returns a new DELTA aggregation by comparing two cumulative measurements.
*/
SumAggregator.prototype.diff = function (previous, current) {
var prevPv = previous.toPointValue();
var currPv = current.toPointValue();
/**
* If the SumAggregator is a monotonic one and the previous point value is
* greater than the current one, a reset is deemed to be happened.
* Return the current point value to prevent the value from been reset.
*/
if (this.monotonic && prevPv > currPv) {
return new SumAccumulation(current.startTime, this.monotonic, currPv, true);
}
return new SumAccumulation(current.startTime, this.monotonic, currPv - prevPv);
};
SumAggregator.prototype.toMetricData = function (descriptor, aggregationTemporality, accumulationByAttributes, endTime) {
return {
descriptor: descriptor,
aggregationTemporality: aggregationTemporality,
dataPointType: DataPointType.SUM,
dataPoints: accumulationByAttributes.map(function (_a) {
var _b = __read(_a, 2), attributes = _b[0], accumulation = _b[1];
return {
attributes: attributes,
startTime: accumulation.startTime,
endTime: endTime,
value: accumulation.toPointValue(),
};
}),
isMonotonic: this.monotonic,
};
};
return SumAggregator;
}());
export { SumAggregator };
//# sourceMappingURL=Sum.js.map