Socket
Socket
Sign inDemoInstall

appium-support

Package Overview
Dependencies
Maintainers
8
Versions
145
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

appium-support - npm Package Compare versions

Comparing version 2.54.3 to 2.54.4

29

build/lib/net.js

@@ -54,3 +54,4 @@ "use strict";

fileFieldName = 'file',
formFields
formFields,
streamLength
} = uploadOptions;

@@ -73,2 +74,4 @@ const {

requestOpts.headers = Object.assign({}, _lodash.default.isPlainObject(headers) ? headers : {});
if (fileFieldName) {

@@ -94,7 +97,9 @@ const form = new _formData.default();

requestOpts.headers = Object.assign({}, _lodash.default.isPlainObject(headers) ? headers : {}, form.getHeaders());
Object.assign(requestOpts.headers, form.getHeaders());
requestOpts.data = form;
} else {
if (_lodash.default.isPlainObject(headers)) {
requestOpts.headers = headers;
if (streamLength) {
Object.assign(requestOpts.headers, {
'Content-Length': streamLength
});
}

@@ -172,17 +177,13 @@

if (['http:', 'https:'].includes(parsedUri.protocol)) {
if (!uploadOptions.fileFieldName) {
uploadOptions.headers = Object.assign({}, _lodash.default.isPlainObject(uploadOptions.headers) ? uploadOptions.headers : {}, {
'Content-Length': size
});
}
await uploadFileToHttp(_fs.default.createReadStream(localPath), parsedUri, uploadOptions);
await uploadFileToHttp(_fs.default.createReadStream(localPath), parsedUri, { ...uploadOptions,
streamLength: size
});
} else if (parsedUri.protocol === 'ftp:') {
await uploadFileToFtp(_fs.default.createReadStream(localPath), parsedUri, uploadOptions);
} else {
throw new Error(`Cannot upload the file at '${localPath}' to '${remoteUri}'. ` + `Unsupported remote protocol '${parsedUri.protocol}'. ` + `Only http/https and ftp/ftps protocols are supported.`);
throw new Error(`Cannot upload the file at '${localPath}' to '${remoteUri}'. ` + `Unsupported remote protocol '${parsedUri.protocol}'. ` + `Only http/https and ftp protocols are supported.`);
}
if (isMetered) {
_logger.default.info(`Uploaded '${localPath}' of ${(0, _util.toReadableSizeString)(size)} size in ` + `${timer.getDuration().asSeconds.toFixed(3)}s`);
_logger.default.info(`Uploaded '${localPath}' of ${(0, _util.toReadableSizeString)(size)} in ` + `${timer.getDuration().asSeconds.toFixed(3)}s`);
}

@@ -260,2 +261,2 @@ }

//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/net.js"],"names":["DEFAULT_TIMEOUT_MS","toAxiosAuth","auth","_","isPlainObject","axiosAuth","username","user","password","pass","uploadFileToHttp","localFileStream","parsedUri","uploadOptions","method","timeout","headers","fileFieldName","formFields","href","requestOpts","url","maxContentLength","Infinity","maxBodyLength","form","FormData","append","pairs","isArray","toPairs","key","value","toLower","Object","assign","getHeaders","data","log","debug","JSON","stringify","omit","status","statusText","info","uploadFileToFtp","hostname","port","protocol","pathname","ftpOpts","host","B","resolve","reject","Ftp","put","err","uploadFile","localPath","remoteUri","fs","exists","Error","isMetered","parse","size","stat","timer","Timer","start","includes","createReadStream","getDuration","asSeconds","toFixed","downloadFile","remoteUrl","dstPath","downloadOptions","responseType","responseLength","writer","createWriteStream","responseStream","responseHeaders","parseInt","pipe","once","e","unpipe","message","rimraf","secondsElapsed","bytesPerSec","Math","floor"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport fs from './fs';\nimport url from 'url';\nimport B from 'bluebird';\nimport { toReadableSizeString } from './util';\nimport log from './logger';\nimport Ftp from 'jsftp';\nimport Timer from './timing';\nimport axios from 'axios';\nimport FormData from 'form-data';\n\nconst DEFAULT_TIMEOUT_MS = 4 * 60 * 1000;\n\n\nfunction toAxiosAuth (auth) {\n  if (!_.isPlainObject(auth)) {\n    return null;\n  }\n\n  const axiosAuth = {\n    username: auth.username || auth.user,\n    password: auth.password || auth.pass,\n  };\n  return (axiosAuth.username && axiosAuth.password) ? axiosAuth : null;\n}\n\nasync function uploadFileToHttp (localFileStream, parsedUri, uploadOptions = {}) {\n  const {\n    method = 'POST',\n    timeout = DEFAULT_TIMEOUT_MS,\n    headers,\n    auth,\n    fileFieldName = 'file',\n    formFields,\n  } = uploadOptions;\n  const { href } = parsedUri;\n\n  const requestOpts = {\n    url: href,\n    method,\n    timeout,\n    maxContentLength: Infinity,\n    maxBodyLength: Infinity,\n  };\n  const axiosAuth = toAxiosAuth(auth);\n  if (axiosAuth) {\n    requestOpts.auth = axiosAuth;\n  }\n  if (fileFieldName) {\n    const form = new FormData();\n    form.append(fileFieldName, localFileStream);\n    if (formFields) {\n      let pairs = [];\n      if (_.isArray(formFields)) {\n        pairs = formFields;\n      } else if (_.isPlainObject(formFields)) {\n        pairs = _.toPairs(formFields);\n      }\n      for (const [key, value] of pairs) {\n        if (_.toLower(key) !== _.toLower(fileFieldName)) {\n          form.append(key, value);\n        }\n      }\n    }\n    requestOpts.headers = Object.assign({}, _.isPlainObject(headers) ? headers : {},\n      form.getHeaders());\n    requestOpts.data = form;\n  } else {\n    if (_.isPlainObject(headers)) {\n      requestOpts.headers = headers;\n    }\n    requestOpts.data = localFileStream;\n  }\n  log.debug(`Performing ${method} to ${href} with options (excluding data): ` +\n    JSON.stringify(_.omit(requestOpts, ['data'])));\n\n  const {status, statusText} = await axios(requestOpts);\n  log.info(`Server response: ${status} ${statusText}`);\n}\n\nasync function uploadFileToFtp (localFileStream, parsedUri, uploadOptions = {}) {\n  const {\n    auth,\n    user,\n    pass,\n  } = uploadOptions;\n  const {\n    hostname,\n    port,\n    protocol,\n    pathname,\n  } = parsedUri;\n\n  const ftpOpts = {\n    host: hostname,\n    port: port || 21,\n  };\n  if ((auth?.user && auth?.pass) || (user && pass)) {\n    ftpOpts.user = auth?.user || user;\n    ftpOpts.pass = auth?.pass || pass;\n  }\n  log.debug(`${protocol} upload options: ${JSON.stringify(ftpOpts)}`);\n  return await new B((resolve, reject) => {\n    new Ftp(ftpOpts).put(localFileStream, pathname, (err) => {\n      if (err) {\n        reject(err);\n      } else {\n        resolve();\n      }\n    });\n  });\n}\n\n/**\n * @typedef {Object} AuthCredentials\n * @property {string} user - Non-empty user name\n * @property {string} pass - Non-empty password\n */\n\n/**\n * @typedef {Object} FtpUploadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual upload performance\n * (e.g. timings and speed)\n * @property {AuthCredentials} auth\n */\n\n/**\n * @typedef {Object} HttpUploadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual upload performance\n * (e.g. timings and speed)\n * @property {string} method [POST] - The HTTP method used for file upload\n * @property {AuthCredentials} auth\n * @property {number} timeout [240000] - The actual request timeout in milliseconds\n * @property {Object} headers - Additional request headers mapping\n * @property {?string} fileFieldName [file] - The name of the form field containing the file\n * content to be uploaded. Any falsy value make the request to use non-multipart upload\n * @property {Array<Pair>|Object} formFields - The additional form fields\n * to be included into the upload request. This property is only considered if\n * `fileFieldName` is set\n */\n\n/**\n * Uploads the given file to a remote location. HTTP(S) and FTP\n * protocols are supported.\n *\n * @param {string} localPath - The path to a file on the local storage.\n * @param {string} remoteUri - The remote URI to upload the file to.\n * @param {?FtpUploadOptions|HttpUploadOptions} uploadOptions\n */\nasync function uploadFile (localPath, remoteUri, uploadOptions = {}) {\n  if (!await fs.exists(localPath)) {\n    throw new Error (`'${localPath}' does not exists or is not accessible`);\n  }\n\n  const {\n    isMetered = true,\n  } = uploadOptions;\n\n  const parsedUri = url.parse(remoteUri);\n  const {size} = await fs.stat(localPath);\n  if (isMetered) {\n    log.info(`Uploading '${localPath}' of ${toReadableSizeString(size)} size to '${remoteUri}'`);\n  }\n  const timer = new Timer().start();\n  if (['http:', 'https:'].includes(parsedUri.protocol)) {\n    if (!uploadOptions.fileFieldName) {\n      uploadOptions.headers = Object.assign({},\n        _.isPlainObject(uploadOptions.headers) ? uploadOptions.headers : {},\n        {'Content-Length': size}\n      );\n    }\n    await uploadFileToHttp(fs.createReadStream(localPath), parsedUri, uploadOptions);\n  } else if (parsedUri.protocol === 'ftp:') {\n    await uploadFileToFtp(fs.createReadStream(localPath), parsedUri, uploadOptions);\n  } else {\n    throw new Error(`Cannot upload the file at '${localPath}' to '${remoteUri}'. ` +\n      `Unsupported remote protocol '${parsedUri.protocol}'. ` +\n      `Only http/https and ftp/ftps protocols are supported.`);\n  }\n  if (isMetered) {\n    log.info(`Uploaded '${localPath}' of ${toReadableSizeString(size)} size in ` +\n      `${timer.getDuration().asSeconds.toFixed(3)}s`);\n  }\n}\n\n/**\n * @typedef {Object} DownloadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual download performance\n * (e.g. timings and speed)\n * @property {AuthCredentials} auth\n * @property {number} timeout [240000] - The actual request timeout in milliseconds\n * @property {Object} headers - Request headers mapping\n */\n\n/**\n * Downloads the given file via HTTP(S)\n *\n * @param {string} remoteUrl - The remote url\n * @param {string} dstPath - The local path to download the file to\n * @param {?DownloadOptions} downloadOptions\n * @throws {Error} If download operation fails\n */\nasync function downloadFile (remoteUrl, dstPath, downloadOptions = {}) {\n  const {\n    isMetered = true,\n    auth,\n    timeout = DEFAULT_TIMEOUT_MS,\n    headers,\n  } = downloadOptions;\n\n  const requestOpts = {\n    url: remoteUrl,\n    responseType: 'stream',\n    timeout,\n  };\n  const axiosAuth = toAxiosAuth(auth);\n  if (axiosAuth) {\n    requestOpts.auth = axiosAuth;\n  }\n  if (_.isPlainObject(headers)) {\n    requestOpts.headers = headers;\n  }\n\n  const timer = new Timer().start();\n  let responseLength;\n  try {\n    const writer = fs.createWriteStream(dstPath);\n    const {\n      data: responseStream,\n      headers: responseHeaders,\n    } = await axios(requestOpts);\n    responseLength = parseInt(responseHeaders['content-length'], 10);\n    responseStream.pipe(writer);\n\n    await new B((resolve, reject) => {\n      responseStream.once('error', reject);\n      writer.once('finish', resolve);\n      writer.once('error', (e) => {\n        responseStream.unpipe(writer);\n        reject(e);\n      });\n    });\n  } catch (err) {\n    throw new Error(`Cannot download the file from ${remoteUrl}: ${err.message}`);\n  }\n\n  const {size} = await fs.stat(dstPath);\n  if (responseLength && size !== responseLength) {\n    await fs.rimraf(dstPath);\n    throw new Error(`The size of the file downloaded from ${remoteUrl} (${size} bytes) ` +\n      `differs from the one in Content-Length response header (${responseLength} bytes)`);\n  }\n  if (isMetered) {\n    const secondsElapsed = timer.getDuration().asSeconds;\n    log.debug(`${remoteUrl} (${toReadableSizeString(size)}) ` +\n      `has been downloaded to '${dstPath}' in ${secondsElapsed.toFixed(3)}s`);\n    if (secondsElapsed >= 2) {\n      const bytesPerSec = Math.floor(size / secondsElapsed);\n      log.debug(`Approximate download speed: ${toReadableSizeString(bytesPerSec)}/s`);\n    }\n  }\n}\n\nexport { uploadFile, downloadFile };\n"],"file":"lib/net.js","sourceRoot":"../.."}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/net.js"],"names":["DEFAULT_TIMEOUT_MS","toAxiosAuth","auth","_","isPlainObject","axiosAuth","username","user","password","pass","uploadFileToHttp","localFileStream","parsedUri","uploadOptions","method","timeout","headers","fileFieldName","formFields","streamLength","href","requestOpts","url","maxContentLength","Infinity","maxBodyLength","Object","assign","form","FormData","append","pairs","isArray","toPairs","key","value","toLower","getHeaders","data","log","debug","JSON","stringify","omit","status","statusText","info","uploadFileToFtp","hostname","port","protocol","pathname","ftpOpts","host","B","resolve","reject","Ftp","put","err","uploadFile","localPath","remoteUri","fs","exists","Error","isMetered","parse","size","stat","timer","Timer","start","includes","createReadStream","getDuration","asSeconds","toFixed","downloadFile","remoteUrl","dstPath","downloadOptions","responseType","responseLength","writer","createWriteStream","responseStream","responseHeaders","parseInt","pipe","once","e","unpipe","message","rimraf","secondsElapsed","bytesPerSec","Math","floor"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport fs from './fs';\nimport url from 'url';\nimport B from 'bluebird';\nimport { toReadableSizeString } from './util';\nimport log from './logger';\nimport Ftp from 'jsftp';\nimport Timer from './timing';\nimport axios from 'axios';\nimport FormData from 'form-data';\n\nconst DEFAULT_TIMEOUT_MS = 4 * 60 * 1000;\n\n\nfunction toAxiosAuth (auth) {\n  if (!_.isPlainObject(auth)) {\n    return null;\n  }\n\n  const axiosAuth = {\n    username: auth.username || auth.user,\n    password: auth.password || auth.pass,\n  };\n  return (axiosAuth.username && axiosAuth.password) ? axiosAuth : null;\n}\n\nasync function uploadFileToHttp (localFileStream, parsedUri, uploadOptions = {}) {\n  const {\n    method = 'POST',\n    timeout = DEFAULT_TIMEOUT_MS,\n    headers,\n    auth,\n    fileFieldName = 'file',\n    formFields,\n    streamLength,\n  } = uploadOptions;\n  const { href } = parsedUri;\n\n  const requestOpts = {\n    url: href,\n    method,\n    timeout,\n    maxContentLength: Infinity,\n    maxBodyLength: Infinity,\n  };\n  const axiosAuth = toAxiosAuth(auth);\n  if (axiosAuth) {\n    requestOpts.auth = axiosAuth;\n  }\n  requestOpts.headers = Object.assign({}, _.isPlainObject(headers) ? headers : {});\n  if (fileFieldName) {\n    const form = new FormData();\n    form.append(fileFieldName, localFileStream);\n    if (formFields) {\n      let pairs = [];\n      if (_.isArray(formFields)) {\n        pairs = formFields;\n      } else if (_.isPlainObject(formFields)) {\n        pairs = _.toPairs(formFields);\n      }\n      for (const [key, value] of pairs) {\n        if (_.toLower(key) !== _.toLower(fileFieldName)) {\n          form.append(key, value);\n        }\n      }\n    }\n    Object.assign(requestOpts.headers, form.getHeaders());\n    requestOpts.data = form;\n  } else {\n    if (streamLength) {\n      Object.assign(requestOpts.headers, {'Content-Length': streamLength});\n    }\n    requestOpts.data = localFileStream;\n  }\n  log.debug(`Performing ${method} to ${href} with options (excluding data): ` +\n    JSON.stringify(_.omit(requestOpts, ['data'])));\n\n  const {status, statusText} = await axios(requestOpts);\n  log.info(`Server response: ${status} ${statusText}`);\n}\n\nasync function uploadFileToFtp (localFileStream, parsedUri, uploadOptions = {}) {\n  const {\n    auth,\n    user,\n    pass,\n  } = uploadOptions;\n  const {\n    hostname,\n    port,\n    protocol,\n    pathname,\n  } = parsedUri;\n\n  const ftpOpts = {\n    host: hostname,\n    port: port || 21,\n  };\n  if ((auth?.user && auth?.pass) || (user && pass)) {\n    ftpOpts.user = auth?.user || user;\n    ftpOpts.pass = auth?.pass || pass;\n  }\n  log.debug(`${protocol} upload options: ${JSON.stringify(ftpOpts)}`);\n  return await new B((resolve, reject) => {\n    new Ftp(ftpOpts).put(localFileStream, pathname, (err) => {\n      if (err) {\n        reject(err);\n      } else {\n        resolve();\n      }\n    });\n  });\n}\n\n/**\n * @typedef {Object} AuthCredentials\n * @property {string} user - Non-empty user name\n * @property {string} pass - Non-empty password\n */\n\n/**\n * @typedef {Object} FtpUploadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual upload performance\n * (e.g. timings and speed)\n * @property {AuthCredentials} auth\n */\n\n/**\n * @typedef {Object} HttpUploadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual upload performance\n * (e.g. timings and speed)\n * @property {string} method [POST] - The HTTP method used for file upload\n * @property {AuthCredentials} auth\n * @property {number} timeout [240000] - The actual request timeout in milliseconds\n * @property {Object} headers - Additional request headers mapping\n * @property {?string} fileFieldName [file] - The name of the form field containing the file\n * content to be uploaded. Any falsy value make the request to use non-multipart upload\n * @property {Array<Pair>|Object} formFields - The additional form fields\n * to be included into the upload request. This property is only considered if\n * `fileFieldName` is set\n */\n\n/**\n * Uploads the given file to a remote location. HTTP(S) and FTP\n * protocols are supported.\n *\n * @param {string} localPath - The path to a file on the local storage.\n * @param {string} remoteUri - The remote URI to upload the file to.\n * @param {?FtpUploadOptions|HttpUploadOptions} uploadOptions\n */\nasync function uploadFile (localPath, remoteUri, uploadOptions = {}) {\n  if (!await fs.exists(localPath)) {\n    throw new Error (`'${localPath}' does not exists or is not accessible`);\n  }\n\n  const {\n    isMetered = true,\n  } = uploadOptions;\n\n  const parsedUri = url.parse(remoteUri);\n  const {size} = await fs.stat(localPath);\n  if (isMetered) {\n    log.info(`Uploading '${localPath}' of ${toReadableSizeString(size)} size to '${remoteUri}'`);\n  }\n  const timer = new Timer().start();\n  if (['http:', 'https:'].includes(parsedUri.protocol)) {\n    await uploadFileToHttp(fs.createReadStream(localPath), parsedUri, {\n      ...uploadOptions,\n      streamLength: size,\n    });\n  } else if (parsedUri.protocol === 'ftp:') {\n    await uploadFileToFtp(fs.createReadStream(localPath), parsedUri, uploadOptions);\n  } else {\n    throw new Error(`Cannot upload the file at '${localPath}' to '${remoteUri}'. ` +\n      `Unsupported remote protocol '${parsedUri.protocol}'. ` +\n      `Only http/https and ftp protocols are supported.`);\n  }\n  if (isMetered) {\n    log.info(`Uploaded '${localPath}' of ${toReadableSizeString(size)} in ` +\n      `${timer.getDuration().asSeconds.toFixed(3)}s`);\n  }\n}\n\n/**\n * @typedef {Object} DownloadOptions\n * @property {boolean} isMetered [true] - Whether to log the actual download performance\n * (e.g. timings and speed)\n * @property {AuthCredentials} auth\n * @property {number} timeout [240000] - The actual request timeout in milliseconds\n * @property {Object} headers - Request headers mapping\n */\n\n/**\n * Downloads the given file via HTTP(S)\n *\n * @param {string} remoteUrl - The remote url\n * @param {string} dstPath - The local path to download the file to\n * @param {?DownloadOptions} downloadOptions\n * @throws {Error} If download operation fails\n */\nasync function downloadFile (remoteUrl, dstPath, downloadOptions = {}) {\n  const {\n    isMetered = true,\n    auth,\n    timeout = DEFAULT_TIMEOUT_MS,\n    headers,\n  } = downloadOptions;\n\n  const requestOpts = {\n    url: remoteUrl,\n    responseType: 'stream',\n    timeout,\n  };\n  const axiosAuth = toAxiosAuth(auth);\n  if (axiosAuth) {\n    requestOpts.auth = axiosAuth;\n  }\n  if (_.isPlainObject(headers)) {\n    requestOpts.headers = headers;\n  }\n\n  const timer = new Timer().start();\n  let responseLength;\n  try {\n    const writer = fs.createWriteStream(dstPath);\n    const {\n      data: responseStream,\n      headers: responseHeaders,\n    } = await axios(requestOpts);\n    responseLength = parseInt(responseHeaders['content-length'], 10);\n    responseStream.pipe(writer);\n\n    await new B((resolve, reject) => {\n      responseStream.once('error', reject);\n      writer.once('finish', resolve);\n      writer.once('error', (e) => {\n        responseStream.unpipe(writer);\n        reject(e);\n      });\n    });\n  } catch (err) {\n    throw new Error(`Cannot download the file from ${remoteUrl}: ${err.message}`);\n  }\n\n  const {size} = await fs.stat(dstPath);\n  if (responseLength && size !== responseLength) {\n    await fs.rimraf(dstPath);\n    throw new Error(`The size of the file downloaded from ${remoteUrl} (${size} bytes) ` +\n      `differs from the one in Content-Length response header (${responseLength} bytes)`);\n  }\n  if (isMetered) {\n    const secondsElapsed = timer.getDuration().asSeconds;\n    log.debug(`${remoteUrl} (${toReadableSizeString(size)}) ` +\n      `has been downloaded to '${dstPath}' in ${secondsElapsed.toFixed(3)}s`);\n    if (secondsElapsed >= 2) {\n      const bytesPerSec = Math.floor(size / secondsElapsed);\n      log.debug(`Approximate download speed: ${toReadableSizeString(bytesPerSec)}/s`);\n    }\n  }\n}\n\nexport { uploadFile, downloadFile };\n"],"file":"lib/net.js","sourceRoot":"../.."}

@@ -35,2 +35,3 @@ import _ from 'lodash';

formFields,
streamLength,
} = uploadOptions;

@@ -50,2 +51,3 @@ const { href } = parsedUri;

}
requestOpts.headers = Object.assign({}, _.isPlainObject(headers) ? headers : {});
if (fileFieldName) {

@@ -67,8 +69,7 @@ const form = new FormData();

}
requestOpts.headers = Object.assign({}, _.isPlainObject(headers) ? headers : {},
form.getHeaders());
Object.assign(requestOpts.headers, form.getHeaders());
requestOpts.data = form;
} else {
if (_.isPlainObject(headers)) {
requestOpts.headers = headers;
if (streamLength) {
Object.assign(requestOpts.headers, {'Content-Length': streamLength});
}

@@ -169,9 +170,6 @@ requestOpts.data = localFileStream;

if (['http:', 'https:'].includes(parsedUri.protocol)) {
if (!uploadOptions.fileFieldName) {
uploadOptions.headers = Object.assign({},
_.isPlainObject(uploadOptions.headers) ? uploadOptions.headers : {},
{'Content-Length': size}
);
}
await uploadFileToHttp(fs.createReadStream(localPath), parsedUri, uploadOptions);
await uploadFileToHttp(fs.createReadStream(localPath), parsedUri, {
...uploadOptions,
streamLength: size,
});
} else if (parsedUri.protocol === 'ftp:') {

@@ -182,6 +180,6 @@ await uploadFileToFtp(fs.createReadStream(localPath), parsedUri, uploadOptions);

`Unsupported remote protocol '${parsedUri.protocol}'. ` +
`Only http/https and ftp/ftps protocols are supported.`);
`Only http/https and ftp protocols are supported.`);
}
if (isMetered) {
log.info(`Uploaded '${localPath}' of ${toReadableSizeString(size)} size in ` +
log.info(`Uploaded '${localPath}' of ${toReadableSizeString(size)} in ` +
`${timer.getDuration().asSeconds.toFixed(3)}s`);

@@ -188,0 +186,0 @@ }

@@ -7,3 +7,3 @@ {

],
"version": "2.54.3",
"version": "2.54.4",
"author": "appium",

@@ -52,3 +52,3 @@ "license": "Apache-2.0",

"ncp": "^2.0.0",
"npmlog": "^5.0.0",
"npmlog": "^6.0.0",
"plist": "^3.0.1",

@@ -95,4 +95,4 @@ "pluralize": "^8.0.0",

"pre-commit": "^1.1.3",
"sinon": "^11.0.0"
"sinon": "^12.0.0"
}
}
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