Socket
Socket
Sign inDemoInstall

filestack-js

Package Overview
Dependencies
Maintainers
1
Versions
169
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

filestack-js - npm Package Compare versions

Comparing version 3.19.0 to 3.20.0

src/lib/request/.DS_Store

4

build/browser/manifest.json
{
"main.js": {
"src": "filestack.min.js",
"integrity": "sha256-1o1JI9Cu7dd8eAPKNmRcLFI34kWD93vHcYoY9MW+OGU= sha384-S1zn6gkOxtAaG/IYvJM4kFXEP5tPPTbWn+6+7tYMBwym+dQBkqbVu1zTXXVpdrV4 sha512-2Hn4YoAHlDYixqy7b8ZWNKZt3q5jPHEh0beManp1vhjSVL4gNZzQWoB9b7eyn9507+j8AZnopORb+FFUzKXOJA=="
"integrity": "sha256-OAe5hvOCsAFAIGzeheYY8yjZiA6Yegjzk41RZYJGTU8= sha384-+zvvSWeIiEyjBlqxxnoImyI8yU1UWnMKavnApmRfO5P8bHZRmSzQkcArPCnIXiFf sha512-+/BcnyKttZz6CJBzaXQxg6oP2fQ8SNWc1A0kgHi//FeUgY2KhN0tqUkArqj3QMeaq2I06NaDAmuo98vwHnxrqA=="
},
"main.js.map": {
"src": "filestack.min.js.map",
"integrity": "sha256-QjYEj7fCuYaWtL0ku4exPK6iWKcV8BWAmuVcjCR3iAM= sha384-Z0IcfD6U/Q4TNZpZ7baDvfgskxlBvedp5ar8PzsT9Bhf/ajyBQYwKNaQ/jIuk4Yx sha512-u1we4B7sFjsGRtGNy62J3zTMX7bHxFQRmLZXFwmmEOcCbDnAds6bUX/qIU2UXnrwLTb5y+J2REwajATIKAnRWA=="
"integrity": "sha256-j0qzlizRyp5og/g4bgVqt5+x1PoeOcdRYk240IUX3k0= sha384-gTMg7pzwxBmxXwSdk5NZWKS9FRBEkb2yXfJ+gFsFjJ8wcmPG18UsBzuwnrTx4RmV sha512-/1Cpjed7h8WsklRGXlz4+lUpGPsK/T+4EAJQvCqSzPNpKI9j9iN80Vn9TiijEcKjOs1KbPqS1YoELJtyYTbDEw=="
}
}

@@ -22,3 +22,3 @@ "use strict";

