Edit File: http2.js
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.plugin = exports.Http2Plugin = void 0; const core_1 = require("@opencensus/core"); const http_1 = require("./http"); const shimmer = require("shimmer"); const url = require("url"); const uuid = require("uuid"); class Http2Plugin extends http_1.HttpPlugin { constructor() { super('http2'); } applyPatch() { shimmer.wrap(this.moduleExports, 'createServer', this.getPatchCreateServerFunction()); shimmer.wrap(this.moduleExports, 'createSecureServer', this.getPatchCreateServerFunction()); shimmer.wrap(this.moduleExports, 'connect', this.getPatchConnectFunction()); return this.moduleExports; } applyUnpatch() { shimmer.unwrap(this.moduleExports, 'createServer'); shimmer.unwrap(this.moduleExports, 'createSecureServer'); shimmer.unwrap(this.moduleExports, 'connect'); } getPatchConnectFunction() { const plugin = this; return (original) => { return function patchedConnect(authority) { const client = original.apply(this, arguments); shimmer.wrap(client, 'request', (original) => (plugin.getPatchRequestFunction())(original, authority)); shimmer.unwrap(plugin.moduleExports, 'connect'); return client; }; }; } getPatchRequestFunction() { const plugin = this; return (original, authority) => { return function patchedRequest(headers) { if (headers['x-opencensus-outgoing-request']) { return original.apply(this, arguments); } const request = original.apply(this, arguments); plugin.tracer.wrapEmitter(request); const traceOptions = { name: `http2-${(headers[':method'] || 'GET').toLowerCase()}`, kind: core_1.SpanKind.CLIENT }; if (!plugin.tracer.currentRootSpan) { return plugin.tracer.startRootSpan(traceOptions, plugin.getMakeHttp2RequestTraceFunction(request, headers, authority, plugin)); } else { const span = plugin.tracer.startChildSpan(traceOptions.name, traceOptions.kind); return (plugin.getMakeHttp2RequestTraceFunction(request, headers, authority, plugin))(span); } }; }; } getMakeHttp2RequestTraceFunction(request, headers, authority, plugin) { return (span) => { if (!span) return request; const setter = { setHeader(name, value) { headers[name] = value; } }; const propagation = plugin.tracer.propagation; if (propagation) { propagation.inject(setter, span.spanContext); } request.on('response', (responseHeaders) => { const status = `${responseHeaders[':status']}`; span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_STATUS_CODE, status); span.setStatus(Http2Plugin.convertTraceStatus(parseInt(status, 10))); }); request.on('end', () => { const userAgent = headers['user-agent'] || headers['User-Agent'] || null; span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_HOST, `${url.parse(authority).host}`); span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_METHOD, `${headers[':method']}`); span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_PATH, `${headers[':path']}`); span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_ROUTE, `${headers[':path']}`); if (userAgent) { span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_USER_AGENT, `${userAgent}`); } span.addMessageEvent(core_1.MessageEventType.SENT, uuid.v4().split('-').join('')); span.end(); }); request.on('error', (err) => { span.addAttribute(http_1.HttpPlugin.ATTRIBUTE_HTTP_ERROR_NAME, err.name); span.addAttribute(http_1.HttpPlugin.ATTRIBUTE_HTTP_ERROR_MESSAGE, err.message); span.setStatus(core_1.CanonicalCode.UNKNOWN, err.message); span.end(); }); return request; }; } getPatchCreateServerFunction() { const plugin = this; return (original) => { return function patchedCreateServer() { const server = original.apply(this, arguments); shimmer.wrap(server.constructor.prototype, 'emit', plugin.getPatchEmitFunction()); shimmer.unwrap(plugin.moduleExports, 'createServer'); shimmer.unwrap(plugin.moduleExports, 'createSecureServer'); return server; }; }; } getPatchEmitFunction() { const plugin = this; return (original) => { return function patchedEmit(event, stream, headers) { if (event !== 'stream') { return original.apply(this, arguments); } const propagation = plugin.tracer.propagation; const getter = { getHeader(name) { return headers[name]; } }; const traceOptions = { name: headers[':path'], kind: core_1.SpanKind.SERVER, spanContext: propagation ? propagation.extract(getter) : null }; let statusCode = 0; const originalRespond = stream.respond; stream.respond = function () { stream.respond = originalRespond; statusCode = arguments[0][':status']; return stream.respond.apply(this, arguments); }; return plugin.tracer.startRootSpan(traceOptions, rootSpan => { if (!rootSpan) return original.apply(this, arguments); plugin.tracer.wrapEmitter(stream); const originalEnd = stream.end; stream.end = function () { stream.end = originalEnd; const returned = stream.end.apply(this, arguments); const userAgent = (headers['user-agent'] || headers['User-Agent'] || null); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_HOST, `${headers[':authority']}`); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_METHOD, `${headers[':method']}`); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_PATH, `${headers[':path']}`); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_ROUTE, `${headers[':path']}`); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_USER_AGENT, userAgent); rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_STATUS_CODE, `${statusCode}`); rootSpan.setStatus(Http2Plugin.convertTraceStatus(statusCode)); rootSpan.addMessageEvent(core_1.MessageEventType.RECEIVED, uuid.v4().split('-').join('')); rootSpan.end(); return returned; }; return original.apply(this, arguments); }); }; }; } } exports.Http2Plugin = Http2Plugin; const plugin = new Http2Plugin(); exports.plugin = plugin; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http2.js","sourceRoot":"","sources":["../../../../src/census/plugins/http2.ts"],"names":[],"mappings":"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"}
Back to File Manager