FilesController.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = exports.FilesController = void 0;
  6. var _cryptoUtils = require("../cryptoUtils");
  7. var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
  8. var _FilesAdapter = require("../Adapters/Files/FilesAdapter");
  9. var _path = _interopRequireDefault(require("path"));
  10. var _mime = _interopRequireDefault(require("mime"));
  11. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  12. // FilesController.js
  13. const Parse = require('parse').Parse;
  14. const legacyFilesRegex = new RegExp('^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}-.*');
  15. class FilesController extends _AdaptableController.default {
  16. getFileData(config, filename) {
  17. return this.adapter.getFileData(filename);
  18. }
  19. async createFile(config, filename, data, contentType, options) {
  20. const extname = _path.default.extname(filename);
  21. const hasExtension = extname.length > 0;
  22. if (!hasExtension && contentType && _mime.default.getExtension(contentType)) {
  23. filename = filename + '.' + _mime.default.getExtension(contentType);
  24. } else if (hasExtension && !contentType) {
  25. contentType = _mime.default.getType(filename);
  26. }
  27. if (!this.options.preserveFileName) {
  28. filename = (0, _cryptoUtils.randomHexString)(32) + '_' + filename;
  29. }
  30. const location = await this.adapter.getFileLocation(config, filename);
  31. await this.adapter.createFile(filename, data, contentType, options);
  32. return {
  33. url: location,
  34. name: filename
  35. };
  36. }
  37. deleteFile(config, filename) {
  38. return this.adapter.deleteFile(filename);
  39. }
  40. getMetadata(filename) {
  41. if (typeof this.adapter.getMetadata === 'function') {
  42. return this.adapter.getMetadata(filename);
  43. }
  44. return Promise.resolve({});
  45. }
  46. /**
  47. * Find file references in REST-format object and adds the url key
  48. * with the current mount point and app id.
  49. * Object may be a single object or list of REST-format objects.
  50. */
  51. async expandFilesInObject(config, object) {
  52. if (object instanceof Array) {
  53. const promises = object.map(obj => this.expandFilesInObject(config, obj));
  54. await Promise.all(promises);
  55. return;
  56. }
  57. if (typeof object !== 'object') {
  58. return;
  59. }
  60. for (const key in object) {
  61. const fileObject = object[key];
  62. if (fileObject && fileObject['__type'] === 'File') {
  63. if (fileObject['url']) {
  64. continue;
  65. }
  66. const filename = fileObject['name'];
  67. // all filenames starting with "tfss-" should be from files.parsetfss.com
  68. // all filenames starting with a "-" seperated UUID should be from files.parse.com
  69. // all other filenames have been migrated or created from Parse Server
  70. if (config.fileKey === undefined) {
  71. fileObject['url'] = await this.adapter.getFileLocation(config, filename);
  72. } else {
  73. if (filename.indexOf('tfss-') === 0) {
  74. fileObject['url'] = 'http://files.parsetfss.com/' + config.fileKey + '/' + encodeURIComponent(filename);
  75. } else if (legacyFilesRegex.test(filename)) {
  76. fileObject['url'] = 'http://files.parse.com/' + config.fileKey + '/' + encodeURIComponent(filename);
  77. } else {
  78. fileObject['url'] = await this.adapter.getFileLocation(config, filename);
  79. }
  80. }
  81. }
  82. }
  83. }
  84. expectedAdapterType() {
  85. return _FilesAdapter.FilesAdapter;
  86. }
  87. handleFileStream(config, filename, req, res, contentType) {
  88. return this.adapter.handleFileStream(filename, req, res, contentType);
  89. }
  90. validateFilename(filename) {
  91. if (typeof this.adapter.validateFilename === 'function') {
  92. const error = this.adapter.validateFilename(filename);
  93. if (typeof error !== 'string') {
  94. return error;
  95. }
  96. return new Parse.Error(Parse.Error.INVALID_FILE_NAME, error);
  97. }
  98. return (0, _FilesAdapter.validateFilename)(filename);
  99. }
  100. }
  101. exports.FilesController = FilesController;
  102. var _default = exports.default = FilesController;
  103. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cryptoUtils","require","_AdaptableController","_interopRequireDefault","_FilesAdapter","_path","_mime","e","__esModule","default","Parse","legacyFilesRegex","RegExp","FilesController","AdaptableController","getFileData","config","filename","adapter","createFile","data","contentType","options","extname","path","hasExtension","length","mime","getExtension","getType","preserveFileName","randomHexString","location","getFileLocation","url","name","deleteFile","getMetadata","Promise","resolve","expandFilesInObject","object","Array","promises","map","obj","all","key","fileObject","fileKey","undefined","indexOf","encodeURIComponent","test","expectedAdapterType","FilesAdapter","handleFileStream","req","res","validateFilename","error","Error","INVALID_FILE_NAME","exports","_default"],"sources":["../../src/Controllers/FilesController.js"],"sourcesContent":["// FilesController.js\nimport { randomHexString } from '../cryptoUtils';\nimport AdaptableController from './AdaptableController';\nimport { validateFilename, FilesAdapter } from '../Adapters/Files/FilesAdapter';\nimport path from 'path';\nimport mime from 'mime';\nconst Parse = require('parse').Parse;\n\nconst legacyFilesRegex = new RegExp(\n  '^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}-.*'\n);\n\nexport class FilesController extends AdaptableController {\n  getFileData(config, filename) {\n    return this.adapter.getFileData(filename);\n  }\n\n  async createFile(config, filename, data, contentType, options) {\n    const extname = path.extname(filename);\n\n    const hasExtension = extname.length > 0;\n\n    if (!hasExtension && contentType && mime.getExtension(contentType)) {\n      filename = filename + '.' + mime.getExtension(contentType);\n    } else if (hasExtension && !contentType) {\n      contentType = mime.getType(filename);\n    }\n\n    if (!this.options.preserveFileName) {\n      filename = randomHexString(32) + '_' + filename;\n    }\n\n    const location = await this.adapter.getFileLocation(config, filename);\n    await this.adapter.createFile(filename, data, contentType, options);\n    return {\n      url: location,\n      name: filename,\n    }\n  }\n\n  deleteFile(config, filename) {\n    return this.adapter.deleteFile(filename);\n  }\n\n  getMetadata(filename) {\n    if (typeof this.adapter.getMetadata === 'function') {\n      return this.adapter.getMetadata(filename);\n    }\n    return Promise.resolve({});\n  }\n\n  /**\n   * Find file references in REST-format object and adds the url key\n   * with the current mount point and app id.\n   * Object may be a single object or list of REST-format objects.\n   */\n  async expandFilesInObject(config, object) {\n    if (object instanceof Array) {\n      const promises = object.map(obj => this.expandFilesInObject(config, obj));\n      await Promise.all(promises);\n      return;\n    }\n    if (typeof object !== 'object') {\n      return;\n    }\n    for (const key in object) {\n      const fileObject = object[key];\n      if (fileObject && fileObject['__type'] === 'File') {\n        if (fileObject['url']) {\n          continue;\n        }\n        const filename = fileObject['name'];\n        // all filenames starting with \"tfss-\" should be from files.parsetfss.com\n        // all filenames starting with a \"-\" seperated UUID should be from files.parse.com\n        // all other filenames have been migrated or created from Parse Server\n        if (config.fileKey === undefined) {\n          fileObject['url'] = await this.adapter.getFileLocation(config, filename);\n        } else {\n          if (filename.indexOf('tfss-') === 0) {\n            fileObject['url'] =\n              'http://files.parsetfss.com/' + config.fileKey + '/' + encodeURIComponent(filename);\n          } else if (legacyFilesRegex.test(filename)) {\n            fileObject['url'] =\n              'http://files.parse.com/' + config.fileKey + '/' + encodeURIComponent(filename);\n          } else {\n            fileObject['url'] = await this.adapter.getFileLocation(config, filename);\n          }\n        }\n      }\n    }\n  }\n\n  expectedAdapterType() {\n    return FilesAdapter;\n  }\n\n  handleFileStream(config, filename, req, res, contentType) {\n    return this.adapter.handleFileStream(filename, req, res, contentType);\n  }\n\n  validateFilename(filename) {\n    if (typeof this.adapter.validateFilename === 'function') {\n      const error = this.adapter.validateFilename(filename);\n      if (typeof error !== 'string') {\n        return error;\n      }\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, error);\n    }\n    return validateFilename(filename);\n  }\n}\n\nexport default FilesController;\n"],"mappings":"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","ignoreList":[]}