*/
var PICKER_VERSION = '1.19.0';
var PICKER_VERSION = '1.19.1';
exports.config = {

@@ -35,2 +35,2 @@ urls: {

//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7R0FlRzs7QUFFSDs7R0FFRztBQUNILElBQU0sY0FBYyxHQUFHLFFBQVEsQ0FBQztBQXNCbkIsUUFBQSxNQUFNLEdBQUc7SUFDcEIsSUFBSSxFQUFFO1FBQ0osVUFBVSxFQUFFLGtDQUFrQztRQUM5QyxVQUFVLEVBQUUsdUNBQXVDO1FBQ25ELFlBQVksRUFBRSxpQ0FBaUM7UUFDL0MsV0FBVyxFQUFFLGdDQUFnQztRQUM3QyxNQUFNLEVBQUUsa0NBQWtDO1FBQzFDLFNBQVMsRUFBRSw0Q0FBMEMsY0FBYyxlQUFZO0tBQ2hGO0NBQ0YsQ0FBQyIsImZpbGUiOiJjb25maWcuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDE4IGJ5IEZpbGVzdGFjay5cbiAqIFNvbWUgcmlnaHRzIHJlc2VydmVkLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG4vKipcbiAqIEBwcml2YXRlXG4gKi9cbmNvbnN0IFBJQ0tFUl9WRVJTSU9OID0gJzEuMTkuMCc7XG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBIb3N0cyB7XG4gIFt1cmw6IHN0cmluZ106IHN0cmluZztcbiAgZmlsZUFwaVVybDogc3RyaW5nO1xuICB1cGxvYWRBcGlVcmw6IHN0cmluZztcbiAgY2xvdWRBcGlVcmw6IHN0cmluZztcbiAgY2RuVXJsOiBzdHJpbmc7XG4gIHBpY2tlclVybDogc3RyaW5nO1xuICBwcm9jZXNzVXJsOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICB1cmxzOiBIb3N0cztcbn1cblxuZXhwb3J0IGNvbnN0IGNvbmZpZyA9IHtcbiAgdXJsczoge1xuICAgIHByb2Nlc3NVcmw6ICdodHRwczovL3Byb2Nlc3MuZmlsZXN0YWNrYXBpLmNvbScsXG4gICAgZmlsZUFwaVVybDogJ2h0dHBzOi8vd3d3LmZpbGVzdGFja2FwaS5jb20vYXBpL2ZpbGUnLFxuICAgIHVwbG9hZEFwaVVybDogJ2h0dHBzOi8vdXBsb2FkLmZpbGVzdGFja2FwaS5jb20nLFxuICAgIGNsb3VkQXBpVXJsOiAnaHR0cHM6Ly9jbG91ZC5maWxlc3RhY2thcGkuY29tJyxcbiAgICBjZG5Vcmw6ICdodHRwczovL2Nkbi5maWxlc3RhY2tjb250ZW50LmNvbScsXG4gICAgcGlja2VyVXJsOiBgaHR0cHM6Ly9zdGF0aWMuZmlsZXN0YWNrYXBpLmNvbS9waWNrZXIvJHtQSUNLRVJfVkVSU0lPTn0vcGlja2VyLmpzYCxcbiAgfSxcbn07XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7R0FlRzs7QUFFSDs7R0FFRztBQUNILElBQU0sY0FBYyxHQUFHLFFBQVEsQ0FBQztBQXNCbkIsUUFBQSxNQUFNLEdBQUc7SUFDcEIsSUFBSSxFQUFFO1FBQ0osVUFBVSxFQUFFLGtDQUFrQztRQUM5QyxVQUFVLEVBQUUsdUNBQXVDO1FBQ25ELFlBQVksRUFBRSxpQ0FBaUM7UUFDL0MsV0FBVyxFQUFFLGdDQUFnQztRQUM3QyxNQUFNLEVBQUUsa0NBQWtDO1FBQzFDLFNBQVMsRUFBRSw0Q0FBMEMsY0FBYyxlQUFZO0tBQ2hGO0NBQ0YsQ0FBQyIsImZpbGUiOiJjb25maWcuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDE4IGJ5IEZpbGVzdGFjay5cbiAqIFNvbWUgcmlnaHRzIHJlc2VydmVkLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG4vKipcbiAqIEBwcml2YXRlXG4gKi9cbmNvbnN0IFBJQ0tFUl9WRVJTSU9OID0gJzEuMTkuMSc7XG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBIb3N0cyB7XG4gIFt1cmw6IHN0cmluZ106IHN0cmluZztcbiAgZmlsZUFwaVVybDogc3RyaW5nO1xuICB1cGxvYWRBcGlVcmw6IHN0cmluZztcbiAgY2xvdWRBcGlVcmw6IHN0cmluZztcbiAgY2RuVXJsOiBzdHJpbmc7XG4gIHBpY2tlclVybDogc3RyaW5nO1xuICBwcm9jZXNzVXJsOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuICB1cmxzOiBIb3N0cztcbn1cblxuZXhwb3J0IGNvbnN0IGNvbmZpZyA9IHtcbiAgdXJsczoge1xuICAgIHByb2Nlc3NVcmw6ICdodHRwczovL3Byb2Nlc3MuZmlsZXN0YWNrYXBpLmNvbScsXG4gICAgZmlsZUFwaVVybDogJ2h0dHBzOi8vd3d3LmZpbGVzdGFja2FwaS5jb20vYXBpL2ZpbGUnLFxuICAgIHVwbG9hZEFwaVVybDogJ2h0dHBzOi8vdXBsb2FkLmZpbGVzdGFja2FwaS5jb20nLFxuICAgIGNsb3VkQXBpVXJsOiAnaHR0cHM6Ly9jbG91ZC5maWxlc3RhY2thcGkuY29tJyxcbiAgICBjZG5Vcmw6ICdodHRwczovL2Nkbi5maWxlc3RhY2tjb250ZW50LmNvbScsXG4gICAgcGlja2VyVXJsOiBgaHR0cHM6Ly9zdGF0aWMuZmlsZXN0YWNrYXBpLmNvbS9waWNrZXIvJHtQSUNLRVJfVkVSU0lPTn0vcGlja2VyLmpzYCxcbiAgfSxcbn07XG4iXX0=

@@ -26,3 +26,3 @@ import { SecurityOptions, getSecurity, validateWebhookSignature, WebhookValidatePayload } from './lib/api/security';

*/
export declare const version = "3.19.0";
export declare const version = "3.20.0";
export * from './lib/api/transform';

@@ -29,0 +29,0 @@ export * from './lib/filelink';

@@ -50,4 +50,4 @@ "use strict";

*/
exports.version = '3.19.0';
loader_1.registerModule(loader_1.FILESTACK_MODULES.FILESTACK_SDK, exports.Filestack, { version: '3.19.0' });
exports.version = '3.20.0';
loader_1.registerModule(loader_1.FILESTACK_MODULES.FILESTACK_SDK, exports.Filestack, { version: '3.20.0' });
tslib_1.__exportStar(require("./lib/api/transform"), exports);

@@ -54,0 +54,0 @@ tslib_1.__exportStar(require("./lib/filelink"), exports);

@@ -5,2 +5,3 @@ import { EventEmitter } from 'eventemitter3';

import { TransformOptions } from './api/transform';
import * as Utils from './utils';
import { InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';

@@ -71,2 +72,9 @@ import { PreviewOptions } from './api/preview';

private forwardErrors;
/**
* Returns filestack utils
*
* @readonly
* @memberof Client
*/
get utils(): typeof Utils;
constructor(apikey: string, options?: ClientOptions);

@@ -73,0 +81,0 @@ /**

@@ -27,3 +27,3 @@ "use strict";

var store_1 = require("./api/store");
var utils_1 = require("./utils");
var Utils = require("./utils");
var upload_1 = require("./api/upload");

@@ -64,3 +64,3 @@ var preview_1 = require("./api/preview");

scope.setTag('apikey', apikey);
scope.setTag('sdk-version', utils_1.getVersion());
scope.setTag('sdk-version', Utils.getVersion());
scope.setExtra('clientOptions', options);

@@ -82,2 +82,15 @@ });

}
Object.defineProperty(Client.prototype, "utils", {
/**
* Returns filestack utils
*
* @readonly
* @memberof Client
*/
get: function () {
return Utils;
},
enumerable: true,
configurable: true
});
/**

@@ -118,3 +131,3 @@ * Make basic prefetch request to check permissions

this.session.cname = cname;
this.session.urls = utils_1.resolveHost(this.session.urls, cname);
this.session.urls = Utils.resolveHost(this.session.urls, cname);
};

@@ -372,4 +385,4 @@ /**

Sentry.withScope(function (scope) {
scope.setExtras(e.details);
scope.setExtras({ uploadOptions: options, storeOptions: storeOptions });
scope.setExtras({ uploadOptions: options, storeOptions: storeOptions, details: e.details });
e.message = "FS-" + e.message;
Sentry.captureException(e);

@@ -439,2 +452,2 @@ });

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/client.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;GAeG;;;AAEH,+CAA6C;AAC7C,wCAA0C;AAC1C,oCAA0C;AAC1C,wDAAsD;AACtD,mCAA0F;AAC1F,6CAA8D;AAC9D,qCAAuC;AACvC,iCAAkD;AAClD,uCAAgG;AAChG,yCAAwD;AACxD,qCAA0C;AAC1C,2CAA6E;AAG7E,mCAAiE;AAEjE,0BAA0B;AAC1B,MAAM,CAAC,aAAa,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,wBAAwB,EAAE,CAAC,CAAC;AA6C7E;;;;;;;;;;;;;;;GAeG;AACH;IAA4B,kCAAY;IAOtC,gBAAY,MAAc,EAAE,OAAuB;QAAnD,YACE,iBAAO,SA6BR;QAhCO,mBAAa,GAAY,IAAI,CAAC;QAKpC,wBAAwB;QACxB,IAAI,OAAO,IAAI,OAAO,CAAC,aAAa,EAAE;YACpC,KAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;SAC5C;QAED,0BAA0B;QAC1B,MAAM,CAAC,cAAc,CAAC,UAAA,KAAK;YACzB,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC/B,KAAK,CAAC,MAAM,CAAC,aAAa,EAAE,kBAAU,EAAE,CAAC,CAAC;YAC1C,KAAK,CAAC,QAAQ,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;YAChE,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAC;SAC7E;QACO,IAAA,2BAAI,CAAY;QACxB,KAAI,CAAC,OAAO,GAAG,EAAE,MAAM,QAAA,EAAE,IAAI,MAAA,EAAE,CAAC;QAEhC,IAAI,OAAO,EAAE;YACH,IAAA,qBAAK,EAAE,2BAAQ,CAAa;YAEpC,KAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC3B,KAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACtB;QAED,KAAI,CAAC,gBAAgB,GAAG,IAAI,mBAAQ,CAAC,KAAI,CAAC,OAAO,CAAC,CAAC;QACnD,KAAI,CAAC,KAAK,GAAG,IAAI,mBAAW,CAAC,KAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;;IACtD,CAAC;IAED;;;;OAIG;IACH,yBAAQ,GAAR,UAAS,MAAuB;QAC9B,OAAO,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACjD,CAAC;IAED;;;;;OAKG;IACH,4BAAW,GAAX,UAAY,QAAkB;QAC5B,IAAI,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,SAAS,CAAC,EAAE;YACxD,MAAM,IAAI,gCAAc,CAAC,4DAA4D,CAAC,CAAC;SACxF;QAED,IAAI,QAAQ,IAAI,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,SAAS,EAAE;YACrD,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;YACtC,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;SAC7C;IACH,CAAC;IAED;;;;;;OAMG;IACH,yBAAQ,GAAR,UAAS,KAAa;QACpB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAChC,OAAO;SACR;QAED,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,mBAAW,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;IAED;;;;;OAKG;IACH,uBAAM,GAAN,UAAO,IAAa;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IACD;;;;;;;;;;;;;;;;;;;OAmBG;IACH,yBAAQ,GAAR,UAAS,MAAc,EAAE,OAAyB,EAAE,QAAmB;QACrE,0BAA0B;QAC1B,OAAO,eAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC3D,CAAC;IACD;;OAEG;IACH,uBAAM,GAAN,UAAO,OAAuB;QAC5B,0BAA0B;QAC1B,OAAO,eAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAC/B,CAAC;IACD;;;;;;;;;;;;;OAaG;IACH,wBAAO,GAAP,UAAQ,MAAc,EAAE,OAAwB;QAC9C,0BAA0B;QAC1B,OAAO,iBAAO,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAChD,CAAC;IACD;;;;;;;;;;;;;;;;;;;;OAoBG;IACH,uBAAM,GAAN,UAAO,MAAc,EAAE,QAAmB;QACxC,0BAA0B;QAC1B,OAAO,aAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;IACvD,CAAC;IACD;;;;;;;;;;;;;;;;;;;;OAoBG;IACH,+BAAc,GAAd,UAAe,MAAc,EAAE,QAAmB;QAChD,0BAA0B;QAC1B,OAAO,aAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;IACtD,CAAC;IACD;;;;;;;;;;;;;;;;;OAiBG;IACH,yBAAQ,GAAR,UAAS,GAAW,EAAE,WAAyB,EAAE,KAAW,EAAE,QAAmB,EAAE,UAAuB,EAAE,OAAiC;QAC3I,OAAO,gBAAQ,CAAC;YACd,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,GAAG,KAAA;YACH,WAAW,aAAA;YACX,KAAK,OAAA;YACL,QAAQ,UAAA;YACR,UAAU,YAAA;YACV,OAAO,SAAA;SACR,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACH,yBAAQ,GAAR,UAAS,MAAc,EAAE,OAAyB,EAAE,QAAmB;QACrE,0BAA0B;QAC1B,OAAO,eAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAgCG;IACH,0BAAS,GAAT,UAAU,GAAsB,EAAE,OAAyB,EAAE,GAAoB;QAApB,oBAAA,EAAA,WAAoB;QAC/E,0BAA0B;QAC1B,OAAO,qBAAS,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACH,uBAAM,GAAN,UAAO,IAAe,EAAE,OAAuB,EAAE,YAAiC,EAAE,KAAW,EAAE,QAAmB;QAApH,iBA0BC;QAzBC,IAAI,MAAM,GAAG,IAAI,eAAM,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QAC/C,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEhC,IAAI,KAAK,EAAE;YACT,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxB;QAED,IAAI,QAAQ,EAAE;YACZ,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;SAC9B;QAED,0BAA0B;QAC1B,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,UAAA,CAAC;YAClB,IAAI,KAAI,CAAC,aAAa,EAAE;gBACtB,MAAM,CAAC,SAAS,CAAC,UAAA,KAAK;oBACpB,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;oBAC3B,KAAK,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,YAAY,cAAA,EAAE,CAAC,CAAC;oBAC1D,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;gBAC7B,CAAC,CAAC,CAAC;aACJ;YAED,KAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACH,4BAAW,GAAX,UAAY,IAAiB,EAAE,OAAuB,EAAE,YAAiC,EAAE,KAAW,EAAE,QAAmB;QAA3H,iBAyBC;QAxBC,IAAI,MAAM,GAAG,IAAI,eAAM,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QAE/C,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEhC,IAAI,KAAK,EAAE;YACT,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxB;QAED,IAAI,QAAQ,EAAE;YACZ,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;SAC9B;QAED,0BAA0B;QAC1B,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,UAAA,CAAC;YAClB,MAAM,CAAC,SAAS,CAAC,UAAA,KAAK;gBACpB,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;gBAC3B,KAAK,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,YAAY,cAAA,EAAE,CAAC,CAAC;gBAC1D,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;YAEH,KAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IACH,aAAC;AAAD,CAtZA,AAsZC,CAtZ2B,4BAAY,GAsZvC;AAtZY,wBAAM","file":"lib/client.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventEmitter } from 'eventemitter3';\nimport * as Sentry from '@sentry/minimal';\nimport { config, Hosts } from '../config';\nimport { FilestackError } from './../filestack_error';\nimport { metadata, MetadataOptions, remove, retrieve, RetrieveOptions } from './api/file';\nimport { transform, TransformOptions } from './api/transform';\nimport { storeURL } from './api/store';\nimport { resolveHost, getVersion } from './utils';\nimport { Upload, InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';\nimport { preview, PreviewOptions } from './api/preview';\nimport { CloudClient } from './api/cloud';\nimport { Prefetch, PrefetchResponse, PrefetchOptions } from './api/prefetch';\nimport { StoreParams } from './filelink';\n\nimport { picker, PickerInstance, PickerOptions } from './picker';\n\n/* istanbul ignore next */\nSentry.addBreadcrumb({ category: 'sdk', message: 'filestack-js-sdk scope' });\n\nexport interface Session {\n  apikey: string;\n  urls: Hosts;\n  cname?: string;\n  policy?: string;\n  signature?: string;\n  prefetch?: PrefetchResponse;\n}\n\nexport interface Security {\n  policy: string;\n  signature: string;\n}\n\nexport interface ClientOptions {\n  [option: string]: any;\n  /**\n   * Security object with policy and signature keys.\n   * Can be used to limit client capabilities and protect public URLs.\n   * It is intended to be used with server-side policy and signature generation.\n   * Read about [security policies](https://www.filestack.com/docs/concepts/security).\n   */\n  security?: Security;\n  /**\n   * Domain to use for all URLs. __Requires the custom CNAME addon__.\n   * If this is enabled then you must also set up your own OAuth applications\n   * for each cloud source you wish to use in the picker.\n   */\n  cname?: string;\n  /**\n   * Enable/disable caching of the cloud session token. Default is false.\n   * This ensures that users will be remembered on your domain when calling the cloud API from the browser.\n   * Please be aware that tokens stored in localStorage are accessible by other scripts on the same domain.\n   */\n  sessionCache?: boolean;\n\n  /**\n   * Enable forwarding error logs to sentry\n   * @default false\n   */\n  forwardErrors?: boolean;\n}\n\n/**\n * The Filestack client, the entry point for all public methods. Encapsulates session information.\n *\n * ### Example\n * ```js\n * // ES module\n * import * as filestack from 'filestack-js';\n * const client = filestack.init('apikey');\n * ```\n *\n * ```js\n * // UMD module in browser\n * <script src=\"https://static.filestackapi.com/filestack-js/3.x.x/filestack.min.js\"></script>\n * const client = filestack.init('apikey');\n * ```\n */\nexport class Client extends EventEmitter {\n  public session: Session;\n  private cloud: CloudClient;\n  private prefetchInstance: Prefetch;\n\n  private forwardErrors: boolean = true;\n\n  constructor(apikey: string, options?: ClientOptions) {\n    super();\n\n    /* istanbul ignore if */\n    if (options && options.forwardErrors) {\n      this.forwardErrors = options.forwardErrors;\n    }\n\n    /* istanbul ignore next */\n    Sentry.configureScope(scope => {\n      scope.setTag('apikey', apikey);\n      scope.setTag('sdk-version', getVersion());\n      scope.setExtra('clientOptions', options);\n    });\n\n    if (!apikey || typeof apikey !== 'string' || apikey.length === 0) {\n      throw new Error('An apikey is required to initialize the Filestack client');\n    }\n    const { urls } = config;\n    this.session = { apikey, urls };\n\n    if (options) {\n      const { cname, security } = options;\n\n      this.setSecurity(security);\n      this.setCname(cname);\n    }\n\n    this.prefetchInstance = new Prefetch(this.session);\n    this.cloud = new CloudClient(this.session, options);\n  }\n\n  /**\n   * Make basic prefetch request to check permissions\n   *\n   * @param params\n   */\n  prefetch(params: PrefetchOptions) {\n    return this.prefetchInstance.getConfig(params);\n  }\n\n  /**\n   * Set security object\n   *\n   * @param {Security} security\n   * @memberof Client\n   */\n  setSecurity(security: Security) {\n    if (security && !(security.policy && security.signature)) {\n      throw new FilestackError('Both policy and signature are required for client security');\n    }\n\n    if (security && security.policy && security.signature) {\n      this.session.policy = security.policy;\n      this.session.signature = security.signature;\n    }\n  }\n\n  /**\n   * Set custom cname\n   *\n   * @param {string} cname\n   * @returns\n   * @memberof Client\n   */\n  setCname(cname: string) {\n    if (!cname || cname.length === 0) {\n      return;\n    }\n\n    this.session.cname = cname;\n    this.session.urls = resolveHost(this.session.urls, cname);\n  }\n\n  /**\n   * Clear all current cloud sessions in the picker.\n   * Optionally pass a cloud source name to only log out of that cloud source.\n   * This essentially clears the OAuth authorization codes from the Filestack session.\n   * @param name Optional cloud source name.\n   */\n  logout(name?: string) {\n    return this.cloud.logout(name);\n  }\n  /**\n   * Retrieve detailed data of stored files.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .metadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Metadata](https://www.filestack.com/docs/api/file#metadata).\n   * @param handle Valid Filestack handle.\n   * @param options Metadata fields to enable on response.\n   * @param security Optional security override.\n   */\n  metadata(handle: string, options?: MetadataOptions, security?: Security) {\n    /* istanbul ignore next */\n    return metadata(this.session, handle, options, security);\n  }\n  /**\n   * Construct a new picker instance.\n   */\n  picker(options?: PickerOptions): PickerInstance {\n    /* istanbul ignore next */\n    return picker(this, options);\n  }\n  /**\n   * Used for viewing files via Filestack handles or storage aliases, __requires Document Viewer addon to your Filestack application__.\n   * Opens document viewer in new window if id option is not provided.\n   *\n   * ### Example\n   *\n   * ```js\n   * // <div id=\"preview\"></div>\n   *\n   * client.preview('DCL5K46FS3OIxb5iuKby', { id: 'preview' });\n   * ```\n   * @param handle Valid Filestack handle.\n   * @param options Preview options\n   */\n  preview(handle: string, options?: PreviewOptions) {\n    /* istanbul ignore next */\n    return preview(this.session, handle, options);\n  }\n  /**\n   * Remove a file from storage and the Filestack system.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .remove('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  remove(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, false, security);\n  }\n  /**\n   * Remove a file **only** from the Filestack system. The file remains in storage.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .removeMetadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  removeMetadata(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, true, security);\n  }\n  /**\n   * Store a file from its URL.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .storeURL('https://d1wtqaffaaj63z.cloudfront.net/images/NY_199_E_of_Hammertown_2014.jpg')\n   *   .then(res => console.log(res));\n   * ```\n   * @see [File API - Store](https://www.filestack.com/docs/api/file#store)\n   * @param url       Valid URL to a file.\n   * @param options   Configure file storage.\n   * @param token     Optional control token to call .cancel()\n   * @param security  Optional security override.\n   * @param uploadTags Optional tags visible in webhooks.\n   * @param headers    Optional headers to send\n   */\n  storeURL(url: string, storeParams?: StoreParams, token?: any, security?: Security, uploadTags?: UploadTags, headers?: {[key: string]: string}): Promise<Object> {\n    return storeURL({\n      session: this.session,\n      url,\n      storeParams,\n      token,\n      security,\n      uploadTags,\n      headers,\n    });\n  }\n\n  /**\n   * Access files via their Filestack handles.\n   *\n   * If head option is provided - request headers are returned in promise\n   * If metadata option is provided - metadata object is returned in promise\n   * Otherwise file blob is returned\n   * Metadata and head options cannot be mixed\n   *\n   * ### Example\n   *\n   * ```js\n   * client.retrieve('fileHandle', {\n   *  metadata: true,\n   * }).then((response) => {\n   *  console.log(response);\n   * }).catch((err) => {\n   *  console.error(err);\n   * })\n   * ```\n   *\n   * @see [File API - Download](https://www.filestack.com/docs/api/file#download)\n   * @param handle    Valid file handle\n   * @param options   RetrieveOptions\n   * @param security  Optional security override.\n   * @throws          Error\n   */\n  retrieve(handle: string, options?: RetrieveOptions, security?: Security): Promise<Object | Blob> {\n    /* istanbul ignore next */\n    return retrieve(this.session, handle, options, security);\n  }\n\n  /**\n   * Interface to the Filestack [Processing API](https://www.filestack.com/docs/api/processing).\n   * Convert a URL, handle, or storage alias to another URL which links to the transformed file.\n   * You can optionally store the returned URL with client.storeURL.\n   *\n   * Transform params can be provided in camelCase or snakeCase style ie: partial_pixelate or partialPixelate\n   *\n   * ### Example\n   *\n   * ```js\n   * const transformedUrl = client.transform(url, {\n   *   crop: {\n   *     dim: [x, y, width, height],\n   *   },\n   *   vignette: {\n   *     blurmode: 'gaussian',\n   *     amount: 50,\n   *   },\n   *   flip: true,\n   *   partial_pixelate: {\n   *     objects: [[10, 20, 200, 250], [275, 91, 500, 557]],\n   *   },\n   * };\n   *\n   * // optionally store the new URL\n   * client.storeURL(transformedUrl).then(res => console.log(res));\n   * ```\n   * @see [Filestack Processing API](https://www.filestack.com/docs/api/processing)\n   * @param url     Single or multiple valid URLs (http(s)://), file handles, or storage aliases (src://) to an image.\n   * @param options Transformations are applied in the order specified by this object.\n   * @param b64     Use new more safe format for generating transforms url (default=false) Note: If there will be any issues with url please test it with enabled b64 support\n   * @returns       A new URL that points to the transformed resource.\n   */\n  transform(url: string | string[], options: TransformOptions, b64: boolean = false) {\n    /* istanbul ignore next */\n    return transform(this.session, url, options, b64);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.upload(file, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.upload({file, name}, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile}    file           Must be a valid [File | Blob | Buffer | string]\n   * @param uploadOptions  Uploader options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  upload(file: InputFile, options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      if (this.forwardErrors) {\n        Sentry.withScope(scope => {\n          scope.setExtras(e.details);\n          scope.setExtras({ uploadOptions: options, storeOptions });\n          Sentry.captureException(e);\n        });\n      }\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.upload(file);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.multiupload([file], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.multiupload([{file, name}], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile[]}  file           Must be a valid [File | Blob | Buffer | string (base64)]\n   * @param uploadOptions  Upload options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  multiupload(file: InputFile[], options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      Sentry.withScope(scope => {\n        scope.setExtras(e.details);\n        scope.setExtras({ uploadOptions: options, storeOptions });\n        Sentry.captureException(e);\n      });\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.multiupload(file);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/client.ts"],"names":[],"mappings":"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","file":"lib/client.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventEmitter } from 'eventemitter3';\nimport * as Sentry from '@sentry/minimal';\nimport { config, Hosts } from '../config';\nimport { FilestackError } from './../filestack_error';\nimport { metadata, MetadataOptions, remove, retrieve, RetrieveOptions } from './api/file';\nimport { transform, TransformOptions } from './api/transform';\nimport { storeURL } from './api/store';\nimport * as Utils from './utils';\nimport { Upload, InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';\nimport { preview, PreviewOptions } from './api/preview';\nimport { CloudClient } from './api/cloud';\nimport { Prefetch, PrefetchResponse, PrefetchOptions } from './api/prefetch';\nimport { StoreParams } from './filelink';\n\nimport { picker, PickerInstance, PickerOptions } from './picker';\n\n/* istanbul ignore next */\nSentry.addBreadcrumb({ category: 'sdk', message: 'filestack-js-sdk scope' });\n\nexport interface Session {\n  apikey: string;\n  urls: Hosts;\n  cname?: string;\n  policy?: string;\n  signature?: string;\n  prefetch?: PrefetchResponse;\n}\n\nexport interface Security {\n  policy: string;\n  signature: string;\n}\n\nexport interface ClientOptions {\n  [option: string]: any;\n  /**\n   * Security object with policy and signature keys.\n   * Can be used to limit client capabilities and protect public URLs.\n   * It is intended to be used with server-side policy and signature generation.\n   * Read about [security policies](https://www.filestack.com/docs/concepts/security).\n   */\n  security?: Security;\n  /**\n   * Domain to use for all URLs. __Requires the custom CNAME addon__.\n   * If this is enabled then you must also set up your own OAuth applications\n   * for each cloud source you wish to use in the picker.\n   */\n  cname?: string;\n  /**\n   * Enable/disable caching of the cloud session token. Default is false.\n   * This ensures that users will be remembered on your domain when calling the cloud API from the browser.\n   * Please be aware that tokens stored in localStorage are accessible by other scripts on the same domain.\n   */\n  sessionCache?: boolean;\n\n  /**\n   * Enable forwarding error logs to sentry\n   * @default false\n   */\n  forwardErrors?: boolean;\n}\n\n/**\n * The Filestack client, the entry point for all public methods. Encapsulates session information.\n *\n * ### Example\n * ```js\n * // ES module\n * import * as filestack from 'filestack-js';\n * const client = filestack.init('apikey');\n * ```\n *\n * ```js\n * // UMD module in browser\n * <script src=\"https://static.filestackapi.com/filestack-js/3.x.x/filestack.min.js\"></script>\n * const client = filestack.init('apikey');\n * ```\n */\nexport class Client extends EventEmitter {\n  public session: Session;\n  private cloud: CloudClient;\n  private prefetchInstance: Prefetch;\n\n  private forwardErrors: boolean = true;\n\n  /**\n   * Returns filestack utils\n   *\n   * @readonly\n   * @memberof Client\n   */\n  get utils() {\n    return Utils;\n  }\n\n  constructor(apikey: string, options?: ClientOptions) {\n    super();\n\n    /* istanbul ignore if */\n    if (options && options.forwardErrors) {\n      this.forwardErrors = options.forwardErrors;\n    }\n\n    /* istanbul ignore next */\n    Sentry.configureScope(scope => {\n      scope.setTag('apikey', apikey);\n      scope.setTag('sdk-version', Utils.getVersion());\n      scope.setExtra('clientOptions', options);\n    });\n\n    if (!apikey || typeof apikey !== 'string' || apikey.length === 0) {\n      throw new Error('An apikey is required to initialize the Filestack client');\n    }\n    const { urls } = config;\n    this.session = { apikey, urls };\n\n    if (options) {\n      const { cname, security } = options;\n\n      this.setSecurity(security);\n      this.setCname(cname);\n    }\n\n    this.prefetchInstance = new Prefetch(this.session);\n    this.cloud = new CloudClient(this.session, options);\n  }\n\n  /**\n   * Make basic prefetch request to check permissions\n   *\n   * @param params\n   */\n  prefetch(params: PrefetchOptions) {\n    return this.prefetchInstance.getConfig(params);\n  }\n\n  /**\n   * Set security object\n   *\n   * @param {Security} security\n   * @memberof Client\n   */\n  setSecurity(security: Security) {\n    if (security && !(security.policy && security.signature)) {\n      throw new FilestackError('Both policy and signature are required for client security');\n    }\n\n    if (security && security.policy && security.signature) {\n      this.session.policy = security.policy;\n      this.session.signature = security.signature;\n    }\n  }\n\n  /**\n   * Set custom cname\n   *\n   * @param {string} cname\n   * @returns\n   * @memberof Client\n   */\n  setCname(cname: string) {\n    if (!cname || cname.length === 0) {\n      return;\n    }\n\n    this.session.cname = cname;\n    this.session.urls = Utils.resolveHost(this.session.urls, cname);\n  }\n\n  /**\n   * Clear all current cloud sessions in the picker.\n   * Optionally pass a cloud source name to only log out of that cloud source.\n   * This essentially clears the OAuth authorization codes from the Filestack session.\n   * @param name Optional cloud source name.\n   */\n  logout(name?: string) {\n    return this.cloud.logout(name);\n  }\n  /**\n   * Retrieve detailed data of stored files.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .metadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Metadata](https://www.filestack.com/docs/api/file#metadata).\n   * @param handle Valid Filestack handle.\n   * @param options Metadata fields to enable on response.\n   * @param security Optional security override.\n   */\n  metadata(handle: string, options?: MetadataOptions, security?: Security) {\n    /* istanbul ignore next */\n    return metadata(this.session, handle, options, security);\n  }\n  /**\n   * Construct a new picker instance.\n   */\n  picker(options?: PickerOptions): PickerInstance {\n    /* istanbul ignore next */\n    return picker(this, options);\n  }\n  /**\n   * Used for viewing files via Filestack handles or storage aliases, __requires Document Viewer addon to your Filestack application__.\n   * Opens document viewer in new window if id option is not provided.\n   *\n   * ### Example\n   *\n   * ```js\n   * // <div id=\"preview\"></div>\n   *\n   * client.preview('DCL5K46FS3OIxb5iuKby', { id: 'preview' });\n   * ```\n   * @param handle Valid Filestack handle.\n   * @param options Preview options\n   */\n  preview(handle: string, options?: PreviewOptions) {\n    /* istanbul ignore next */\n    return preview(this.session, handle, options);\n  }\n  /**\n   * Remove a file from storage and the Filestack system.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .remove('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  remove(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, false, security);\n  }\n  /**\n   * Remove a file **only** from the Filestack system. The file remains in storage.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .removeMetadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  removeMetadata(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, true, security);\n  }\n  /**\n   * Store a file from its URL.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .storeURL('https://d1wtqaffaaj63z.cloudfront.net/images/NY_199_E_of_Hammertown_2014.jpg')\n   *   .then(res => console.log(res));\n   * ```\n   * @see [File API - Store](https://www.filestack.com/docs/api/file#store)\n   * @param url       Valid URL to a file.\n   * @param options   Configure file storage.\n   * @param token     Optional control token to call .cancel()\n   * @param security  Optional security override.\n   * @param uploadTags Optional tags visible in webhooks.\n   * @param headers    Optional headers to send\n   */\n  storeURL(url: string, storeParams?: StoreParams, token?: any, security?: Security, uploadTags?: UploadTags, headers?: {[key: string]: string}): Promise<Object> {\n    return storeURL({\n      session: this.session,\n      url,\n      storeParams,\n      token,\n      security,\n      uploadTags,\n      headers,\n    });\n  }\n\n  /**\n   * Access files via their Filestack handles.\n   *\n   * If head option is provided - request headers are returned in promise\n   * If metadata option is provided - metadata object is returned in promise\n   * Otherwise file blob is returned\n   * Metadata and head options cannot be mixed\n   *\n   * ### Example\n   *\n   * ```js\n   * client.retrieve('fileHandle', {\n   *  metadata: true,\n   * }).then((response) => {\n   *  console.log(response);\n   * }).catch((err) => {\n   *  console.error(err);\n   * })\n   * ```\n   *\n   * @see [File API - Download](https://www.filestack.com/docs/api/file#download)\n   * @param handle    Valid file handle\n   * @param options   RetrieveOptions\n   * @param security  Optional security override.\n   * @throws          Error\n   */\n  retrieve(handle: string, options?: RetrieveOptions, security?: Security): Promise<Object | Blob> {\n    /* istanbul ignore next */\n    return retrieve(this.session, handle, options, security);\n  }\n\n  /**\n   * Interface to the Filestack [Processing API](https://www.filestack.com/docs/api/processing).\n   * Convert a URL, handle, or storage alias to another URL which links to the transformed file.\n   * You can optionally store the returned URL with client.storeURL.\n   *\n   * Transform params can be provided in camelCase or snakeCase style ie: partial_pixelate or partialPixelate\n   *\n   * ### Example\n   *\n   * ```js\n   * const transformedUrl = client.transform(url, {\n   *   crop: {\n   *     dim: [x, y, width, height],\n   *   },\n   *   vignette: {\n   *     blurmode: 'gaussian',\n   *     amount: 50,\n   *   },\n   *   flip: true,\n   *   partial_pixelate: {\n   *     objects: [[10, 20, 200, 250], [275, 91, 500, 557]],\n   *   },\n   * };\n   *\n   * // optionally store the new URL\n   * client.storeURL(transformedUrl).then(res => console.log(res));\n   * ```\n   * @see [Filestack Processing API](https://www.filestack.com/docs/api/processing)\n   * @param url     Single or multiple valid URLs (http(s)://), file handles, or storage aliases (src://) to an image.\n   * @param options Transformations are applied in the order specified by this object.\n   * @param b64     Use new more safe format for generating transforms url (default=false) Note: If there will be any issues with url please test it with enabled b64 support\n   * @returns       A new URL that points to the transformed resource.\n   */\n  transform(url: string | string[], options: TransformOptions, b64: boolean = false) {\n    /* istanbul ignore next */\n    return transform(this.session, url, options, b64);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.upload(file, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.upload({file, name}, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile}    file           Must be a valid [File | Blob | Buffer | string]\n   * @param uploadOptions  Uploader options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  upload(file: InputFile, options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      if (this.forwardErrors) {\n        Sentry.withScope(scope => {\n          scope.setExtras({ uploadOptions: options, storeOptions, details: e.details });\n          e.message = `FS-${e.message}`;\n\n          Sentry.captureException(e);\n        });\n      }\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.upload(file);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.multiupload([file], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.multiupload([{file, name}], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile[]}  file           Must be a valid [File | Blob | Buffer | string (base64)]\n   * @param uploadOptions  Upload options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  multiupload(file: InputFile[], options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      Sentry.withScope(scope => {\n        scope.setExtras(e.details);\n        scope.setExtras({ uploadOptions: options, storeOptions });\n        Sentry.captureException(e);\n      });\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.multiupload(file);\n  }\n}\n"]}

@@ -274,5 +274,3 @@ "use strict";

if (config.timeout) {
console.log(config.timeout);
req.setTimeout(config.timeout, function () {
console.log('socket timeouted===========');
req.abort();

@@ -329,2 +327,2 @@ if (cancelListener) {

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/request/adapters/http.ts"],"names":[],"mappings":"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","file":"lib/request/adapters/http.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as url from 'url';\nimport * as zlib from 'zlib';\nimport Debug from 'debug';\n\nimport { AdapterInterface } from './interface';\nimport { getVersion } from '../../utils';\nimport * as Stream from 'stream';\nimport { FsRequestOptions, FsResponse } from '../types';\nimport * as utils from '../utils';\nimport { prepareData, parseResponse, combineURL, set as setHeader, normalizeHeaders } from './../helpers';\nimport { FsRequestErrorCode, FsRequestError } from '../error';\nimport { FsHttpMethod } from './../types';\n\nconst HTTPS_REGEXP = /https:?/;\nconst HTTP_CHUNK_SIZE = 16 * 1024;\nconst MAX_REDIRECTS = 10;\nconst CANCEL_CLEAR = `FsCleanMemory`;\nconst debug = Debug('fs:request:http');\n\n/**\n * Writable stream thats overwrap http request for progress event\n *\n * @class HttpWritableStream\n * @extends {Stream.Writable}\n */\nclass HttpWritableStream extends Stream.Writable {\n  private request;\n\n  constructor(req, opts = {}) {\n    super(opts);\n\n    this.request = req;\n    req.once('drain', () => this.emit('drain'));\n  }\n\n  _write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): void {\n    this.request.write(chunk, encoding, cb);\n  }\n\n  end(chunk) {\n    if (chunk) {\n      this.request.write(chunk);\n    }\n\n    this.request.end();\n  }\n}\n\n/**\n * Node http request class\n *\n * @export\n * @class HttpAdapter\n * @implements {AdapterInterface}\n */\nexport class HttpAdapter implements AdapterInterface {\n  private redirectHoops = 0;\n  private redirectPaths = [];\n\n  /**\n   * do request based on configuration\n   *\n   * @param {FsRequestOptions} config\n   * @returns\n   * @memberof HttpAdapter\n   */\n  request(config: FsRequestOptions) {\n    // if this option is unspecified set it by default\n    if (typeof config.filestackHeaders === 'undefined') {\n      config.filestackHeaders = true;\n    }\n\n    config.headers = normalizeHeaders(config.headers);\n\n    let { data, headers } = prepareData(config);\n\n    headers = setHeader(headers, 'user-agent', `filestack-request/${getVersion()}`);\n\n    // for now we are not using streams\n    if (data) {\n      debug('Request data %O', data);\n\n      if (!Buffer.isBuffer(data)) {\n        if (!utils.isString(data)) {\n          return Promise.reject(new FsRequestError('Data must be a string, JSON or a Buffer', config));\n        }\n\n        data = Buffer.from(data, 'utf-8');\n      }\n\n      headers = setHeader(headers, 'content-length', data.length, true);\n    }\n\n    // HTTP basic authentication\n    let auth;\n    if (config.auth) {\n      if (!config.auth.username || config.auth.username.length === 0) {\n        return Promise.reject(new FsRequestError(`Basic auth: username is required ${config.auth}`, config));\n      }\n\n      auth = `${config.auth.username}:${config.auth.password}`;\n    }\n\n    // Parse url\n    let parsed = url.parse(config.url);\n\n    // try to add default https protocol\n    if (!parsed.protocol) {\n      parsed = url.parse(`https://${config.url}`);\n    }\n\n    /* istanbul ignore next: just be sure that the host is parsed correctly, not needed to test */\n    if (!parsed.host) {\n      return Promise.reject(new FsRequestError(`Cannot parse provided url ${config.url}`, config));\n    }\n\n    // normalize auth header\n    if (auth && headers.Authorization) {\n      delete headers.Authorization;\n    }\n\n    const isHttpsRequest = HTTPS_REGEXP.test(parsed.protocol);\n    const agent = isHttpsRequest ? require('https') : require('http');\n\n    const options = {\n      path: combineURL(parsed.path, config.params),\n      host: parsed.host,\n      port: parsed.port,\n      protocol: parsed.protocol,\n      method: config.method.toUpperCase(),\n      headers: headers,\n      agent: new agent.Agent(),\n      auth: auth,\n    };\n\n    debug('Starting %s request with options %O', isHttpsRequest ? 'https' : 'http', options);\n\n    return new Promise<FsResponse>((resolve, reject): any => {\n      let req;\n      let cancelListener;\n\n      if (config.cancelToken) {\n        cancelListener = config.cancelToken.on('cancel', (reason) => {\n          // cleanup handler\n          cancelListener = null;\n\n          // do nothing if promise is resolved by system\n          if (reason && reason.message === CANCEL_CLEAR) {\n            return;\n          }\n\n          /* istanbul ignore next: if request is done cancel token should not throw any error */\n          if (req) {\n            req.abort();\n            req = null;\n          }\n\n          debug('Request canceled by user %s, config: %O', reason, config);\n          return reject(new FsRequestError(`Request aborted. Reason: ${reason}`, config, null, FsRequestErrorCode.ABORTED));\n        });\n      }\n\n      req = agent.request(options, res => {\n        /* istanbul ignore next: just be sure that response will not be called after request is aborted */\n        if (!req || req.aborted) {\n          return reject(new FsRequestError('Request aborted', config));\n        }\n\n        let stream = res;\n        debug('Response statusCode: %d, Response Headers: %O', res.statusCode, res.headers);\n\n        const compressHeaders = res.headers['content-encoding'];\n\n        if (compressHeaders && compressHeaders.length && ['gzip', 'compress', 'deflate'].some((v) => compressHeaders.indexOf(v) > -1)) {\n          // add the unzipper to the body stream processing pipeline\n          stream = res.statusCode === 204 ? stream : stream.pipe(zlib.createUnzip());\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n        }\n\n        let response: FsResponse = {\n          status: res.statusCode,\n          statusText: res.statusMessage,\n          headers: res.headers,\n          config,\n          data: {},\n        };\n\n        // we need to follow redirect so make same request with new location\n        if ([301, 302].indexOf(res.statusCode) > -1) {\n          debug('Redirect received %s', res.statusCode);\n\n          if (this.redirectHoops >= MAX_REDIRECTS) {\n            return reject(new FsRequestError(`Max redirects (${this.redirectHoops}) reached. Exiting`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          const url = res.headers['location'];\n\n          if (!url || url.length === 0) {\n            return reject(new FsRequestError(`Redirect header location not found`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          if (this.redirectPaths.indexOf(url) > -1) {\n            return reject(new FsRequestError(`Redirect loop detected at url ${url}`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          this.redirectPaths.push(url);\n          this.redirectHoops++;\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          debug('Redirecting request to %s (hoop-count: %d)', url, this.redirectHoops);\n\n          return resolve(this.request(Object.assign({}, config, { url })));\n        }\n\n        let responseBuffer = [];\n        stream.on('data', chunk => responseBuffer.push(chunk));\n\n        /* istanbul ignore next: its hard to test socket events with jest and nock - tested manually */\n        stream.on('error', err => {\n          res = undefined;\n          req = undefined;\n          responseBuffer = undefined;\n          debug('Request error: Aborted %O', err);\n\n          if (req.aborted) {\n            return;\n          }\n\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError(err.message, config, null, FsRequestErrorCode.NETWORK));\n        });\n\n        stream.on('end', async () => {\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          // check if there is any response data inside\n          if (res.statusCode !== 204) {\n            // prepare response\n            response.data = Buffer.concat(responseBuffer);\n            response = await parseResponse(response);\n          } else {\n            response.data = null;\n          }\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          responseBuffer = undefined;\n\n          if (500 <= response.status && response.status <= 599) {\n            // server error throw\n            debug('Server error(5xx) - %O', response);\n            return reject(new FsRequestError(`Server error ${url}`, config, response, FsRequestErrorCode.SERVER));\n          } else if (400 <= response.status && response.status <= 499) {\n            debug('Request error(4xx) - %O', response);\n            return reject(new FsRequestError(`Request error ${url}`, config, response, FsRequestErrorCode.REQUEST));\n          }\n\n          debug('Request ends: %O', response);\n          return resolve(response);\n        });\n      });\n\n      if (config.timeout) {\n        console.log(config.timeout);\n        req.setTimeout(config.timeout, () => {\n          console.log('socket timeouted===========');\n          req.abort();\n\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError('Request timeout', config, null, FsRequestErrorCode.TIMEOUT));\n        });\n      }\n\n      req.on('error', err => {\n        if (cancelListener) {\n          config.cancelToken.removeListener(cancelListener);\n        }\n\n        if (!req || req.aborted) {\n          return;\n        }\n\n        debug('Request error: %s - %O', err, err.code);\n        return reject(new FsRequestError(`Request error: ${err.code}`, config, null, FsRequestErrorCode.NETWORK));\n      });\n\n      if (Buffer.isBuffer(data) && ['POST', 'PUT'].indexOf(config.method) > -1) {\n        return this.bufferToChunks(data).pipe(this.getProgressMonitor(config, data.length)).pipe(new HttpWritableStream(req));\n      }\n\n      req.end(data);\n    });\n  }\n\n  /**\n   * Monitor and emit progress event if needed\n   *\n   * @private\n   * @memberof HttpAdapter\n   */\n  private getProgressMonitor = (config, total) => {\n    let loaded = 0;\n\n    const progress = new Stream.Transform();\n    progress._transform = (chunk, encoding, cb) => {\n      if (typeof config.onProgress === 'function' && [FsHttpMethod.POST, FsHttpMethod.PUT].indexOf(config.method) > -1) {\n        loaded += chunk.length;\n        config.onProgress({\n          lengthComputable: true,\n          loaded,\n          total,\n        });\n      }\n      cb(null, chunk);\n    };\n\n    return progress;\n  }\n\n  /**\n   * Convert buffer to stream\n   *\n   * @private\n   * @param {*} buffer\n   * @returns {Stream.Readable}\n   * @memberof HttpAdapter\n   */\n  private bufferToChunks(buffer): Stream.Readable {\n    const chunking = new Stream.Readable();\n    const totalLength = buffer.length;\n    const remainder = totalLength % HTTP_CHUNK_SIZE;\n    const cutoff = totalLength - remainder;\n\n    for (let i = 0; i < cutoff; i += HTTP_CHUNK_SIZE) {\n      const chunk = buffer.slice(i, i + HTTP_CHUNK_SIZE);\n      chunking.push(chunk);\n    }\n\n    if (remainder > 0) {\n      const remainderBuffer = buffer.slice(-remainder);\n      chunking.push(remainderBuffer);\n    }\n\n    chunking.push(null);\n\n    return chunking;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/request/adapters/http.ts"],"names":[],"mappings":"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","file":"lib/request/adapters/http.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as url from 'url';\nimport * as zlib from 'zlib';\nimport Debug from 'debug';\n\nimport { AdapterInterface } from './interface';\nimport { getVersion } from '../../utils';\nimport * as Stream from 'stream';\nimport { FsRequestOptions, FsResponse } from '../types';\nimport * as utils from '../utils';\nimport { prepareData, parseResponse, combineURL, set as setHeader, normalizeHeaders } from './../helpers';\nimport { FsRequestErrorCode, FsRequestError } from '../error';\nimport { FsHttpMethod } from './../types';\n\nconst HTTPS_REGEXP = /https:?/;\nconst HTTP_CHUNK_SIZE = 16 * 1024;\nconst MAX_REDIRECTS = 10;\nconst CANCEL_CLEAR = `FsCleanMemory`;\nconst debug = Debug('fs:request:http');\n\n/**\n * Writable stream thats overwrap http request for progress event\n *\n * @class HttpWritableStream\n * @extends {Stream.Writable}\n */\nclass HttpWritableStream extends Stream.Writable {\n  private request;\n\n  constructor(req, opts = {}) {\n    super(opts);\n\n    this.request = req;\n    req.once('drain', () => this.emit('drain'));\n  }\n\n  _write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): void {\n    this.request.write(chunk, encoding, cb);\n  }\n\n  end(chunk) {\n    if (chunk) {\n      this.request.write(chunk);\n    }\n\n    this.request.end();\n  }\n}\n\n/**\n * Node http request class\n *\n * @export\n * @class HttpAdapter\n * @implements {AdapterInterface}\n */\nexport class HttpAdapter implements AdapterInterface {\n  private redirectHoops = 0;\n  private redirectPaths = [];\n\n  /**\n   * do request based on configuration\n   *\n   * @param {FsRequestOptions} config\n   * @returns\n   * @memberof HttpAdapter\n   */\n  request(config: FsRequestOptions) {\n    // if this option is unspecified set it by default\n    if (typeof config.filestackHeaders === 'undefined') {\n      config.filestackHeaders = true;\n    }\n\n    config.headers = normalizeHeaders(config.headers);\n\n    let { data, headers } = prepareData(config);\n\n    headers = setHeader(headers, 'user-agent', `filestack-request/${getVersion()}`);\n\n    // for now we are not using streams\n    if (data) {\n      debug('Request data %O', data);\n\n      if (!Buffer.isBuffer(data)) {\n        if (!utils.isString(data)) {\n          return Promise.reject(new FsRequestError('Data must be a string, JSON or a Buffer', config));\n        }\n\n        data = Buffer.from(data, 'utf-8');\n      }\n\n      headers = setHeader(headers, 'content-length', data.length, true);\n    }\n\n    // HTTP basic authentication\n    let auth;\n    if (config.auth) {\n      if (!config.auth.username || config.auth.username.length === 0) {\n        return Promise.reject(new FsRequestError(`Basic auth: username is required ${config.auth}`, config));\n      }\n\n      auth = `${config.auth.username}:${config.auth.password}`;\n    }\n\n    // Parse url\n    let parsed = url.parse(config.url);\n\n    // try to add default https protocol\n    if (!parsed.protocol) {\n      parsed = url.parse(`https://${config.url}`);\n    }\n\n    /* istanbul ignore next: just be sure that the host is parsed correctly, not needed to test */\n    if (!parsed.host) {\n      return Promise.reject(new FsRequestError(`Cannot parse provided url ${config.url}`, config));\n    }\n\n    // normalize auth header\n    if (auth && headers.Authorization) {\n      delete headers.Authorization;\n    }\n\n    const isHttpsRequest = HTTPS_REGEXP.test(parsed.protocol);\n    const agent = isHttpsRequest ? require('https') : require('http');\n\n    const options = {\n      path: combineURL(parsed.path, config.params),\n      host: parsed.host,\n      port: parsed.port,\n      protocol: parsed.protocol,\n      method: config.method.toUpperCase(),\n      headers: headers,\n      agent: new agent.Agent(),\n      auth: auth,\n    };\n\n    debug('Starting %s request with options %O', isHttpsRequest ? 'https' : 'http', options);\n\n    return new Promise<FsResponse>((resolve, reject): any => {\n      let req;\n      let cancelListener;\n\n      if (config.cancelToken) {\n        cancelListener = config.cancelToken.on('cancel', (reason) => {\n          // cleanup handler\n          cancelListener = null;\n\n          // do nothing if promise is resolved by system\n          if (reason && reason.message === CANCEL_CLEAR) {\n            return;\n          }\n\n          /* istanbul ignore next: if request is done cancel token should not throw any error */\n          if (req) {\n            req.abort();\n            req = null;\n          }\n\n          debug('Request canceled by user %s, config: %O', reason, config);\n          return reject(new FsRequestError(`Request aborted. Reason: ${reason}`, config, null, FsRequestErrorCode.ABORTED));\n        });\n      }\n\n      req = agent.request(options, res => {\n        /* istanbul ignore next: just be sure that response will not be called after request is aborted */\n        if (!req || req.aborted) {\n          return reject(new FsRequestError('Request aborted', config));\n        }\n\n        let stream = res;\n        debug('Response statusCode: %d, Response Headers: %O', res.statusCode, res.headers);\n\n        const compressHeaders = res.headers['content-encoding'];\n\n        if (compressHeaders && compressHeaders.length && ['gzip', 'compress', 'deflate'].some((v) => compressHeaders.indexOf(v) > -1)) {\n          // add the unzipper to the body stream processing pipeline\n          stream = res.statusCode === 204 ? stream : stream.pipe(zlib.createUnzip());\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n        }\n\n        let response: FsResponse = {\n          status: res.statusCode,\n          statusText: res.statusMessage,\n          headers: res.headers,\n          config,\n          data: {},\n        };\n\n        // we need to follow redirect so make same request with new location\n        if ([301, 302].indexOf(res.statusCode) > -1) {\n          debug('Redirect received %s', res.statusCode);\n\n          if (this.redirectHoops >= MAX_REDIRECTS) {\n            return reject(new FsRequestError(`Max redirects (${this.redirectHoops}) reached. Exiting`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          const url = res.headers['location'];\n\n          if (!url || url.length === 0) {\n            return reject(new FsRequestError(`Redirect header location not found`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          if (this.redirectPaths.indexOf(url) > -1) {\n            return reject(new FsRequestError(`Redirect loop detected at url ${url}`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          this.redirectPaths.push(url);\n          this.redirectHoops++;\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          debug('Redirecting request to %s (hoop-count: %d)', url, this.redirectHoops);\n\n          return resolve(this.request(Object.assign({}, config, { url })));\n        }\n\n        let responseBuffer = [];\n        stream.on('data', chunk => responseBuffer.push(chunk));\n\n        /* istanbul ignore next: its hard to test socket events with jest and nock - tested manually */\n        stream.on('error', err => {\n          res = undefined;\n          req = undefined;\n          responseBuffer = undefined;\n          debug('Request error: Aborted %O', err);\n\n          if (req.aborted) {\n            return;\n          }\n\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError(err.message, config, null, FsRequestErrorCode.NETWORK));\n        });\n\n        stream.on('end', async () => {\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          // check if there is any response data inside\n          if (res.statusCode !== 204) {\n            // prepare response\n            response.data = Buffer.concat(responseBuffer);\n            response = await parseResponse(response);\n          } else {\n            response.data = null;\n          }\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          responseBuffer = undefined;\n\n          if (500 <= response.status && response.status <= 599) {\n            // server error throw\n            debug('Server error(5xx) - %O', response);\n            return reject(new FsRequestError(`Server error ${url}`, config, response, FsRequestErrorCode.SERVER));\n          } else if (400 <= response.status && response.status <= 499) {\n            debug('Request error(4xx) - %O', response);\n            return reject(new FsRequestError(`Request error ${url}`, config, response, FsRequestErrorCode.REQUEST));\n          }\n\n          debug('Request ends: %O', response);\n          return resolve(response);\n        });\n      });\n\n      if (config.timeout) {\n        req.setTimeout(config.timeout, () => {\n          req.abort();\n\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError('Request timeout', config, null, FsRequestErrorCode.TIMEOUT));\n        });\n      }\n\n      req.on('error', err => {\n        if (cancelListener) {\n          config.cancelToken.removeListener(cancelListener);\n        }\n\n        if (!req || req.aborted) {\n          return;\n        }\n\n        debug('Request error: %s - %O', err, err.code);\n        return reject(new FsRequestError(`Request error: ${err.code}`, config, null, FsRequestErrorCode.NETWORK));\n      });\n\n      if (Buffer.isBuffer(data) && ['POST', 'PUT'].indexOf(config.method) > -1) {\n        return this.bufferToChunks(data).pipe(this.getProgressMonitor(config, data.length)).pipe(new HttpWritableStream(req));\n      }\n\n      req.end(data);\n    });\n  }\n\n  /**\n   * Monitor and emit progress event if needed\n   *\n   * @private\n   * @memberof HttpAdapter\n   */\n  private getProgressMonitor = (config, total) => {\n    let loaded = 0;\n\n    const progress = new Stream.Transform();\n    progress._transform = (chunk, encoding, cb) => {\n      if (typeof config.onProgress === 'function' && [FsHttpMethod.POST, FsHttpMethod.PUT].indexOf(config.method) > -1) {\n        loaded += chunk.length;\n        config.onProgress({\n          lengthComputable: true,\n          loaded,\n          total,\n        });\n      }\n      cb(null, chunk);\n    };\n\n    return progress;\n  }\n\n  /**\n   * Convert buffer to stream\n   *\n   * @private\n   * @param {*} buffer\n   * @returns {Stream.Readable}\n   * @memberof HttpAdapter\n   */\n  private bufferToChunks(buffer): Stream.Readable {\n    const chunking = new Stream.Readable();\n    const totalLength = buffer.length;\n    const remainder = totalLength % HTTP_CHUNK_SIZE;\n    const cutoff = totalLength - remainder;\n\n    for (let i = 0; i < cutoff; i += HTTP_CHUNK_SIZE) {\n      const chunk = buffer.slice(i, i + HTTP_CHUNK_SIZE);\n      chunking.push(chunk);\n    }\n\n    if (remainder > 0) {\n      const remainderBuffer = buffer.slice(-remainder);\n      chunking.push(remainderBuffer);\n    }\n\n    chunking.push(null);\n\n    return chunking;\n  }\n}\n"]}

@@ -1,2 +0,2 @@

export declare const Map: {
export declare const ExtensionsMap: {
'application/andrew-inset': string[];

@@ -3,0 +3,0 @@ 'application/applixware': string[];

@@ -48,3 +48,3 @@ "use strict";

exports.getVersion = function () {
return 'JS-3.19.0';
return 'JS-3.20.0';
};

@@ -51,0 +51,0 @@ /**

@@ -42,2 +42,9 @@ /// <reference types="node" />

/**
* Change extension to according mimetype using ext=>mimetype map
*
* @param ext - string
* @return string|boolean
*/
export declare const extensionToMime: (ext: string) => string;
/**
* Sanitizer Options

@@ -44,0 +51,0 @@ */

@@ -100,9 +100,5 @@ "use strict";

if (name && name.indexOf('.') > -1) {
var ext = name.split('.').pop();
var keys = Object.keys(extensions_1.Map);
var mapLen = keys.length;
for (var i = 0; i < mapLen; i++) {
if (extensions_1.Map[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
var mime_1 = exports.extensionToMime(name);
if (mime_1) {
return mime_1;
}

@@ -128,2 +124,27 @@ }

/**
* Change extension to according mimetype using ext=>mimetype map
*
* @param ext - string
* @return string|boolean
*/
exports.extensionToMime = function (ext) {
if (!ext || ext.length === 0) {
return;
}
if (ext.split('/').length === 2) {
return ext;
}
if (ext.indexOf('.') > -1) {
ext = ext.split('.').pop();
}
var keys = Object.keys(extensions_1.ExtensionsMap);
var mapLen = keys.length;
for (var i = 0; i < mapLen; i++) {
if (extensions_1.ExtensionsMap[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
}
return;
};
/**
* Sanitize file name

@@ -198,2 +219,2 @@ *

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.ts"],"names":[],"mappings":"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","file":"lib/utils/index.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Session } from '../client';\nimport { Hosts } from './../../config';\nimport { Map } from './extensions';\nimport fileType from 'file-type';\nimport * as isutf8 from 'isutf8';\n\n/**\n * Resolve cdn url based on handle type\n *\n * @private\n * @param session session object\n * @param handle file handle (hash, src://alias, url)\n */\nexport const resolveCdnUrl = (session: Session, handle: string): string => {\n  const cdnURL = session.urls.cdnUrl;\n\n  if (handle && (handle.indexOf('src:') === 0 || handle.indexOf('http') === 0)) {\n    if (!session.apikey) {\n      throw new Error('Api key is required when storage alias is provided');\n    }\n\n    // apikey is required for alias or external sources call\n    return `${cdnURL}/${session.apikey}`;\n  }\n\n  return cdnURL;\n};\n\n/**\n * Resolve all urls with provided cnames\n *\n * @private\n * @param urls\n * @param cname\n */\nexport const resolveHost = (urls: Hosts, cname: string): Hosts => {\n  if (!cname) {\n    return urls;\n  }\n\n  const hosts = /filestackapi.com|filestackcontent.com/i;\n\n  Object.keys(urls).forEach(key => {\n    urls[key] = urls[key].replace(hosts, cname);\n  });\n\n  return urls;\n};\n\n/**\n * Removes empty options from object\n *\n * @private\n * @param obj\n */\nexport const removeEmpty = (obj: any) => {\n  const newObj = { ...obj };\n  Object.keys(newObj).forEach(k => !newObj[k] && typeof newObj[k] !== 'boolean' && delete newObj[k]);\n  return newObj;\n};\n\n/**\n * Returns unique time\n */\nlet last;\nexport const uniqueTime = () => {\n  const time = Date.now();\n  last = time === last ? time + 1 : time;\n  return last;\n};\n\n/**\n * Generates random string with provided length\n *\n * @param len\n */\nexport const uniqueId = (len: number = 10): string => {\n  return new Array(len).join().replace(/(.|$)/g, () => ((Math.random() * 36) | 0).toString(36)[Math.random() < 0.5 ? 'toString' : 'toUpperCase']());\n};\n\n/**\n * Check if input is a svg\n *\n * @param {Uint8Array | Buffer} file\n * @returns {string} - mimetype\n */\nexport const getMimetype = (file: Uint8Array | Buffer, name?: string): string => {\n  let type = fileType(file);\n\n  const excludedMimetypes = ['text/plain', 'application/octet-stream', 'application/x-ms', 'application/x-msi', 'application/zip'];\n\n  if (type && excludedMimetypes.indexOf(type.mime) === -1) {\n    return type.mime;\n  }\n\n  if (name && name.indexOf('.') > -1) {\n    const ext = name.split('.').pop();\n    const keys = Object.keys(Map);\n    const mapLen = keys.length;\n\n    for (let i = 0; i < mapLen; i++) {\n      if (Map[keys[i]].indexOf(ext) > -1) {\n        return keys[i];\n      }\n    }\n  }\n\n  try {\n    if (isutf8(file)) {\n      return 'text/plain';\n    }\n  } catch (e) {\n    /* istanbul ignore next */\n    console.warn('Additional mimetype checks (text/plain) are currently not supported for browsers');\n  }\n  // this is only fallback, omit it in coverage\n  /* istanbul ignore next */\n\n  // if we cant find types by extensions and we have magic bytes fallback to it\n  if (type) {\n    return type.mime;\n  }\n\n  return 'application/octet-stream';\n};\n\n/**\n * Sanitizer Options\n */\nexport type SanitizeOptions =\n  | boolean\n  | {\n    exclude?: string[];\n    replacement?: string;\n  };\n\n/**\n * Sanitize file name\n *\n * @param name\n * @param {bool} options  - enable,disable sanitizer, default enabled\n * @param {string} options.replacement - replacement for sanitized chars defaults to \"-\"\n * @param {string[]} options.exclude - array with excluded chars default - ['\\', '{', '}','|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>']\n */\nexport const sanitizeName = (name: string, options: SanitizeOptions = true): string => {\n  if (typeof options === 'boolean' && !options) {\n    return name;\n  }\n\n  let ext;\n\n  const replacement = typeof options !== 'boolean' && options.replacement ? options.replacement : '-';\n  const exclude = typeof options !== 'boolean' && options.exclude ? options.exclude : ['\\\\', '{', '}', '|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>'];\n\n  if (!name || name.length === 0) {\n    return 'undefined';\n  }\n\n  const fileParts = name.split('.');\n\n  if (fileParts.length > 1) {\n    ext = fileParts.pop();\n  }\n\n  return `${fileParts\n    .join('.')\n    .split('')\n    .map(char => (exclude.indexOf(char) > -1 ? replacement : char))\n    .join('')}${ext ? '.' + ext : ''}`;\n};\n\n/**\n * Filter object to given fields\n *\n * @param toFilter\n * @param requiredFields\n */\nexport const filterObject = (toFilter, requiredFields: string[]) => {\n  if (!requiredFields || requiredFields.length === 0) {\n    return toFilter;\n  }\n\n  if (Object.keys(toFilter).length === 0) {\n    return toFilter;\n  }\n\n  return Object.keys(toFilter)\n    .filter(f => requiredFields.indexOf(f) > -1)\n    .reduce((obj, key) => ({ ...obj, [key]: toFilter[key] }), {});\n};\n\n/**\n * Deep cleanup object from functions\n *\n * @param obj\n */\nexport const cleanUpCallbacks = (obj: any) => {\n  if (!obj || Object.keys(obj).length === 0) {\n    return obj;\n  }\n\n  Object.keys(obj).forEach(k => {\n    if (typeof obj[k] === 'function') {\n      obj[k] = undefined;\n    }\n\n    if (obj[k] === Object(obj[k])) {\n      obj[k] = cleanUpCallbacks(obj[k]);\n    }\n  });\n\n  return obj;\n};\n\nexport * from './index.node';\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.ts"],"names":[],"mappings":"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","file":"lib/utils/index.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Session } from '../client';\nimport { Hosts } from './../../config';\nimport { ExtensionsMap } from './extensions';\nimport fileType from 'file-type';\nimport * as isutf8 from 'isutf8';\n\n/**\n * Resolve cdn url based on handle type\n *\n * @private\n * @param session session object\n * @param handle file handle (hash, src://alias, url)\n */\nexport const resolveCdnUrl = (session: Session, handle: string): string => {\n  const cdnURL = session.urls.cdnUrl;\n\n  if (handle && (handle.indexOf('src:') === 0 || handle.indexOf('http') === 0)) {\n    if (!session.apikey) {\n      throw new Error('Api key is required when storage alias is provided');\n    }\n\n    // apikey is required for alias or external sources call\n    return `${cdnURL}/${session.apikey}`;\n  }\n\n  return cdnURL;\n};\n\n/**\n * Resolve all urls with provided cnames\n *\n * @private\n * @param urls\n * @param cname\n */\nexport const resolveHost = (urls: Hosts, cname: string): Hosts => {\n  if (!cname) {\n    return urls;\n  }\n\n  const hosts = /filestackapi.com|filestackcontent.com/i;\n\n  Object.keys(urls).forEach(key => {\n    urls[key] = urls[key].replace(hosts, cname);\n  });\n\n  return urls;\n};\n\n/**\n * Removes empty options from object\n *\n * @private\n * @param obj\n */\nexport const removeEmpty = (obj: any) => {\n  const newObj = { ...obj };\n  Object.keys(newObj).forEach(k => !newObj[k] && typeof newObj[k] !== 'boolean' && delete newObj[k]);\n  return newObj;\n};\n\n/**\n * Returns unique time\n */\nlet last;\nexport const uniqueTime = () => {\n  const time = Date.now();\n  last = time === last ? time + 1 : time;\n  return last;\n};\n\n/**\n * Generates random string with provided length\n *\n * @param len\n */\nexport const uniqueId = (len: number = 10): string => {\n  return new Array(len).join().replace(/(.|$)/g, () => ((Math.random() * 36) | 0).toString(36)[Math.random() < 0.5 ? 'toString' : 'toUpperCase']());\n};\n\n/**\n * Check if input is a svg\n *\n * @param {Uint8Array | Buffer} file\n * @returns {string} - mimetype\n */\nexport const getMimetype = (file: Uint8Array | Buffer, name?: string): string => {\n  let type = fileType(file);\n\n  const excludedMimetypes = ['text/plain', 'application/octet-stream', 'application/x-ms', 'application/x-msi', 'application/zip'];\n\n  if (type && excludedMimetypes.indexOf(type.mime) === -1) {\n    return type.mime;\n  }\n\n  if (name && name.indexOf('.') > -1) {\n    const mime = extensionToMime(name);\n\n    if (mime) {\n      return mime;\n    }\n  }\n\n  try {\n    if (isutf8(file)) {\n      return 'text/plain';\n    }\n  } catch (e) {\n    /* istanbul ignore next */\n    console.warn('Additional mimetype checks (text/plain) are currently not supported for browsers');\n  }\n  // this is only fallback, omit it in coverage\n  /* istanbul ignore next */\n\n  // if we cant find types by extensions and we have magic bytes fallback to it\n  if (type) {\n    return type.mime;\n  }\n\n  return 'application/octet-stream';\n};\n\n/**\n * Change extension to according mimetype using ext=>mimetype map\n *\n * @param ext - string\n * @return string|boolean\n */\nexport const extensionToMime = (ext: string) => {\n  if (!ext || ext.length === 0) {\n    return;\n  }\n\n  if (ext.split('/').length === 2) {\n    return ext;\n  }\n\n  if (ext.indexOf('.') > -1) {\n    ext = ext.split('.').pop();\n  }\n\n  const keys = Object.keys(ExtensionsMap);\n  const mapLen = keys.length;\n\n  for (let i = 0; i < mapLen; i++) {\n    if (ExtensionsMap[keys[i]].indexOf(ext) > -1) {\n      return keys[i];\n    }\n  }\n\n  return;\n};\n\n/**\n * Sanitizer Options\n */\nexport type SanitizeOptions =\n  | boolean\n  | {\n    exclude?: string[];\n    replacement?: string;\n  };\n\n/**\n * Sanitize file name\n *\n * @param name\n * @param {bool} options  - enable,disable sanitizer, default enabled\n * @param {string} options.replacement - replacement for sanitized chars defaults to \"-\"\n * @param {string[]} options.exclude - array with excluded chars default - ['\\', '{', '}','|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>']\n */\nexport const sanitizeName = (name: string, options: SanitizeOptions = true): string => {\n  if (typeof options === 'boolean' && !options) {\n    return name;\n  }\n\n  let ext;\n\n  const replacement = typeof options !== 'boolean' && options.replacement ? options.replacement : '-';\n  const exclude = typeof options !== 'boolean' && options.exclude ? options.exclude : ['\\\\', '{', '}', '|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>'];\n\n  if (!name || name.length === 0) {\n    return 'undefined';\n  }\n\n  const fileParts = name.split('.');\n\n  if (fileParts.length > 1) {\n    ext = fileParts.pop();\n  }\n\n  return `${fileParts\n    .join('.')\n    .split('')\n    .map(char => (exclude.indexOf(char) > -1 ? replacement : char))\n    .join('')}${ext ? '.' + ext : ''}`;\n};\n\n/**\n * Filter object to given fields\n *\n * @param toFilter\n * @param requiredFields\n */\nexport const filterObject = (toFilter, requiredFields: string[]) => {\n  if (!requiredFields || requiredFields.length === 0) {\n    return toFilter;\n  }\n\n  if (Object.keys(toFilter).length === 0) {\n    return toFilter;\n  }\n\n  return Object.keys(toFilter)\n    .filter(f => requiredFields.indexOf(f) > -1)\n    .reduce((obj, key) => ({ ...obj, [key]: toFilter[key] }), {});\n};\n\n/**\n * Deep cleanup object from functions\n *\n * @param obj\n */\nexport const cleanUpCallbacks = (obj: any) => {\n  if (!obj || Object.keys(obj).length === 0) {\n    return obj;\n  }\n\n  Object.keys(obj).forEach(k => {\n    if (typeof obj[k] === 'function') {\n      obj[k] = undefined;\n    }\n\n    if (obj[k] === Object(obj[k])) {\n      obj[k] = cleanUpCallbacks(obj[k]);\n    }\n  });\n\n  return obj;\n};\n\nexport * from './index.node';\n"]}

@@ -47,3 +47,3 @@ "use strict";

exports.getVersion = function () {
return 'JS-3.19.0';
return 'JS-3.20.0';
};

@@ -50,0 +50,0 @@ /**

@@ -23,3 +23,3 @@ "use strict";

it('should return version string to replace', function () {
expect(utils.getVersion()).toEqual("JS-3.19.0");
expect(utils.getVersion()).toEqual("JS-3.20.0");
});

@@ -26,0 +26,0 @@ });

@@ -158,2 +158,25 @@ "use strict";

});
describe('extensionToMime', function () {
it('should return mimetype if mime is passed', function () {
expect(index_1.extensionToMime('')).toEqual(undefined);
});
it('should return same mime is passed', function () {
expect(index_1.extensionToMime('image/png')).toEqual('image/png');
expect(index_1.extensionToMime('image/jpg')).toEqual('image/jpg');
expect(index_1.extensionToMime('application/pdf')).toEqual('application/pdf');
});
it('it should return correct mimes for ext', function () {
expect(index_1.extensionToMime('.png')).toEqual('image/png');
expect(index_1.extensionToMime('.jpg')).toEqual('image/jpeg');
expect(index_1.extensionToMime('.pdf')).toEqual('application/pdf');
expect(index_1.extensionToMime('.key')).toEqual('application/vnd.apple.keynote');
expect(index_1.extensionToMime('.zip')).toEqual('application/zip');
expect(index_1.extensionToMime('.numbers')).toEqual('application/vnd.apple.numbers');
});
it('it should extract extensions form filename or ext with dot', function () {
expect(index_1.extensionToMime('test.png')).toEqual('image/png');
expect(index_1.extensionToMime('test.jpg')).toEqual('image/jpeg');
expect(index_1.extensionToMime('test.pdf')).toEqual('application/pdf');
});
});
describe('CleanupCallbacks', function () {

@@ -184,2 +207,2 @@ it('should set callbacks as undefined and return untouched object', function () {

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.spec.ts"],"names":[],"mappings":"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","file":"lib/utils/index.spec.js","sourcesContent":["/*\n * Copyright (c) 2019 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';\nimport { config } from '../../config';\nconst v = require('../../../../package.json').version;\n\ndescribe('utils:index', () => {\n  describe('resolveCdnUrl', () => {\n\n    const session = {\n      apikey: 'TEST_API_KEY',\n      cname: 'example.com',\n      urls: config.urls,\n    };\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = '5aYkEQJSQCmYShsoCnZN';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com');\n    });\n\n    it('should properly resolve cdn url with src handle', () => {\n      const handle = 'src://test123/test.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = 'https://static1.squarespace.com/static/544eb3cce4b0ef091773611f/t/59ba7ce1bd10f00dcdc80a5f/1505394087367/DSC_0527.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should throw an error when using src handle or url without apikey', () => {\n      const handle = 'src://test123/test.jpg';\n      session.apikey = '';\n      expect(() => { resolveCdnUrl(session, handle); }).toThrow('Api key is required when storage alias is provided');\n    });\n  });\n\n  describe('resolveHost', () => {\n    const hosts = config.urls;\n\n    const checkHosts = (hosts, expected) => {\n      Object.keys(hosts).forEach((k) => {\n        expect(hosts[k].indexOf(expected) > -1).toBeTruthy();\n      });\n    };\n\n    it('should return proper host', () => {\n      const cname = 'example.com';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n\n    it('should return hosts when cname is an empty string', () => {\n      const cname = '';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n  });\n\n  describe('removeEmpty', () => {\n    it('should remove empty options from an object', () => {\n      const testOb = { test1: true, test2: undefined, test3: false };\n      expect(removeEmpty(testOb)).toEqual({ test1: true, test3: false });\n    });\n  });\n\n  describe('uniqueTime', () => {\n    it('should return unique times', () => {\n      expect(uniqueTime()).not.toEqual(uniqueTime());\n    });\n  });\n\n  describe('uniqueId', () => {\n    it('should get different ids each time', () => {\n      expect(uniqueId()).not.toEqual(uniqueId());\n    });\n\n    it('should return id with given length', () => {\n      expect(uniqueId(12).length).toEqual(12);\n      expect(uniqueId(4).length).toEqual(4);\n    });\n  });\n\n  describe('md5', () => {\n    it('should return correct md5 value', () => {\n      expect(md5(Buffer.from('test'))).toEqual('CY9rzUYh03PK3k6DJie09g==');\n    });\n  });\n\n  describe('getVersion', () => {\n    it('should return correct version from package json', () => {\n      expect(getVersion()).toEqual(`JS-${v}`);\n    });\n  });\n\n  describe('b64', () => {\n    it('should return correct b65 value', () => {\n      expect(b64('testtext')).toEqual('dGVzdHRleHQ=');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"/\"', () => {\n      expect(b64('*0eijATh#\"I$PR)s<uTa}{t>E\"LC:L', true)).toEqual('KjBlaWpBVGgjIkkkUFIpczx1VGF9e3Q-RSJMQzpM');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"\"', () => {\n      expect(b64('W{wpB@ckYD0O@&?!||9PS)7^+F*H8N', true)).toEqual('V3t3cEJAY2tZRDBPQCY_IXx8OVBTKTdeK0YqSDhO');\n    });\n  });\n\n  describe('sanitizeName', () => {\n    it('should sanitize file name with extension', () => {\n      expect(sanitizeName('a\\\\{%`\"~[]#|^<>1.jpg')).toEqual('a-------------1.jpg');\n    });\n\n    it('should sanitize file name without extension', () => {\n      expect(sanitizeName('123qwe')).toEqual('123qwe');\n    });\n\n    it('should return undefined on empty string', () => {\n      expect(sanitizeName('')).toEqual('undefined');\n    });\n\n    it('should respect sanitize options as boolean', () => {\n      expect(sanitizeName('[]#|.jpg', false)).toEqual('[]#|.jpg');\n    });\n\n    it('should not change dots in filename', () => {\n      expect(sanitizeName('[]#some.tar.gz', false)).toEqual('[]#some.tar.gz');\n    });\n\n    it('should respect sanitize options with provided options', () => {\n      expect(sanitizeName('[]#|.jpg', {\n        exclude: ['[', ']'],\n        replacement: '_',\n      })).toEqual('__#|.jpg');\n    });\n  });\n\n  describe('filterObject', () => {\n    it('should filter object', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, ['test', 'test2'])).toEqual({\n        test: 1,\n        test2: 2,\n      });\n    });\n\n    it('should result the same object on empty requirements', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, [])).toEqual({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      });\n    });\n\n    it('should not throw on empty filtered object', () => {\n      expect(filterObject({}, ['test'])).toEqual({});\n    });\n  });\n\n  describe('CleanupCallbacks', () => {\n    it('should set callbacks as undefined and return untouched object', () => {\n      const testObj = {\n        fn: () => 1,\n        test: {\n          fn2: () => 2,\n        },\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      };\n\n      expect(cleanUpCallbacks(testObj)).toEqual({\n        test: {},\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      });\n    });\n  });\n});\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.spec.ts"],"names":[],"mappings":";;AAAA;;;;;;;;;;;;;;;GAeG;AACH,iCAA6K;AAC7K,uCAAsC;AACtC,IAAM,CAAC,GAAG,OAAO,CAAC,0BAA0B,CAAC,CAAC,OAAO,CAAC;AAEtD,QAAQ,CAAC,aAAa,EAAE;IACtB,QAAQ,CAAC,eAAe,EAAE;QAExB,IAAM,OAAO,GAAG;YACd,MAAM,EAAE,cAAc;YACtB,KAAK,EAAE,aAAa;YACpB,IAAI,EAAE,eAAM,CAAC,IAAI;SAClB,CAAC;QAEF,EAAE,CAAC,oDAAoD,EAAE;YACvD,IAAM,MAAM,GAAG,sBAAsB,CAAC;YACtC,IAAM,MAAM,GAAG,qBAAa,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,kCAAkC,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE;YACpD,IAAM,MAAM,GAAG,wBAAwB,CAAC;YACxC,IAAM,MAAM,GAAG,qBAAa,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,+CAA+C,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oDAAoD,EAAE;YACvD,IAAM,MAAM,GAAG,uHAAuH,CAAC;YACvI,IAAM,MAAM,GAAG,qBAAa,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,+CAA+C,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mEAAmE,EAAE;YACtE,IAAM,MAAM,GAAG,wBAAwB,CAAC;YACxC,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC;YACpB,MAAM,CAAC,cAAQ,qBAAa,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,oDAAoD,CAAC,CAAC;QAClH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,aAAa,EAAE;QACtB,IAAM,KAAK,GAAG,eAAM,CAAC,IAAI,CAAC;QAE1B,IAAM,UAAU,GAAG,UAAC,KAAK,EAAE,QAAQ;YACjC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,UAAC,CAAC;gBAC3B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC;YACvD,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,EAAE,CAAC,2BAA2B,EAAE;YAC9B,IAAM,KAAK,GAAG,aAAa,CAAC;YAC5B,IAAM,MAAM,GAAG,mBAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACzC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE;YACtD,IAAM,KAAK,GAAG,EAAE,CAAC;YACjB,IAAM,MAAM,GAAG,mBAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACzC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,aAAa,EAAE;QACtB,EAAE,CAAC,4CAA4C,EAAE;YAC/C,IAAM,MAAM,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;YAC/D,MAAM,CAAC,mBAAW,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,YAAY,EAAE;QACrB,EAAE,CAAC,4BAA4B,EAAE;YAC/B,MAAM,CAAC,kBAAU,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,kBAAU,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,UAAU,EAAE;QACnB,EAAE,CAAC,oCAAoC,EAAE;YACvC,MAAM,CAAC,gBAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,gBAAQ,EAAE,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oCAAoC,EAAE;YACvC,MAAM,CAAC,gBAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACxC,MAAM,CAAC,gBAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,KAAK,EAAE;QACd,EAAE,CAAC,iCAAiC,EAAE;YACpC,MAAM,CAAC,WAAG,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,YAAY,EAAE;QACrB,EAAE,CAAC,iDAAiD,EAAE;YACpD,MAAM,CAAC,kBAAU,EAAE,CAAC,CAAC,OAAO,CAAC,QAAM,CAAG,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,KAAK,EAAE;QACd,EAAE,CAAC,iCAAiC,EAAE;YACpC,MAAM,CAAC,WAAG,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4DAA4D,EAAE;YAC/D,MAAM,CAAC,WAAG,CAAC,gCAAgC,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,0CAA0C,CAAC,CAAC;QAC1G,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2DAA2D,EAAE;YAC9D,MAAM,CAAC,WAAG,CAAC,gCAAgC,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,0CAA0C,CAAC,CAAC;QAC1G,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE;QACvB,EAAE,CAAC,0CAA0C,EAAE;YAC7C,MAAM,CAAC,oBAAY,CAAC,sBAAsB,CAAC,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;QAC9E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6CAA6C,EAAE;YAChD,MAAM,CAAC,oBAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE;YAC5C,MAAM,CAAC,oBAAY,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE;YAC/C,MAAM,CAAC,oBAAY,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oCAAoC,EAAE;YACvC,MAAM,CAAC,oBAAY,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uDAAuD,EAAE;YAC1D,MAAM,CAAC,oBAAY,CAAC,UAAU,EAAE;gBAC9B,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;gBACnB,WAAW,EAAE,GAAG;aACjB,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE;QACvB,EAAE,CAAC,sBAAsB,EAAE;YACzB,MAAM,CAAC,oBAAY,CAAC;gBAClB,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;gBACR,KAAK,EAAE,CAAC;aACT,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;gBAC7B,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;aACT,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qDAAqD,EAAE;YACxD,MAAM,CAAC,oBAAY,CAAC;gBAClB,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;gBACR,KAAK,EAAE,CAAC;aACT,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;gBACd,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;gBACR,KAAK,EAAE,CAAC;aACT,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE;YAC9C,MAAM,CAAC,oBAAY,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iBAAiB,EAAE;QAC1B,EAAE,CAAC,0CAA0C,EAAE;YAC7C,MAAM,CAAC,uBAAe,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE;YACtC,MAAM,CAAC,uBAAe,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC1D,MAAM,CAAC,uBAAe,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC1D,MAAM,CAAC,uBAAe,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE;YAC3C,MAAM,CAAC,uBAAe,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACrD,MAAM,CAAC,uBAAe,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACtD,MAAM,CAAC,uBAAe,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;YAE3D,MAAM,CAAC,uBAAe,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC;YACzE,MAAM,CAAC,uBAAe,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;YAC3D,MAAM,CAAC,uBAAe,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC;QAC/E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4DAA4D,EAAE;YAC/D,MAAM,CAAC,uBAAe,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACzD,MAAM,CAAC,uBAAe,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YAC1D,MAAM,CAAC,uBAAe,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kBAAkB,EAAE;QAC3B,EAAE,CAAC,+DAA+D,EAAE;YAClE,IAAM,OAAO,GAAG;gBACd,EAAE,EAAE,cAAM,OAAA,CAAC,EAAD,CAAC;gBACX,IAAI,EAAE;oBACJ,GAAG,EAAE,cAAM,OAAA,CAAC,EAAD,CAAC;iBACb;gBACD,KAAK,EAAE,GAAG;gBACV,KAAK,EAAE,QAAQ;gBACf,OAAO,EAAE;oBACP,GAAG,EAAE,GAAG;iBACT;aACF,CAAC;YAEF,MAAM,CAAC,wBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;gBACxC,IAAI,EAAE,EAAE;gBACR,KAAK,EAAE,GAAG;gBACV,KAAK,EAAE,QAAQ;gBACf,OAAO,EAAE;oBACP,GAAG,EAAE,GAAG;iBACT;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","file":"lib/utils/index.spec.js","sourcesContent":["/*\n * Copyright (c) 2019 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, extensionToMime, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';\nimport { config } from '../../config';\nconst v = require('../../../../package.json').version;\n\ndescribe('utils:index', () => {\n  describe('resolveCdnUrl', () => {\n\n    const session = {\n      apikey: 'TEST_API_KEY',\n      cname: 'example.com',\n      urls: config.urls,\n    };\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = '5aYkEQJSQCmYShsoCnZN';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com');\n    });\n\n    it('should properly resolve cdn url with src handle', () => {\n      const handle = 'src://test123/test.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = 'https://static1.squarespace.com/static/544eb3cce4b0ef091773611f/t/59ba7ce1bd10f00dcdc80a5f/1505394087367/DSC_0527.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should throw an error when using src handle or url without apikey', () => {\n      const handle = 'src://test123/test.jpg';\n      session.apikey = '';\n      expect(() => { resolveCdnUrl(session, handle); }).toThrow('Api key is required when storage alias is provided');\n    });\n  });\n\n  describe('resolveHost', () => {\n    const hosts = config.urls;\n\n    const checkHosts = (hosts, expected) => {\n      Object.keys(hosts).forEach((k) => {\n        expect(hosts[k].indexOf(expected) > -1).toBeTruthy();\n      });\n    };\n\n    it('should return proper host', () => {\n      const cname = 'example.com';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n\n    it('should return hosts when cname is an empty string', () => {\n      const cname = '';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n  });\n\n  describe('removeEmpty', () => {\n    it('should remove empty options from an object', () => {\n      const testOb = { test1: true, test2: undefined, test3: false };\n      expect(removeEmpty(testOb)).toEqual({ test1: true, test3: false });\n    });\n  });\n\n  describe('uniqueTime', () => {\n    it('should return unique times', () => {\n      expect(uniqueTime()).not.toEqual(uniqueTime());\n    });\n  });\n\n  describe('uniqueId', () => {\n    it('should get different ids each time', () => {\n      expect(uniqueId()).not.toEqual(uniqueId());\n    });\n\n    it('should return id with given length', () => {\n      expect(uniqueId(12).length).toEqual(12);\n      expect(uniqueId(4).length).toEqual(4);\n    });\n  });\n\n  describe('md5', () => {\n    it('should return correct md5 value', () => {\n      expect(md5(Buffer.from('test'))).toEqual('CY9rzUYh03PK3k6DJie09g==');\n    });\n  });\n\n  describe('getVersion', () => {\n    it('should return correct version from package json', () => {\n      expect(getVersion()).toEqual(`JS-${v}`);\n    });\n  });\n\n  describe('b64', () => {\n    it('should return correct b65 value', () => {\n      expect(b64('testtext')).toEqual('dGVzdHRleHQ=');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"/\"', () => {\n      expect(b64('*0eijATh#\"I$PR)s<uTa}{t>E\"LC:L', true)).toEqual('KjBlaWpBVGgjIkkkUFIpczx1VGF9e3Q-RSJMQzpM');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"\"', () => {\n      expect(b64('W{wpB@ckYD0O@&?!||9PS)7^+F*H8N', true)).toEqual('V3t3cEJAY2tZRDBPQCY_IXx8OVBTKTdeK0YqSDhO');\n    });\n  });\n\n  describe('sanitizeName', () => {\n    it('should sanitize file name with extension', () => {\n      expect(sanitizeName('a\\\\{%`\"~[]#|^<>1.jpg')).toEqual('a-------------1.jpg');\n    });\n\n    it('should sanitize file name without extension', () => {\n      expect(sanitizeName('123qwe')).toEqual('123qwe');\n    });\n\n    it('should return undefined on empty string', () => {\n      expect(sanitizeName('')).toEqual('undefined');\n    });\n\n    it('should respect sanitize options as boolean', () => {\n      expect(sanitizeName('[]#|.jpg', false)).toEqual('[]#|.jpg');\n    });\n\n    it('should not change dots in filename', () => {\n      expect(sanitizeName('[]#some.tar.gz', false)).toEqual('[]#some.tar.gz');\n    });\n\n    it('should respect sanitize options with provided options', () => {\n      expect(sanitizeName('[]#|.jpg', {\n        exclude: ['[', ']'],\n        replacement: '_',\n      })).toEqual('__#|.jpg');\n    });\n  });\n\n  describe('filterObject', () => {\n    it('should filter object', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, ['test', 'test2'])).toEqual({\n        test: 1,\n        test2: 2,\n      });\n    });\n\n    it('should result the same object on empty requirements', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, [])).toEqual({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      });\n    });\n\n    it('should not throw on empty filtered object', () => {\n      expect(filterObject({}, ['test'])).toEqual({});\n    });\n  });\n\n  describe('extensionToMime', () => {\n    it('should return mimetype if mime is passed', () => {\n      expect(extensionToMime('')).toEqual(undefined);\n    });\n\n    it('should return same mime is passed', () => {\n      expect(extensionToMime('image/png')).toEqual('image/png');\n      expect(extensionToMime('image/jpg')).toEqual('image/jpg');\n      expect(extensionToMime('application/pdf')).toEqual('application/pdf');\n    });\n\n    it('it should return correct mimes for ext', () => {\n      expect(extensionToMime('.png')).toEqual('image/png');\n      expect(extensionToMime('.jpg')).toEqual('image/jpeg');\n      expect(extensionToMime('.pdf')).toEqual('application/pdf');\n\n      expect(extensionToMime('.key')).toEqual('application/vnd.apple.keynote');\n      expect(extensionToMime('.zip')).toEqual('application/zip');\n      expect(extensionToMime('.numbers')).toEqual('application/vnd.apple.numbers');\n    });\n\n    it('it should extract extensions form filename or ext with dot', () => {\n      expect(extensionToMime('test.png')).toEqual('image/png');\n      expect(extensionToMime('test.jpg')).toEqual('image/jpeg');\n      expect(extensionToMime('test.pdf')).toEqual('application/pdf');\n    });\n  });\n\n  describe('CleanupCallbacks', () => {\n    it('should set callbacks as undefined and return untouched object', () => {\n      const testObj = {\n        fn: () => 1,\n        test: {\n          fn2: () => 2,\n        },\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      };\n\n      expect(cleanUpCallbacks(testObj)).toEqual({\n        test: {},\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      });\n    });\n  });\n});\n"]}

@@ -20,3 +20,3 @@ /*

*/
var PICKER_VERSION = '1.19.0';
var PICKER_VERSION = '1.19.1';
export var config = {

@@ -33,2 +33,2 @@ urls: {

//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBRUg7O0dBRUc7QUFDSCxJQUFNLGNBQWMsR0FBRyxRQUFRLENBQUM7QUFzQmhDLE1BQU0sQ0FBQyxJQUFNLE1BQU0sR0FBRztJQUNwQixJQUFJLEVBQUU7UUFDSixVQUFVLEVBQUUsa0NBQWtDO1FBQzlDLFVBQVUsRUFBRSx1Q0FBdUM7UUFDbkQsWUFBWSxFQUFFLGlDQUFpQztRQUMvQyxXQUFXLEVBQUUsZ0NBQWdDO1FBQzdDLE1BQU0sRUFBRSxrQ0FBa0M7UUFDMUMsU0FBUyxFQUFFLDRDQUEwQyxjQUFjLGVBQVk7S0FDaEY7Q0FDRixDQUFDIiwiZmlsZSI6ImNvbmZpZy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTggYnkgRmlsZXN0YWNrLlxuICogU29tZSByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuY29uc3QgUElDS0VSX1ZFUlNJT04gPSAnMS4xOS4wJztcblxuLyoqXG4gKiBAcHJpdmF0ZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEhvc3RzIHtcbiAgW3VybDogc3RyaW5nXTogc3RyaW5nO1xuICBmaWxlQXBpVXJsOiBzdHJpbmc7XG4gIHVwbG9hZEFwaVVybDogc3RyaW5nO1xuICBjbG91ZEFwaVVybDogc3RyaW5nO1xuICBjZG5Vcmw6IHN0cmluZztcbiAgcGlja2VyVXJsOiBzdHJpbmc7XG4gIHByb2Nlc3NVcmw6IHN0cmluZztcbn1cblxuLyoqXG4gKiBAcHJpdmF0ZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbmZpZyB7XG4gIHVybHM6IEhvc3RzO1xufVxuXG5leHBvcnQgY29uc3QgY29uZmlnID0ge1xuICB1cmxzOiB7XG4gICAgcHJvY2Vzc1VybDogJ2h0dHBzOi8vcHJvY2Vzcy5maWxlc3RhY2thcGkuY29tJyxcbiAgICBmaWxlQXBpVXJsOiAnaHR0cHM6Ly93d3cuZmlsZXN0YWNrYXBpLmNvbS9hcGkvZmlsZScsXG4gICAgdXBsb2FkQXBpVXJsOiAnaHR0cHM6Ly91cGxvYWQuZmlsZXN0YWNrYXBpLmNvbScsXG4gICAgY2xvdWRBcGlVcmw6ICdodHRwczovL2Nsb3VkLmZpbGVzdGFja2FwaS5jb20nLFxuICAgIGNkblVybDogJ2h0dHBzOi8vY2RuLmZpbGVzdGFja2NvbnRlbnQuY29tJyxcbiAgICBwaWNrZXJVcmw6IGBodHRwczovL3N0YXRpYy5maWxlc3RhY2thcGkuY29tL3BpY2tlci8ke1BJQ0tFUl9WRVJTSU9OfS9waWNrZXIuanNgLFxuICB9LFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBRUg7O0dBRUc7QUFDSCxJQUFNLGNBQWMsR0FBRyxRQUFRLENBQUM7QUFzQmhDLE1BQU0sQ0FBQyxJQUFNLE1BQU0sR0FBRztJQUNwQixJQUFJLEVBQUU7UUFDSixVQUFVLEVBQUUsa0NBQWtDO1FBQzlDLFVBQVUsRUFBRSx1Q0FBdUM7UUFDbkQsWUFBWSxFQUFFLGlDQUFpQztRQUMvQyxXQUFXLEVBQUUsZ0NBQWdDO1FBQzdDLE1BQU0sRUFBRSxrQ0FBa0M7UUFDMUMsU0FBUyxFQUFFLDRDQUEwQyxjQUFjLGVBQVk7S0FDaEY7Q0FDRixDQUFDIiwiZmlsZSI6ImNvbmZpZy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTggYnkgRmlsZXN0YWNrLlxuICogU29tZSByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8qKlxuICogQHByaXZhdGVcbiAqL1xuY29uc3QgUElDS0VSX1ZFUlNJT04gPSAnMS4xOS4xJztcblxuLyoqXG4gKiBAcHJpdmF0ZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEhvc3RzIHtcbiAgW3VybDogc3RyaW5nXTogc3RyaW5nO1xuICBmaWxlQXBpVXJsOiBzdHJpbmc7XG4gIHVwbG9hZEFwaVVybDogc3RyaW5nO1xuICBjbG91ZEFwaVVybDogc3RyaW5nO1xuICBjZG5Vcmw6IHN0cmluZztcbiAgcGlja2VyVXJsOiBzdHJpbmc7XG4gIHByb2Nlc3NVcmw6IHN0cmluZztcbn1cblxuLyoqXG4gKiBAcHJpdmF0ZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbmZpZyB7XG4gIHVybHM6IEhvc3RzO1xufVxuXG5leHBvcnQgY29uc3QgY29uZmlnID0ge1xuICB1cmxzOiB7XG4gICAgcHJvY2Vzc1VybDogJ2h0dHBzOi8vcHJvY2Vzcy5maWxlc3RhY2thcGkuY29tJyxcbiAgICBmaWxlQXBpVXJsOiAnaHR0cHM6Ly93d3cuZmlsZXN0YWNrYXBpLmNvbS9hcGkvZmlsZScsXG4gICAgdXBsb2FkQXBpVXJsOiAnaHR0cHM6Ly91cGxvYWQuZmlsZXN0YWNrYXBpLmNvbScsXG4gICAgY2xvdWRBcGlVcmw6ICdodHRwczovL2Nsb3VkLmZpbGVzdGFja2FwaS5jb20nLFxuICAgIGNkblVybDogJ2h0dHBzOi8vY2RuLmZpbGVzdGFja2NvbnRlbnQuY29tJyxcbiAgICBwaWNrZXJVcmw6IGBodHRwczovL3N0YXRpYy5maWxlc3RhY2thcGkuY29tL3BpY2tlci8ke1BJQ0tFUl9WRVJTSU9OfS9waWNrZXIuanNgLFxuICB9LFxufTtcbiJdfQ==

@@ -26,3 +26,3 @@ import { SecurityOptions, getSecurity, validateWebhookSignature, WebhookValidatePayload } from './lib/api/security';

*/
export declare const version = "3.19.0";
export declare const version = "3.20.0";
export * from './lib/api/transform';

@@ -29,0 +29,0 @@ export * from './lib/filelink';

@@ -39,4 +39,4 @@ /*

*/
export var version = '3.19.0';
registerModule(FILESTACK_MODULES.FILESTACK_SDK, Filestack, { version: '3.19.0' });
export var version = '3.20.0';
registerModule(FILESTACK_MODULES.FILESTACK_SDK, Filestack, { version: '3.20.0' });
export * from './lib/api/transform';

@@ -43,0 +43,0 @@ export * from './lib/filelink';

@@ -5,2 +5,3 @@ import { EventEmitter } from 'eventemitter3';

import { TransformOptions } from './api/transform';
import * as Utils from './utils';
import { InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';

@@ -71,2 +72,9 @@ import { PreviewOptions } from './api/preview';

private forwardErrors;
/**
* Returns filestack utils
*
* @readonly
* @memberof Client
*/
get utils(): typeof Utils;
constructor(apikey: string, options?: ClientOptions);

@@ -73,0 +81,0 @@ /**

@@ -25,3 +25,3 @@ /*

import { storeURL } from './api/store';
import { resolveHost, getVersion } from './utils';
import * as Utils from './utils';
import { Upload } from './api/upload';

@@ -62,3 +62,3 @@ import { preview } from './api/preview';

scope.setTag('apikey', apikey);
scope.setTag('sdk-version', getVersion());
scope.setTag('sdk-version', Utils.getVersion());
scope.setExtra('clientOptions', options);

@@ -80,2 +80,15 @@ });

}
Object.defineProperty(Client.prototype, "utils", {
/**
* Returns filestack utils
*
* @readonly
* @memberof Client
*/
get: function () {
return Utils;
},
enumerable: true,
configurable: true
});
/**

@@ -116,3 +129,3 @@ * Make basic prefetch request to check permissions

this.session.cname = cname;
this.session.urls = resolveHost(this.session.urls, cname);
this.session.urls = Utils.resolveHost(this.session.urls, cname);
};

@@ -370,4 +383,4 @@ /**

Sentry.withScope(function (scope) {
scope.setExtras(e.details);
scope.setExtras({ uploadOptions: options, storeOptions: storeOptions });
scope.setExtras({ uploadOptions: options, storeOptions: storeOptions, details: e.details });
e.message = "FS-" + e.message;
Sentry.captureException(e);

@@ -437,2 +450,2 @@ });

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/client.ts"],"names":[],"mappings":"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","file":"lib/client.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventEmitter } from 'eventemitter3';\nimport * as Sentry from '@sentry/minimal';\nimport { config, Hosts } from '../config';\nimport { FilestackError } from './../filestack_error';\nimport { metadata, MetadataOptions, remove, retrieve, RetrieveOptions } from './api/file';\nimport { transform, TransformOptions } from './api/transform';\nimport { storeURL } from './api/store';\nimport { resolveHost, getVersion } from './utils';\nimport { Upload, InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';\nimport { preview, PreviewOptions } from './api/preview';\nimport { CloudClient } from './api/cloud';\nimport { Prefetch, PrefetchResponse, PrefetchOptions } from './api/prefetch';\nimport { StoreParams } from './filelink';\n\nimport { picker, PickerInstance, PickerOptions } from './picker';\n\n/* istanbul ignore next */\nSentry.addBreadcrumb({ category: 'sdk', message: 'filestack-js-sdk scope' });\n\nexport interface Session {\n  apikey: string;\n  urls: Hosts;\n  cname?: string;\n  policy?: string;\n  signature?: string;\n  prefetch?: PrefetchResponse;\n}\n\nexport interface Security {\n  policy: string;\n  signature: string;\n}\n\nexport interface ClientOptions {\n  [option: string]: any;\n  /**\n   * Security object with policy and signature keys.\n   * Can be used to limit client capabilities and protect public URLs.\n   * It is intended to be used with server-side policy and signature generation.\n   * Read about [security policies](https://www.filestack.com/docs/concepts/security).\n   */\n  security?: Security;\n  /**\n   * Domain to use for all URLs. __Requires the custom CNAME addon__.\n   * If this is enabled then you must also set up your own OAuth applications\n   * for each cloud source you wish to use in the picker.\n   */\n  cname?: string;\n  /**\n   * Enable/disable caching of the cloud session token. Default is false.\n   * This ensures that users will be remembered on your domain when calling the cloud API from the browser.\n   * Please be aware that tokens stored in localStorage are accessible by other scripts on the same domain.\n   */\n  sessionCache?: boolean;\n\n  /**\n   * Enable forwarding error logs to sentry\n   * @default false\n   */\n  forwardErrors?: boolean;\n}\n\n/**\n * The Filestack client, the entry point for all public methods. Encapsulates session information.\n *\n * ### Example\n * ```js\n * // ES module\n * import * as filestack from 'filestack-js';\n * const client = filestack.init('apikey');\n * ```\n *\n * ```js\n * // UMD module in browser\n * <script src=\"https://static.filestackapi.com/filestack-js/3.x.x/filestack.min.js\"></script>\n * const client = filestack.init('apikey');\n * ```\n */\nexport class Client extends EventEmitter {\n  public session: Session;\n  private cloud: CloudClient;\n  private prefetchInstance: Prefetch;\n\n  private forwardErrors: boolean = true;\n\n  constructor(apikey: string, options?: ClientOptions) {\n    super();\n\n    /* istanbul ignore if */\n    if (options && options.forwardErrors) {\n      this.forwardErrors = options.forwardErrors;\n    }\n\n    /* istanbul ignore next */\n    Sentry.configureScope(scope => {\n      scope.setTag('apikey', apikey);\n      scope.setTag('sdk-version', getVersion());\n      scope.setExtra('clientOptions', options);\n    });\n\n    if (!apikey || typeof apikey !== 'string' || apikey.length === 0) {\n      throw new Error('An apikey is required to initialize the Filestack client');\n    }\n    const { urls } = config;\n    this.session = { apikey, urls };\n\n    if (options) {\n      const { cname, security } = options;\n\n      this.setSecurity(security);\n      this.setCname(cname);\n    }\n\n    this.prefetchInstance = new Prefetch(this.session);\n    this.cloud = new CloudClient(this.session, options);\n  }\n\n  /**\n   * Make basic prefetch request to check permissions\n   *\n   * @param params\n   */\n  prefetch(params: PrefetchOptions) {\n    return this.prefetchInstance.getConfig(params);\n  }\n\n  /**\n   * Set security object\n   *\n   * @param {Security} security\n   * @memberof Client\n   */\n  setSecurity(security: Security) {\n    if (security && !(security.policy && security.signature)) {\n      throw new FilestackError('Both policy and signature are required for client security');\n    }\n\n    if (security && security.policy && security.signature) {\n      this.session.policy = security.policy;\n      this.session.signature = security.signature;\n    }\n  }\n\n  /**\n   * Set custom cname\n   *\n   * @param {string} cname\n   * @returns\n   * @memberof Client\n   */\n  setCname(cname: string) {\n    if (!cname || cname.length === 0) {\n      return;\n    }\n\n    this.session.cname = cname;\n    this.session.urls = resolveHost(this.session.urls, cname);\n  }\n\n  /**\n   * Clear all current cloud sessions in the picker.\n   * Optionally pass a cloud source name to only log out of that cloud source.\n   * This essentially clears the OAuth authorization codes from the Filestack session.\n   * @param name Optional cloud source name.\n   */\n  logout(name?: string) {\n    return this.cloud.logout(name);\n  }\n  /**\n   * Retrieve detailed data of stored files.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .metadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Metadata](https://www.filestack.com/docs/api/file#metadata).\n   * @param handle Valid Filestack handle.\n   * @param options Metadata fields to enable on response.\n   * @param security Optional security override.\n   */\n  metadata(handle: string, options?: MetadataOptions, security?: Security) {\n    /* istanbul ignore next */\n    return metadata(this.session, handle, options, security);\n  }\n  /**\n   * Construct a new picker instance.\n   */\n  picker(options?: PickerOptions): PickerInstance {\n    /* istanbul ignore next */\n    return picker(this, options);\n  }\n  /**\n   * Used for viewing files via Filestack handles or storage aliases, __requires Document Viewer addon to your Filestack application__.\n   * Opens document viewer in new window if id option is not provided.\n   *\n   * ### Example\n   *\n   * ```js\n   * // <div id=\"preview\"></div>\n   *\n   * client.preview('DCL5K46FS3OIxb5iuKby', { id: 'preview' });\n   * ```\n   * @param handle Valid Filestack handle.\n   * @param options Preview options\n   */\n  preview(handle: string, options?: PreviewOptions) {\n    /* istanbul ignore next */\n    return preview(this.session, handle, options);\n  }\n  /**\n   * Remove a file from storage and the Filestack system.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .remove('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  remove(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, false, security);\n  }\n  /**\n   * Remove a file **only** from the Filestack system. The file remains in storage.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .removeMetadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  removeMetadata(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, true, security);\n  }\n  /**\n   * Store a file from its URL.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .storeURL('https://d1wtqaffaaj63z.cloudfront.net/images/NY_199_E_of_Hammertown_2014.jpg')\n   *   .then(res => console.log(res));\n   * ```\n   * @see [File API - Store](https://www.filestack.com/docs/api/file#store)\n   * @param url       Valid URL to a file.\n   * @param options   Configure file storage.\n   * @param token     Optional control token to call .cancel()\n   * @param security  Optional security override.\n   * @param uploadTags Optional tags visible in webhooks.\n   * @param headers    Optional headers to send\n   */\n  storeURL(url: string, storeParams?: StoreParams, token?: any, security?: Security, uploadTags?: UploadTags, headers?: {[key: string]: string}): Promise<Object> {\n    return storeURL({\n      session: this.session,\n      url,\n      storeParams,\n      token,\n      security,\n      uploadTags,\n      headers,\n    });\n  }\n\n  /**\n   * Access files via their Filestack handles.\n   *\n   * If head option is provided - request headers are returned in promise\n   * If metadata option is provided - metadata object is returned in promise\n   * Otherwise file blob is returned\n   * Metadata and head options cannot be mixed\n   *\n   * ### Example\n   *\n   * ```js\n   * client.retrieve('fileHandle', {\n   *  metadata: true,\n   * }).then((response) => {\n   *  console.log(response);\n   * }).catch((err) => {\n   *  console.error(err);\n   * })\n   * ```\n   *\n   * @see [File API - Download](https://www.filestack.com/docs/api/file#download)\n   * @param handle    Valid file handle\n   * @param options   RetrieveOptions\n   * @param security  Optional security override.\n   * @throws          Error\n   */\n  retrieve(handle: string, options?: RetrieveOptions, security?: Security): Promise<Object | Blob> {\n    /* istanbul ignore next */\n    return retrieve(this.session, handle, options, security);\n  }\n\n  /**\n   * Interface to the Filestack [Processing API](https://www.filestack.com/docs/api/processing).\n   * Convert a URL, handle, or storage alias to another URL which links to the transformed file.\n   * You can optionally store the returned URL with client.storeURL.\n   *\n   * Transform params can be provided in camelCase or snakeCase style ie: partial_pixelate or partialPixelate\n   *\n   * ### Example\n   *\n   * ```js\n   * const transformedUrl = client.transform(url, {\n   *   crop: {\n   *     dim: [x, y, width, height],\n   *   },\n   *   vignette: {\n   *     blurmode: 'gaussian',\n   *     amount: 50,\n   *   },\n   *   flip: true,\n   *   partial_pixelate: {\n   *     objects: [[10, 20, 200, 250], [275, 91, 500, 557]],\n   *   },\n   * };\n   *\n   * // optionally store the new URL\n   * client.storeURL(transformedUrl).then(res => console.log(res));\n   * ```\n   * @see [Filestack Processing API](https://www.filestack.com/docs/api/processing)\n   * @param url     Single or multiple valid URLs (http(s)://), file handles, or storage aliases (src://) to an image.\n   * @param options Transformations are applied in the order specified by this object.\n   * @param b64     Use new more safe format for generating transforms url (default=false) Note: If there will be any issues with url please test it with enabled b64 support\n   * @returns       A new URL that points to the transformed resource.\n   */\n  transform(url: string | string[], options: TransformOptions, b64: boolean = false) {\n    /* istanbul ignore next */\n    return transform(this.session, url, options, b64);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.upload(file, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.upload({file, name}, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile}    file           Must be a valid [File | Blob | Buffer | string]\n   * @param uploadOptions  Uploader options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  upload(file: InputFile, options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      if (this.forwardErrors) {\n        Sentry.withScope(scope => {\n          scope.setExtras(e.details);\n          scope.setExtras({ uploadOptions: options, storeOptions });\n          Sentry.captureException(e);\n        });\n      }\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.upload(file);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.multiupload([file], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.multiupload([{file, name}], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile[]}  file           Must be a valid [File | Blob | Buffer | string (base64)]\n   * @param uploadOptions  Upload options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  multiupload(file: InputFile[], options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      Sentry.withScope(scope => {\n        scope.setExtras(e.details);\n        scope.setExtras({ uploadOptions: options, storeOptions });\n        Sentry.captureException(e);\n      });\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.multiupload(file);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/client.ts"],"names":[],"mappings":"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","file":"lib/client.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventEmitter } from 'eventemitter3';\nimport * as Sentry from '@sentry/minimal';\nimport { config, Hosts } from '../config';\nimport { FilestackError } from './../filestack_error';\nimport { metadata, MetadataOptions, remove, retrieve, RetrieveOptions } from './api/file';\nimport { transform, TransformOptions } from './api/transform';\nimport { storeURL } from './api/store';\nimport * as Utils from './utils';\nimport { Upload, InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';\nimport { preview, PreviewOptions } from './api/preview';\nimport { CloudClient } from './api/cloud';\nimport { Prefetch, PrefetchResponse, PrefetchOptions } from './api/prefetch';\nimport { StoreParams } from './filelink';\n\nimport { picker, PickerInstance, PickerOptions } from './picker';\n\n/* istanbul ignore next */\nSentry.addBreadcrumb({ category: 'sdk', message: 'filestack-js-sdk scope' });\n\nexport interface Session {\n  apikey: string;\n  urls: Hosts;\n  cname?: string;\n  policy?: string;\n  signature?: string;\n  prefetch?: PrefetchResponse;\n}\n\nexport interface Security {\n  policy: string;\n  signature: string;\n}\n\nexport interface ClientOptions {\n  [option: string]: any;\n  /**\n   * Security object with policy and signature keys.\n   * Can be used to limit client capabilities and protect public URLs.\n   * It is intended to be used with server-side policy and signature generation.\n   * Read about [security policies](https://www.filestack.com/docs/concepts/security).\n   */\n  security?: Security;\n  /**\n   * Domain to use for all URLs. __Requires the custom CNAME addon__.\n   * If this is enabled then you must also set up your own OAuth applications\n   * for each cloud source you wish to use in the picker.\n   */\n  cname?: string;\n  /**\n   * Enable/disable caching of the cloud session token. Default is false.\n   * This ensures that users will be remembered on your domain when calling the cloud API from the browser.\n   * Please be aware that tokens stored in localStorage are accessible by other scripts on the same domain.\n   */\n  sessionCache?: boolean;\n\n  /**\n   * Enable forwarding error logs to sentry\n   * @default false\n   */\n  forwardErrors?: boolean;\n}\n\n/**\n * The Filestack client, the entry point for all public methods. Encapsulates session information.\n *\n * ### Example\n * ```js\n * // ES module\n * import * as filestack from 'filestack-js';\n * const client = filestack.init('apikey');\n * ```\n *\n * ```js\n * // UMD module in browser\n * <script src=\"https://static.filestackapi.com/filestack-js/3.x.x/filestack.min.js\"></script>\n * const client = filestack.init('apikey');\n * ```\n */\nexport class Client extends EventEmitter {\n  public session: Session;\n  private cloud: CloudClient;\n  private prefetchInstance: Prefetch;\n\n  private forwardErrors: boolean = true;\n\n  /**\n   * Returns filestack utils\n   *\n   * @readonly\n   * @memberof Client\n   */\n  get utils() {\n    return Utils;\n  }\n\n  constructor(apikey: string, options?: ClientOptions) {\n    super();\n\n    /* istanbul ignore if */\n    if (options && options.forwardErrors) {\n      this.forwardErrors = options.forwardErrors;\n    }\n\n    /* istanbul ignore next */\n    Sentry.configureScope(scope => {\n      scope.setTag('apikey', apikey);\n      scope.setTag('sdk-version', Utils.getVersion());\n      scope.setExtra('clientOptions', options);\n    });\n\n    if (!apikey || typeof apikey !== 'string' || apikey.length === 0) {\n      throw new Error('An apikey is required to initialize the Filestack client');\n    }\n    const { urls } = config;\n    this.session = { apikey, urls };\n\n    if (options) {\n      const { cname, security } = options;\n\n      this.setSecurity(security);\n      this.setCname(cname);\n    }\n\n    this.prefetchInstance = new Prefetch(this.session);\n    this.cloud = new CloudClient(this.session, options);\n  }\n\n  /**\n   * Make basic prefetch request to check permissions\n   *\n   * @param params\n   */\n  prefetch(params: PrefetchOptions) {\n    return this.prefetchInstance.getConfig(params);\n  }\n\n  /**\n   * Set security object\n   *\n   * @param {Security} security\n   * @memberof Client\n   */\n  setSecurity(security: Security) {\n    if (security && !(security.policy && security.signature)) {\n      throw new FilestackError('Both policy and signature are required for client security');\n    }\n\n    if (security && security.policy && security.signature) {\n      this.session.policy = security.policy;\n      this.session.signature = security.signature;\n    }\n  }\n\n  /**\n   * Set custom cname\n   *\n   * @param {string} cname\n   * @returns\n   * @memberof Client\n   */\n  setCname(cname: string) {\n    if (!cname || cname.length === 0) {\n      return;\n    }\n\n    this.session.cname = cname;\n    this.session.urls = Utils.resolveHost(this.session.urls, cname);\n  }\n\n  /**\n   * Clear all current cloud sessions in the picker.\n   * Optionally pass a cloud source name to only log out of that cloud source.\n   * This essentially clears the OAuth authorization codes from the Filestack session.\n   * @param name Optional cloud source name.\n   */\n  logout(name?: string) {\n    return this.cloud.logout(name);\n  }\n  /**\n   * Retrieve detailed data of stored files.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .metadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Metadata](https://www.filestack.com/docs/api/file#metadata).\n   * @param handle Valid Filestack handle.\n   * @param options Metadata fields to enable on response.\n   * @param security Optional security override.\n   */\n  metadata(handle: string, options?: MetadataOptions, security?: Security) {\n    /* istanbul ignore next */\n    return metadata(this.session, handle, options, security);\n  }\n  /**\n   * Construct a new picker instance.\n   */\n  picker(options?: PickerOptions): PickerInstance {\n    /* istanbul ignore next */\n    return picker(this, options);\n  }\n  /**\n   * Used for viewing files via Filestack handles or storage aliases, __requires Document Viewer addon to your Filestack application__.\n   * Opens document viewer in new window if id option is not provided.\n   *\n   * ### Example\n   *\n   * ```js\n   * // <div id=\"preview\"></div>\n   *\n   * client.preview('DCL5K46FS3OIxb5iuKby', { id: 'preview' });\n   * ```\n   * @param handle Valid Filestack handle.\n   * @param options Preview options\n   */\n  preview(handle: string, options?: PreviewOptions) {\n    /* istanbul ignore next */\n    return preview(this.session, handle, options);\n  }\n  /**\n   * Remove a file from storage and the Filestack system.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .remove('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  remove(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, false, security);\n  }\n  /**\n   * Remove a file **only** from the Filestack system. The file remains in storage.\n   *\n   * __Requires a valid security policy and signature__. The policy and signature will be pulled from the client session, or it can be overridden with the security parameter.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .removeMetadata('DCL5K46FS3OIxb5iuKby')\n   *   .then((res) => {\n   *     console.log(res);\n   *   })\n   *   .catch((err) => {\n   *     console.log(err);\n   *   }));\n   * ```\n   * @see [File API - Delete](https://www.filestack.com/docs/api/file#delete)\n   * @param handle Valid Filestack handle.\n   * @param security Optional security override.\n   */\n  removeMetadata(handle: string, security?: Security): Promise<any> {\n    /* istanbul ignore next */\n    return remove(this.session, handle, true, security);\n  }\n  /**\n   * Store a file from its URL.\n   *\n   * ### Example\n   *\n   * ```js\n   * client\n   *   .storeURL('https://d1wtqaffaaj63z.cloudfront.net/images/NY_199_E_of_Hammertown_2014.jpg')\n   *   .then(res => console.log(res));\n   * ```\n   * @see [File API - Store](https://www.filestack.com/docs/api/file#store)\n   * @param url       Valid URL to a file.\n   * @param options   Configure file storage.\n   * @param token     Optional control token to call .cancel()\n   * @param security  Optional security override.\n   * @param uploadTags Optional tags visible in webhooks.\n   * @param headers    Optional headers to send\n   */\n  storeURL(url: string, storeParams?: StoreParams, token?: any, security?: Security, uploadTags?: UploadTags, headers?: {[key: string]: string}): Promise<Object> {\n    return storeURL({\n      session: this.session,\n      url,\n      storeParams,\n      token,\n      security,\n      uploadTags,\n      headers,\n    });\n  }\n\n  /**\n   * Access files via their Filestack handles.\n   *\n   * If head option is provided - request headers are returned in promise\n   * If metadata option is provided - metadata object is returned in promise\n   * Otherwise file blob is returned\n   * Metadata and head options cannot be mixed\n   *\n   * ### Example\n   *\n   * ```js\n   * client.retrieve('fileHandle', {\n   *  metadata: true,\n   * }).then((response) => {\n   *  console.log(response);\n   * }).catch((err) => {\n   *  console.error(err);\n   * })\n   * ```\n   *\n   * @see [File API - Download](https://www.filestack.com/docs/api/file#download)\n   * @param handle    Valid file handle\n   * @param options   RetrieveOptions\n   * @param security  Optional security override.\n   * @throws          Error\n   */\n  retrieve(handle: string, options?: RetrieveOptions, security?: Security): Promise<Object | Blob> {\n    /* istanbul ignore next */\n    return retrieve(this.session, handle, options, security);\n  }\n\n  /**\n   * Interface to the Filestack [Processing API](https://www.filestack.com/docs/api/processing).\n   * Convert a URL, handle, or storage alias to another URL which links to the transformed file.\n   * You can optionally store the returned URL with client.storeURL.\n   *\n   * Transform params can be provided in camelCase or snakeCase style ie: partial_pixelate or partialPixelate\n   *\n   * ### Example\n   *\n   * ```js\n   * const transformedUrl = client.transform(url, {\n   *   crop: {\n   *     dim: [x, y, width, height],\n   *   },\n   *   vignette: {\n   *     blurmode: 'gaussian',\n   *     amount: 50,\n   *   },\n   *   flip: true,\n   *   partial_pixelate: {\n   *     objects: [[10, 20, 200, 250], [275, 91, 500, 557]],\n   *   },\n   * };\n   *\n   * // optionally store the new URL\n   * client.storeURL(transformedUrl).then(res => console.log(res));\n   * ```\n   * @see [Filestack Processing API](https://www.filestack.com/docs/api/processing)\n   * @param url     Single or multiple valid URLs (http(s)://), file handles, or storage aliases (src://) to an image.\n   * @param options Transformations are applied in the order specified by this object.\n   * @param b64     Use new more safe format for generating transforms url (default=false) Note: If there will be any issues with url please test it with enabled b64 support\n   * @returns       A new URL that points to the transformed resource.\n   */\n  transform(url: string | string[], options: TransformOptions, b64: boolean = false) {\n    /* istanbul ignore next */\n    return transform(this.session, url, options, b64);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.upload(file, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.upload({file, name}, { onRetry }, { filename: 'foobar.jpg' }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile}    file           Must be a valid [File | Blob | Buffer | string]\n   * @param uploadOptions  Uploader options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  upload(file: InputFile, options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      if (this.forwardErrors) {\n        Sentry.withScope(scope => {\n          scope.setExtras({ uploadOptions: options, storeOptions, details: e.details });\n          e.message = `FS-${e.message}`;\n\n          Sentry.captureException(e);\n        });\n      }\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.upload(file);\n  }\n\n  /**\n   * Initiates a multi-part upload flow. Use this for Filestack CIN and FII uploads.\n   *\n   * In Node runtimes the file argument is treated as a file path.\n   * Uploading from a Node buffer is not yet implemented.\n   *\n   * ### Example\n   *\n   * ```js\n   * const token = {};\n   * const onRetry = (obj) => {\n   *   console.log(`Retrying ${obj.location} for ${obj.filename}. Attempt ${obj.attempt} of 10.`);\n   * };\n   *\n   * client.multiupload([file], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * client.multiupload([{file, name}], { onRetry }, token)\n   *   .then(res => console.log(res));\n   *\n   * token.pause();  // Pause flow\n   * token.resume(); // Resume flow\n   * token.cancel(); // Cancel flow (rejects)\n   * ```\n   * @param {InputFile[]}  file           Must be a valid [File | Blob | Buffer | string (base64)]\n   * @param uploadOptions  Upload options.\n   * @param storeOptions   Storage options.\n   * @param token          A control token that can be used to call cancel(), pause(), and resume().\n   * @param security       Optional security policy and signature override.\n   *\n   * @returns {Promise}\n   */\n  multiupload(file: InputFile[], options?: UploadOptions, storeOptions?: StoreUploadOptions, token?: any, security?: Security) {\n    let upload = new Upload(options, storeOptions);\n\n    upload.setSession(this.session);\n\n    if (token) {\n      upload.setToken(token);\n    }\n\n    if (security) {\n      upload.setSecurity(security);\n    }\n\n    /* istanbul ignore next */\n    upload.on('error', e => {\n      Sentry.withScope(scope => {\n        scope.setExtras(e.details);\n        scope.setExtras({ uploadOptions: options, storeOptions });\n        Sentry.captureException(e);\n      });\n\n      this.emit('upload.error', e);\n    });\n\n    return upload.multiupload(file);\n  }\n}\n"]}

@@ -272,5 +272,3 @@ /*

if (config.timeout) {
console.log(config.timeout);
req.setTimeout(config.timeout, function () {
console.log('socket timeouted===========');
req.abort();

@@ -327,2 +325,2 @@ if (cancelListener) {

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/request/adapters/http.ts"],"names":[],"mappings":"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","file":"lib/request/adapters/http.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as url from 'url';\nimport * as zlib from 'zlib';\nimport Debug from 'debug';\n\nimport { AdapterInterface } from './interface';\nimport { getVersion } from '../../utils';\nimport * as Stream from 'stream';\nimport { FsRequestOptions, FsResponse } from '../types';\nimport * as utils from '../utils';\nimport { prepareData, parseResponse, combineURL, set as setHeader, normalizeHeaders } from './../helpers';\nimport { FsRequestErrorCode, FsRequestError } from '../error';\nimport { FsHttpMethod } from './../types';\n\nconst HTTPS_REGEXP = /https:?/;\nconst HTTP_CHUNK_SIZE = 16 * 1024;\nconst MAX_REDIRECTS = 10;\nconst CANCEL_CLEAR = `FsCleanMemory`;\nconst debug = Debug('fs:request:http');\n\n/**\n * Writable stream thats overwrap http request for progress event\n *\n * @class HttpWritableStream\n * @extends {Stream.Writable}\n */\nclass HttpWritableStream extends Stream.Writable {\n  private request;\n\n  constructor(req, opts = {}) {\n    super(opts);\n\n    this.request = req;\n    req.once('drain', () => this.emit('drain'));\n  }\n\n  _write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): void {\n    this.request.write(chunk, encoding, cb);\n  }\n\n  end(chunk) {\n    if (chunk) {\n      this.request.write(chunk);\n    }\n\n    this.request.end();\n  }\n}\n\n/**\n * Node http request class\n *\n * @export\n * @class HttpAdapter\n * @implements {AdapterInterface}\n */\nexport class HttpAdapter implements AdapterInterface {\n  private redirectHoops = 0;\n  private redirectPaths = [];\n\n  /**\n   * do request based on configuration\n   *\n   * @param {FsRequestOptions} config\n   * @returns\n   * @memberof HttpAdapter\n   */\n  request(config: FsRequestOptions) {\n    // if this option is unspecified set it by default\n    if (typeof config.filestackHeaders === 'undefined') {\n      config.filestackHeaders = true;\n    }\n\n    config.headers = normalizeHeaders(config.headers);\n\n    let { data, headers } = prepareData(config);\n\n    headers = setHeader(headers, 'user-agent', `filestack-request/${getVersion()}`);\n\n    // for now we are not using streams\n    if (data) {\n      debug('Request data %O', data);\n\n      if (!Buffer.isBuffer(data)) {\n        if (!utils.isString(data)) {\n          return Promise.reject(new FsRequestError('Data must be a string, JSON or a Buffer', config));\n        }\n\n        data = Buffer.from(data, 'utf-8');\n      }\n\n      headers = setHeader(headers, 'content-length', data.length, true);\n    }\n\n    // HTTP basic authentication\n    let auth;\n    if (config.auth) {\n      if (!config.auth.username || config.auth.username.length === 0) {\n        return Promise.reject(new FsRequestError(`Basic auth: username is required ${config.auth}`, config));\n      }\n\n      auth = `${config.auth.username}:${config.auth.password}`;\n    }\n\n    // Parse url\n    let parsed = url.parse(config.url);\n\n    // try to add default https protocol\n    if (!parsed.protocol) {\n      parsed = url.parse(`https://${config.url}`);\n    }\n\n    /* istanbul ignore next: just be sure that the host is parsed correctly, not needed to test */\n    if (!parsed.host) {\n      return Promise.reject(new FsRequestError(`Cannot parse provided url ${config.url}`, config));\n    }\n\n    // normalize auth header\n    if (auth && headers.Authorization) {\n      delete headers.Authorization;\n    }\n\n    const isHttpsRequest = HTTPS_REGEXP.test(parsed.protocol);\n    const agent = isHttpsRequest ? require('https') : require('http');\n\n    const options = {\n      path: combineURL(parsed.path, config.params),\n      host: parsed.host,\n      port: parsed.port,\n      protocol: parsed.protocol,\n      method: config.method.toUpperCase(),\n      headers: headers,\n      agent: new agent.Agent(),\n      auth: auth,\n    };\n\n    debug('Starting %s request with options %O', isHttpsRequest ? 'https' : 'http', options);\n\n    return new Promise<FsResponse>((resolve, reject): any => {\n      let req;\n      let cancelListener;\n\n      if (config.cancelToken) {\n        cancelListener = config.cancelToken.on('cancel', (reason) => {\n          // cleanup handler\n          cancelListener = null;\n\n          // do nothing if promise is resolved by system\n          if (reason && reason.message === CANCEL_CLEAR) {\n            return;\n          }\n\n          /* istanbul ignore next: if request is done cancel token should not throw any error */\n          if (req) {\n            req.abort();\n            req = null;\n          }\n\n          debug('Request canceled by user %s, config: %O', reason, config);\n          return reject(new FsRequestError(`Request aborted. Reason: ${reason}`, config, null, FsRequestErrorCode.ABORTED));\n        });\n      }\n\n      req = agent.request(options, res => {\n        /* istanbul ignore next: just be sure that response will not be called after request is aborted */\n        if (!req || req.aborted) {\n          return reject(new FsRequestError('Request aborted', config));\n        }\n\n        let stream = res;\n        debug('Response statusCode: %d, Response Headers: %O', res.statusCode, res.headers);\n\n        const compressHeaders = res.headers['content-encoding'];\n\n        if (compressHeaders && compressHeaders.length && ['gzip', 'compress', 'deflate'].some((v) => compressHeaders.indexOf(v) > -1)) {\n          // add the unzipper to the body stream processing pipeline\n          stream = res.statusCode === 204 ? stream : stream.pipe(zlib.createUnzip());\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n        }\n\n        let response: FsResponse = {\n          status: res.statusCode,\n          statusText: res.statusMessage,\n          headers: res.headers,\n          config,\n          data: {},\n        };\n\n        // we need to follow redirect so make same request with new location\n        if ([301, 302].indexOf(res.statusCode) > -1) {\n          debug('Redirect received %s', res.statusCode);\n\n          if (this.redirectHoops >= MAX_REDIRECTS) {\n            return reject(new FsRequestError(`Max redirects (${this.redirectHoops}) reached. Exiting`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          const url = res.headers['location'];\n\n          if (!url || url.length === 0) {\n            return reject(new FsRequestError(`Redirect header location not found`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          if (this.redirectPaths.indexOf(url) > -1) {\n            return reject(new FsRequestError(`Redirect loop detected at url ${url}`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          this.redirectPaths.push(url);\n          this.redirectHoops++;\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          debug('Redirecting request to %s (hoop-count: %d)', url, this.redirectHoops);\n\n          return resolve(this.request(Object.assign({}, config, { url })));\n        }\n\n        let responseBuffer = [];\n        stream.on('data', chunk => responseBuffer.push(chunk));\n\n        /* istanbul ignore next: its hard to test socket events with jest and nock - tested manually */\n        stream.on('error', err => {\n          res = undefined;\n          req = undefined;\n          responseBuffer = undefined;\n          debug('Request error: Aborted %O', err);\n\n          if (req.aborted) {\n            return;\n          }\n\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError(err.message, config, null, FsRequestErrorCode.NETWORK));\n        });\n\n        stream.on('end', async () => {\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          // check if there is any response data inside\n          if (res.statusCode !== 204) {\n            // prepare response\n            response.data = Buffer.concat(responseBuffer);\n            response = await parseResponse(response);\n          } else {\n            response.data = null;\n          }\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          responseBuffer = undefined;\n\n          if (500 <= response.status && response.status <= 599) {\n            // server error throw\n            debug('Server error(5xx) - %O', response);\n            return reject(new FsRequestError(`Server error ${url}`, config, response, FsRequestErrorCode.SERVER));\n          } else if (400 <= response.status && response.status <= 499) {\n            debug('Request error(4xx) - %O', response);\n            return reject(new FsRequestError(`Request error ${url}`, config, response, FsRequestErrorCode.REQUEST));\n          }\n\n          debug('Request ends: %O', response);\n          return resolve(response);\n        });\n      });\n\n      if (config.timeout) {\n        console.log(config.timeout);\n        req.setTimeout(config.timeout, () => {\n          console.log('socket timeouted===========');\n          req.abort();\n\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError('Request timeout', config, null, FsRequestErrorCode.TIMEOUT));\n        });\n      }\n\n      req.on('error', err => {\n        if (cancelListener) {\n          config.cancelToken.removeListener(cancelListener);\n        }\n\n        if (!req || req.aborted) {\n          return;\n        }\n\n        debug('Request error: %s - %O', err, err.code);\n        return reject(new FsRequestError(`Request error: ${err.code}`, config, null, FsRequestErrorCode.NETWORK));\n      });\n\n      if (Buffer.isBuffer(data) && ['POST', 'PUT'].indexOf(config.method) > -1) {\n        return this.bufferToChunks(data).pipe(this.getProgressMonitor(config, data.length)).pipe(new HttpWritableStream(req));\n      }\n\n      req.end(data);\n    });\n  }\n\n  /**\n   * Monitor and emit progress event if needed\n   *\n   * @private\n   * @memberof HttpAdapter\n   */\n  private getProgressMonitor = (config, total) => {\n    let loaded = 0;\n\n    const progress = new Stream.Transform();\n    progress._transform = (chunk, encoding, cb) => {\n      if (typeof config.onProgress === 'function' && [FsHttpMethod.POST, FsHttpMethod.PUT].indexOf(config.method) > -1) {\n        loaded += chunk.length;\n        config.onProgress({\n          lengthComputable: true,\n          loaded,\n          total,\n        });\n      }\n      cb(null, chunk);\n    };\n\n    return progress;\n  }\n\n  /**\n   * Convert buffer to stream\n   *\n   * @private\n   * @param {*} buffer\n   * @returns {Stream.Readable}\n   * @memberof HttpAdapter\n   */\n  private bufferToChunks(buffer): Stream.Readable {\n    const chunking = new Stream.Readable();\n    const totalLength = buffer.length;\n    const remainder = totalLength % HTTP_CHUNK_SIZE;\n    const cutoff = totalLength - remainder;\n\n    for (let i = 0; i < cutoff; i += HTTP_CHUNK_SIZE) {\n      const chunk = buffer.slice(i, i + HTTP_CHUNK_SIZE);\n      chunking.push(chunk);\n    }\n\n    if (remainder > 0) {\n      const remainderBuffer = buffer.slice(-remainder);\n      chunking.push(remainderBuffer);\n    }\n\n    chunking.push(null);\n\n    return chunking;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/request/adapters/http.ts"],"names":[],"mappings":"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","file":"lib/request/adapters/http.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as url from 'url';\nimport * as zlib from 'zlib';\nimport Debug from 'debug';\n\nimport { AdapterInterface } from './interface';\nimport { getVersion } from '../../utils';\nimport * as Stream from 'stream';\nimport { FsRequestOptions, FsResponse } from '../types';\nimport * as utils from '../utils';\nimport { prepareData, parseResponse, combineURL, set as setHeader, normalizeHeaders } from './../helpers';\nimport { FsRequestErrorCode, FsRequestError } from '../error';\nimport { FsHttpMethod } from './../types';\n\nconst HTTPS_REGEXP = /https:?/;\nconst HTTP_CHUNK_SIZE = 16 * 1024;\nconst MAX_REDIRECTS = 10;\nconst CANCEL_CLEAR = `FsCleanMemory`;\nconst debug = Debug('fs:request:http');\n\n/**\n * Writable stream thats overwrap http request for progress event\n *\n * @class HttpWritableStream\n * @extends {Stream.Writable}\n */\nclass HttpWritableStream extends Stream.Writable {\n  private request;\n\n  constructor(req, opts = {}) {\n    super(opts);\n\n    this.request = req;\n    req.once('drain', () => this.emit('drain'));\n  }\n\n  _write(chunk: any, encoding?: string, cb?: (error: Error | null | undefined) => void): void {\n    this.request.write(chunk, encoding, cb);\n  }\n\n  end(chunk) {\n    if (chunk) {\n      this.request.write(chunk);\n    }\n\n    this.request.end();\n  }\n}\n\n/**\n * Node http request class\n *\n * @export\n * @class HttpAdapter\n * @implements {AdapterInterface}\n */\nexport class HttpAdapter implements AdapterInterface {\n  private redirectHoops = 0;\n  private redirectPaths = [];\n\n  /**\n   * do request based on configuration\n   *\n   * @param {FsRequestOptions} config\n   * @returns\n   * @memberof HttpAdapter\n   */\n  request(config: FsRequestOptions) {\n    // if this option is unspecified set it by default\n    if (typeof config.filestackHeaders === 'undefined') {\n      config.filestackHeaders = true;\n    }\n\n    config.headers = normalizeHeaders(config.headers);\n\n    let { data, headers } = prepareData(config);\n\n    headers = setHeader(headers, 'user-agent', `filestack-request/${getVersion()}`);\n\n    // for now we are not using streams\n    if (data) {\n      debug('Request data %O', data);\n\n      if (!Buffer.isBuffer(data)) {\n        if (!utils.isString(data)) {\n          return Promise.reject(new FsRequestError('Data must be a string, JSON or a Buffer', config));\n        }\n\n        data = Buffer.from(data, 'utf-8');\n      }\n\n      headers = setHeader(headers, 'content-length', data.length, true);\n    }\n\n    // HTTP basic authentication\n    let auth;\n    if (config.auth) {\n      if (!config.auth.username || config.auth.username.length === 0) {\n        return Promise.reject(new FsRequestError(`Basic auth: username is required ${config.auth}`, config));\n      }\n\n      auth = `${config.auth.username}:${config.auth.password}`;\n    }\n\n    // Parse url\n    let parsed = url.parse(config.url);\n\n    // try to add default https protocol\n    if (!parsed.protocol) {\n      parsed = url.parse(`https://${config.url}`);\n    }\n\n    /* istanbul ignore next: just be sure that the host is parsed correctly, not needed to test */\n    if (!parsed.host) {\n      return Promise.reject(new FsRequestError(`Cannot parse provided url ${config.url}`, config));\n    }\n\n    // normalize auth header\n    if (auth && headers.Authorization) {\n      delete headers.Authorization;\n    }\n\n    const isHttpsRequest = HTTPS_REGEXP.test(parsed.protocol);\n    const agent = isHttpsRequest ? require('https') : require('http');\n\n    const options = {\n      path: combineURL(parsed.path, config.params),\n      host: parsed.host,\n      port: parsed.port,\n      protocol: parsed.protocol,\n      method: config.method.toUpperCase(),\n      headers: headers,\n      agent: new agent.Agent(),\n      auth: auth,\n    };\n\n    debug('Starting %s request with options %O', isHttpsRequest ? 'https' : 'http', options);\n\n    return new Promise<FsResponse>((resolve, reject): any => {\n      let req;\n      let cancelListener;\n\n      if (config.cancelToken) {\n        cancelListener = config.cancelToken.on('cancel', (reason) => {\n          // cleanup handler\n          cancelListener = null;\n\n          // do nothing if promise is resolved by system\n          if (reason && reason.message === CANCEL_CLEAR) {\n            return;\n          }\n\n          /* istanbul ignore next: if request is done cancel token should not throw any error */\n          if (req) {\n            req.abort();\n            req = null;\n          }\n\n          debug('Request canceled by user %s, config: %O', reason, config);\n          return reject(new FsRequestError(`Request aborted. Reason: ${reason}`, config, null, FsRequestErrorCode.ABORTED));\n        });\n      }\n\n      req = agent.request(options, res => {\n        /* istanbul ignore next: just be sure that response will not be called after request is aborted */\n        if (!req || req.aborted) {\n          return reject(new FsRequestError('Request aborted', config));\n        }\n\n        let stream = res;\n        debug('Response statusCode: %d, Response Headers: %O', res.statusCode, res.headers);\n\n        const compressHeaders = res.headers['content-encoding'];\n\n        if (compressHeaders && compressHeaders.length && ['gzip', 'compress', 'deflate'].some((v) => compressHeaders.indexOf(v) > -1)) {\n          // add the unzipper to the body stream processing pipeline\n          stream = res.statusCode === 204 ? stream : stream.pipe(zlib.createUnzip());\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n        }\n\n        let response: FsResponse = {\n          status: res.statusCode,\n          statusText: res.statusMessage,\n          headers: res.headers,\n          config,\n          data: {},\n        };\n\n        // we need to follow redirect so make same request with new location\n        if ([301, 302].indexOf(res.statusCode) > -1) {\n          debug('Redirect received %s', res.statusCode);\n\n          if (this.redirectHoops >= MAX_REDIRECTS) {\n            return reject(new FsRequestError(`Max redirects (${this.redirectHoops}) reached. Exiting`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          const url = res.headers['location'];\n\n          if (!url || url.length === 0) {\n            return reject(new FsRequestError(`Redirect header location not found`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          if (this.redirectPaths.indexOf(url) > -1) {\n            return reject(new FsRequestError(`Redirect loop detected at url ${url}`, config, response, FsRequestErrorCode.REDIRECT));\n          }\n\n          this.redirectPaths.push(url);\n          this.redirectHoops++;\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          debug('Redirecting request to %s (hoop-count: %d)', url, this.redirectHoops);\n\n          return resolve(this.request(Object.assign({}, config, { url })));\n        }\n\n        let responseBuffer = [];\n        stream.on('data', chunk => responseBuffer.push(chunk));\n\n        /* istanbul ignore next: its hard to test socket events with jest and nock - tested manually */\n        stream.on('error', err => {\n          res = undefined;\n          req = undefined;\n          responseBuffer = undefined;\n          debug('Request error: Aborted %O', err);\n\n          if (req.aborted) {\n            return;\n          }\n\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError(err.message, config, null, FsRequestErrorCode.NETWORK));\n        });\n\n        stream.on('end', async () => {\n          // clear cancel token to avoid memory leak\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          // check if there is any response data inside\n          if (res.statusCode !== 204) {\n            // prepare response\n            response.data = Buffer.concat(responseBuffer);\n            response = await parseResponse(response);\n          } else {\n            response.data = null;\n          }\n\n          // free resources\n          res = undefined;\n          req = undefined;\n\n          responseBuffer = undefined;\n\n          if (500 <= response.status && response.status <= 599) {\n            // server error throw\n            debug('Server error(5xx) - %O', response);\n            return reject(new FsRequestError(`Server error ${url}`, config, response, FsRequestErrorCode.SERVER));\n          } else if (400 <= response.status && response.status <= 499) {\n            debug('Request error(4xx) - %O', response);\n            return reject(new FsRequestError(`Request error ${url}`, config, response, FsRequestErrorCode.REQUEST));\n          }\n\n          debug('Request ends: %O', response);\n          return resolve(response);\n        });\n      });\n\n      if (config.timeout) {\n        req.setTimeout(config.timeout, () => {\n          req.abort();\n\n          if (cancelListener) {\n            config.cancelToken.removeListener(cancelListener);\n          }\n\n          return reject(new FsRequestError('Request timeout', config, null, FsRequestErrorCode.TIMEOUT));\n        });\n      }\n\n      req.on('error', err => {\n        if (cancelListener) {\n          config.cancelToken.removeListener(cancelListener);\n        }\n\n        if (!req || req.aborted) {\n          return;\n        }\n\n        debug('Request error: %s - %O', err, err.code);\n        return reject(new FsRequestError(`Request error: ${err.code}`, config, null, FsRequestErrorCode.NETWORK));\n      });\n\n      if (Buffer.isBuffer(data) && ['POST', 'PUT'].indexOf(config.method) > -1) {\n        return this.bufferToChunks(data).pipe(this.getProgressMonitor(config, data.length)).pipe(new HttpWritableStream(req));\n      }\n\n      req.end(data);\n    });\n  }\n\n  /**\n   * Monitor and emit progress event if needed\n   *\n   * @private\n   * @memberof HttpAdapter\n   */\n  private getProgressMonitor = (config, total) => {\n    let loaded = 0;\n\n    const progress = new Stream.Transform();\n    progress._transform = (chunk, encoding, cb) => {\n      if (typeof config.onProgress === 'function' && [FsHttpMethod.POST, FsHttpMethod.PUT].indexOf(config.method) > -1) {\n        loaded += chunk.length;\n        config.onProgress({\n          lengthComputable: true,\n          loaded,\n          total,\n        });\n      }\n      cb(null, chunk);\n    };\n\n    return progress;\n  }\n\n  /**\n   * Convert buffer to stream\n   *\n   * @private\n   * @param {*} buffer\n   * @returns {Stream.Readable}\n   * @memberof HttpAdapter\n   */\n  private bufferToChunks(buffer): Stream.Readable {\n    const chunking = new Stream.Readable();\n    const totalLength = buffer.length;\n    const remainder = totalLength % HTTP_CHUNK_SIZE;\n    const cutoff = totalLength - remainder;\n\n    for (let i = 0; i < cutoff; i += HTTP_CHUNK_SIZE) {\n      const chunk = buffer.slice(i, i + HTTP_CHUNK_SIZE);\n      chunking.push(chunk);\n    }\n\n    if (remainder > 0) {\n      const remainderBuffer = buffer.slice(-remainder);\n      chunking.push(remainderBuffer);\n    }\n\n    chunking.push(null);\n\n    return chunking;\n  }\n}\n"]}

@@ -1,2 +0,2 @@

export declare const Map: {
export declare const ExtensionsMap: {
'application/andrew-inset': string[];

@@ -3,0 +3,0 @@ 'application/applixware': string[];

@@ -46,3 +46,3 @@ /*

export var getVersion = function () {
return 'JS-3.19.0';
return 'JS-3.20.0';
};

@@ -49,0 +49,0 @@ /**

@@ -42,2 +42,9 @@ /// <reference types="node" />

/**
* Change extension to according mimetype using ext=>mimetype map
*
* @param ext - string
* @return string|boolean
*/
export declare const extensionToMime: (ext: string) => string;
/**
* Sanitizer Options

@@ -44,0 +51,0 @@ */

@@ -18,3 +18,3 @@ /*

import { __assign } from "tslib";
import { Map } from './extensions';
import { ExtensionsMap } from './extensions';
import fileType from 'file-type';

@@ -99,9 +99,5 @@ import * as isutf8 from 'isutf8';

if (name && name.indexOf('.') > -1) {
var ext = name.split('.').pop();
var keys = Object.keys(Map);
var mapLen = keys.length;
for (var i = 0; i < mapLen; i++) {
if (Map[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
var mime_1 = extensionToMime(name);
if (mime_1) {
return mime_1;
}

@@ -127,2 +123,27 @@ }

/**
* Change extension to according mimetype using ext=>mimetype map
*
* @param ext - string
* @return string|boolean
*/
export var extensionToMime = function (ext) {
if (!ext || ext.length === 0) {
return;
}
if (ext.split('/').length === 2) {
return ext;
}
if (ext.indexOf('.') > -1) {
ext = ext.split('.').pop();
}
var keys = Object.keys(ExtensionsMap);
var mapLen = keys.length;
for (var i = 0; i < mapLen; i++) {
if (ExtensionsMap[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
}
return;
};
/**
* Sanitize file name

@@ -197,2 +218,2 @@ *

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.ts"],"names":[],"mappings":"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","file":"lib/utils/index.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Session } from '../client';\nimport { Hosts } from './../../config';\nimport { Map } from './extensions';\nimport fileType from 'file-type';\nimport * as isutf8 from 'isutf8';\n\n/**\n * Resolve cdn url based on handle type\n *\n * @private\n * @param session session object\n * @param handle file handle (hash, src://alias, url)\n */\nexport const resolveCdnUrl = (session: Session, handle: string): string => {\n  const cdnURL = session.urls.cdnUrl;\n\n  if (handle && (handle.indexOf('src:') === 0 || handle.indexOf('http') === 0)) {\n    if (!session.apikey) {\n      throw new Error('Api key is required when storage alias is provided');\n    }\n\n    // apikey is required for alias or external sources call\n    return `${cdnURL}/${session.apikey}`;\n  }\n\n  return cdnURL;\n};\n\n/**\n * Resolve all urls with provided cnames\n *\n * @private\n * @param urls\n * @param cname\n */\nexport const resolveHost = (urls: Hosts, cname: string): Hosts => {\n  if (!cname) {\n    return urls;\n  }\n\n  const hosts = /filestackapi.com|filestackcontent.com/i;\n\n  Object.keys(urls).forEach(key => {\n    urls[key] = urls[key].replace(hosts, cname);\n  });\n\n  return urls;\n};\n\n/**\n * Removes empty options from object\n *\n * @private\n * @param obj\n */\nexport const removeEmpty = (obj: any) => {\n  const newObj = { ...obj };\n  Object.keys(newObj).forEach(k => !newObj[k] && typeof newObj[k] !== 'boolean' && delete newObj[k]);\n  return newObj;\n};\n\n/**\n * Returns unique time\n */\nlet last;\nexport const uniqueTime = () => {\n  const time = Date.now();\n  last = time === last ? time + 1 : time;\n  return last;\n};\n\n/**\n * Generates random string with provided length\n *\n * @param len\n */\nexport const uniqueId = (len: number = 10): string => {\n  return new Array(len).join().replace(/(.|$)/g, () => ((Math.random() * 36) | 0).toString(36)[Math.random() < 0.5 ? 'toString' : 'toUpperCase']());\n};\n\n/**\n * Check if input is a svg\n *\n * @param {Uint8Array | Buffer} file\n * @returns {string} - mimetype\n */\nexport const getMimetype = (file: Uint8Array | Buffer, name?: string): string => {\n  let type = fileType(file);\n\n  const excludedMimetypes = ['text/plain', 'application/octet-stream', 'application/x-ms', 'application/x-msi', 'application/zip'];\n\n  if (type && excludedMimetypes.indexOf(type.mime) === -1) {\n    return type.mime;\n  }\n\n  if (name && name.indexOf('.') > -1) {\n    const ext = name.split('.').pop();\n    const keys = Object.keys(Map);\n    const mapLen = keys.length;\n\n    for (let i = 0; i < mapLen; i++) {\n      if (Map[keys[i]].indexOf(ext) > -1) {\n        return keys[i];\n      }\n    }\n  }\n\n  try {\n    if (isutf8(file)) {\n      return 'text/plain';\n    }\n  } catch (e) {\n    /* istanbul ignore next */\n    console.warn('Additional mimetype checks (text/plain) are currently not supported for browsers');\n  }\n  // this is only fallback, omit it in coverage\n  /* istanbul ignore next */\n\n  // if we cant find types by extensions and we have magic bytes fallback to it\n  if (type) {\n    return type.mime;\n  }\n\n  return 'application/octet-stream';\n};\n\n/**\n * Sanitizer Options\n */\nexport type SanitizeOptions =\n  | boolean\n  | {\n    exclude?: string[];\n    replacement?: string;\n  };\n\n/**\n * Sanitize file name\n *\n * @param name\n * @param {bool} options  - enable,disable sanitizer, default enabled\n * @param {string} options.replacement - replacement for sanitized chars defaults to \"-\"\n * @param {string[]} options.exclude - array with excluded chars default - ['\\', '{', '}','|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>']\n */\nexport const sanitizeName = (name: string, options: SanitizeOptions = true): string => {\n  if (typeof options === 'boolean' && !options) {\n    return name;\n  }\n\n  let ext;\n\n  const replacement = typeof options !== 'boolean' && options.replacement ? options.replacement : '-';\n  const exclude = typeof options !== 'boolean' && options.exclude ? options.exclude : ['\\\\', '{', '}', '|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>'];\n\n  if (!name || name.length === 0) {\n    return 'undefined';\n  }\n\n  const fileParts = name.split('.');\n\n  if (fileParts.length > 1) {\n    ext = fileParts.pop();\n  }\n\n  return `${fileParts\n    .join('.')\n    .split('')\n    .map(char => (exclude.indexOf(char) > -1 ? replacement : char))\n    .join('')}${ext ? '.' + ext : ''}`;\n};\n\n/**\n * Filter object to given fields\n *\n * @param toFilter\n * @param requiredFields\n */\nexport const filterObject = (toFilter, requiredFields: string[]) => {\n  if (!requiredFields || requiredFields.length === 0) {\n    return toFilter;\n  }\n\n  if (Object.keys(toFilter).length === 0) {\n    return toFilter;\n  }\n\n  return Object.keys(toFilter)\n    .filter(f => requiredFields.indexOf(f) > -1)\n    .reduce((obj, key) => ({ ...obj, [key]: toFilter[key] }), {});\n};\n\n/**\n * Deep cleanup object from functions\n *\n * @param obj\n */\nexport const cleanUpCallbacks = (obj: any) => {\n  if (!obj || Object.keys(obj).length === 0) {\n    return obj;\n  }\n\n  Object.keys(obj).forEach(k => {\n    if (typeof obj[k] === 'function') {\n      obj[k] = undefined;\n    }\n\n    if (obj[k] === Object(obj[k])) {\n      obj[k] = cleanUpCallbacks(obj[k]);\n    }\n  });\n\n  return obj;\n};\n\nexport * from './index.node';\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.ts"],"names":[],"mappings":"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","file":"lib/utils/index.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Session } from '../client';\nimport { Hosts } from './../../config';\nimport { ExtensionsMap } from './extensions';\nimport fileType from 'file-type';\nimport * as isutf8 from 'isutf8';\n\n/**\n * Resolve cdn url based on handle type\n *\n * @private\n * @param session session object\n * @param handle file handle (hash, src://alias, url)\n */\nexport const resolveCdnUrl = (session: Session, handle: string): string => {\n  const cdnURL = session.urls.cdnUrl;\n\n  if (handle && (handle.indexOf('src:') === 0 || handle.indexOf('http') === 0)) {\n    if (!session.apikey) {\n      throw new Error('Api key is required when storage alias is provided');\n    }\n\n    // apikey is required for alias or external sources call\n    return `${cdnURL}/${session.apikey}`;\n  }\n\n  return cdnURL;\n};\n\n/**\n * Resolve all urls with provided cnames\n *\n * @private\n * @param urls\n * @param cname\n */\nexport const resolveHost = (urls: Hosts, cname: string): Hosts => {\n  if (!cname) {\n    return urls;\n  }\n\n  const hosts = /filestackapi.com|filestackcontent.com/i;\n\n  Object.keys(urls).forEach(key => {\n    urls[key] = urls[key].replace(hosts, cname);\n  });\n\n  return urls;\n};\n\n/**\n * Removes empty options from object\n *\n * @private\n * @param obj\n */\nexport const removeEmpty = (obj: any) => {\n  const newObj = { ...obj };\n  Object.keys(newObj).forEach(k => !newObj[k] && typeof newObj[k] !== 'boolean' && delete newObj[k]);\n  return newObj;\n};\n\n/**\n * Returns unique time\n */\nlet last;\nexport const uniqueTime = () => {\n  const time = Date.now();\n  last = time === last ? time + 1 : time;\n  return last;\n};\n\n/**\n * Generates random string with provided length\n *\n * @param len\n */\nexport const uniqueId = (len: number = 10): string => {\n  return new Array(len).join().replace(/(.|$)/g, () => ((Math.random() * 36) | 0).toString(36)[Math.random() < 0.5 ? 'toString' : 'toUpperCase']());\n};\n\n/**\n * Check if input is a svg\n *\n * @param {Uint8Array | Buffer} file\n * @returns {string} - mimetype\n */\nexport const getMimetype = (file: Uint8Array | Buffer, name?: string): string => {\n  let type = fileType(file);\n\n  const excludedMimetypes = ['text/plain', 'application/octet-stream', 'application/x-ms', 'application/x-msi', 'application/zip'];\n\n  if (type && excludedMimetypes.indexOf(type.mime) === -1) {\n    return type.mime;\n  }\n\n  if (name && name.indexOf('.') > -1) {\n    const mime = extensionToMime(name);\n\n    if (mime) {\n      return mime;\n    }\n  }\n\n  try {\n    if (isutf8(file)) {\n      return 'text/plain';\n    }\n  } catch (e) {\n    /* istanbul ignore next */\n    console.warn('Additional mimetype checks (text/plain) are currently not supported for browsers');\n  }\n  // this is only fallback, omit it in coverage\n  /* istanbul ignore next */\n\n  // if we cant find types by extensions and we have magic bytes fallback to it\n  if (type) {\n    return type.mime;\n  }\n\n  return 'application/octet-stream';\n};\n\n/**\n * Change extension to according mimetype using ext=>mimetype map\n *\n * @param ext - string\n * @return string|boolean\n */\nexport const extensionToMime = (ext: string) => {\n  if (!ext || ext.length === 0) {\n    return;\n  }\n\n  if (ext.split('/').length === 2) {\n    return ext;\n  }\n\n  if (ext.indexOf('.') > -1) {\n    ext = ext.split('.').pop();\n  }\n\n  const keys = Object.keys(ExtensionsMap);\n  const mapLen = keys.length;\n\n  for (let i = 0; i < mapLen; i++) {\n    if (ExtensionsMap[keys[i]].indexOf(ext) > -1) {\n      return keys[i];\n    }\n  }\n\n  return;\n};\n\n/**\n * Sanitizer Options\n */\nexport type SanitizeOptions =\n  | boolean\n  | {\n    exclude?: string[];\n    replacement?: string;\n  };\n\n/**\n * Sanitize file name\n *\n * @param name\n * @param {bool} options  - enable,disable sanitizer, default enabled\n * @param {string} options.replacement - replacement for sanitized chars defaults to \"-\"\n * @param {string[]} options.exclude - array with excluded chars default - ['\\', '{', '}','|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>']\n */\nexport const sanitizeName = (name: string, options: SanitizeOptions = true): string => {\n  if (typeof options === 'boolean' && !options) {\n    return name;\n  }\n\n  let ext;\n\n  const replacement = typeof options !== 'boolean' && options.replacement ? options.replacement : '-';\n  const exclude = typeof options !== 'boolean' && options.exclude ? options.exclude : ['\\\\', '{', '}', '|', '%', '`', '\"', \"'\", '~', '[', ']', '#', '|', '^', '<', '>'];\n\n  if (!name || name.length === 0) {\n    return 'undefined';\n  }\n\n  const fileParts = name.split('.');\n\n  if (fileParts.length > 1) {\n    ext = fileParts.pop();\n  }\n\n  return `${fileParts\n    .join('.')\n    .split('')\n    .map(char => (exclude.indexOf(char) > -1 ? replacement : char))\n    .join('')}${ext ? '.' + ext : ''}`;\n};\n\n/**\n * Filter object to given fields\n *\n * @param toFilter\n * @param requiredFields\n */\nexport const filterObject = (toFilter, requiredFields: string[]) => {\n  if (!requiredFields || requiredFields.length === 0) {\n    return toFilter;\n  }\n\n  if (Object.keys(toFilter).length === 0) {\n    return toFilter;\n  }\n\n  return Object.keys(toFilter)\n    .filter(f => requiredFields.indexOf(f) > -1)\n    .reduce((obj, key) => ({ ...obj, [key]: toFilter[key] }), {});\n};\n\n/**\n * Deep cleanup object from functions\n *\n * @param obj\n */\nexport const cleanUpCallbacks = (obj: any) => {\n  if (!obj || Object.keys(obj).length === 0) {\n    return obj;\n  }\n\n  Object.keys(obj).forEach(k => {\n    if (typeof obj[k] === 'function') {\n      obj[k] = undefined;\n    }\n\n    if (obj[k] === Object(obj[k])) {\n      obj[k] = cleanUpCallbacks(obj[k]);\n    }\n  });\n\n  return obj;\n};\n\nexport * from './index.node';\n"]}

@@ -45,3 +45,3 @@ /*

export var getVersion = function () {
return 'JS-3.19.0';
return 'JS-3.20.0';
};

@@ -48,0 +48,0 @@ /**

@@ -21,3 +21,3 @@ /*

it('should return version string to replace', function () {
expect(utils.getVersion()).toEqual("JS-3.19.0");
expect(utils.getVersion()).toEqual("JS-3.20.0");
});

@@ -24,0 +24,0 @@ });

@@ -17,3 +17,3 @@ /*

*/
import { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';
import { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, extensionToMime, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';
import { config } from '../../config';

@@ -157,2 +157,25 @@ var v = require('../../../../package.json').version;

});
describe('extensionToMime', function () {
it('should return mimetype if mime is passed', function () {
expect(extensionToMime('')).toEqual(undefined);
});
it('should return same mime is passed', function () {
expect(extensionToMime('image/png')).toEqual('image/png');
expect(extensionToMime('image/jpg')).toEqual('image/jpg');
expect(extensionToMime('application/pdf')).toEqual('application/pdf');
});
it('it should return correct mimes for ext', function () {
expect(extensionToMime('.png')).toEqual('image/png');
expect(extensionToMime('.jpg')).toEqual('image/jpeg');
expect(extensionToMime('.pdf')).toEqual('application/pdf');
expect(extensionToMime('.key')).toEqual('application/vnd.apple.keynote');
expect(extensionToMime('.zip')).toEqual('application/zip');
expect(extensionToMime('.numbers')).toEqual('application/vnd.apple.numbers');
});
it('it should extract extensions form filename or ext with dot', function () {
expect(extensionToMime('test.png')).toEqual('image/png');
expect(extensionToMime('test.jpg')).toEqual('image/jpeg');
expect(extensionToMime('test.pdf')).toEqual('application/pdf');
});
});
describe('CleanupCallbacks', function () {

@@ -183,2 +206,2 @@ it('should set callbacks as undefined and return untouched object', function () {

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.spec.ts"],"names":[],"mappings":"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","file":"lib/utils/index.spec.js","sourcesContent":["/*\n * Copyright (c) 2019 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';\nimport { config } from '../../config';\nconst v = require('../../../../package.json').version;\n\ndescribe('utils:index', () => {\n  describe('resolveCdnUrl', () => {\n\n    const session = {\n      apikey: 'TEST_API_KEY',\n      cname: 'example.com',\n      urls: config.urls,\n    };\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = '5aYkEQJSQCmYShsoCnZN';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com');\n    });\n\n    it('should properly resolve cdn url with src handle', () => {\n      const handle = 'src://test123/test.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = 'https://static1.squarespace.com/static/544eb3cce4b0ef091773611f/t/59ba7ce1bd10f00dcdc80a5f/1505394087367/DSC_0527.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should throw an error when using src handle or url without apikey', () => {\n      const handle = 'src://test123/test.jpg';\n      session.apikey = '';\n      expect(() => { resolveCdnUrl(session, handle); }).toThrow('Api key is required when storage alias is provided');\n    });\n  });\n\n  describe('resolveHost', () => {\n    const hosts = config.urls;\n\n    const checkHosts = (hosts, expected) => {\n      Object.keys(hosts).forEach((k) => {\n        expect(hosts[k].indexOf(expected) > -1).toBeTruthy();\n      });\n    };\n\n    it('should return proper host', () => {\n      const cname = 'example.com';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n\n    it('should return hosts when cname is an empty string', () => {\n      const cname = '';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n  });\n\n  describe('removeEmpty', () => {\n    it('should remove empty options from an object', () => {\n      const testOb = { test1: true, test2: undefined, test3: false };\n      expect(removeEmpty(testOb)).toEqual({ test1: true, test3: false });\n    });\n  });\n\n  describe('uniqueTime', () => {\n    it('should return unique times', () => {\n      expect(uniqueTime()).not.toEqual(uniqueTime());\n    });\n  });\n\n  describe('uniqueId', () => {\n    it('should get different ids each time', () => {\n      expect(uniqueId()).not.toEqual(uniqueId());\n    });\n\n    it('should return id with given length', () => {\n      expect(uniqueId(12).length).toEqual(12);\n      expect(uniqueId(4).length).toEqual(4);\n    });\n  });\n\n  describe('md5', () => {\n    it('should return correct md5 value', () => {\n      expect(md5(Buffer.from('test'))).toEqual('CY9rzUYh03PK3k6DJie09g==');\n    });\n  });\n\n  describe('getVersion', () => {\n    it('should return correct version from package json', () => {\n      expect(getVersion()).toEqual(`JS-${v}`);\n    });\n  });\n\n  describe('b64', () => {\n    it('should return correct b65 value', () => {\n      expect(b64('testtext')).toEqual('dGVzdHRleHQ=');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"/\"', () => {\n      expect(b64('*0eijATh#\"I$PR)s<uTa}{t>E\"LC:L', true)).toEqual('KjBlaWpBVGgjIkkkUFIpczx1VGF9e3Q-RSJMQzpM');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"\"', () => {\n      expect(b64('W{wpB@ckYD0O@&?!||9PS)7^+F*H8N', true)).toEqual('V3t3cEJAY2tZRDBPQCY_IXx8OVBTKTdeK0YqSDhO');\n    });\n  });\n\n  describe('sanitizeName', () => {\n    it('should sanitize file name with extension', () => {\n      expect(sanitizeName('a\\\\{%`\"~[]#|^<>1.jpg')).toEqual('a-------------1.jpg');\n    });\n\n    it('should sanitize file name without extension', () => {\n      expect(sanitizeName('123qwe')).toEqual('123qwe');\n    });\n\n    it('should return undefined on empty string', () => {\n      expect(sanitizeName('')).toEqual('undefined');\n    });\n\n    it('should respect sanitize options as boolean', () => {\n      expect(sanitizeName('[]#|.jpg', false)).toEqual('[]#|.jpg');\n    });\n\n    it('should not change dots in filename', () => {\n      expect(sanitizeName('[]#some.tar.gz', false)).toEqual('[]#some.tar.gz');\n    });\n\n    it('should respect sanitize options with provided options', () => {\n      expect(sanitizeName('[]#|.jpg', {\n        exclude: ['[', ']'],\n        replacement: '_',\n      })).toEqual('__#|.jpg');\n    });\n  });\n\n  describe('filterObject', () => {\n    it('should filter object', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, ['test', 'test2'])).toEqual({\n        test: 1,\n        test2: 2,\n      });\n    });\n\n    it('should result the same object on empty requirements', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, [])).toEqual({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      });\n    });\n\n    it('should not throw on empty filtered object', () => {\n      expect(filterObject({}, ['test'])).toEqual({});\n    });\n  });\n\n  describe('CleanupCallbacks', () => {\n    it('should set callbacks as undefined and return untouched object', () => {\n      const testObj = {\n        fn: () => 1,\n        test: {\n          fn2: () => 2,\n        },\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      };\n\n      expect(cleanUpCallbacks(testObj)).toEqual({\n        test: {},\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      });\n    });\n  });\n});\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/utils/index.spec.ts"],"names":[],"mappings":"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","file":"lib/utils/index.spec.js","sourcesContent":["/*\n * Copyright (c) 2019 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, extensionToMime, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';\nimport { config } from '../../config';\nconst v = require('../../../../package.json').version;\n\ndescribe('utils:index', () => {\n  describe('resolveCdnUrl', () => {\n\n    const session = {\n      apikey: 'TEST_API_KEY',\n      cname: 'example.com',\n      urls: config.urls,\n    };\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = '5aYkEQJSQCmYShsoCnZN';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com');\n    });\n\n    it('should properly resolve cdn url with src handle', () => {\n      const handle = 'src://test123/test.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should properly resolve cdn url with hashed handle', () => {\n      const handle = 'https://static1.squarespace.com/static/544eb3cce4b0ef091773611f/t/59ba7ce1bd10f00dcdc80a5f/1505394087367/DSC_0527.jpg';\n      const result = resolveCdnUrl(session, handle);\n      expect(result).toEqual('https://cdn.filestackcontent.com/TEST_API_KEY');\n    });\n\n    it('should throw an error when using src handle or url without apikey', () => {\n      const handle = 'src://test123/test.jpg';\n      session.apikey = '';\n      expect(() => { resolveCdnUrl(session, handle); }).toThrow('Api key is required when storage alias is provided');\n    });\n  });\n\n  describe('resolveHost', () => {\n    const hosts = config.urls;\n\n    const checkHosts = (hosts, expected) => {\n      Object.keys(hosts).forEach((k) => {\n        expect(hosts[k].indexOf(expected) > -1).toBeTruthy();\n      });\n    };\n\n    it('should return proper host', () => {\n      const cname = 'example.com';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n\n    it('should return hosts when cname is an empty string', () => {\n      const cname = '';\n      const result = resolveHost(hosts, cname);\n      checkHosts(result, cname);\n    });\n  });\n\n  describe('removeEmpty', () => {\n    it('should remove empty options from an object', () => {\n      const testOb = { test1: true, test2: undefined, test3: false };\n      expect(removeEmpty(testOb)).toEqual({ test1: true, test3: false });\n    });\n  });\n\n  describe('uniqueTime', () => {\n    it('should return unique times', () => {\n      expect(uniqueTime()).not.toEqual(uniqueTime());\n    });\n  });\n\n  describe('uniqueId', () => {\n    it('should get different ids each time', () => {\n      expect(uniqueId()).not.toEqual(uniqueId());\n    });\n\n    it('should return id with given length', () => {\n      expect(uniqueId(12).length).toEqual(12);\n      expect(uniqueId(4).length).toEqual(4);\n    });\n  });\n\n  describe('md5', () => {\n    it('should return correct md5 value', () => {\n      expect(md5(Buffer.from('test'))).toEqual('CY9rzUYh03PK3k6DJie09g==');\n    });\n  });\n\n  describe('getVersion', () => {\n    it('should return correct version from package json', () => {\n      expect(getVersion()).toEqual(`JS-${v}`);\n    });\n  });\n\n  describe('b64', () => {\n    it('should return correct b65 value', () => {\n      expect(b64('testtext')).toEqual('dGVzdHRleHQ=');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"/\"', () => {\n      expect(b64('*0eijATh#\"I$PR)s<uTa}{t>E\"LC:L', true)).toEqual('KjBlaWpBVGgjIkkkUFIpczx1VGF9e3Q-RSJMQzpM');\n    });\n\n    it('should escape chars to make b64 url safe string - char \"\"', () => {\n      expect(b64('W{wpB@ckYD0O@&?!||9PS)7^+F*H8N', true)).toEqual('V3t3cEJAY2tZRDBPQCY_IXx8OVBTKTdeK0YqSDhO');\n    });\n  });\n\n  describe('sanitizeName', () => {\n    it('should sanitize file name with extension', () => {\n      expect(sanitizeName('a\\\\{%`\"~[]#|^<>1.jpg')).toEqual('a-------------1.jpg');\n    });\n\n    it('should sanitize file name without extension', () => {\n      expect(sanitizeName('123qwe')).toEqual('123qwe');\n    });\n\n    it('should return undefined on empty string', () => {\n      expect(sanitizeName('')).toEqual('undefined');\n    });\n\n    it('should respect sanitize options as boolean', () => {\n      expect(sanitizeName('[]#|.jpg', false)).toEqual('[]#|.jpg');\n    });\n\n    it('should not change dots in filename', () => {\n      expect(sanitizeName('[]#some.tar.gz', false)).toEqual('[]#some.tar.gz');\n    });\n\n    it('should respect sanitize options with provided options', () => {\n      expect(sanitizeName('[]#|.jpg', {\n        exclude: ['[', ']'],\n        replacement: '_',\n      })).toEqual('__#|.jpg');\n    });\n  });\n\n  describe('filterObject', () => {\n    it('should filter object', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, ['test', 'test2'])).toEqual({\n        test: 1,\n        test2: 2,\n      });\n    });\n\n    it('should result the same object on empty requirements', () => {\n      expect(filterObject({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      }, [])).toEqual({\n        test: 1,\n        test2: 2,\n        test3: 3,\n      });\n    });\n\n    it('should not throw on empty filtered object', () => {\n      expect(filterObject({}, ['test'])).toEqual({});\n    });\n  });\n\n  describe('extensionToMime', () => {\n    it('should return mimetype if mime is passed', () => {\n      expect(extensionToMime('')).toEqual(undefined);\n    });\n\n    it('should return same mime is passed', () => {\n      expect(extensionToMime('image/png')).toEqual('image/png');\n      expect(extensionToMime('image/jpg')).toEqual('image/jpg');\n      expect(extensionToMime('application/pdf')).toEqual('application/pdf');\n    });\n\n    it('it should return correct mimes for ext', () => {\n      expect(extensionToMime('.png')).toEqual('image/png');\n      expect(extensionToMime('.jpg')).toEqual('image/jpeg');\n      expect(extensionToMime('.pdf')).toEqual('application/pdf');\n\n      expect(extensionToMime('.key')).toEqual('application/vnd.apple.keynote');\n      expect(extensionToMime('.zip')).toEqual('application/zip');\n      expect(extensionToMime('.numbers')).toEqual('application/vnd.apple.numbers');\n    });\n\n    it('it should extract extensions form filename or ext with dot', () => {\n      expect(extensionToMime('test.png')).toEqual('image/png');\n      expect(extensionToMime('test.jpg')).toEqual('image/jpeg');\n      expect(extensionToMime('test.pdf')).toEqual('application/pdf');\n    });\n  });\n\n  describe('CleanupCallbacks', () => {\n    it('should set callbacks as undefined and return untouched object', () => {\n      const testObj = {\n        fn: () => 1,\n        test: {\n          fn2: () => 2,\n        },\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      };\n\n      expect(cleanUpCallbacks(testObj)).toEqual({\n        test: {},\n        testN: 123,\n        tests: 'string',\n        testObj: {\n          tst: 123,\n        },\n      });\n    });\n  });\n});\n"]}

@@ -5,2 +5,15 @@ # Changelog

## [3.20.0](https://github.com/filestack/filestack-js/compare/v3.19.0...v3.20.0) (2020-11-18)
### Features
* **picker:** bump picker version ([4b155b3](https://github.com/filestack/filestack-js/commit/4b155b359b1b939ec80ad224703e194effc4a791))
* **utils:** add converting extension to mimetype ([#400](https://github.com/filestack/filestack-js/issues/400)) ([669e178](https://github.com/filestack/filestack-js/commit/669e178ef9d6cbd4d2303cec0f8cbbbf208b50fd))
### Bug Fixes
* **sentry:** update sentry errors ([5a53ddd](https://github.com/filestack/filestack-js/commit/5a53ddd75db9c41396b1c2d9c23dab5784ca2419))
## [3.19.0](https://github.com/filestack/filestack-js/compare/v3.18.0...v3.19.0) (2020-11-03)

@@ -7,0 +20,0 @@

{
"name": "filestack-js",
"version": "3.19.0",
"version": "3.20.0",
"description": "Official JavaScript library for Filestack",

@@ -5,0 +5,0 @@ "main": "build/main/index.js",

@@ -21,3 +21,3 @@ /*

*/
const PICKER_VERSION = '1.19.0';
const PICKER_VERSION = '1.19.1';

@@ -24,0 +24,0 @@ /**

@@ -25,3 +25,3 @@ /*

import { storeURL } from './api/store';
import { resolveHost, getVersion } from './utils';
import * as Utils from './utils';
import { Upload, InputFile, UploadOptions, StoreUploadOptions, UploadTags } from './api/upload';

@@ -104,2 +104,12 @@ import { preview, PreviewOptions } from './api/preview';

/**
* Returns filestack utils
*
* @readonly
* @memberof Client
*/
get utils() {
return Utils;
}
constructor(apikey: string, options?: ClientOptions) {

@@ -116,3 +126,3 @@ super();

scope.setTag('apikey', apikey);
scope.setTag('sdk-version', getVersion());
scope.setTag('sdk-version', Utils.getVersion());
scope.setExtra('clientOptions', options);

@@ -177,3 +187,3 @@ });

this.session.cname = cname;
this.session.urls = resolveHost(this.session.urls, cname);
this.session.urls = Utils.resolveHost(this.session.urls, cname);
}

@@ -436,4 +446,5 @@

Sentry.withScope(scope => {
scope.setExtras(e.details);
scope.setExtras({ uploadOptions: options, storeOptions });
scope.setExtras({ uploadOptions: options, storeOptions, details: e.details });
e.message = `FS-${e.message}`;
Sentry.captureException(e);

@@ -440,0 +451,0 @@ });

@@ -294,5 +294,3 @@ /*

if (config.timeout) {
console.log(config.timeout);
req.setTimeout(config.timeout, () => {
console.log('socket timeouted===========');
req.abort();

@@ -299,0 +297,0 @@

@@ -18,3 +18,3 @@ /*

export const Map = {
export const ExtensionsMap = {
'application/andrew-inset': ['ez'],

@@ -21,0 +21,0 @@ 'application/applixware': ['aw'],

@@ -17,3 +17,3 @@ /*

*/
import { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';
import { resolveCdnUrl, resolveHost, removeEmpty, uniqueTime, uniqueId, md5, extensionToMime, sanitizeName, filterObject, b64, getVersion, cleanUpCallbacks } from './index';
import { config } from '../../config';

@@ -186,2 +186,30 @@ const v = require('../../../../package.json').version;

describe('extensionToMime', () => {
it('should return mimetype if mime is passed', () => {
expect(extensionToMime('')).toEqual(undefined);
});
it('should return same mime is passed', () => {
expect(extensionToMime('image/png')).toEqual('image/png');
expect(extensionToMime('image/jpg')).toEqual('image/jpg');
expect(extensionToMime('application/pdf')).toEqual('application/pdf');
});
it('it should return correct mimes for ext', () => {
expect(extensionToMime('.png')).toEqual('image/png');
expect(extensionToMime('.jpg')).toEqual('image/jpeg');
expect(extensionToMime('.pdf')).toEqual('application/pdf');
expect(extensionToMime('.key')).toEqual('application/vnd.apple.keynote');
expect(extensionToMime('.zip')).toEqual('application/zip');
expect(extensionToMime('.numbers')).toEqual('application/vnd.apple.numbers');
});
it('it should extract extensions form filename or ext with dot', () => {
expect(extensionToMime('test.png')).toEqual('image/png');
expect(extensionToMime('test.jpg')).toEqual('image/jpeg');
expect(extensionToMime('test.pdf')).toEqual('application/pdf');
});
});
describe('CleanupCallbacks', () => {

@@ -188,0 +216,0 @@ it('should set callbacks as undefined and return untouched object', () => {

@@ -20,3 +20,3 @@ /*

import { Hosts } from './../../config';
import { Map } from './extensions';
import { ExtensionsMap } from './extensions';
import fileType from 'file-type';

@@ -115,10 +115,6 @@ import * as isutf8 from 'isutf8';

if (name && name.indexOf('.') > -1) {
const ext = name.split('.').pop();
const keys = Object.keys(Map);
const mapLen = keys.length;
const mime = extensionToMime(name);
for (let i = 0; i < mapLen; i++) {
if (Map[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
if (mime) {
return mime;
}

@@ -147,2 +143,33 @@ }

/**
* Change extension to according mimetype using ext=>mimetype map
*
* @param ext - string
* @return string|boolean
*/
export const extensionToMime = (ext: string) => {
if (!ext || ext.length === 0) {
return;
}
if (ext.split('/').length === 2) {
return ext;
}
if (ext.indexOf('.') > -1) {
ext = ext.split('.').pop();
}
const keys = Object.keys(ExtensionsMap);
const mapLen = keys.length;
for (let i = 0; i < mapLen; i++) {
if (ExtensionsMap[keys[i]].indexOf(ext) > -1) {
return keys[i];
}
}
return;
};
/**
* Sanitizer Options

@@ -149,0 +176,0 @@ */

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc