filestack-js
Version:
Official JavaScript library for Filestack
151 lines (149 loc) • 20.5 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 { __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"]}