Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

saucelabs

Package Overview
Dependencies
Maintainers
4
Versions
122
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

saucelabs - npm Package Compare versions

Comparing version 2.0.0-beta.5 to 2.0.0-beta.6

2

a.js

@@ -15,3 +15,3 @@ const SauceLabs = require('./build').default

api.downloadJobAsset('59088c444518488b8a6bbb1ee2d015ba', 'automator.log', 'foobar.json')
api.downloadJobAsset('59088c444518488b8a6bbb1ee2d015ba', 'automator.log', 'lala.json')
.then(

@@ -18,0 +18,0 @@ (a) => console.log('fertig', a),

@@ -66,3 +66,3 @@ "use strict";

const params = description.parameters.map(urlParameter => urlParameter.$ref ? _constants.PARAMETERS_MAP.get(urlParameter.$ref.split('/').slice(-1)[0]) : urlParameter);
const params = (description.parameters || []).map(urlParameter => urlParameter.$ref ? _constants.PARAMETERS_MAP.get(urlParameter.$ref.split('/').slice(-1)[0]) : urlParameter);
/**

@@ -82,3 +82,3 @@ * validate required url params

url = endpoint.replace(`{${urlParam.name}}`, param);
url = url.replace(`{${urlParam.name}}`, param);
}

@@ -157,26 +157,35 @@ /**

const fd = _fs.default.createWriteStream(_path.default.resolve(process.cwd(), downloadPath));
const hmac = await (0, _utils.createHMAC)(this.username, this.accessKey, jobId);
return new Promise((resolve, reject) => {
const req = (0, _request.default)({
method: 'GET',
uri: `https://assets.${this.host}/jobs/${jobId}/${assetName}?ts=${Date.now()}&auth=${hmac}`
}, (err, res, body) => {
/**
* check if request was successful
*/
if (err) {
return reject(err);
}
/**
* check if we received the asset
*/
const hmac = await (0, _utils.createHMAC)(this.username, this.accessKey, jobId);
return new Promise((resolve, reject) => (0, _request.default)({
method: 'GET',
uri: `https://assets.${this.host}/jobs/${jobId}/${assetName}?ts=${Date.now()}&auth=${hmac}`
}, (err, res, body) => {
if (res.statusCode !== 200) {
return reject(new Error(`There was an error downloading asset ${assetName}, status code: ${res.statusCode}`));
}
return resolve(body);
});
/**
* check if request was successful
* only pipe asset to file if path is given
*/
if (err) {
return reject(err);
}
/**
* check if we received the asset
*/
if (downloadPath) {
const fd = _fs.default.createWriteStream(_path.default.resolve(process.cwd(), downloadPath));
if (res.statusCode !== 200) {
return reject(new Error(`There was an error downloading asset ${assetName}, status code: ${res.statusCode}`));
req.pipe(fd);
}
return resolve(body);
}).pipe(fd));
});
}

@@ -187,2 +196,2 @@

