| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 | 
							- Integrations = new Mongo.Collection('integrations');
 
- Integrations.attachSchema(new SimpleSchema({
 
-   enabled: {
 
-     type: Boolean,
 
-     defaultValue: true,
 
-   },
 
-   title: {
 
-     type: String,
 
-     optional: true,
 
-   },
 
-   type: {
 
-     type: String,
 
-     defaultValue: 'outgoing-webhooks',
 
-   },
 
-   activities: {
 
-     type: [String],
 
-     defaultValue: ['all'],
 
-   },
 
-   url: { // URL validation regex (https://mathiasbynens.be/demo/url-regex)
 
-     type: String,
 
-   },
 
-   token: {
 
-     type: String,
 
-     optional: true,
 
-   },
 
-   boardId: {
 
-     type: String,
 
-   },
 
-   createdAt: {
 
-     type: Date,
 
-     denyUpdate: false,
 
-     autoValue() { // eslint-disable-line consistent-return
 
-       if (this.isInsert) {
 
-         return new Date();
 
-       } else {
 
-         this.unset();
 
-       }
 
-     },
 
-   },
 
-   userId: {
 
-     type: String,
 
-   },
 
- }));
 
- Integrations.allow({
 
-   insert(userId, doc) {
 
-     return allowIsBoardAdmin(userId, Boards.findOne(doc.boardId));
 
-   },
 
-   update(userId, doc) {
 
-     return allowIsBoardAdmin(userId, Boards.findOne(doc.boardId));
 
-   },
 
-   remove(userId, doc) {
 
-     return allowIsBoardAdmin(userId, Boards.findOne(doc.boardId));
 
-   },
 
-   fetch: ['boardId'],
 
- });
 
- //INTEGRATIONS REST API
 
- if (Meteor.isServer) {
 
-   // Get all integrations in board
 
-   JsonRoutes.add('GET', '/api/boards/:boardId/integrations', function(req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       const data = Integrations.find({ boardId: paramBoardId }, { fields: { token: 0 } }).map(function(doc) {
 
-         return doc;
 
-       });
 
-       JsonRoutes.sendResult(res, {code: 200, data});
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Get a single integration in board
 
-   JsonRoutes.add('GET', '/api/boards/:boardId/integrations/:intId', function(req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       const paramIntId = req.params.intId;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: Integrations.findOne({ _id: paramIntId, boardId: paramBoardId }, { fields: { token: 0 } }),
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Create a new integration
 
-   JsonRoutes.add('POST', '/api/boards/:boardId/integrations', function(req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       const id = Integrations.insert({
 
-         userId: req.userId,
 
-         boardId: paramBoardId,
 
-         url: req.body.url,
 
-       });
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: {
 
-           _id: id,
 
-         },
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Edit integration data
 
-   JsonRoutes.add('PUT', '/api/boards/:boardId/integrations/:intId', function (req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       const paramIntId = req.params.intId;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       if (req.body.hasOwnProperty('enabled')) {
 
-         const newEnabled = req.body.enabled;
 
-         Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-           {$set: {enabled: newEnabled}});
 
-       }
 
-       if (req.body.hasOwnProperty('title')) {
 
-         const newTitle = req.body.title;
 
-         Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-           {$set: {title: newTitle}});
 
-       }
 
-       if (req.body.hasOwnProperty('url')) {
 
-         const newUrl = req.body.url;
 
-         Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-           {$set: {url: newUrl}});
 
-       }
 
-       if (req.body.hasOwnProperty('token')) {
 
-         const newToken = req.body.token;
 
-         Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-           {$set: {token: newToken}});
 
-       }
 
-       if (req.body.hasOwnProperty('activities')) {
 
-         const newActivities = req.body.activities;
 
-         Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-           {$set: {activities: newActivities}});
 
-       }
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: {
 
-           _id: paramIntId,
 
-         },
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Delete subscribed activities
 
-   JsonRoutes.add('DELETE', '/api/boards/:boardId/integrations/:intId/activities', function (req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       const paramIntId = req.params.intId;
 
-       const newActivities = req.body.activities;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-         {$pullAll: {activities: newActivities}});
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: Integrations.findOne({_id: paramIntId, boardId: paramBoardId}, { fields: {_id: 1, activities: 1}}),
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Add subscribed activities
 
-   JsonRoutes.add('POST', '/api/boards/:boardId/integrations/:intId/activities', function (req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       const paramIntId = req.params.intId;
 
-       const newActivities = req.body.activities;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       Integrations.direct.update({_id: paramIntId, boardId: paramBoardId},
 
-         {$addToSet: {activities: { $each: newActivities}}});
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: Integrations.findOne({_id: paramIntId, boardId: paramBoardId}, { fields: {_id: 1, activities: 1}}),
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
-   // Delete integration
 
-   JsonRoutes.add('DELETE', '/api/boards/:boardId/integrations/:intId', function (req, res) {
 
-     try {
 
-       const paramBoardId = req.params.boardId;
 
-       const paramIntId = req.params.intId;
 
-       Authentication.checkBoardAccess(req.userId, paramBoardId);
 
-       Integrations.direct.remove({_id: paramIntId, boardId: paramBoardId});
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: {
 
-           _id: paramIntId,
 
-         },
 
-       });
 
-     }
 
-     catch (error) {
 
-       JsonRoutes.sendResult(res, {
 
-         code: 200,
 
-         data: error,
 
-       });
 
-     }
 
-   });
 
- }
 
 
  |