UNPKG

@contentstack/management

Version:

The Content Management API is used to manage the content of your Contentstack account

337 lines (329 loc) 13.9 kB
"use strict"; var _interopRequireDefault3 = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireDefault2 = _interopRequireDefault3(require("@babel/runtime/helpers/interopRequireDefault")); Object.defineProperty(exports, "__esModule", { value: true }); var _defineProperty2 = require("@babel/runtime/helpers/defineProperty"); var _defineProperty3 = (0, _interopRequireDefault2["default"])(_defineProperty2); var _asyncToGenerator2 = require("@babel/runtime/helpers/asyncToGenerator"); var _asyncToGenerator3 = (0, _interopRequireDefault2["default"])(_asyncToGenerator2); exports.Webhook = Webhook; exports.WebhookCollection = WebhookCollection; exports.createFormData = createFormData; var _regenerator = require("@babel/runtime/regenerator"); var _regenerator2 = (0, _interopRequireDefault2["default"])(_regenerator); var _cloneDeep = require("lodash/cloneDeep"); var _cloneDeep2 = (0, _interopRequireDefault2["default"])(_cloneDeep); var _entity = require("../../entity"); var _contentstackError = require("../../core/contentstackError"); var _contentstackError2 = (0, _interopRequireDefault2["default"])(_contentstackError); var _formData = require("form-data"); var _formData2 = (0, _interopRequireDefault2["default"])(_formData); var _fs = require("fs"); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty3["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /** * A webhook is a mechanism that sends real-time information to any third-party app or service to keep your application in sync with your Contentstack account. Webhooks allow you to specify a URL to which you would like Contentstack to post data when an event happens. Read more about <a href='https://www.contentstack.com/docs/developers/set-up-webhooks'>Webhooks</a>. * @namespace Webhook */ function Webhook(http) { var _this = this; var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; this.stackHeaders = data.stackHeaders; this.urlPath = "/webhooks"; if (data.webhook) { Object.assign(this, (0, _cloneDeep2["default"])(data.webhook)); this.urlPath = "/webhooks/".concat(this.uid); /** * @description The Update Webhook call lets you update the name and description of an existing Webhook. * @memberof Webhook * @func update * @returns {Promise<Webhook.Webhook>} Promise for Webhook instance * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * client.stack({ api_key: 'api_key'}).webhook('webhook_uid').fetch() * .then((webhook) => { * webhook.title = 'My New Webhook' * webhook.description = 'Webhook description' * return webhook.update() * }) * .then((webhook) => console.log(webhook)) * */ this.update = (0, _entity.update)(http, 'webhook'); /** * @description The Delete Webhook call is used to delete an existing Webhook permanently from your Stack. * @memberof Webhook * @func delete * @returns {Object} Response Object. * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * client.stack({ api_key: 'api_key'}).webhook('webhook_uid').delete() * .then((response) => console.log(response.notice)) */ this["delete"] = (0, _entity.deleteEntity)(http); /** * @description The fetch Webhook call fetches Webhook details. * @memberof Webhook * @func fetch * @returns {Promise<Webhook.Webhook>} Promise for Webhook instance * @param {Object=} param - Query parameters * @prop {Int} param.version - Enter the version number of the webhook you want to retrieve. * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * client.stack({ api_key: 'api_key'}).webhook('webhook_uid').fetch() * .then((webhook) => console.log(webhook)) * */ this.fetch = (0, _entity.fetch)(http, 'webhook'); /** * @description The Get executions of a webhook call provides the execution details of a specific webhook, which includes the execution UID. * @memberof Webhook * @func executions * @async * @param {Object=} params - Query parameters. * @prop {Number=} params.skip - To skip number of data. * @prop {Number=} params.limit - To limit number of results. * @returns {Promise<Object>} Response object for webhook execution * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * client.stack({ api_key: 'api_key'}).webhook('webhook_uid').executions() * .then((webhook) => console.log(webhook)) */ this.executions = /*#__PURE__*/function () { var _ref = (0, _asyncToGenerator3["default"])(/*#__PURE__*/_regenerator2["default"].mark(function _callee(params) { var headers, response, _t; return _regenerator2["default"].wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: headers = {}; if (_this.stackHeaders) { headers.headers = _this.stackHeaders; } if (params) { headers.params = _objectSpread({}, (0, _cloneDeep2["default"])(params)); } _context.prev = 1; _context.next = 2; return http.get("".concat(_this.urlPath, "/executions"), headers); case 2: response = _context.sent; if (!response.data) { _context.next = 3; break; } return _context.abrupt("return", response.data); case 3: throw (0, _contentstackError2["default"])(response); case 4: _context.next = 6; break; case 5: _context.prev = 5; _t = _context["catch"](1); throw (0, _contentstackError2["default"])(_t); case 6: case "end": return _context.stop(); } }, _callee, null, [[1, 5]]); })); return function (_x) { return _ref.apply(this, arguments); }; }(); /** * @description The Retry webhook execution call retries a failed webhook execution. * @memberof Webhook * @func retry * @async * @param {String} executionUid execution UID that you receive when you execute the 'Get executions of webhooks' call. * @returns {Promise<Object>} Response Object. */ this.retry = /*#__PURE__*/function () { var _ref2 = (0, _asyncToGenerator3["default"])(/*#__PURE__*/_regenerator2["default"].mark(function _callee2(executionUid) { var headers, response, _t2; return _regenerator2["default"].wrap(function (_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: headers = {}; if (_this.stackHeaders) { headers.headers = _this.stackHeaders; } _context2.prev = 1; _context2.next = 2; return http.post("".concat(_this.urlPath, "/retry"), { execution_uid: executionUid }, headers); case 2: response = _context2.sent; if (!response.data) { _context2.next = 3; break; } return _context2.abrupt("return", response.data); case 3: throw (0, _contentstackError2["default"])(response); case 4: _context2.next = 6; break; case 5: _context2.prev = 5; _t2 = _context2["catch"](1); throw (0, _contentstackError2["default"])(_t2); case 6: case "end": return _context2.stop(); } }, _callee2, null, [[1, 5]]); })); return function (_x2) { return _ref2.apply(this, arguments); }; }(); } else { /** * @description The Create a webhook request allows you to create a new webhook in a specific stack. * @memberof Webhook * @func create * @returns {Promise<Webhook.Webhook>} Promise for Webhook instance * * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * const webhook = { * name: 'Test', * destinations: [{ * target_url: 'http://example.com', * http_basic_auth: 'basic', * http_basic_password: 'test', * custom_header: [{ * header_name: 'Custom', * value: 'testing' * }] * }], * channels: [ * 'assets.create' * ], * retry_policy: 'manual', * disabled: false * } * client.stack().webhook().create({ webhook }) * .then((webhook) => console.log(webhook)) */ this.create = (0, _entity.create)({ http: http }); /** * @description The Get all Webhook call lists all Webhooks from Stack. * @memberof Webhook * @func fetchAll * @param {Object=} param - Query parameters. * @prop {Number=} param.limit - The limit parameter will return a specific number of webhooks in the output. * @prop {Number=} param.skip - The skip parameter will skip a specific number of webhooks in the output. * @prop {String=} param.asc - When fetching webhooks, you can sort them in the ascending order with respect to the value of a specific field in the response body. * @prop {String=} param.desc - When fetching webhooks, you can sort them in the descending order with respect to the value of a specific field in the response body. * @prop {Boolean=} param.include_count - To retrieve the count of webhooks. * @returns {Promise<ContentstackCollection>} Promise for ContentstackCollection instance. * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * client.stack({ api_key: 'api_key'}).webhook().fetchAll() * .then((collection) => console.log(collection)) * */ this.fetchAll = (0, _entity.fetchAll)(http, WebhookCollection); } /** * @description The 'Import Webhook' section consists of the following two requests that will help you to import new Webhooks or update existing ones by uploading JSON files. * @memberof Webhook * @func import * @async * @param {Object} data - Import data object. * @prop {string} data.webhook - Path to webhook file. * @returns {Promise<Webhook.Webhook>} Promise for Webhook instance * @example * import * as contentstack from '@contentstack/management' * const client = contentstack.client() * * const data = { * webhook: 'path/to/file.json', * } * // Import a Webhook * client.stack({ api_key: 'api_key'}).webhook().import(data) * .then((webhook) => console.log(webhook)) * * // Import an Existing Webhook * client.stack({ api_key: 'api_key'}).webhook('webhook_uid').import(data) * .then((webhook) => console.log(webhook)) */ this["import"] = /*#__PURE__*/function () { var _ref3 = (0, _asyncToGenerator3["default"])(/*#__PURE__*/_regenerator2["default"].mark(function _callee3(data) { var response, _t3; return _regenerator2["default"].wrap(function (_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: _context3.prev = 0; _context3.next = 1; return (0, _entity.upload)({ http: http, urlPath: "".concat(_this.urlPath, "/import"), stackHeaders: _this.stackHeaders, formData: createFormData(data) }); case 1: response = _context3.sent; if (!response.data) { _context3.next = 2; break; } return _context3.abrupt("return", new _this.constructor(http, (0, _entity.parseData)(response, _this.stackHeaders))); case 2: throw (0, _contentstackError2["default"])(response); case 3: _context3.next = 5; break; case 4: _context3.prev = 4; _t3 = _context3["catch"](0); throw (0, _contentstackError2["default"])(_t3); case 5: case "end": return _context3.stop(); } }, _callee3, null, [[0, 4]]); })); return function (_x3) { return _ref3.apply(this, arguments); }; }(); return this; } function WebhookCollection(http, data) { var obj = (0, _cloneDeep2["default"])(data.webhooks) || []; var webhookCollection = obj.map(function (userdata) { return new Webhook(http, { webhook: userdata, stackHeaders: data.stackHeaders }); }); return webhookCollection; } function createFormData(data) { return function () { var formData = new _formData2["default"](); var uploadStream = (0, _fs.createReadStream)(data.webhook); formData.append('webhook', uploadStream); return formData; }; }