exports.default = SauceLabs;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["SauceLabs","constructor","username","accessKey","host","auth","user","pass","Proxy","get","obj","propName","PROTOCOL_MAP","has","Error","downloadJobAsset","args","description","method","endpoint","params","parameters","map","urlParameter","$ref","PARAMETERS_MAP","split","slice","url","i","urlParam","Object","entries","filter","p","in","param","type","replace","name","bodyMap","Map","options","required","length","optionParam","expectedType","option","changeCase","camelCase","isRequired","Boolean","default","set","body","reduce","e","k","v","Promise","resolve","reject","uri","toUpperCase","json","err","response","statusCode","message","jobId","assetName","downloadPath","JOB_ASSET_NAMES","includes","join","fd","fs","createWriteStream","path","process","cwd","hmac","Date","now","res","pipe"],"mappings":"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","sourcesContent":["import fs from 'fs'\nimport path from 'path'\nimport request from 'request'\nimport changeCase from 'change-case'\n\nimport { createHMAC } from './utils'\n\nimport { PROTOCOL_MAP, PARAMETERS_MAP, JOB_ASSET_NAMES } from './constants'\n\nexport default class SauceLabs {\n    constructor (username, accessKey) {\n        this.username = username\n        this.accessKey = accessKey\n        this.host = 'saucelabs.com'\n        this.auth = {\n            user: this.username,\n            pass: this.accessKey\n        }\n        return new Proxy({}, { get: ::this.get })\n    }\n\n    get (obj, propName) {\n        /**\n         * allow to return publicly registered class properties\n         */\n        if (this[propName]) {\n            return this[propName]\n        }\n\n        if (!PROTOCOL_MAP.has(propName)) {\n            throw new Error(`Couldn't find API endpoint for command \"${propName}\"`)\n        }\n\n        /**\n         * handle special commands not defined in the protocol\n         */\n        if (propName === 'downloadJobAsset') {\n            return ::this.downloadJobAsset\n        }\n\n        return (...args) => {\n            const { description, method, endpoint, host } = PROTOCOL_MAP.get(propName)\n            const params = description.parameters.map(\n                (urlParameter) => urlParameter.$ref\n                    ? PARAMETERS_MAP.get(urlParameter.$ref.split('/').slice(-1)[0])\n                    : urlParameter)\n\n            /**\n             * validate required url params\n             */\n            let url = endpoint\n            for (const [i, urlParam] of Object.entries(params.filter(p => p.in === 'path'))) {\n                const param = args[i]\n                const type = urlParam.type.replace('integer', 'number')\n\n                if (typeof param !== type) {\n                    throw new Error(`Expected parameter for url param '${urlParam.name}' from type '${type}', found '${typeof param}'`)\n                }\n\n                url = endpoint.replace(`{${urlParam.name}}`, param)\n            }\n\n            /**\n             * validate required options\n             */\n            const bodyMap = new Map()\n            const options = args.slice(params.filter(p => p.required).length)[0] || {}\n            for (const optionParam of params.filter(p => p.in === 'query')) {\n                const expectedType = optionParam.type.replace('integer', 'number')\n                const option = options[changeCase.camelCase(optionParam.name)]\n                const isRequired = Boolean(optionParam.required) || (typeof optionParam.required === 'undefined' && typeof optionParam.default === 'undefined')\n                if (isRequired && (!option || typeof option !== expectedType)) {\n                    throw new Error(`Expected parameter for option '${optionParam.name}' from type '${expectedType}', found '${typeof option}'`)\n                }\n\n                if (option) {\n                    bodyMap.set(optionParam.name, option)\n                }\n            }\n\n            /**\n             * convert map into json object\n             */\n            const body = [...bodyMap.entries()].reduce((e, [k, v]) => {\n                e[k] = v\n                return e\n            }, {})\n\n            /**\n             * make request\n             */\n            return new Promise((resolve, reject) => request({\n                uri: `https://${host}${url}`,\n                method: method.toUpperCase(),\n                [method === 'post' ? 'json' : 'qs']: body,\n                json: true,\n                auth: this.auth\n            }, (err, response, body) => {\n                if (err) {\n                    return reject(err)\n                }\n\n                if (response.statusCode !== 200) {\n                    return reject(new Error(body.message || 'unknown error'))\n                }\n\n                return resolve(body)\n            }))\n        }\n    }\n\n    async downloadJobAsset (jobId, assetName, downloadPath) {\n        /**\n         * check job id\n         */\n        if (typeof jobId !== 'string') {\n            throw new Error('You need to define a job id')\n        }\n\n        /**\n         * throw if asset is not know\n         */\n        if (!JOB_ASSET_NAMES.includes(assetName)) {\n            throw new Error(`Unknown asset '${assetName}', the following assets are available: ${JOB_ASSET_NAMES.join(', ')}`)\n        }\n\n        const fd = fs.createWriteStream(path.resolve(process.cwd(), downloadPath))\n        const hmac = await createHMAC(this.username, this.accessKey, jobId)\n        return new Promise((resolve, reject) => request({\n            method: 'GET',\n            uri: `https://assets.${this.host}/jobs/${jobId}/${assetName}?ts=${Date.now()}&auth=${hmac}`,\n        }, (err, res, body) => {\n            /**\n             * check if request was successful\n             */\n            if (err) {\n                return reject(err)\n            }\n\n            /**\n             * check if we received the asset\n             */\n            if (res.statusCode !== 200) {\n                return reject(new Error(`There was an error downloading asset ${assetName}, status code: ${res.statusCode}`))\n            }\n\n            return resolve(body)\n        }).pipe(fd))\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["SauceLabs","constructor","username","accessKey","host","auth","user","pass","Proxy","get","obj","propName","PROTOCOL_MAP","has","Error","downloadJobAsset","args","description","method","endpoint","params","parameters","map","urlParameter","$ref","PARAMETERS_MAP","split","slice","url","i","urlParam","Object","entries","filter","p","in","param","type","replace","name","bodyMap","Map","options","required","length","optionParam","expectedType","option","changeCase","camelCase","isRequired","Boolean","default","set","body","reduce","e","k","v","Promise","resolve","reject","uri","toUpperCase","json","err","response","statusCode","message","jobId","assetName","downloadPath","JOB_ASSET_NAMES","includes","join","hmac","req","Date","now","res","fd","fs","createWriteStream","path","process","cwd","pipe"],"mappings":"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","sourcesContent":["import fs from 'fs'\nimport path from 'path'\nimport request from 'request'\nimport changeCase from 'change-case'\n\nimport { createHMAC } from './utils'\n\nimport { PROTOCOL_MAP, PARAMETERS_MAP, JOB_ASSET_NAMES } from './constants'\n\nexport default class SauceLabs {\n    constructor (username, accessKey) {\n        this.username = username\n        this.accessKey = accessKey\n        this.host = 'saucelabs.com'\n        this.auth = {\n            user: this.username,\n            pass: this.accessKey\n        }\n        return new Proxy({}, { get: ::this.get })\n    }\n\n    get (obj, propName) {\n        /**\n         * allow to return publicly registered class properties\n         */\n        if (this[propName]) {\n            return this[propName]\n        }\n\n        if (!PROTOCOL_MAP.has(propName)) {\n            throw new Error(`Couldn't find API endpoint for command \"${propName}\"`)\n        }\n\n        /**\n         * handle special commands not defined in the protocol\n         */\n        if (propName === 'downloadJobAsset') {\n            return ::this.downloadJobAsset\n        }\n\n        return (...args) => {\n            const { description, method, endpoint, host } = PROTOCOL_MAP.get(propName)\n            const params = (description.parameters || []).map(\n                (urlParameter) => urlParameter.$ref\n                    ? PARAMETERS_MAP.get(urlParameter.$ref.split('/').slice(-1)[0])\n                    : urlParameter)\n\n            /**\n             * validate required url params\n             */\n            let url = endpoint\n            for (const [i, urlParam] of Object.entries(params.filter(p => p.in === 'path'))) {\n                const param = args[i]\n                const type = urlParam.type.replace('integer', 'number')\n\n                if (typeof param !== type) {\n                    throw new Error(`Expected parameter for url param '${urlParam.name}' from type '${type}', found '${typeof param}'`)\n                }\n\n                url = url.replace(`{${urlParam.name}}`, param)\n            }\n\n            /**\n             * validate required options\n             */\n            const bodyMap = new Map()\n            const options = args.slice(params.filter(p => p.required).length)[0] || {}\n            for (const optionParam of params.filter(p => p.in === 'query')) {\n                const expectedType = optionParam.type.replace('integer', 'number')\n                const option = options[changeCase.camelCase(optionParam.name)]\n                const isRequired = Boolean(optionParam.required) || (typeof optionParam.required === 'undefined' && typeof optionParam.default === 'undefined')\n                if (isRequired && (!option || typeof option !== expectedType)) {\n                    throw new Error(`Expected parameter for option '${optionParam.name}' from type '${expectedType}', found '${typeof option}'`)\n                }\n\n                if (option) {\n                    bodyMap.set(optionParam.name, option)\n                }\n            }\n\n            /**\n             * convert map into json object\n             */\n            const body = [...bodyMap.entries()].reduce((e, [k, v]) => {\n                e[k] = v\n                return e\n            }, {})\n\n            /**\n             * make request\n             */\n            return new Promise((resolve, reject) => request({\n                uri: `https://${host}${url}`,\n                method: method.toUpperCase(),\n                [method === 'post' ? 'json' : 'qs']: body,\n                json: true,\n                auth: this.auth\n            }, (err, response, body) => {\n                if (err) {\n                    return reject(err)\n                }\n\n                if (response.statusCode !== 200) {\n                    return reject(new Error(body.message || 'unknown error'))\n                }\n\n                return resolve(body)\n            }))\n        }\n    }\n\n    async downloadJobAsset (jobId, assetName, downloadPath) {\n        /**\n         * check job id\n         */\n        if (typeof jobId !== 'string') {\n            throw new Error('You need to define a job id')\n        }\n\n        /**\n         * throw if asset is not know\n         */\n        if (!JOB_ASSET_NAMES.includes(assetName)) {\n            throw new Error(`Unknown asset '${assetName}', the following assets are available: ${JOB_ASSET_NAMES.join(', ')}`)\n        }\n\n        const hmac = await createHMAC(this.username, this.accessKey, jobId)\n        return new Promise((resolve, reject) => {\n            const req = request({\n                method: 'GET',\n                uri: `https://assets.${this.host}/jobs/${jobId}/${assetName}?ts=${Date.now()}&auth=${hmac}`,\n            }, (err, res, body) => {\n                /**\n                 * check if request was successful\n                 */\n                if (err) {\n                    return reject(err)\n                }\n\n                /**\n                 * check if we received the asset\n                 */\n                if (res.statusCode !== 200) {\n                    return reject(new Error(`There was an error downloading asset ${assetName}, status code: ${res.statusCode}`))\n                }\n\n                return resolve(body)\n            })\n\n            /**\n             * only pipe asset to file if path is given\n             */\n            if (downloadPath) {\n                const fd = fs.createWriteStream(path.resolve(process.cwd(), downloadPath))\n                req.pipe(fd)\n            }\n        })\n    }\n}\n"]}
{
"name": "saucelabs",
"version": "2.0.0-beta.5",
"version": "2.0.0-beta.6",
"author": "Dan Jenkins <dan.jenkins@holidayextras.com> (www.dan-jenkins.co.uk)",

@@ -5,0 +5,0 @@ "description": "A wrapper around Sauce Labs REST API",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc