|  | @@ -11,6 +11,11 @@ Integrations.attachSchema(new SimpleSchema({
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    type: {
 |  |    type: {
 | 
											
												
													
														|  |      type: String,
 |  |      type: String,
 | 
											
												
													
														|  | 
 |  | +    defaultValue: 'outgoing-webhooks',
 | 
											
												
													
														|  | 
 |  | +  },
 | 
											
												
													
														|  | 
 |  | +  activities: {
 | 
											
												
													
														|  | 
 |  | +    type: [String],
 | 
											
												
													
														|  | 
 |  | +    defaultValue: ['all'],
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    url: { // URL validation regex (https://mathiasbynens.be/demo/url-regex)
 |  |    url: { // URL validation regex (https://mathiasbynens.be/demo/url-regex)
 | 
											
												
													
														|  |      type: String,
 |  |      type: String,
 | 
											
										
											
												
													
														|  | @@ -35,11 +40,6 @@ Integrations.attachSchema(new SimpleSchema({
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    userId: {
 |  |    userId: {
 | 
											
												
													
														|  |      type: String,
 |  |      type: String,
 | 
											
												
													
														|  | -    autoValue() { // eslint-disable-line consistent-return
 |  | 
 | 
											
												
													
														|  | -      if (this.isInsert || this.isUpdate) {
 |  | 
 | 
											
												
													
														|  | -        return this.userId;
 |  | 
 | 
											
												
													
														|  | -      }
 |  | 
 | 
											
												
													
														|  | -    },
 |  | 
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |  }));
 |  |  }));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -52,3 +52,136 @@ Integrations.allow({
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    fetch: ['boardId'],
 |  |    fetch: ['boardId'],
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +//INTEGRATIONS REST API
 | 
											
												
													
														|  | 
 |  | +if (Meteor.isServer) {
 | 
											
												
													
														|  | 
 |  | +  // Get all integrations in board
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('GET', '/api/boards/:boardId/integrations', function(req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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});
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Get a single integration in board
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('GET', '/api/boards/:boardId/integrations/:intId', function(req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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 } }),
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Create a new integration
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('POST', '/api/boards/:boardId/integrations', function(req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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,
 | 
											
												
													
														|  | 
 |  | +      },
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Edit integration data
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('PUT', '/api/boards/:boardId/integrations/:intId', function (req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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,
 | 
											
												
													
														|  | 
 |  | +      },
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Delete subscribed activities
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('DELETE', '/api/boards/:boardId/integrations/:intId/activities', function (req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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}}),
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Add subscribed activities
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('POST', '/api/boards/:boardId/integrations/:intId/activities', function (req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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}}),
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Delete integration
 | 
											
												
													
														|  | 
 |  | +  JsonRoutes.add('DELETE', '/api/boards/:boardId/integrations/:intId', function (req, res, next) {
 | 
											
												
													
														|  | 
 |  | +    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,
 | 
											
												
													
														|  | 
 |  | +      },
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +}
 |