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

119 lines
4.2 KiB
JavaScript

'use strict';
var eventstreamCodec = require('@smithy/eventstream-codec');
var node_stream = require('node:stream');
class EventSigningTransformStream extends node_stream.Transform {
priorSignature;
messageSigner;
eventStreamCodec;
systemClockOffsetProvider;
constructor(options) {
super({
autoDestroy: true,
readableObjectMode: true,
writableObjectMode: true,
...options,
});
this.priorSignature = options.priorSignature;
this.eventStreamCodec = options.eventStreamCodec;
this.messageSigner = options.messageSigner;
this.systemClockOffsetProvider = options.systemClockOffsetProvider;
}
async _transform(chunk, encoding, callback) {
try {
const now = new Date(Date.now() + (await this.systemClockOffsetProvider()));
const dateHeader = {
":date": { type: "timestamp", value: now },
};
const signedMessage = await this.messageSigner.sign({
message: {
body: chunk,
headers: dateHeader,
},
priorSignature: this.priorSignature,
}, {
signingDate: now,
});
this.priorSignature = signedMessage.signature;
const serializedSigned = this.eventStreamCodec.encode({
headers: {
...dateHeader,
":chunk-signature": {
type: "binary",
value: getSignatureBinary(signedMessage.signature),
},
},
body: chunk,
});
this.push(serializedSigned);
return callback();
}
catch (err) {
callback(err);
}
}
}
function getSignatureBinary(signature) {
const buf = Buffer.from(signature, "hex");
return new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength / Uint8Array.BYTES_PER_ELEMENT);
}
class EventStreamPayloadHandler {
messageSigner;
eventStreamCodec;
systemClockOffsetProvider;
constructor(options) {
this.messageSigner = options.messageSigner;
this.eventStreamCodec = new eventstreamCodec.EventStreamCodec(options.utf8Encoder, options.utf8Decoder);
this.systemClockOffsetProvider = async () => options.systemClockOffset ?? 0;
}
async handle(next, args, context = {}) {
const request = args.request;
const { body: payload, query } = request;
if (!(payload instanceof node_stream.Readable)) {
throw new Error("Eventstream payload must be a Readable stream.");
}
const payloadStream = payload;
request.body = new node_stream.PassThrough({
objectMode: true,
});
const match = request.headers?.authorization?.match(/Signature=([\w]+)$/);
let priorSignature = match?.[1] ?? query?.["X-Amz-Signature"] ?? "";
if (context.__staticSignature) {
priorSignature = "";
}
const signingStream = new EventSigningTransformStream({
priorSignature,
eventStreamCodec: this.eventStreamCodec,
messageSigner: await this.messageSigner(),
systemClockOffsetProvider: this.systemClockOffsetProvider,
});
let resolvePipeline;
const pipelineError = new Promise((resolve, reject) => {
resolvePipeline = () => resolve(undefined);
node_stream.pipeline(payloadStream, signingStream, request.body, (err) => {
if (err) {
reject(new Error(`Pipeline error in @aws-sdk/eventstream-handler-node: ${err.message}`, { cause: err }));
}
});
});
let result;
try {
result = await Promise.race([next(args), pipelineError]);
}
catch (e) {
request.body.end();
throw e;
}
finally {
resolvePipeline();
}
return result;
}
}
const eventStreamPayloadHandlerProvider = (options) => new EventStreamPayloadHandler(options);
exports.eventStreamPayloadHandlerProvider = eventStreamPayloadHandlerProvider;