http2.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. const core_1 = require("@opencensus/core");
  4. const http_1 = require("./http");
  5. const shimmer = require("shimmer");
  6. const url = require("url");
  7. const uuid = require("uuid");
  8. class Http2Plugin extends http_1.HttpPlugin {
  9. constructor() {
  10. super('http2');
  11. }
  12. applyPatch() {
  13. shimmer.wrap(this.moduleExports, 'createServer', this.getPatchCreateServerFunction());
  14. shimmer.wrap(this.moduleExports, 'createSecureServer', this.getPatchCreateServerFunction());
  15. shimmer.wrap(this.moduleExports, 'connect', this.getPatchConnectFunction());
  16. return this.moduleExports;
  17. }
  18. applyUnpatch() {
  19. shimmer.unwrap(this.moduleExports, 'createServer');
  20. shimmer.unwrap(this.moduleExports, 'createSecureServer');
  21. shimmer.unwrap(this.moduleExports, 'connect');
  22. }
  23. getPatchConnectFunction() {
  24. const plugin = this;
  25. return (original) => {
  26. return function patchedConnect(authority) {
  27. const client = original.apply(this, arguments);
  28. shimmer.wrap(client, 'request', (original) => (plugin.getPatchRequestFunction())(original, authority));
  29. shimmer.unwrap(plugin.moduleExports, 'connect');
  30. return client;
  31. };
  32. };
  33. }
  34. getPatchRequestFunction() {
  35. const plugin = this;
  36. return (original, authority) => {
  37. return function patchedRequest(headers) {
  38. if (headers['x-opencensus-outgoing-request']) {
  39. return original.apply(this, arguments);
  40. }
  41. const request = original.apply(this, arguments);
  42. plugin.tracer.wrapEmitter(request);
  43. const traceOptions = {
  44. name: `http2-${(headers[':method'] || 'GET').toLowerCase()}`,
  45. kind: core_1.SpanKind.CLIENT
  46. };
  47. if (!plugin.tracer.currentRootSpan) {
  48. return plugin.tracer.startRootSpan(traceOptions, plugin.getMakeHttp2RequestTraceFunction(request, headers, authority, plugin));
  49. }
  50. else {
  51. const span = plugin.tracer.startChildSpan(traceOptions.name, traceOptions.kind);
  52. return (plugin.getMakeHttp2RequestTraceFunction(request, headers, authority, plugin))(span);
  53. }
  54. };
  55. };
  56. }
  57. getMakeHttp2RequestTraceFunction(request, headers, authority, plugin) {
  58. return (span) => {
  59. if (!span)
  60. return request;
  61. const setter = {
  62. setHeader(name, value) {
  63. headers[name] = value;
  64. }
  65. };
  66. const propagation = plugin.tracer.propagation;
  67. if (propagation) {
  68. propagation.inject(setter, span.spanContext);
  69. }
  70. request.on('response', (responseHeaders) => {
  71. const status = `${responseHeaders[':status']}`;
  72. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_STATUS_CODE, status);
  73. span.setStatus(Http2Plugin.convertTraceStatus(parseInt(status, 10)));
  74. });
  75. request.on('end', () => {
  76. const userAgent = headers['user-agent'] || headers['User-Agent'] || null;
  77. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_HOST, `${url.parse(authority).host}`);
  78. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_METHOD, `${headers[':method']}`);
  79. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_PATH, `${headers[':path']}`);
  80. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_ROUTE, `${headers[':path']}`);
  81. if (userAgent) {
  82. span.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_USER_AGENT, `${userAgent}`);
  83. }
  84. span.addMessageEvent(core_1.MessageEventType.SENT, uuid.v4().split('-').join(''));
  85. span.end();
  86. });
  87. request.on('error', (err) => {
  88. span.addAttribute(http_1.HttpPlugin.ATTRIBUTE_HTTP_ERROR_NAME, err.name);
  89. span.addAttribute(http_1.HttpPlugin.ATTRIBUTE_HTTP_ERROR_MESSAGE, err.message);
  90. span.setStatus(core_1.CanonicalCode.UNKNOWN, err.message);
  91. span.end();
  92. });
  93. return request;
  94. };
  95. }
  96. getPatchCreateServerFunction() {
  97. const plugin = this;
  98. return (original) => {
  99. return function patchedCreateServer() {
  100. const server = original.apply(this, arguments);
  101. shimmer.wrap(server.constructor.prototype, 'emit', plugin.getPatchEmitFunction());
  102. shimmer.unwrap(plugin.moduleExports, 'createServer');
  103. shimmer.unwrap(plugin.moduleExports, 'createSecureServer');
  104. return server;
  105. };
  106. };
  107. }
  108. getPatchEmitFunction() {
  109. const plugin = this;
  110. return (original) => {
  111. return function patchedEmit(event, stream, headers) {
  112. if (event !== 'stream') {
  113. return original.apply(this, arguments);
  114. }
  115. const propagation = plugin.tracer.propagation;
  116. const getter = {
  117. getHeader(name) {
  118. return headers[name];
  119. }
  120. };
  121. const traceOptions = {
  122. name: headers[':path'],
  123. kind: core_1.SpanKind.SERVER,
  124. spanContext: propagation ? propagation.extract(getter) : null
  125. };
  126. let statusCode = 0;
  127. const originalRespond = stream.respond;
  128. stream.respond = function () {
  129. stream.respond = originalRespond;
  130. statusCode = arguments[0][':status'];
  131. return stream.respond.apply(this, arguments);
  132. };
  133. return plugin.tracer.startRootSpan(traceOptions, rootSpan => {
  134. if (!rootSpan)
  135. return original.apply(this, arguments);
  136. plugin.tracer.wrapEmitter(stream);
  137. const originalEnd = stream.end;
  138. stream.end = function () {
  139. stream.end = originalEnd;
  140. const returned = stream.end.apply(this, arguments);
  141. const userAgent = (headers['user-agent'] || headers['User-Agent'] ||
  142. null);
  143. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_HOST, `${headers[':authority']}`);
  144. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_METHOD, `${headers[':method']}`);
  145. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_PATH, `${headers[':path']}`);
  146. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_ROUTE, `${headers[':path']}`);
  147. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_USER_AGENT, userAgent);
  148. rootSpan.addAttribute(Http2Plugin.ATTRIBUTE_HTTP_STATUS_CODE, `${statusCode}`);
  149. rootSpan.setStatus(Http2Plugin.convertTraceStatus(statusCode));
  150. rootSpan.addMessageEvent(core_1.MessageEventType.RECEIVED, uuid.v4().split('-').join(''));
  151. rootSpan.end();
  152. return returned;
  153. };
  154. return original.apply(this, arguments);
  155. });
  156. };
  157. };
  158. }
  159. }
  160. exports.Http2Plugin = Http2Plugin;
  161. const plugin = new Http2Plugin();
  162. exports.plugin = plugin;
  163. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http2.js","sourceRoot":"","sources":["../../../../src/census/plugins/http2.ts"],"names":[],"mappings":"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"}