UNPKG

filestack-js

Version:

Official JavaScript library for Filestack

151 lines (149 loc) 20.5 kB
/* * 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 { __assign } from "tslib"; import { Filelink } from './../filelink'; import { removeEmpty } from '../utils'; import { FilestackError } from './../../filestack_error'; import { getValidator, MetadataParamsSchema, RetrieveParamsSchema } from './../../schema'; import { FsRequest, FsHttpMethod } from '../request'; /** * Remove given file * * @private * @param session * @param handle * @param security */ export var remove = function (session, handle, skipStorage, security) { if (!handle || typeof handle !== 'string') { throw new FilestackError('A valid Filestack handle is required for remove'); } if (!(session.policy && session.signature) && (!security || !(security.policy && security.signature))) { throw new FilestackError('Security policy and signature are required for remove'); } var fileApiUrl = session.urls.fileApiUrl; var baseURL = "".concat(fileApiUrl, "/").concat(handle); var options = { key: session.apikey, policy: (security && security.policy) || session.policy, signature: (security && security.signature) || session.signature, }; if (skipStorage) { options.skip_storage = true; } return FsRequest.delete(baseURL, { filestackHeaders: false, params: removeEmpty(options), }); }; /** * Returns file metadata * * @private * @param session * @param handle * @param opts * @param security */ export var metadata = function (session, handle, opts, security) { if (!handle || typeof handle !== 'string') { throw new FilestackError('A valid Filestack handle is required for metadata'); } var validateRes = getValidator(MetadataParamsSchema)(opts); if (validateRes.errors.length) { throw new FilestackError("Invalid metadata params", validateRes.errors); } var options = __assign({}, opts); options.source_url = options.sourceUrl; // source_url is snake_case options.policy = (security && security.policy) || session.policy; options.signature = (security && security.signature) || session.signature; var baseURL = "".concat(session.urls.fileApiUrl, "/").concat(handle, "/metadata"); return new Promise(function (resolve, reject) { FsRequest.get(baseURL, { params: removeEmpty(options), filestackHeaders: false }) .then(function (res) { return resolve(__assign(__assign({}, res.data), { handle: handle })); }) .catch(reject); }); }; /** * Download file to blob or buffer format * * @param session * @param handle */ export var download = function (session, handle, security) { var fl = new Filelink(handle, session.apikey); var policy = (security && security.policy) || session.policy; var signature = (security && security.signature) || session.signature; if (policy && signature) { fl.security({ signature: signature, policy: policy }); } return FsRequest.dispatch(fl.toString(), { method: FsHttpMethod.GET, blobResponse: true }); }; /** * Returns file information * * @private * @deprecated * @param session * @param handle * @param options * @param security */ export var retrieve = function (session, handle, options, security) { if (options === void 0) { options = {}; } if (!handle || handle.length === 0 || typeof handle !== 'string') { throw new FilestackError('File handle is required'); } console.info('Retrieve method is deprecated and it will be removed. Please use metadata or download'); var validateRes = getValidator(RetrieveParamsSchema)(options); if (validateRes.errors.length) { throw new FilestackError("Invalid retrieve params", validateRes.errors); } var requestOptions = __assign({}, options); requestOptions.key = session.apikey; requestOptions.policy = (security && security.policy) || session.policy; requestOptions.signature = (security && security.signature) || session.signature; var method = FsHttpMethod.GET; if (requestOptions.head) { method = FsHttpMethod.HEAD; delete requestOptions.head; } var extension; if (requestOptions.extension && requestOptions.extension.length) { extension = requestOptions.extension; delete requestOptions.extension; } var metadata; if (requestOptions.metadata) { if (method === FsHttpMethod.HEAD) { throw new FilestackError('Head and metadata options cannot be used together'); } metadata = requestOptions.metadata; delete requestOptions.metadata; } var baseURL = "".concat(session.urls.fileApiUrl, "/").concat(handle) + (extension ? "+".concat(extension) : '') + (metadata ? '/metadata' : ''); return new Promise(function (resolve, reject) { FsRequest.dispatch(baseURL, { method: method, filestackHeaders: false, params: removeEmpty(requestOptions), }) .then(function (res) { return resolve(method === FsHttpMethod.HEAD ? res.headers : res.data); }) .catch(reject); }); }; //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/file.ts"],"names":[],"mappings":"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","file":"lib/api/file.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 { Security, Session } from '../client';\nimport { Filelink } from './../filelink';\nimport { removeEmpty } from '../utils';\nimport { FsResponse } from './../request/types';\nimport { FilestackError } from './../../filestack_error';\nimport { getValidator, MetadataParamsSchema, RetrieveParamsSchema } from './../../schema';\nimport { FsRequest, FsHttpMethod } from '../request';\n\n/**\n * Remove given file\n *\n * @private\n * @param session\n * @param handle\n * @param security\n */\nexport const remove = (session: Session, handle?: string, skipStorage?: boolean, security?: Security): Promise<any> => {\n  if (!handle || typeof handle !== 'string') {\n    throw new FilestackError('A valid Filestack handle is required for remove');\n  }\n\n  if (!(session.policy && session.signature) && (!security || !(security.policy && security.signature))) {\n    throw new FilestackError('Security policy and signature are required for remove');\n  }\n\n  const fileApiUrl = session.urls.fileApiUrl;\n  const baseURL = `${fileApiUrl}/${handle}`;\n  const options: any = {\n    key: session.apikey,\n    policy: (security && security.policy) || session.policy,\n    signature: (security && security.signature) || session.signature,\n  };\n\n  if (skipStorage) {\n    options.skip_storage = true;\n  }\n\n  return FsRequest.delete(baseURL, {\n    filestackHeaders: false,\n    params: removeEmpty(options),\n  });\n};\n\nexport interface MetadataOptions {\n  size?: boolean;\n  mimetype?: boolean;\n  filename?: boolean;\n  width?: boolean;\n  height?: boolean;\n  uploaded?: boolean;\n  writeable?: boolean;\n  cloud?: boolean;\n  sourceUrl?: boolean;\n  md5?: boolean;\n  sha1?: boolean;\n  sha224?: boolean;\n  sha256?: boolean;\n  sha384?: boolean;\n  sha512?: boolean;\n  location?: boolean;\n  path?: boolean;\n  container?: boolean;\n  exif?: boolean;\n}\n\n/**\n * Returns file metadata\n *\n * @private\n * @param session\n * @param handle\n * @param opts\n * @param security\n */\nexport const metadata = (session: Session, handle?: string, opts?: MetadataOptions, security?: Security): Promise<any> => {\n  if (!handle || typeof handle !== 'string') {\n    throw new FilestackError('A valid Filestack handle is required for metadata');\n  }\n\n  const validateRes = getValidator(MetadataParamsSchema)(opts);\n\n  if (validateRes.errors.length) {\n    throw new FilestackError(`Invalid metadata params`, validateRes.errors);\n  }\n\n  const options: any = { ...opts };\n  options.source_url = options.sourceUrl; // source_url is snake_case\n  options.policy = (security && security.policy) || session.policy;\n  options.signature = (security && security.signature) || session.signature;\n\n  const baseURL = `${session.urls.fileApiUrl}/${handle}/metadata`;\n  return new Promise((resolve, reject) => {\n    FsRequest.get(baseURL, { params: removeEmpty(options), filestackHeaders: false })\n      .then(res => resolve({ ...res.data, handle }))\n      .catch(reject);\n  });\n};\n\n/**\n * Download file to blob or buffer format\n *\n * @param session\n * @param handle\n */\nexport const download = (session: Session, handle: string,  security?: Security): Promise<FsResponse> => {\n  const fl = new Filelink(handle, session.apikey);\n\n  const policy = (security && security.policy) || session.policy;\n  const signature = (security && security.signature) || session.signature;\n\n  if (policy && signature) {\n    fl.security({ signature, policy });\n  }\n\n  return FsRequest.dispatch(fl.toString(), { method: FsHttpMethod.GET, blobResponse: true });\n};\n\nexport interface RetrieveOptions {\n  metadata?: boolean;\n  head?: boolean;\n  dl?: boolean;\n  extension?: string;\n  cache?: boolean;\n}\n\n/**\n * Returns file information\n *\n * @private\n * @deprecated\n * @param session\n * @param handle\n * @param options\n * @param security\n */\nexport const retrieve = (session: Session, handle: string, options: RetrieveOptions = {}, security?: Security): Promise<Object | Blob> => {\n  if (!handle || handle.length === 0 || typeof handle !== 'string') {\n    throw new FilestackError('File handle is required');\n  }\n\n  console.info('Retrieve method is deprecated and it will be removed. Please use metadata or download');\n\n  const validateRes = getValidator(RetrieveParamsSchema)(options);\n\n  if (validateRes.errors.length) {\n    throw new FilestackError(`Invalid retrieve params`, validateRes.errors);\n  }\n\n  const requestOptions: any = { ...options };\n  requestOptions.key = session.apikey;\n  requestOptions.policy = (security && security.policy) || session.policy;\n  requestOptions.signature = (security && security.signature) || session.signature;\n\n  let method: FsHttpMethod = FsHttpMethod.GET;\n\n  if (requestOptions.head) {\n    method = FsHttpMethod.HEAD;\n    delete requestOptions.head;\n  }\n\n  let extension;\n\n  if (requestOptions.extension && requestOptions.extension.length) {\n    extension = requestOptions.extension;\n    delete requestOptions.extension;\n  }\n\n  let metadata;\n  if (requestOptions.metadata) {\n    if (method === FsHttpMethod.HEAD) {\n      throw new FilestackError('Head and metadata options cannot be used together');\n    }\n\n    metadata = requestOptions.metadata;\n    delete requestOptions.metadata;\n  }\n\n  const baseURL = `${session.urls.fileApiUrl}/${handle}` + (extension ? `+${extension}` : '') + (metadata ? '/metadata' : '');\n\n  return new Promise((resolve, reject) => {\n    FsRequest.dispatch(baseURL, {\n      method,\n      filestackHeaders: false,\n      params: removeEmpty(requestOptions),\n    })\n      .then(res => resolve(method === FsHttpMethod.HEAD ? res.headers : res.data))\n      .catch(reject);\n  });\n};\n"]}