UNPKG

box-node-sdk

Version:

Official SDK for Box Plaform APIs

200 lines 8.77 kB
"use strict"; /** * @fileoverview Manager for the Web Links Resource */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; const url_path_1 = __importDefault(require("../util/url-path")); // ------------------------------------------------------------------------------ // Private // ------------------------------------------------------------------------------ const BASE_PATH = '/web_links'; // ------------------------------------------------------------------------------ // Public // ------------------------------------------------------------------------------ /** * Simple manager for interacting with all 'Weblinks' endpoints and actions. * * @constructor * @param {BoxClient} client - The Box API Client that is responsible for making calls to the API * @returns {void} */ class WebLinks { constructor(client) { this.client = client; } /** * Creates a web link object within a given folder. * * API Endpoint: '/web_links' * Method: POST * * @param {string} url - URL you want the web link to point to. Must include http:// or https:// * @param {string} parentID - The ID of the parent folder where you're creating the web link * @param {Object} [options] - Additional parameters * @param {string} [options.name] - Name for the web link. Will default to the URL if empty. * @param {string} [options.description] - Description of the web link. Will provide more context to users about the web link. * @param {Function} [callback] - Passed the new web link information if it was acquired successfully, error otherwise * @returns {Promise<Object>} A promise resolving to the created weblink object */ create(url, parentID, options, callback) { var apiPath = (0, url_path_1.default)(BASE_PATH), params = { body: { url, parent: { id: parentID, }, }, }; Object.assign(params.body, options); return this.client.wrapWithDefaultHandler(this.client.post)(apiPath, params, callback); } /** * Use to get information about the web link. * * API Endpoint: '/web_links/:weblinkID' * Method: GET * * @param {string} weblinkID - The Box ID of web link being requested * @param {Object} [options] - Additional options for the request. Can be left null in most cases. * @param {Function} [callback] - Passed the web-link information if it was acquired successfully, error otherwise * @returns {Promise<Object>} A promise resolving to the weblink object */ get(weblinkID, options, callback) { var apiPath = (0, url_path_1.default)(BASE_PATH, weblinkID), params = { qs: options, }; return this.client.wrapWithDefaultHandler(this.client.get)(apiPath, params, callback); } /** * Updates information for a web link. * * API Endpoint: '/web_links/:weblinkID' * Method: PUT * * @param {string} weblinkID - The Box ID of the web link being updated * @param {Object} updates - Fields of the weblink to update * @param {string} [updates.name] - Name for the web link. Will default to the URL if empty. * @param {string} [updates.description] - Description of the web link. Will provide more context to users about the web link. * @param {Function} [callback] - Passed the updated web link information if it was acquired successfully, error otherwise * @returns {Promise<Object>} A promise resolving to the updated web link object */ update(weblinkID, updates, callback) { var apiPath = (0, url_path_1.default)(BASE_PATH, weblinkID), params = { body: updates, }; return this.client.wrapWithDefaultHandler(this.client.put)(apiPath, params, callback); } /** * Deletes a web link and moves it to the trash * * API Endpoint: '/web_links/:weblinkID' * Method: DELETE * * @param {string} weblinkID - The Box ID of the web link being moved to the trash * @param {Function} [callback] - Empty body passed if successful, error otherwise * @returns {Promise<Object>} A promise resolving to nothing */ delete(weblinkID, callback) { var apiPath = (0, url_path_1.default)(BASE_PATH, weblinkID); return this.client.wrapWithDefaultHandler(this.client.del)(apiPath, null, callback); } /** * Move a web link into a new parent folder. * * API Endpoint: '/web_links/:webLinkID' * Method: PUT * * @param {string} webLinkID - The Box ID of the web link being requested * @param {string} newParentID - The Box ID for the new parent folder. '0' to move to All Files. * @param {Function} [callback] - Passed the updated web link information if it was acquired successfully * @returns {Promise<Object>} A promise resolving to the updated web link object */ move(webLinkID, newParentID, callback) { var params = { body: { parent: { id: newParentID, }, }, }; var apiPath = (0, url_path_1.default)(BASE_PATH, webLinkID); return this.client.wrapWithDefaultHandler(this.client.put)(apiPath, params, callback); } /** * Copy a web link into a new, different folder * * API Endpoint: '/web_links/:webLinkID/copy * Method: POST * * @param {string} webLinkID - The Box ID of the web link being requested * @param {string} newParentID - The Box ID for the new parent folder. '0' to copy to All Files. * @param {Object} [options] - Optional parameters for the copy operation, can be left null in most cases * @param {string} [options.name] - A new name to use if there is an identically-named item in the new parent folder * @param {Function} [callback] - passed the new web link info if call was successful * @returns {Promise<Object>} A promise resolving to the new web link object */ copy(webLinkID, newParentID, options, callback) { options = options || {}; options.parent = { id: newParentID, }; var params = { body: options, }; var apiPath = (0, url_path_1.default)(BASE_PATH, webLinkID, '/copy'); return this.client.wrapWithDefaultHandler(this.client.post)(apiPath, params, callback); } /** * Add a web link to a given collection * * API Endpoint: '/web_links/:webLinkID' * Method: PUT * * @param {string} webLinkID - The web link to add to the collection * @param {string} collectionID - The collection to add the web link to * @param {Function} [callback] - Passed the updated web link if successful, error otherwise * @returns {Promise<Object>} A promise resolving to the updated web link object */ addToCollection(webLinkID, collectionID, callback) { return this.get(webLinkID, { fields: 'collections' }) .then((data /* FIXME */) => { var collections = data.collections || []; // Convert to correct format collections = collections.map((c /* FIXME */) => ({ id: c.id, })); if (!collections.find((c /* FIXME */) => c.id === collectionID)) { collections.push({ id: collectionID }); } return this.update(webLinkID, { collections }); }) .asCallback(callback); } /** * Remove a web link from a given collection * * API Endpoint: '/web_links/:webLinkID' * Method: PUT * * @param {string} webLinkID - The web link to remove from the collection * @param {string} collectionID - The collection to remove the web link from * @param {Function} [callback] - Passed the updated web link if successful, error otherwise * @returns {Promise<Object>} A promise resolving to the updated web link object */ removeFromCollection(webLinkID, collectionID, callback) { return this.get(webLinkID, { fields: 'collections' }) .then((data /* FIXME */) => { var collections = data.collections || []; // Convert to correct object format and remove the specified collection collections = collections .map((c /* FIXME */) => ({ id: c.id })) .filter((c /* FIXME */) => c.id !== collectionID); return this.update(webLinkID, { collections }); }) .asCallback(callback); } } module.exports = WebLinks; //# sourceMappingURL=web-links.js.map