UNPKG

@lskjs/bots-plugin-notify

Version:

LSK.js plugin for @lskjs/bots module for telegram, slack, discord, whatsapp, twitter, instagram and vk bots creation

387 lines (386 loc) 31.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.NotifyApi = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _get3 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _env = require("@lskjs/env"); var _err = _interopRequireDefault(require("@lskjs/err")); var _serverApi = _interopRequireDefault(require("@lskjs/server-api")); var _bluebird = _interopRequireDefault(require("bluebird")); var _find = _interopRequireDefault(require("lodash/find")); var _get4 = _interopRequireDefault(require("lodash/get")); var _groupBy2 = _interopRequireDefault(require("lodash/groupBy")); var _isEmpty = _interopRequireDefault(require("lodash/isEmpty")); var _utils = require("../utils"); var _helpers = require("./helpers"); function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var NotifyApi = /*#__PURE__*/function (_Api) { (0, _inherits2["default"])(NotifyApi, _Api); var _super = _createSuper(NotifyApi); function NotifyApi() { var _this; (0, _classCallCheck2["default"])(this, NotifyApi); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); _this.messages = []; _this.messageTimeout = 500; return _this; } (0, _createClass2["default"])(NotifyApi, [{ key: "getRoutes", value: function () { var _getRoutes = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() { return _regeneratorRuntime().wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.t0 = _objectSpread; _context.t1 = _objectSpread; _context.t2 = {}; _context.next = 5; return (0, _get3["default"])((0, _getPrototypeOf2["default"])(NotifyApi.prototype), "getRoutes", this).call(this); case 5: _context.t3 = _context.sent; _context.t4 = (0, _context.t1)(_context.t2, _context.t3); _context.t5 = {}; _context.t6 = { '/': this.notify.bind(this), '/:projectName': this.notify.bind(this) }; return _context.abrupt("return", (0, _context.t0)(_context.t4, _context.t5, _context.t6)); case 10: case "end": return _context.stop(); } } }, _callee, this); })); function getRoutes() { return _getRoutes.apply(this, arguments); } return getRoutes; }() }, { key: "init", value: function () { var _init = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() { var _yield$this$app$modul, plugins, telegram, slack, notify, sendNotification, config; return _regeneratorRuntime().wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: _context2.next = 2; return (0, _get3["default"])((0, _getPrototypeOf2["default"])(NotifyApi.prototype), "init", this).call(this); case 2: _context2.next = 4; return this.app.module('bots'); case 4: _yield$this$app$modul = _context2.sent; plugins = _yield$this$app$modul.plugins; telegram = _yield$this$app$modul.telegram; slack = _yield$this$app$modul.slack; notify = plugins.notify; sendNotification = notify.sendNotification, config = notify.config; this.bot = { telegram: telegram, slack: slack }; this.notifyConfig = config; this.sendNotification = sendNotification.bind(notify); case 13: case "end": return _context2.stop(); } } }, _callee2, this); })); function init() { return _init.apply(this, arguments); } return init; }() }, { key: "sendError", value: function () { var _sendError = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(_ref) { var _error$response, _error$response$data, _error$response2, _error$response2$data, _error$response3, _error$response4, _error$response4$data, _error$response5, _this$notifyConfig$pr, _this$notifyConfig$pr2, _this2 = this; var error, message, errorMessage, errorChats; return _regeneratorRuntime().wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: error = _ref.error, message = _ref.message; errorMessage = JSON.stringify({ message: message || "\u041D\u0435 \u0443\u0434\u0430\u043B\u043E\u0441\u044C \u0441\u043E\u0431\u0440\u0430\u0442\u044C message! \u0421\u043C\u043E\u0442\u0440\u0438 \u043A\u043E\u043D\u0441\u043E\u043B\u044C", date: new Date().toISOString(), error: { message: (error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : (_error$response$data = _error$response.data) === null || _error$response$data === void 0 ? void 0 : _error$response$data.message) || (error === null || error === void 0 ? void 0 : error.message), code: (error === null || error === void 0 ? void 0 : (_error$response2 = error.response) === null || _error$response2 === void 0 ? void 0 : (_error$response2$data = _error$response2.data) === null || _error$response2$data === void 0 ? void 0 : _error$response2$data.code) || (error === null || error === void 0 ? void 0 : (_error$response3 = error.response) === null || _error$response3 === void 0 ? void 0 : _error$response3.error_code) || (error === null || error === void 0 ? void 0 : error.code), description: (error === null || error === void 0 ? void 0 : (_error$response4 = error.response) === null || _error$response4 === void 0 ? void 0 : (_error$response4$data = _error$response4.data) === null || _error$response4$data === void 0 ? void 0 : _error$response4$data.description) || (error === null || error === void 0 ? void 0 : (_error$response5 = error.response) === null || _error$response5 === void 0 ? void 0 : _error$response5.description) || (error === null || error === void 0 ? void 0 : error.description) } }); console.error('[sendError]', errorMessage, error); errorChats = (_this$notifyConfig$pr = this.notifyConfig.projects) === null || _this$notifyConfig$pr === void 0 ? void 0 : (_this$notifyConfig$pr2 = _this$notifyConfig$pr._error) === null || _this$notifyConfig$pr2 === void 0 ? void 0 : _this$notifyConfig$pr2.telegram; if (!(0, _isEmpty["default"])(errorChats)) { _context3.next = 6; break; } return _context3.abrupt("return"); case 6: _context3.next = 8; return _bluebird["default"].each(errorChats, function (errorChat) { return _this2.bot.telegram.sendMessage(errorChat, errorMessage)["catch"](function (err) { console.error('[sendError.sendMessage]', err); throw err; }); }); case 8: case "end": return _context3.stop(); } } }, _callee3, this); })); function sendError(_x) { return _sendError.apply(this, arguments); } return sendError; }() }, { key: "sendNotifications", value: function () { var _sendNotifications = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6() { var _this3 = this; var date, _groupBy, _groupBy$old, old, _groupBy$new, new2, sendTelegram, sendSlack, res; return _regeneratorRuntime().wrap(function _callee6$(_context6) { while (1) { switch (_context6.prev = _context6.next) { case 0: date = Date.now() - this.messageTimeout; _groupBy = (0, _groupBy2["default"])(this.messages, function (m) { return m.createdAt < date ? 'old' : 'new2'; }), _groupBy$old = _groupBy.old, old = _groupBy$old === void 0 ? [] : _groupBy$old, _groupBy$new = _groupBy.new2, new2 = _groupBy$new === void 0 ? [] : _groupBy$new; this.messages = new2; sendTelegram = []; sendSlack = []; if (this.bot.telegram) { sendTelegram = _bluebird["default"].map(old, /*#__PURE__*/function () { var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(message) { return _regeneratorRuntime().wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: return _context4.abrupt("return", _this3.sendNotification({ bot: _this3.bot.telegram, message: message })); case 1: case "end": return _context4.stop(); } } }, _callee4); })); return function (_x2) { return _ref2.apply(this, arguments); }; }(), { concurrency: 10 }); } if (this.bot.slack) { sendSlack = _bluebird["default"].map(old, /*#__PURE__*/function () { var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5(message) { return _regeneratorRuntime().wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: return _context5.abrupt("return", _this3.sendNotification({ bot: _this3.bot.slack, message: message })); case 1: case "end": return _context5.stop(); } } }, _callee5); })); return function (_x3) { return _ref3.apply(this, arguments); }; }(), { concurrency: 10 }); } _context6.next = 9; return Promise.all([sendTelegram, sendSlack]); case 9: res = _context6.sent; if (!_env.isDev) { _context6.next = 12; break; } return _context6.abrupt("return", res); case 12: return _context6.abrupt("return", { status: 'success', code: 200 }); case 13: case "end": return _context6.stop(); } } }, _callee6, this); })); function sendNotifications() { return _sendNotifications.apply(this, arguments); } return sendNotifications; }() }, { key: "createMessage", value: function createMessage(_ref4) { var req = _ref4.req, projectName = _ref4.projectName; var _getReqParams = (0, _utils.getReqParams)(req), gitlabEvent = _getReqParams.gitlabEvent, githubEvent = _getReqParams.githubEvent, isAlertManager = _getReqParams.isAlertManager, isGraylog = _getReqParams.isGraylog; var project = this.notifyConfig.projects[projectName] || this.notifyConfig.projects._default; var message = { _id: Date.now() + Math.random(), createdAt: new Date(), type: 'manual', projectName: projectName, sended: false, showChannel: !!project.showChannel }; if (gitlabEvent) { message = (0, _helpers.getGitlabMessage)(req, message); } if (githubEvent) { message = (0, _helpers.getGithubMessage)(req, message); } if (isAlertManager) { message = (0, _helpers.getAlertManagerMessage)(req, message); } if (isGraylog) { message = (0, _helpers.getGraylogMessage)(req, message); } var _get2 = (0, _get4["default"])(req, 'data', {}), text = _get2.text, md = _get2.md; if (text) message.text = text; if (md) { message.text = md; message.isMd = (0, _utils.getBool)(req.query.isMd, true); } if (message.messageHash) { var _message = message, messageHash = _message.messageHash; var parentMessage = (0, _find["default"])(this.messages, { messageHash: messageHash }); if (parentMessage) { if (!parentMessage.branches) { parentMessage.branches = []; } parentMessage.branches.push(message.branch); return 'duplicate'; } } return message; } }, { key: "notify", value: function () { var _notify = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(req) { var projectName, project, _getReqParams2, token, message, res; return _regeneratorRuntime().wrap(function _callee7$(_context7) { while (1) { switch (_context7.prev = _context7.next) { case 0: projectName = (0, _get4["default"])(req, 'data.projectName') || (0, _get4["default"])(req, 'params.projectName') || '_default'; project = this.notifyConfig.projects[projectName] || this.notifyConfig.projects._default; _getReqParams2 = (0, _utils.getReqParams)(req), token = _getReqParams2.token; if (!(project.secret && token !== project.secret)) { _context7.next = 5; break; } throw new _err["default"]('!acl'); case 5: _context7.prev = 5; message = this.createMessage({ req: req, projectName: projectName }); this.messages.push(message); _context7.next = 10; return _bluebird["default"].delay(this.messageTimeout * 1.3); case 10: _context7.next = 12; return this.sendNotifications(); case 12: res = _context7.sent; return _context7.abrupt("return", res); case 16: _context7.prev = 16; _context7.t0 = _context7["catch"](5); _context7.next = 20; return this.sendError({ error: _context7.t0, message: message }); case 20: return _context7.abrupt("return", { status: 'error', code: 503 }); case 21: case "end": return _context7.stop(); } } }, _callee7, this, [[5, 16]]); })); function notify(_x4) { return _notify.apply(this, arguments); } return notify; }() }]); return NotifyApi; }(_serverApi["default"]); exports.NotifyApi = NotifyApi; var _default = NotifyApi; exports["default"] = _default; //# sourceMappingURL=NotifyApi.js.map