@kdump/code-cli-any-llm
Version:
> A unified gateway for the Gemini, opencode, crush, and Qwen Code AI CLIs
51 lines • 2.33 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var LoggingMiddleware_1;
Object.defineProperty(exports, "__esModule", { value: true });
exports.LoggingMiddleware = void 0;
const common_1 = require("@nestjs/common");
const logging_config_1 = require("../config/logging.config");
let LoggingMiddleware = LoggingMiddleware_1 = class LoggingMiddleware {
logger;
constructor() {
this.logger = new common_1.Logger(LoggingMiddleware_1.name);
}
use(req, res, next) {
const start = Date.now();
const { method, originalUrl, ip, headers } = req;
if (logging_config_1.requestLoggingConfig.skip(req)) {
return next();
}
this.logger.verbose(`[${method}] ${originalUrl}`, {
ip,
userAgent: headers['user-agent'],
timestamp: new Date().toISOString(),
});
const originalEnd = res.end.bind(res);
res.end = (chunk, encoding) => {
const duration = Date.now() - start;
const { statusCode } = res;
this.logger.verbose(`[${method}] ${originalUrl} ${statusCode} ${duration}ms`, {
statusCode,
duration,
timestamp: new Date().toISOString(),
});
return originalEnd.call(res, chunk, encoding);
};
next();
}
};
exports.LoggingMiddleware = LoggingMiddleware;
exports.LoggingMiddleware = LoggingMiddleware = LoggingMiddleware_1 = __decorate([
(0, common_1.Injectable)(),
__metadata("design:paramtypes", [])
], LoggingMiddleware);
//# sourceMappingURL=logging.middleware.js.map
;