UNPKG

filestack-js

Version:

Official JavaScript library for Filestack

268 lines (266 loc) 32.6 kB
"use strict"; /* * 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. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.CloudClient = exports.CALLBACK_URL_KEY = exports.PICKER_KEY = void 0; var utils_1 = require("../utils"); var filestack_error_1 = require("./../../filestack_error"); var request_1 = require("../request"); var store_1 = require("./../utils/store"); /** * @private */ exports.PICKER_KEY = '__fs_picker_token'; /** * key for picker callback url (specifies which tab will be opened after opening picker) * @private */ exports.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_1.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(exports.PICKER_KEY, store_1.STORE_TYPE.LOCAL); if (token) return token; } if (this.isInAppBrowser) { return this.storeAdapter.getItem(exports.PICKER_KEY, store_1.STORE_TYPE.SESSION); } return this._token; }, set: function (key) { if (this.cache) { this.storeAdapter.setItem(exports.PICKER_KEY, key, store_1.STORE_TYPE.LOCAL); } if (this.isInAppBrowser) { this.storeAdapter.setItem(exports.PICKER_KEY, key, store_1.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 request_1.FsCancelToken(); cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken); options.cancelToken = cancelToken; } return request_1.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, pickerSessionId) { 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, picker_session_id: pickerSessionId, store: (0, utils_1.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 request_1.FsCancelToken(); cancelTokenInput.cancel = cancelToken.cancel.bind(cancelToken); requestOptions.cancelToken = cancelToken; } return request_1.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(exports.PICKER_KEY, store_1.STORE_TYPE.LOCAL); } if (this.isInAppBrowser) { this.storeAdapter.removeItem(exports.PICKER_KEY, store_1.STORE_TYPE.SESSION); } } return request_1.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 request_1.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 filestack_error_1.FilestackError('Type must be one of video or audio.'); } return request_1.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 filestack_error_1.FilestackError('Type must be one of video or audio.'); } var payload = { apikey: key, session_id: sessionId, }; return request_1.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 filestack_error_1.FilestackError('Type must be one of video or audio.'); } var payload = { apikey: key, session_id: sessionId, archive_id: archiveId, }; return request_1.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(exports.CALLBACK_URL_KEY, 'init'); return "".concat(window.location.protocol, "//").concat(window.location.host).concat(window.location.pathname, "?").concat(searchParams.toString()); }; return CloudClient; }()); exports.CloudClient = 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, pickerSessionId?: string) {\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          picker_session_id: pickerSessionId,\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"]}