"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.FilesController = void 0; var _cryptoUtils = require("../cryptoUtils"); var _AdaptableController = _interopRequireDefault(require("./AdaptableController")); var _FilesAdapter = require("../Adapters/Files/FilesAdapter"); var _path = _interopRequireDefault(require("path")); var _mime = _interopRequireDefault(require("mime")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } // FilesController.js const Parse = require('parse').Parse; 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}-.*'); class FilesController extends _AdaptableController.default { getFileData(config, filename) { return this.adapter.getFileData(filename); } async createFile(config, filename, data, contentType, options) { const extname = _path.default.extname(filename); const hasExtension = extname.length > 0; if (!hasExtension && contentType && _mime.default.getExtension(contentType)) { filename = filename + '.' + _mime.default.getExtension(contentType); } else if (hasExtension && !contentType) { contentType = _mime.default.getType(filename); } if (!this.options.preserveFileName) { filename = (0, _cryptoUtils.randomHexString)(32) + '_' + filename; } const location = await this.adapter.getFileLocation(config, filename); await this.adapter.createFile(filename, data, contentType, options); return { url: location, name: filename }; } deleteFile(config, filename) { return this.adapter.deleteFile(filename); } getMetadata(filename) { if (typeof this.adapter.getMetadata === 'function') { return this.adapter.getMetadata(filename); } return Promise.resolve({}); } /** * Find file references in REST-format object and adds the url key * with the current mount point and app id. * Object may be a single object or list of REST-format objects. */ async expandFilesInObject(config, object) { if (object instanceof Array) { const promises = object.map(obj => this.expandFilesInObject(config, obj)); await Promise.all(promises); return; } if (typeof object !== 'object') { return; } for (const key in object) { const fileObject = object[key]; if (fileObject && fileObject['__type'] === 'File') { if (fileObject['url']) { continue; } const filename = fileObject['name']; // all filenames starting with "tfss-" should be from files.parsetfss.com // all filenames starting with a "-" seperated UUID should be from files.parse.com // all other filenames have been migrated or created from Parse Server if (config.fileKey === undefined) { fileObject['url'] = await this.adapter.getFileLocation(config, filename); } else { if (filename.indexOf('tfss-') === 0) { fileObject['url'] = 'http://files.parsetfss.com/' + config.fileKey + '/' + encodeURIComponent(filename); } else if (legacyFilesRegex.test(filename)) { fileObject['url'] = 'http://files.parse.com/' + config.fileKey + '/' + encodeURIComponent(filename); } else { fileObject['url'] = await this.adapter.getFileLocation(config, filename); } } } } } expectedAdapterType() { return _FilesAdapter.FilesAdapter; } handleFileStream(config, filename, req, res, contentType) { return this.adapter.handleFileStream(filename, req, res, contentType); } validateFilename(filename) { if (typeof this.adapter.validateFilename === 'function') { const error = this.adapter.validateFilename(filename); if (typeof error !== 'string') { return error; } return new Parse.Error(Parse.Error.INVALID_FILE_NAME, error); } return (0, _FilesAdapter.validateFilename)(filename); } } exports.FilesController = FilesController; var _default = exports.default = FilesController; //# 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":";;;;;;AACA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,oBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,aAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,KAAA,GAAAH,sBAAA,CAAAF,OAAA;AAAwB,SAAAE,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AALxB;;AAMA,MAAMG,KAAK,GAAGT,OAAO,CAAC,OAAO,CAAC,CAACS,KAAK;AAEpC,MAAMC,gBAAgB,GAAG,IAAIC,MAAM,CACjC,iFACF,CAAC;AAEM,MAAMC,eAAe,SAASC,4BAAmB,CAAC;EACvDC,WAAWA,CAACC,MAAM,EAAEC,QAAQ,EAAE;IAC5B,OAAO,IAAI,CAACC,OAAO,CAACH,WAAW,CAACE,QAAQ,CAAC;EAC3C;EAEA,MAAME,UAAUA,CAACH,MAAM,EAAEC,QAAQ,EAAEG,IAAI,EAAEC,WAAW,EAAEC,OAAO,EAAE;IAC7D,MAAMC,OAAO,GAAGC,aAAI,CAACD,OAAO,CAACN,QAAQ,CAAC;IAEtC,MAAMQ,YAAY,GAAGF,OAAO,CAACG,MAAM,GAAG,CAAC;IAEvC,IAAI,CAACD,YAAY,IAAIJ,WAAW,IAAIM,aAAI,CAACC,YAAY,CAACP,WAAW,CAAC,EAAE;MAClEJ,QAAQ,GAAGA,QAAQ,GAAG,GAAG,GAAGU,aAAI,CAACC,YAAY,CAACP,WAAW,CAAC;IAC5D,CAAC,MAAM,IAAII,YAAY,IAAI,CAACJ,WAAW,EAAE;MACvCA,WAAW,GAAGM,aAAI,CAACE,OAAO,CAACZ,QAAQ,CAAC;IACtC;IAEA,IAAI,CAAC,IAAI,CAACK,OAAO,CAACQ,gBAAgB,EAAE;MAClCb,QAAQ,GAAG,IAAAc,4BAAe,EAAC,EAAE,CAAC,GAAG,GAAG,GAAGd,QAAQ;IACjD;IAEA,MAAMe,QAAQ,GAAG,MAAM,IAAI,CAACd,OAAO,CAACe,eAAe,CAACjB,MAAM,EAAEC,QAAQ,CAAC;IACrE,MAAM,IAAI,CAACC,OAAO,CAACC,UAAU,CAACF,QAAQ,EAAEG,IAAI,EAAEC,WAAW,EAAEC,OAAO,CAAC;IACnE,OAAO;MACLY,GAAG,EAAEF,QAAQ;MACbG,IAAI,EAAElB;IACR,CAAC;EACH;EAEAmB,UAAUA,CAACpB,MAAM,EAAEC,QAAQ,EAAE;IAC3B,OAAO,IAAI,CAACC,OAAO,CAACkB,UAAU,CAACnB,QAAQ,CAAC;EAC1C;EAEAoB,WAAWA,CAACpB,QAAQ,EAAE;IACpB,IAAI,OAAO,IAAI,CAACC,OAAO,CAACmB,WAAW,KAAK,UAAU,EAAE;MAClD,OAAO,IAAI,CAACnB,OAAO,CAACmB,WAAW,CAACpB,QAAQ,CAAC;IAC3C;IACA,OAAOqB,OAAO,CAACC,OAAO,CAAC,CAAC,CAAC,CAAC;EAC5B;;EAEA;AACF;AACA;AACA;AACA;EACE,MAAMC,mBAAmBA,CAACxB,MAAM,EAAEyB,MAAM,EAAE;IACxC,IAAIA,MAAM,YAAYC,KAAK,EAAE;MAC3B,MAAMC,QAAQ,GAAGF,MAAM,CAACG,GAAG,CAACC,GAAG,IAAI,IAAI,CAACL,mBAAmB,CAACxB,MAAM,EAAE6B,GAAG,CAAC,CAAC;MACzE,MAAMP,OAAO,CAACQ,GAAG,CAACH,QAAQ,CAAC;MAC3B;IACF;IACA,IAAI,OAAOF,MAAM,KAAK,QAAQ,EAAE;MAC9B;IACF;IACA,KAAK,MAAMM,GAAG,IAAIN,MAAM,EAAE;MACxB,MAAMO,UAAU,GAAGP,MAAM,CAACM,GAAG,CAAC;MAC9B,IAAIC,UAAU,IAAIA,UAAU,CAAC,QAAQ,CAAC,KAAK,MAAM,EAAE;QACjD,IAAIA,UAAU,CAAC,KAAK,CAAC,EAAE;UACrB;QACF;QACA,MAAM/B,QAAQ,GAAG+B,UAAU,CAAC,MAAM,CAAC;QACnC;QACA;QACA;QACA,IAAIhC,MAAM,CAACiC,OAAO,KAAKC,SAAS,EAAE;UAChCF,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC9B,OAAO,CAACe,eAAe,CAACjB,MAAM,EAAEC,QAAQ,CAAC;QAC1E,CAAC,MAAM;UACL,IAAIA,QAAQ,CAACkC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACnCH,UAAU,CAAC,KAAK,CAAC,GACf,6BAA6B,GAAGhC,MAAM,CAACiC,OAAO,GAAG,GAAG,GAAGG,kBAAkB,CAACnC,QAAQ,CAAC;UACvF,CAAC,MAAM,IAAIN,gBAAgB,CAAC0C,IAAI,CAACpC,QAAQ,CAAC,EAAE;YAC1C+B,UAAU,CAAC,KAAK,CAAC,GACf,yBAAyB,GAAGhC,MAAM,CAACiC,OAAO,GAAG,GAAG,GAAGG,kBAAkB,CAACnC,QAAQ,CAAC;UACnF,CAAC,MAAM;YACL+B,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC9B,OAAO,CAACe,eAAe,CAACjB,MAAM,EAAEC,QAAQ,CAAC;UAC1E;QACF;MACF;IACF;EACF;EAEAqC,mBAAmBA,CAAA,EAAG;IACpB,OAAOC,0BAAY;EACrB;EAEAC,gBAAgBA,CAACxC,MAAM,EAAEC,QAAQ,EAAEwC,GAAG,EAAEC,GAAG,EAAErC,WAAW,EAAE;IACxD,OAAO,IAAI,CAACH,OAAO,CAACsC,gBAAgB,CAACvC,QAAQ,EAAEwC,GAAG,EAAEC,GAAG,EAAErC,WAAW,CAAC;EACvE;EAEAsC,gBAAgBA,CAAC1C,QAAQ,EAAE;IACzB,IAAI,OAAO,IAAI,CAACC,OAAO,CAACyC,gBAAgB,KAAK,UAAU,EAAE;MACvD,MAAMC,KAAK,GAAG,IAAI,CAAC1C,OAAO,CAACyC,gBAAgB,CAAC1C,QAAQ,CAAC;MACrD,IAAI,OAAO2C,KAAK,KAAK,QAAQ,EAAE;QAC7B,OAAOA,KAAK;MACd;MACA,OAAO,IAAIlD,KAAK,CAACmD,KAAK,CAACnD,KAAK,CAACmD,KAAK,CAACC,iBAAiB,EAAEF,KAAK,CAAC;IAC9D;IACA,OAAO,IAAAD,8BAAgB,EAAC1C,QAAQ,CAAC;EACnC;AACF;AAAC8C,OAAA,CAAAlD,eAAA,GAAAA,eAAA;AAAA,IAAAmD,QAAA,GAAAD,OAAA,CAAAtD,OAAA,GAEcI,eAAe","ignoreList":[]}