Current File : //usr/local/share/.config/yarn/global/node_modules/@pm2/io/build/main/census/plugins/http2.js |
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
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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"}