| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 | 
							- import { TAPi18n } from '/imports/i18n';
 
- import { runOnServer } from './runOnServer';
 
- runOnServer(function() {
 
-   // the ExporterCardPDF class is only available on server and in order to import
 
-   // it here we use runOnServer to have it inside a function instead of an
 
-   // if (Meteor.isServer) block
 
-   import { ExporterCardPDF } from './server/ExporterCardPDF';
 
-   import { Picker } from 'meteor/communitypackages:picker';
 
-   // todo XXX once we have a real API in place, move that route there
 
-   // todo XXX also  share the route definition between the client and the server
 
-   // so that we could use something like
 
-   // `ApiRoutes.path('boards/exportExcel', boardId)``
 
-   // on the client instead of copy/pasting the route path manually between the
 
-   // client and the server.
 
-   /**
 
-    * @operation exportExcel
 
-    * @tag Boards
 
-    *
 
-    * @summary This route is used to export the board Excel.
 
-    *
 
-    * @description If user is already logged-in, pass loginToken as param
 
-    * "authToken": '/api/boards/:boardId/exportExcel?authToken=:token'
 
-    *
 
-    * See https://blog.kayla.com.au/server-side-route-authentication-in-meteor/
 
-    * for detailed explanations
 
-    *
 
-    * @param {string} boardId the ID of the board we are exporting
 
-    * @param {string} authToken the loginToken
 
-    */
 
-   Picker.route('/api/boards/:boardId/lists/:listId/cards/:cardId/exportPDF', function (params, req, res) {
 
-     const boardId = params.boardId;
 
-     const paramListId = req.params.listId;
 
-     const paramCardId = req.params.cardId;
 
-     let user = null;
 
-     let impersonateDone = false;
 
-     let adminId = null;
 
-     const loginToken = params.query.authToken;
 
-     if (loginToken) {
 
-       const hashToken = Accounts._hashLoginToken(loginToken);
 
-       user = Meteor.users.findOne({
 
-         'services.resume.loginTokens.hashedToken': hashToken,
 
-       });
 
-       adminId = user._id.toString();
 
-       impersonateDone = ImpersonatedUsers.findOne({
 
-         adminId: adminId,
 
-       });
 
-     } else if (!Meteor.settings.public.sandstorm) {
 
-       Authentication.checkUserId(req.userId);
 
-       user = Users.findOne({
 
-         _id: req.userId,
 
-         isAdmin: true,
 
-       });
 
-     }
 
-     const exporterCardPDF = new ExporterCardPDF(boardId);
 
-     if (exporterCardPDF.canExport(user) || impersonateDone) {
 
-       if (impersonateDone) {
 
-         ImpersonatedUsers.insert({
 
-           adminId: adminId,
 
-           boardId: boardId,
 
-           reason: 'exportCardPDF',
 
-         });
 
-       }
 
-       exporterCardPDF.build(res);
 
-     } else {
 
-       res.end(TAPi18n.__('user-can-not-export-card-to-pdf'));
 
-     }
 
-   });
 
- });
 
 
  |