filestack-js
Version:
Official JavaScript library for Filestack
264 lines (262 loc) • 32.1 kB
JavaScript
/*
* Copyright (c) 2018 by Filestack.
* Some rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { removeEmpty } from '../utils';
import { FilestackError } from './../../filestack_error';
import { FsRequest, FsCancelToken } from '../request';
import { Store, STORE_TYPE } from './../utils/store';
/**
* @private
*/
export var PICKER_KEY = '__fs_picker_token';
/**
* key for picker callback url (specifies which tab will be opened after opening picker)
* @private
*/
export var CALLBACK_URL_KEY = 'fs-tab';
/**
* @private
*/
var CloudClient = /** @class */ (function () {
function CloudClient(session, options) {
/**
* Returns flag if token should be cached in local storage
*
* @private
* @type {boolean}
* @memberof CloudClient
*/
this.cache = false;
this.session = session;
this.storeAdapter = new Store();
this.cloudApiUrl = session.urls.cloudApiUrl;
if (options && options.sessionCache) {
this.cache = options.sessionCache;
}
}
Object.defineProperty(CloudClient.prototype, "token", {
get: function () {
if (this.cache) {
var token = this.storeAdapter.getItem(PICKER_KEY, STORE_TYPE.LOCAL);
if (token)
return token;
}
if (this.isInAppBrowser) {
return this.storeAdapter.getItem(PICKER_KEY, STORE_TYPE.SESSION);
}
return this._token;
},
set: function (key) {
if (this.cache) {
this.storeAdapter.setItem(PICKER_KEY, key, STORE_TYPE.LOCAL);
}
if (this.isInAppBrowser) {
this.storeAdapter.setItem(PICKER_KEY, key, STORE_TYPE.SESSION);
}
this._token = key;
},
enumerable: false,
configurable: true
});
Object.defineProperty(CloudClient.prototype, "isInAppBrowser", {
/**
* Return information is inappbrowser flag is set
*
* @readonly
* @memberof CloudClient
*/
get: function () {
if (this.session
&& this.session.prefetch
&& this.session.prefetch.settings
&& this.session.prefetch.settings.inapp_browser) {
return this.session.prefetch.settings.inapp_browser;
}
return false;
},
enumerable: false,
configurable: true
});
CloudClient.prototype.list = function (clouds, cancelTokenInput, accept) {
var _this = this;
var payload = {
apikey: this.session.apikey,
clouds: clouds,
flow: 'web',
token: this.token,
};
if (accept) {
if (!Array.isArray(accept)) {
accept = [accept];
}
// FS-11013.
// google-drive storing uncommon file-types in incorrect format, eg .srt (subrip) file is stored in bin (octet-stream) format
// so if user wants to accept subrip files, we should search google drive for octet-steam file.
if (accept.includes('application/x-subrip') && !accept.includes('application/octet-stream')) {
accept.push('application/octet-stream');
}
// filtering mimetypes in clouds
payload.accept = accept;
}
if (this.isInAppBrowser) {
payload.appurl = this.currentAppUrl();
}
if (this.session.policy && this.session.signature) {
payload.policy = this.session.policy;
payload.signature = this.session.signature;
}
var options = {};
if (cancelTokenInput) {
var cancelToken = new FsCancelToken();
cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken);
options.cancelToken = cancelToken;
}
return FsRequest.post("".concat(this.cloudApiUrl, "/folder/list"), payload, options).then(function (res) {
if (res.data && res.data.token) {
_this.token = res.data.token;
}
return res.data;
});
};
CloudClient.prototype.store = function (name, path, options, customSource, cancelTokenInput, uploadTags) {
var _a;
var _this = this;
if (options === void 0) { options = {}; }
if (customSource === void 0) { customSource = {}; }
if (uploadTags === void 0) { uploadTags = null; }
// Default to S3
if (options.location === undefined) {
options.location = 's3';
}
var payload = {
apikey: this.session.apikey,
token: this.token,
flow: 'web',
upload_tags: uploadTags ? uploadTags : undefined,
clouds: (_a = {},
_a[name] = {
path: path,
store: removeEmpty(options),
},
_a),
};
if (name === 'customsource' && customSource.customSourcePath) {
payload.clouds.customsource.customSourcePath = customSource.customSourcePath;
}
if (name === 'customsource' && customSource.customSourceContainer) {
payload.clouds.customsource.customSourceContainer = customSource.customSourceContainer;
}
if (this.session.policy && this.session.signature) {
payload.policy = this.session.policy;
payload.signature = this.session.signature;
}
var requestOptions = {};
if (cancelTokenInput) {
var cancelToken = new FsCancelToken();
cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken);
requestOptions.cancelToken = cancelToken;
}
return FsRequest.post("".concat(this.cloudApiUrl, "/store/"), payload, requestOptions).then(function (res) {
if (res.data && res.data.token) {
_this.token = res.data.token;
}
if (res.data && res.data[name]) {
return res.data[name];
}
return res.data;
});
};
CloudClient.prototype.logout = function (name) {
var _a;
var payload = {
apikey: this.session.apikey,
flow: 'web',
token: this.token,
};
if (name) {
payload.clouds = (_a = {}, _a[name] = {}, _a);
}
else {
if (this.cache) {
// No name means logout of ALL clouds. Clear local session.
this.storeAdapter.removeItem(PICKER_KEY, STORE_TYPE.LOCAL);
}
if (this.isInAppBrowser) {
this.storeAdapter.removeItem(PICKER_KEY, STORE_TYPE.SESSION);
}
}
return FsRequest.post("".concat(this.cloudApiUrl, "/auth/logout"), payload).then(function (res) {
if (res.data && res.data[name]) {
return res.data[name];
}
return res.data;
});
};
CloudClient.prototype.metadata = function (url, headers) {
var payload = {
apikey: this.session.apikey,
url: url,
headers: headers,
};
if (this.session.policy && this.session.signature) {
payload.policy = this.session.policy;
payload.signature = this.session.signature;
}
return FsRequest.post("".concat(this.cloudApiUrl, "/metadata"), payload).then(function (res) { return res.data; });
};
// OpenTok API Endpoints
CloudClient.prototype.tokInit = function (type) {
if (type !== 'video' && type !== 'audio') {
throw new FilestackError('Type must be one of video or audio.');
}
return FsRequest.post("".concat(this.cloudApiUrl, "/recording/").concat(type, "/init")).then(function (res) { return res.data; });
};
CloudClient.prototype.tokStart = function (type, key, sessionId) {
if (type !== 'video' && type !== 'audio') {
throw new FilestackError('Type must be one of video or audio.');
}
var payload = {
apikey: key,
session_id: sessionId,
};
return FsRequest.post("".concat(this.cloudApiUrl, "/recording/").concat(type, "/start"), payload).then(function (res) { return res.data; });
};
CloudClient.prototype.tokStop = function (type, key, sessionId, archiveId) {
if (type !== 'video' && type !== 'audio') {
throw new FilestackError('Type must be one of video or audio.');
}
var payload = {
apikey: key,
session_id: sessionId,
archive_id: archiveId,
};
return FsRequest.post("".concat(this.cloudApiUrl, "/recording/").concat(type, "/stop"), payload).then(function (res) { return res.data; });
};
CloudClient.prototype.currentAppUrl = function () {
if (!window.URLSearchParams) {
return undefined;
}
// set init string for clouds backend,
// After this cloud service can make redirect back to current page url with selected tab for given cloud
// if param exists and its value is init, backend will fill it with cloud name
var searchParams = new URLSearchParams(window.location.search);
searchParams.set(CALLBACK_URL_KEY, 'init');
return "".concat(window.location.protocol, "//").concat(window.location.host).concat(window.location.pathname, "?").concat(searchParams.toString());
};
return CloudClient;
}());
export { CloudClient };
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/cloud.ts"],"names":[],"mappings":"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","file":"lib/api/cloud.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 { removeEmpty } from '../utils';\nimport { StoreParams } from '../filelink';\nimport { ClientOptions, Session } from '../client';\nimport { FilestackError } from './../../filestack_error';\nimport { UploadTags } from './upload/file';\nimport { FsRequest, FsCancelToken } from '../request';\nimport { Store, STORE_TYPE } from './../utils/store';\n\n/**\n * @private\n */\nexport const PICKER_KEY = '__fs_picker_token';\n\n/**\n * key for picker callback url (specifies which tab will be opened after opening picker)\n * @private\n */\nexport const CALLBACK_URL_KEY = 'fs-tab';\n\n/**\n * @private\n */\nexport class CloudClient {\n  session: Session;\n  cloudApiUrl: string;\n\n  /**\n   * Returns flag if token should be cached in local storage\n   *\n   * @private\n   * @type {boolean}\n   * @memberof CloudClient\n   */\n  private cache: boolean = false;\n\n  /**\n   * Token returned from api for accessing clouds\n   *\n   * @private\n   * @type {string}\n   * @memberof CloudClient\n   */\n  private _token: string;\n\n  /**\n   * Store adapter instance\n   *\n   * @private\n   * @type {Store}\n   * @memberof CloudClient\n   */\n  private storeAdapter: Store;\n\n  constructor(session: Session, options?: ClientOptions) {\n    this.session = session;\n    this.storeAdapter = new Store();\n\n    this.cloudApiUrl = session.urls.cloudApiUrl;\n\n    if (options && options.sessionCache) {\n      this.cache = options.sessionCache;\n    }\n  }\n\n  get token() {\n    if (this.cache) {\n      const token = this.storeAdapter.getItem(PICKER_KEY, STORE_TYPE.LOCAL);\n      if (token) return token;\n    }\n\n    if (this.isInAppBrowser) {\n      return this.storeAdapter.getItem(PICKER_KEY, STORE_TYPE.SESSION);\n    }\n\n    return this._token;\n  }\n\n  set token(key) {\n    if (this.cache) {\n      this.storeAdapter.setItem(PICKER_KEY, key, STORE_TYPE.LOCAL);\n    }\n\n    if (this.isInAppBrowser) {\n      this.storeAdapter.setItem(PICKER_KEY, key, STORE_TYPE.SESSION);\n    }\n\n    this._token = key;\n  }\n\n  /**\n   * Return information is inappbrowser flag is set\n   *\n   * @readonly\n   * @memberof CloudClient\n   */\n  private get isInAppBrowser() {\n    if (this.session\n      && this.session.prefetch\n      && this.session.prefetch.settings\n      && this.session.prefetch.settings.inapp_browser) {\n      return this.session.prefetch.settings.inapp_browser;\n    }\n\n    return false;\n  }\n\n  list(clouds: any, cancelTokenInput?: any, accept?: string[] | string) {\n    const payload: any = {\n      apikey: this.session.apikey,\n      clouds,\n      flow: 'web',\n      token: this.token,\n    };\n\n    if (accept) {\n      if (!Array.isArray(accept)) {\n        accept = [accept];\n      }\n      // FS-11013.\n      // google-drive storing uncommon file-types in incorrect format, eg .srt (subrip) file is stored in bin (octet-stream) format\n      // so if user wants to accept subrip files, we should search google drive for octet-steam file.\n      if (accept.includes('application/x-subrip') && !accept.includes('application/octet-stream')) {\n        accept.push('application/octet-stream');\n      }\n      // filtering mimetypes in clouds\n      payload.accept = accept;\n    }\n\n    if (this.isInAppBrowser) {\n      payload.appurl = this.currentAppUrl();\n    }\n\n    if (this.session.policy && this.session.signature) {\n      payload.policy = this.session.policy;\n      payload.signature = this.session.signature;\n    }\n\n    let options: any = {};\n\n    if (cancelTokenInput) {\n      const cancelToken = new FsCancelToken();\n      cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken);\n      options.cancelToken = cancelToken;\n    }\n\n    return FsRequest.post(`${this.cloudApiUrl}/folder/list`, payload, options).then(res => {\n      if (res.data && res.data.token) {\n        this.token = res.data.token;\n      }\n\n      return res.data;\n    });\n  }\n\n  store(name: string, path: string, options: StoreParams = {}, customSource: any = {}, cancelTokenInput?: any, uploadTags: UploadTags = null) {\n    // Default to S3\n    if (options.location === undefined) {\n      options.location = 's3';\n    }\n\n    const payload: any = {\n      apikey: this.session.apikey,\n      token: this.token,\n      flow: 'web',\n      upload_tags: uploadTags ? uploadTags : undefined,\n      clouds: {\n        [name]: {\n          path,\n          store: removeEmpty(options),\n        },\n      },\n    };\n\n    if (name === 'customsource' && customSource.customSourcePath) {\n      payload.clouds.customsource.customSourcePath = customSource.customSourcePath;\n    }\n\n    if (name === 'customsource' && customSource.customSourceContainer) {\n      payload.clouds.customsource.customSourceContainer = customSource.customSourceContainer;\n    }\n\n    if (this.session.policy && this.session.signature) {\n      payload.policy = this.session.policy;\n      payload.signature = this.session.signature;\n    }\n\n    let requestOptions: any = {};\n\n    if (cancelTokenInput) {\n      const cancelToken = new FsCancelToken();\n      cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken);\n      requestOptions.cancelToken = cancelToken;\n    }\n\n    return FsRequest.post(`${this.cloudApiUrl}/store/`, payload, requestOptions).then(res => {\n      if (res.data && res.data.token) {\n        this.token = res.data.token;\n      }\n\n      if (res.data && res.data[name]) {\n        return res.data[name];\n      }\n\n      return res.data;\n    });\n  }\n\n  logout(name?: string) {\n    const payload: any = {\n      apikey: this.session.apikey,\n      flow: 'web',\n      token: this.token,\n    };\n\n    if (name) {\n      payload.clouds = { [name]: {} };\n    } else {\n      if (this.cache) {\n        // No name means logout of ALL clouds. Clear local session.\n        this.storeAdapter.removeItem(PICKER_KEY, STORE_TYPE.LOCAL);\n      }\n\n      if (this.isInAppBrowser) {\n        this.storeAdapter.removeItem(PICKER_KEY, STORE_TYPE.SESSION);\n      }\n    }\n\n    return FsRequest.post(`${this.cloudApiUrl}/auth/logout`, payload).then(res => {\n      if (res.data && res.data[name]) {\n        return res.data[name];\n      }\n      return res.data;\n    });\n  }\n\n  metadata(url: string, headers?: {[key: string]: string}) {\n    const payload: any = {\n      apikey: this.session.apikey,\n      url,\n      headers,\n    };\n\n    if (this.session.policy && this.session.signature) {\n      payload.policy = this.session.policy;\n      payload.signature = this.session.signature;\n    }\n\n    return FsRequest.post(`${this.cloudApiUrl}/metadata`, payload).then(res => res.data);\n  }\n\n  // OpenTok API Endpoints\n  tokInit(type: string) {\n    if (type !== 'video' && type !== 'audio') {\n      throw new FilestackError('Type must be one of video or audio.');\n    }\n    return FsRequest.post(`${this.cloudApiUrl}/recording/${type}/init`).then(res => res.data);\n  }\n\n  tokStart(type: string, key: string, sessionId: string) {\n    if (type !== 'video' && type !== 'audio') {\n      throw new FilestackError('Type must be one of video or audio.');\n    }\n    const payload = {\n      apikey: key,\n      session_id: sessionId,\n    };\n\n    return FsRequest.post(`${this.cloudApiUrl}/recording/${type}/start`, payload).then(res => res.data);\n  }\n\n  tokStop(type: string, key: string, sessionId: string, archiveId: string) {\n    if (type !== 'video' && type !== 'audio') {\n      throw new FilestackError('Type must be one of video or audio.');\n    }\n\n    const payload = {\n      apikey: key,\n      session_id: sessionId,\n      archive_id: archiveId,\n    };\n\n    return FsRequest.post(`${this.cloudApiUrl}/recording/${type}/stop`, payload).then(res => res.data);\n  }\n\n  private currentAppUrl() {\n    if (!window.URLSearchParams) {\n      return undefined;\n    }\n\n    // set init string for clouds backend,\n    // After this cloud service can make redirect back to current page url with selected tab for given cloud\n    // if param exists and its value is init, backend will fill it with cloud name\n    const searchParams = new URLSearchParams(window.location.search);\n    searchParams.set(CALLBACK_URL_KEY, 'init');\n\n    return `${window.location.protocol}//${window.location.host}${window.location.pathname}?${searchParams.toString()}`;\n  }\n}\n"]}