notify.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. 'use strict';
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. const tslib_1 = require("tslib");
  4. const configuration_1 = require("../configuration");
  5. const serviceManager_1 = require("../serviceManager");
  6. const debug_1 = require("debug");
  7. const semver = require("semver");
  8. const stackParser_1 = require("../utils/stackParser");
  9. const fs = require("fs");
  10. const path = require("path");
  11. class NotifyOptions {
  12. }
  13. exports.NotifyOptions = NotifyOptions;
  14. class ErrorContext {
  15. }
  16. exports.ErrorContext = ErrorContext;
  17. const optionsDefault = {
  18. catchExceptions: true
  19. };
  20. class NotifyFeature {
  21. constructor() {
  22. this.logger = debug_1.default('axm:features:notify');
  23. }
  24. init(options) {
  25. if (options === undefined) {
  26. options = optionsDefault;
  27. }
  28. this.logger('init');
  29. this.transport = serviceManager_1.ServiceManager.get('transport');
  30. if (this.transport === undefined) {
  31. return this.logger(`Failed to load transporter service`);
  32. }
  33. configuration_1.default.configureModule({
  34. error: true
  35. });
  36. if (options.catchExceptions === false)
  37. return;
  38. this.logger('Registering hook to catch unhandled exception/rejection');
  39. this.cache = new stackParser_1.Cache({
  40. miss: (key) => {
  41. try {
  42. const content = fs.readFileSync(path.resolve(key));
  43. return content.toString().split(/\r?\n/);
  44. }
  45. catch (err) {
  46. this.logger('Error while trying to get file from FS : %s', err.message || err);
  47. return null;
  48. }
  49. },
  50. ttl: 30 * 60
  51. });
  52. this.stackParser = new stackParser_1.StackTraceParser({
  53. cache: this.cache,
  54. contextSize: 5
  55. });
  56. this.catchAll();
  57. }
  58. destroy() {
  59. process.removeListener('uncaughtException', this.onUncaughtException);
  60. process.removeListener('unhandledRejection', this.onUnhandledRejection);
  61. this.logger('destroy');
  62. }
  63. getSafeError(err) {
  64. if (err instanceof Error)
  65. return err;
  66. let message;
  67. try {
  68. message = `Non-error value: ${JSON.stringify(err)}`;
  69. }
  70. catch (e) {
  71. try {
  72. message = `Unserializable non-error value: ${String(e)}`;
  73. }
  74. catch (e2) {
  75. message = `Unserializable non-error value that cannot be converted to a string`;
  76. }
  77. }
  78. if (message.length > 1000)
  79. message = message.substr(0, 1000) + '...';
  80. return new Error(message);
  81. }
  82. notifyError(err, context) {
  83. if (typeof context !== 'object') {
  84. context = {};
  85. }
  86. if (this.transport === undefined) {
  87. return this.logger(`Tried to send error without having transporter available`);
  88. }
  89. const safeError = this.getSafeError(err);
  90. let stackContext = null;
  91. if (err instanceof Error) {
  92. stackContext = this.stackParser.retrieveContext(err);
  93. }
  94. const payload = Object.assign({
  95. message: safeError.message,
  96. stack: safeError.stack,
  97. name: safeError.name,
  98. metadata: context
  99. }, stackContext === null ? {} : stackContext);
  100. return this.transport.send('process:exception', payload);
  101. }
  102. onUncaughtException(error) {
  103. if (semver.satisfies(process.version, '< 6')) {
  104. console.error(error.stack);
  105. }
  106. else {
  107. console.error(error);
  108. }
  109. const safeError = this.getSafeError(error);
  110. let stackContext = null;
  111. if (error instanceof Error) {
  112. stackContext = this.stackParser.retrieveContext(error);
  113. }
  114. const payload = Object.assign({
  115. message: safeError.message,
  116. stack: safeError.stack,
  117. name: safeError.name
  118. }, stackContext === null ? {} : stackContext);
  119. if (serviceManager_1.ServiceManager.get('transport')) {
  120. serviceManager_1.ServiceManager.get('transport').send('process:exception', payload);
  121. }
  122. if (process.listeners('uncaughtException').length === 1) {
  123. process.exit(1);
  124. }
  125. }
  126. onUnhandledRejection(error) {
  127. if (error === undefined)
  128. return;
  129. console.error(error);
  130. const safeError = this.getSafeError(error);
  131. let stackContext = null;
  132. if (error instanceof Error) {
  133. stackContext = this.stackParser.retrieveContext(error);
  134. }
  135. const payload = Object.assign({
  136. message: safeError.message,
  137. stack: safeError.stack,
  138. name: safeError.name
  139. }, stackContext === null ? {} : stackContext);
  140. if (serviceManager_1.ServiceManager.get('transport')) {
  141. serviceManager_1.ServiceManager.get('transport').send('process:exception', payload);
  142. }
  143. }
  144. catchAll() {
  145. if (process.env.exec_mode === 'cluster_mode') {
  146. return false;
  147. }
  148. process.on('uncaughtException', this.onUncaughtException.bind(this));
  149. process.on('unhandledRejection', this.onUnhandledRejection.bind(this));
  150. }
  151. expressErrorHandler() {
  152. const self = this;
  153. configuration_1.default.configureModule({
  154. error: true
  155. });
  156. return function errorHandler(err, req, res, next) {
  157. const safeError = self.getSafeError(err);
  158. const payload = {
  159. message: safeError.message,
  160. stack: safeError.stack,
  161. name: safeError.name,
  162. metadata: {
  163. http: {
  164. url: req.url,
  165. params: req.params,
  166. method: req.method,
  167. query: req.query,
  168. body: req.body,
  169. path: req.path,
  170. route: req.route && req.route.path ? req.route.path : undefined
  171. },
  172. custom: {
  173. user: typeof req.user === 'object' ? req.user.id : undefined
  174. }
  175. }
  176. };
  177. if (serviceManager_1.ServiceManager.get('transport')) {
  178. serviceManager_1.ServiceManager.get('transport').send('process:exception', payload);
  179. }
  180. return next(err);
  181. };
  182. }
  183. koaErrorHandler() {
  184. const self = this;
  185. configuration_1.default.configureModule({
  186. error: true
  187. });
  188. return function (ctx, next) {
  189. return tslib_1.__awaiter(this, void 0, void 0, function* () {
  190. try {
  191. yield next();
  192. }
  193. catch (err) {
  194. const safeError = self.getSafeError(err);
  195. const payload = {
  196. message: safeError.message,
  197. stack: safeError.stack,
  198. name: safeError.name,
  199. metadata: {
  200. http: {
  201. url: ctx.request.url,
  202. params: ctx.params,
  203. method: ctx.request.method,
  204. query: ctx.request.query,
  205. body: ctx.request.body,
  206. path: ctx.request.path,
  207. route: ctx._matchedRoute
  208. },
  209. custom: {
  210. user: typeof ctx.user === 'object' ? ctx.user.id : undefined
  211. }
  212. }
  213. };
  214. if (serviceManager_1.ServiceManager.get('transport')) {
  215. serviceManager_1.ServiceManager.get('transport').send('process:exception', payload);
  216. }
  217. throw err;
  218. }
  219. });
  220. };
  221. }
  222. }
  223. exports.NotifyFeature = NotifyFeature;
  224. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notify.js","sourceRoot":"","sources":["../../../src/features/notify.ts"],"names":[],"mappings":"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"}