diff --git a/.github/workflows/api-test-lint-deploy.yaml b/.github/workflows/api-test-lint-deploy.yaml index 6c03ab5cc4d..9b4e8068ec8 100644 --- a/.github/workflows/api-test-lint-deploy.yaml +++ b/.github/workflows/api-test-lint-deploy.yaml @@ -56,7 +56,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' @@ -95,7 +95,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: ${{ matrix.python }} @@ -145,7 +145,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/.github/workflows/app-test-build-deploy.yaml b/.github/workflows/app-test-build-deploy.yaml index dc93eae9c9a..2c0dc55b765 100644 --- a/.github/workflows/app-test-build-deploy.yaml +++ b/.github/workflows/app-test-build-deploy.yaml @@ -61,7 +61,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'set complex environment variables' @@ -110,7 +110,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: actions/setup-python@v4 with: python-version: '3.10' @@ -243,7 +243,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: actions/setup-python@v4 with: python-version: '3.10' @@ -427,7 +427,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'set complex environment variables' diff --git a/.github/workflows/components-test-build-deploy.yaml b/.github/workflows/components-test-build-deploy.yaml index 4ba58f65188..0ad3389fb03 100644 --- a/.github/workflows/components-test-build-deploy.yaml +++ b/.github/workflows/components-test-build-deploy.yaml @@ -44,7 +44,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -78,7 +78,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -104,29 +104,30 @@ jobs: path: storybook-static determine-build-type: - runs-on: 'ubuntu-latest' - name: 'Determine build type' - outputs: - type: ${{steps.determine-build-type.outputs.type}} - steps: - - id: determine-build-type - run: | - echo "Determining build type for event ${{github.event_type}} and ref ${{github.ref}}" - if [ "${{ format('{0}', github.ref == 'refs/heads/edge') }}" = "true" ] ; then - echo "storybook s3 builds for edge" - echo 'type=storybook' >> $GITHUB_OUTPUT - elif [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/components')) }}" = "true" ] ; then - echo "publish builds for components tags" - echo 'type=publish' >> $GITHUB_OUTPUT - else - echo "No build for ref ${{github.ref}} and event ${{github.event_type}}" - echo 'type=none' >> $GITHUB_OUTPUT - fi + runs-on: 'ubuntu-latest' + name: 'Determine build type' + outputs: + type: ${{steps.determine-build-type.outputs.type}} + steps: + - id: determine-build-type + run: | + echo "Determining build type for event ${{github.event_type}} and ref ${{github.ref}}" + if [ "${{ format('{0}', github.ref == 'refs/heads/edge') }}" = "true" ] ; then + echo "storybook s3 builds for edge" + echo 'type=storybook' >> $GITHUB_OUTPUT + elif [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/components')) }}" = "true" ] ; then + echo "publish builds for components tags" + echo 'type=publish' >> $GITHUB_OUTPUT + else + echo "No build for ref ${{github.ref}} and event ${{github.event_type}}" + echo 'type=none' >> $GITHUB_OUTPUT + fi deploy-components: name: 'deploy components storybook artifact to S3' runs-on: 'ubuntu-22.04' - needs: ['js-unit-test', 'build-components-storybook', 'determine-build-type'] + needs: + ['js-unit-test', 'build-components-storybook', 'determine-build-type'] if: needs.determine-build-type.outputs.type != 'none' steps: - uses: 'actions/checkout@v3' @@ -138,7 +139,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'set complex environment variables' id: 'set-vars' uses: actions/github-script@v6 @@ -174,7 +175,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' registry-url: 'https://registry.npmjs.org' - name: 'cache yarn cache' uses: actions/cache@v3 @@ -205,10 +206,10 @@ jobs: json -I -f ./components/package.json -e "this.dependencies['@opentrons/shared-data']=\"$VERSION_STRING\"" - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' registry-url: 'https://registry.npmjs.org' - name: 'publish to npm registry' - env: + env: NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} run: | cd ./components && echo "//registry.npmjs.org/:_authToken=${NODE_AUTH_TOKEN}" > ./.npmrc && npm publish --access public diff --git a/.github/workflows/docs-build.yaml b/.github/workflows/docs-build.yaml index 0eea5d6eb7d..08b1c2b76cf 100644 --- a/.github/workflows/docs-build.yaml +++ b/.github/workflows/docs-build.yaml @@ -51,7 +51,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v3' with: python-version: '3.10' diff --git a/.github/workflows/g-code-testing-lint-test.yaml b/.github/workflows/g-code-testing-lint-test.yaml index 6c1c231ff61..89fe00f4d2d 100644 --- a/.github/workflows/g-code-testing-lint-test.yaml +++ b/.github/workflows/g-code-testing-lint-test.yaml @@ -49,7 +49,7 @@ jobs: run: sudo apt-get update && sudo apt-get install libudev-dev - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'set complex environment variables' id: 'set-vars' uses: actions/github-script@v6 diff --git a/.github/workflows/http-docs-build.yaml b/.github/workflows/http-docs-build.yaml index c9ed4eeb250..6294eeb2172 100644 --- a/.github/workflows/http-docs-build.yaml +++ b/.github/workflows/http-docs-build.yaml @@ -54,7 +54,7 @@ jobs: python-version: '3.10' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: './.github/actions/python/setup' with: project: 'robot-server' diff --git a/.github/workflows/js-check.yaml b/.github/workflows/js-check.yaml index 53bcaa05781..57532b99ce2 100644 --- a/.github/workflows/js-check.yaml +++ b/.github/workflows/js-check.yaml @@ -45,7 +45,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'set complex environment variables' id: 'set-vars' uses: actions/github-script@v6 diff --git a/.github/workflows/ll-test-build-deploy.yaml b/.github/workflows/ll-test-build-deploy.yaml index 6516edbdcb0..e88d7ada743 100644 --- a/.github/workflows/ll-test-build-deploy.yaml +++ b/.github/workflows/ll-test-build-deploy.yaml @@ -47,7 +47,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' # https://github.com/actions/checkout/issues/290 - name: 'Fix actions/checkout odd handling of tags' if: startsWith(github.ref, 'refs/tags') @@ -93,7 +93,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install libudev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -133,7 +133,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install libudev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -176,7 +176,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'set complex environment variables' diff --git a/.github/workflows/pd-test-build-deploy.yaml b/.github/workflows/pd-test-build-deploy.yaml index 566496257b9..c1e6eb832f4 100644 --- a/.github/workflows/pd-test-build-deploy.yaml +++ b/.github/workflows/pd-test-build-deploy.yaml @@ -53,7 +53,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -98,7 +98,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' if: startsWith(matrix.os, 'ubuntu') run: sudo apt-get update && sudo apt-get install libudev-dev @@ -135,7 +135,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -178,7 +178,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'set complex environment variables' diff --git a/.github/workflows/react-api-client-test.yaml b/.github/workflows/react-api-client-test.yaml index d3fc398e7a0..af8e4015497 100644 --- a/.github/workflows/react-api-client-test.yaml +++ b/.github/workflows/react-api-client-test.yaml @@ -39,7 +39,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install libudev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' diff --git a/.github/workflows/robot-server-lint-test.yaml b/.github/workflows/robot-server-lint-test.yaml index b82d769ffc6..96d1969121b 100644 --- a/.github/workflows/robot-server-lint-test.yaml +++ b/.github/workflows/robot-server-lint-test.yaml @@ -61,7 +61,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/.github/workflows/server-utils-lint-test.yaml b/.github/workflows/server-utils-lint-test.yaml index c573ab01d19..240d9e0bd25 100644 --- a/.github/workflows/server-utils-lint-test.yaml +++ b/.github/workflows/server-utils-lint-test.yaml @@ -46,7 +46,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' @@ -67,7 +67,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/.github/workflows/shared-data-test-lint-deploy.yaml b/.github/workflows/shared-data-test-lint-deploy.yaml index 9ae38097949..97228ea2d70 100644 --- a/.github/workflows/shared-data-test-lint-deploy.yaml +++ b/.github/workflows/shared-data-test-lint-deploy.yaml @@ -51,7 +51,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v3' with: python-version: '3.10' @@ -83,7 +83,7 @@ jobs: run: sudo apt-get update && sudo apt-get install libudev-dev - uses: 'actions/setup-node@v1' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: ${{ matrix.python }} @@ -115,7 +115,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' @@ -157,7 +157,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - uses: 'actions/setup-python@v4' @@ -189,24 +189,24 @@ jobs: password: '${{ secrets.OT_PYPI_PASSWORD }}' publish-switch: - runs-on: 'ubuntu-latest' - name: 'Determine whether or not to publish artifacts' - outputs: - should_publish: ${{steps.publish-switch.outputs.should_publish}} - steps: - - id: publish-switch - run: | - echo "Determining whether to publish artifacts for event ${{github.event_type}} and ref ${{github.ref}}" - if [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/shared-data')) }}" = "true" ] ; then - echo "Publishing builds for shared-data@ tags" - echo 'should_publish=true' >> $GITHUB_OUTPUT - elif [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/components')) }}" = "true" ] ; then - echo "Publishing builds for components@ tags" - echo 'should_publish=true' >> $GITHUB_OUTPUT - else - echo "No publish for ref ${{github.ref}} and event ${{github.event_type}}" - echo 'should_publish=false' >> $GITHUB_OUTPUT - fi + runs-on: 'ubuntu-latest' + name: 'Determine whether or not to publish artifacts' + outputs: + should_publish: ${{steps.publish-switch.outputs.should_publish}} + steps: + - id: publish-switch + run: | + echo "Determining whether to publish artifacts for event ${{github.event_type}} and ref ${{github.ref}}" + if [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/shared-data')) }}" = "true" ] ; then + echo "Publishing builds for shared-data@ tags" + echo 'should_publish=true' >> $GITHUB_OUTPUT + elif [ "${{ format('{0}', startsWith(github.ref, 'refs/tags/components')) }}" = "true" ] ; then + echo "Publishing builds for components@ tags" + echo 'should_publish=true' >> $GITHUB_OUTPUT + else + echo "No publish for ref ${{github.ref}} and event ${{github.event_type}}" + echo 'should_publish=false' >> $GITHUB_OUTPUT + fi publish-to-npm: name: 'publish shared-data package to npm' @@ -223,7 +223,7 @@ jobs: git checkout ${{ github.ref }} - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' registry-url: 'https://registry.npmjs.org' - name: 'cache yarn cache' uses: actions/cache@v3 @@ -254,11 +254,10 @@ jobs: cd ./shared-data - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' registry-url: 'https://registry.npmjs.org' - name: 'publish to npm registry' - env: + env: NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} run: | cd ./shared-data && echo "//registry.npmjs.org/:_authToken=${NODE_AUTH_TOKEN}" > ./.npmrc && npm publish --access public - diff --git a/.github/workflows/step-generation-test.yaml b/.github/workflows/step-generation-test.yaml index 6836e50dd02..d61fbcbcfdc 100644 --- a/.github/workflows/step-generation-test.yaml +++ b/.github/workflows/step-generation-test.yaml @@ -40,7 +40,7 @@ jobs: - uses: 'actions/checkout@v3' - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'install udev for usb-detection' run: sudo apt-get update && sudo apt-get install libudev-dev - name: 'cache yarn cache' diff --git a/.github/workflows/system-server-lint-test.yaml b/.github/workflows/system-server-lint-test.yaml index d8a9378e3ad..720ca905bd7 100644 --- a/.github/workflows/system-server-lint-test.yaml +++ b/.github/workflows/system-server-lint-test.yaml @@ -48,7 +48,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' @@ -69,7 +69,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/.github/workflows/tag-releases.yaml b/.github/workflows/tag-releases.yaml index 120c1c462df..d867d3bf8ca 100644 --- a/.github/workflows/tag-releases.yaml +++ b/.github/workflows/tag-releases.yaml @@ -24,7 +24,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - name: 'cache yarn cache' uses: actions/cache@v3 with: diff --git a/.github/workflows/update-server-lint-test.yaml b/.github/workflows/update-server-lint-test.yaml index bb6d616682c..b4d1435838f 100644 --- a/.github/workflows/update-server-lint-test.yaml +++ b/.github/workflows/update-server-lint-test.yaml @@ -46,7 +46,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' @@ -67,7 +67,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/.github/workflows/usb-bridge-lint-test.yaml b/.github/workflows/usb-bridge-lint-test.yaml index 13bd040e81a..2888291871a 100644 --- a/.github/workflows/usb-bridge-lint-test.yaml +++ b/.github/workflows/usb-bridge-lint-test.yaml @@ -46,7 +46,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' @@ -67,7 +67,7 @@ jobs: fetch-depth: 0 - uses: 'actions/setup-node@v3' with: - node-version: '16' + node-version: '18.19.0' - uses: 'actions/setup-python@v4' with: python-version: '3.10' diff --git a/app-shell-odd/Makefile b/app-shell-odd/Makefile index 629a6b63478..60438b05529 100644 --- a/app-shell-odd/Makefile +++ b/app-shell-odd/Makefile @@ -24,7 +24,7 @@ ssh_opts ?= $(default_ssh_opts) builder := yarn electron-builder \ --config electron-builder.config.js \ --publish never - + electron := yarn electron . \ --devtools \ --log.level.console="debug" \ @@ -56,7 +56,7 @@ clean: .PHONY: lib lib: export NODE_ENV := production lib: - OPENTRONS_PROJECT=$(OPENTRONS_PROJECT) webpack --profile + OPENTRONS_PROJECT=$(OPENTRONS_PROJECT) NODE_OPTIONS=--openssl-legacy-provider webpack --profile .PHONY: deps deps: @@ -83,7 +83,7 @@ push-ot3: dist-ot3 .PHONY: dev dev: export NODE_ENV := development dev: - webpack + NODE_OPTIONS=--openssl-legacy-provider webpack $(electron) .PHONY: test diff --git a/app-shell-odd/electron-builder.config.js b/app-shell-odd/electron-builder.config.js index 491e9ddcba7..8613efeb97d 100644 --- a/app-shell-odd/electron-builder.config.js +++ b/app-shell-odd/electron-builder.config.js @@ -2,7 +2,7 @@ module.exports = { appId: 'com.opentrons.odd', - electronVersion: '21.3.1', + electronVersion: '23.3.13', npmRebuild: false, files: [ '**/*', diff --git a/app-shell-odd/src/main.ts b/app-shell-odd/src/main.ts index b05ba1cc6b5..e456652b24c 100644 --- a/app-shell-odd/src/main.ts +++ b/app-shell-odd/src/main.ts @@ -1,5 +1,6 @@ // electron main entry point import { app, ipcMain } from 'electron' +import dns from 'dns' import fse from 'fs-extra' import path from 'path' import { createUi } from './ui' @@ -27,6 +28,15 @@ import { registerNotify, closeAllNotifyConnections } from './notify' import type { BrowserWindow } from 'electron' import type { Dispatch, Logger } from './types' +/** + * node 17 introduced a change to default IP resolving to prefer IPv6 which causes localhost requests to fail + * setting the default to IPv4 fixes the issue + * https://github.com/node-fetch/node-fetch/issues/1624 + */ +// TODO(bh, 2024-1-30): @types/node needs to be updated to address this type error. updating @types/node will also require updating our typescript version +// @ts-expect-error +dns.setDefaultResultOrder('ipv4first') + systemd.sendStatus('starting app') const config = getConfig() const log = createLogger('main') diff --git a/app-shell-odd/src/ui.ts b/app-shell-odd/src/ui.ts index ec5f3e1ae0a..fdae0e8a54d 100644 --- a/app-shell-odd/src/ui.ts +++ b/app-shell-odd/src/ui.ts @@ -59,11 +59,13 @@ export function createUi(dispatch: Dispatch): BrowserWindow { mainWindow.loadURL(url, { extraHeaders: 'pragma: no-cache\n' }) // open new windows ( { - log.debug('Opening external link', { url }) - event.preventDefault() - // eslint-disable-next-line @typescript-eslint/no-floating-promises - shell.openExternal(url) + mainWindow.webContents.setWindowOpenHandler(({ url, disposition }) => { + if (disposition === 'new-window' && url === 'about:blank') { + shell.openExternal(url) + return { action: 'deny' } + } else { + return { action: 'allow' } + } }) return mainWindow diff --git a/app-shell/Makefile b/app-shell/Makefile index afde0f518d3..6082ed2bf75 100644 --- a/app-shell/Makefile +++ b/app-shell/Makefile @@ -59,7 +59,7 @@ no_python_bundle ?= builder := yarn electron-builder \ --config electron-builder.config.js \ - --config.electronVersion=21.3.1 \ + --config.electronVersion=23.3.13 \ --publish never @@ -97,7 +97,7 @@ clean: .PHONY: lib lib: export NODE_ENV := production lib: - webpack --profile + NODE_OPTIONS=--openssl-legacy-provider webpack --profile .PHONY: deps deps: @@ -182,7 +182,7 @@ dev-app-update.yml: dev: export NODE_ENV := development dev: export OPENTRONS_PROJECT := $(OPENTRONS_PROJECT) dev: clean-dev-autoupdate ./dev-app-update.yml - webpack + NODE_OPTIONS=--openssl-legacy-provider webpack $(electron) .PHONY: test diff --git a/app-shell/electron-builder.config.js b/app-shell/electron-builder.config.js index 4d265ac5e3c..a48e3a8b6b2 100644 --- a/app-shell/electron-builder.config.js +++ b/app-shell/electron-builder.config.js @@ -25,7 +25,7 @@ const publishConfig = module.exports = async () => ({ appId: project === 'robot-stack' ? 'com.opentrons.app' : 'com.opentrons.appot3', - electronVersion: '21.3.1', + electronVersion: '23.3.13', npmRebuild: false, releaseInfo: { releaseNotesFile: diff --git a/app-shell/package.json b/app-shell/package.json index b2f2cb10f3e..fff04109769 100644 --- a/app-shell/package.json +++ b/app-shell/package.json @@ -45,7 +45,7 @@ "@types/uuid": "^3.4.7", "ajv": "6.12.3", "dateformat": "3.0.3", - "electron-context-menu": "^3.5.0", + "electron-context-menu": "3.6.1", "electron-debug": "3.0.1", "electron-devtools-installer": "3.2.0", "electron-store": "5.1.1", @@ -62,11 +62,9 @@ "semver": "5.5.0", "serialport": "10.5.0", "tempy": "1.0.1", + "usb": "^2.11.0", "uuid": "3.2.1", "winston": "3.1.0", "yargs-parser": "13.1.2" - }, - "optionalDependencies": { - "usb-detection": "4.14.1" } } diff --git a/app-shell/src/main.ts b/app-shell/src/main.ts index 6f6449801f3..b90fcf6b5c7 100644 --- a/app-shell/src/main.ts +++ b/app-shell/src/main.ts @@ -1,6 +1,8 @@ // electron main entry point import { app, ipcMain } from 'electron' +import dns from 'dns' import contextMenu from 'electron-context-menu' +import { webusb } from 'usb' import { createUi, registerReloadUi } from './ui' import { initializeMenu } from './menu' @@ -14,11 +16,21 @@ import { registerSystemInfo } from './system-info' import { registerProtocolStorage } from './protocol-storage' import { getConfig, getStore, getOverrides, registerConfig } from './config' import { registerUsb } from './usb' +import { createUsbDeviceMonitor } from './system-info/usb-devices' import { registerNotify, closeAllNotifyConnections } from './notify' import type { BrowserWindow } from 'electron' import type { Dispatch, Logger } from './types' +/** + * node 17 introduced a change to default IP resolving to prefer IPv6 which causes localhost requests to fail + * setting the default to IPv4 fixes the issue + * https://github.com/node-fetch/node-fetch/issues/1624 + */ +// TODO(bh, 2024-1-30): @types/node needs to be updated to address this type error. updating @types/node will also require updating our typescript version +// @ts-expect-error +dns.setDefaultResultOrder('ipv4first') + const config = getConfig() const log = createLogger('main') @@ -45,6 +57,9 @@ if (config.devtools) app.once('ready', installDevtools) app.once('window-all-closed', () => { log.debug('all windows closed, quitting the app') + webusb.removeEventListener('connect', () => createUsbDeviceMonitor()) + webusb.removeEventListener('disconnect', () => createUsbDeviceMonitor()) + app.quit() closeAllNotifyConnections() .then(() => { app.quit() @@ -62,6 +77,8 @@ function startUp(): void { log.error('Uncaught Promise rejection: ', { reason }) ) + webusb.addEventListener('connect', () => createUsbDeviceMonitor()) + webusb.addEventListener('disconnect', () => createUsbDeviceMonitor()) mainWindow = createUi() rendererLogger = createRendererLogger() diff --git a/app-shell/src/system-info/__tests__/dispatch.test.ts b/app-shell/src/system-info/__tests__/dispatch.test.ts index 00a057900b5..5376367cfc6 100644 --- a/app-shell/src/system-info/__tests__/dispatch.test.ts +++ b/app-shell/src/system-info/__tests__/dispatch.test.ts @@ -4,8 +4,11 @@ import * as Fixtures from '@opentrons/app/src/redux/system-info/__fixtures__' import * as SystemInfo from '@opentrons/app/src/redux/system-info' import { uiInitialized } from '@opentrons/app/src/redux/shell/actions' import * as OS from '../../os' -import * as UsbDevices from '../usb-devices' -import * as NetworkInterfaces from '../network-interfaces' +import { createUsbDeviceMonitor, getWindowsDriverVersion } from '../usb-devices' +import { + getActiveInterfaces, + createNetworkInterfaceMonitor, +} from '../network-interfaces' import { registerSystemInfo } from '..' import type { Dispatch } from '../../types' @@ -16,20 +19,20 @@ jest.mock('../../os') jest.mock('../usb-devices') jest.mock('../network-interfaces') -const createUsbDeviceMonitor = UsbDevices.createUsbDeviceMonitor as jest.MockedFunction< - typeof UsbDevices.createUsbDeviceMonitor +const mockCreateUsbDeviceMonitor = createUsbDeviceMonitor as jest.MockedFunction< + typeof createUsbDeviceMonitor > -const getWindowsDriverVersion = UsbDevices.getWindowsDriverVersion as jest.MockedFunction< - typeof UsbDevices.getWindowsDriverVersion +const mockGetWindowsDriverVersion = getWindowsDriverVersion as jest.MockedFunction< + typeof getWindowsDriverVersion > -const getActiveInterfaces = NetworkInterfaces.getActiveInterfaces as jest.MockedFunction< - typeof NetworkInterfaces.getActiveInterfaces +const mockGetActiveInterfaces = getActiveInterfaces as jest.MockedFunction< + typeof getActiveInterfaces > -const createNetworkInterfaceMonitor = NetworkInterfaces.createNetworkInterfaceMonitor as jest.MockedFunction< - typeof NetworkInterfaces.createNetworkInterfaceMonitor +const mockCreateNetworkInterfaceMonitor = createNetworkInterfaceMonitor as jest.MockedFunction< + typeof createNetworkInterfaceMonitor > const isWindows = OS.isWindows as jest.MockedFunction @@ -45,17 +48,17 @@ describe('app-shell::system-info module action tests', () => { const usbMonitor: UsbDeviceMonitor = { getAllDevices, stop: jest.fn() } const ifaceMonitor: NetworkInterfaceMonitor = { stop: jest.fn() } const { windowsDriverVersion: _, ...notRealtek } = Fixtures.mockUsbDevice - const realtek0 = { ...notRealtek, manufacturer: 'Realtek' } - const realtek1 = { ...notRealtek, manufacturer: 'realtek' } + const realtek0 = { ...notRealtek, manufacturerName: 'Realtek' } + const realtek1 = { ...notRealtek, manufacturerName: 'realtek' } let handler: Dispatch beforeEach(() => { handler = registerSystemInfo(dispatch) isWindows.mockReturnValue(false) - createUsbDeviceMonitor.mockReturnValue(usbMonitor) - createNetworkInterfaceMonitor.mockReturnValue(ifaceMonitor) + mockCreateUsbDeviceMonitor.mockReturnValue(usbMonitor) + mockCreateNetworkInterfaceMonitor.mockReturnValue(ifaceMonitor) getAllDevices.mockResolvedValue([realtek0]) - getActiveInterfaces.mockReturnValue([ + mockGetActiveInterfaces.mockReturnValue([ Fixtures.mockNetworkInterface, Fixtures.mockNetworkInterfaceV6, ]) @@ -75,7 +78,7 @@ describe('app-shell::system-info module action tests', () => { [Fixtures.mockNetworkInterface, Fixtures.mockNetworkInterfaceV6] ) ) - expect(getWindowsDriverVersion).toHaveBeenCalledTimes(0) + expect(mockGetWindowsDriverVersion).toHaveBeenCalledTimes(0) }) }) @@ -85,14 +88,14 @@ describe('app-shell::system-info module action tests', () => { return flush().then(() => { expect(createUsbDeviceMonitor).toHaveBeenCalledTimes(1) - expect(createNetworkInterfaceMonitor).toHaveBeenCalledTimes(1) + expect(mockCreateNetworkInterfaceMonitor).toHaveBeenCalledTimes(1) expect(dispatch).toHaveBeenCalledTimes(2) }) }) it('sends systemInfo:USB_DEVICE_ADDED when device added', () => { handler(uiInitialized()) - const usbMonitorOptions = createUsbDeviceMonitor.mock.calls[0][0] + const usbMonitorOptions = mockCreateUsbDeviceMonitor.mock.calls[0][0] expect(usbMonitorOptions?.onDeviceAdd).toEqual(expect.any(Function)) const onDeviceAdd = usbMonitorOptions?.onDeviceAdd ?? noop @@ -106,7 +109,7 @@ describe('app-shell::system-info module action tests', () => { it('sends systemInfo:USB_DEVICE_REMOVED when device removed', () => { handler(uiInitialized()) - const usbMonitorOptions = createUsbDeviceMonitor.mock.calls[0][0] + const usbMonitorOptions = mockCreateUsbDeviceMonitor.mock.calls[0][0] expect(usbMonitorOptions?.onDeviceRemove).toEqual(expect.any(Function)) const onDeviceRemove = usbMonitorOptions?.onDeviceRemove ?? noop @@ -121,7 +124,7 @@ describe('app-shell::system-info module action tests', () => { it('sends systemInfo:NETWORK_INTERFACES_CHANGED when ifaces change', () => { handler(uiInitialized()) - const ifaceMonitorOpts = createNetworkInterfaceMonitor.mock.calls[0][0] + const ifaceMonitorOpts = mockCreateNetworkInterfaceMonitor.mock.calls[0][0] expect(ifaceMonitorOpts.onInterfaceChange).toEqual(expect.any(Function)) const { onInterfaceChange } = ifaceMonitorOpts @@ -158,7 +161,7 @@ describe('app-shell::system-info module action tests', () => { describe('on windows', () => { beforeEach(() => { isWindows.mockReturnValue(true) - getWindowsDriverVersion.mockResolvedValue('1.2.3') + mockGetWindowsDriverVersion.mockResolvedValue('1.2.3') }) it('should add Windows driver versions to Realtek devices on initialization', () => { @@ -166,8 +169,8 @@ describe('app-shell::system-info module action tests', () => { handler(uiInitialized()) return flush().then(() => { - expect(getWindowsDriverVersion).toHaveBeenCalledWith(realtek0) - expect(getWindowsDriverVersion).toHaveBeenCalledWith(realtek1) + expect(mockGetWindowsDriverVersion).toHaveBeenCalledWith(realtek0) + expect(mockGetWindowsDriverVersion).toHaveBeenCalledWith(realtek1) expect(dispatch).toHaveBeenCalledWith( SystemInfo.initialized( @@ -185,12 +188,12 @@ describe('app-shell::system-info module action tests', () => { it('should add Windows driver versions to Realtek devices on add', () => { getAllDevices.mockResolvedValue([]) handler(uiInitialized()) - const usbMonitorOptions = createUsbDeviceMonitor.mock.calls[0][0] + const usbMonitorOptions = mockCreateUsbDeviceMonitor.mock.calls[0][0] const onDeviceAdd = usbMonitorOptions?.onDeviceAdd ?? noop onDeviceAdd(realtek0) return flush().then(() => { - expect(getWindowsDriverVersion).toHaveBeenCalledWith(realtek0) + expect(mockGetWindowsDriverVersion).toHaveBeenCalledWith(realtek0) expect(dispatch).toHaveBeenCalledWith( SystemInfo.usbDeviceAdded({ diff --git a/app-shell/src/system-info/__tests__/usb-devices.test.ts b/app-shell/src/system-info/__tests__/usb-devices.test.ts index 1c84dda857d..4f2a7dc8fba 100644 --- a/app-shell/src/system-info/__tests__/usb-devices.test.ts +++ b/app-shell/src/system-info/__tests__/usb-devices.test.ts @@ -1,14 +1,14 @@ import execa from 'execa' -import usbDetection from 'usb-detection' +import { webusb } from 'usb' import * as Fixtures from '@opentrons/app/src/redux/system-info/__fixtures__' import { createUsbDeviceMonitor, getWindowsDriverVersion } from '../usb-devices' jest.mock('execa') -jest.mock('usb-detection') +jest.mock('usb') -const usbDetectionFind = usbDetection.find as jest.MockedFunction< - typeof usbDetection.find +const usbGetDeviceList = webusb.getDevices as jest.MockedFunction< + typeof webusb.getDevices > const execaCommand = execa.command as jest.MockedFunction @@ -19,26 +19,14 @@ describe('app-shell::system-info::usb-devices', () => { jest.resetAllMocks() }) - it('can create a usb device monitor', () => { - expect(usbDetection.startMonitoring).toHaveBeenCalledTimes(0) - createUsbDeviceMonitor() - expect(usbDetection.startMonitoring).toHaveBeenCalledTimes(1) - }) - - it('usb device monitor can be stopped', () => { - const monitor = createUsbDeviceMonitor() - monitor.stop() - expect(usbDetection.stopMonitoring).toHaveBeenCalledTimes(1) - }) - it('can return the list of all devices', async () => { const mockDevices = [ { ...mockDevice, deviceName: 'foo' }, { ...mockDevice, deviceName: 'bar' }, { ...mockDevice, deviceName: 'baz' }, - ] + ] as any - usbDetectionFind.mockResolvedValueOnce(mockDevices) + usbGetDeviceList.mockResolvedValueOnce(mockDevices) const monitor = createUsbDeviceMonitor() const result = monitor.getAllDevices() @@ -49,8 +37,8 @@ describe('app-shell::system-info::usb-devices', () => { it('can notify when devices are added', () => { const onDeviceAdd = jest.fn() createUsbDeviceMonitor({ onDeviceAdd }) - - usbDetection.emit('add', mockDevice) + webusb.removeEventListener('connect', onDeviceAdd(mockDevice)) + webusb.addEventListener('connect', onDeviceAdd(mockDevice)) expect(onDeviceAdd).toHaveBeenCalledWith(mockDevice) }) @@ -58,8 +46,8 @@ describe('app-shell::system-info::usb-devices', () => { it('can notify when devices are removed', () => { const onDeviceRemove = jest.fn() createUsbDeviceMonitor({ onDeviceRemove }) - - usbDetection.emit('remove', mockDevice) + webusb.removeEventListener('disconnect', onDeviceRemove(mockDevice)) + webusb.addEventListener('disconnect', onDeviceRemove(mockDevice)) expect(onDeviceRemove).toHaveBeenCalledWith(mockDevice) }) diff --git a/app-shell/src/system-info/index.ts b/app-shell/src/system-info/index.ts index f42cf474f81..73fff4de6cb 100644 --- a/app-shell/src/system-info/index.ts +++ b/app-shell/src/system-info/index.ts @@ -12,7 +12,7 @@ import { import type { UsbDevice } from '@opentrons/app/src/redux/system-info/types' import type { Action, Dispatch } from '../types' -import type { UsbDeviceMonitor, Device } from './usb-devices' +import type { UsbDeviceMonitor } from './usb-devices' import type { NetworkInterface, NetworkInterfaceMonitor, @@ -26,15 +26,36 @@ const IFACE_POLL_INTERVAL_MS = 30000 const log = createLogger('system-info') -const addDriverVersion = (device: Device): Promise => { - if (isWindows() && RE_REALTEK.test(device.manufacturer)) { +// format USBDevice to UsbDevice type +const createUsbDevice = (device: USBDevice): UsbDevice => { + return { + vendorId: device.vendorId, + productId: device.productId, + productName: device.productName != null ? device.productName : 'no name', + manufacturerName: + device.manufacturerName != null + ? device.manufacturerName + : 'no manufacture', + serialNumber: + device.serialNumber != null ? device.serialNumber : 'no serial', + } +} +const createUsbDevices = (devices: USBDevice[]): UsbDevice[] => + devices.map((device: USBDevice) => createUsbDevice(device)) + +const addDriverVersion = (device: UsbDevice): Promise => { + if ( + isWindows() && + device.manufacturerName != null && + RE_REALTEK.test(device.manufacturerName) + ) { return getWindowsDriverVersion(device).then(windowsDriverVersion => ({ ...device, windowsDriverVersion, })) } - return Promise.resolve({ ...device }) + return Promise.resolve(device) } export function registerSystemInfo( @@ -43,13 +64,13 @@ export function registerSystemInfo( let usbMonitor: UsbDeviceMonitor let ifaceMonitor: NetworkInterfaceMonitor - const handleDeviceAdd = (device: Device): void => { + const handleDeviceAdd = (device: UsbDevice): void => { // eslint-disable-next-line @typescript-eslint/no-floating-promises addDriverVersion(device).then(d => dispatch(SystemInfo.usbDeviceAdded(d))) } - const handleDeviceRemove = (d: Device): void => { - dispatch(SystemInfo.usbDeviceRemoved({ ...d })) + const handleDeviceRemove = (d: UsbDevice): void => { + dispatch(SystemInfo.usbDeviceRemoved(d)) } const handleIfacesChanged = (interfaces: NetworkInterface[]): void => { @@ -89,7 +110,9 @@ export function registerSystemInfo( usbMonitor .getAllDevices() - .then(devices => Promise.all(devices.map(addDriverVersion))) + .then(devices => + Promise.all(createUsbDevices(devices).map(addDriverVersion)) + ) .then(devices => { dispatch(SystemInfo.initialized(devices, getActiveInterfaces())) }) diff --git a/app-shell/src/system-info/usb-devices.ts b/app-shell/src/system-info/usb-devices.ts index 6000229ef9c..c9b26dc2dfa 100644 --- a/app-shell/src/system-info/usb-devices.ts +++ b/app-shell/src/system-info/usb-devices.ts @@ -1,50 +1,49 @@ import assert from 'assert' import execa from 'execa' -import usbDetection from 'usb-detection' +import { usb, WebUSB } from 'usb' import { isWindows } from '../os' import { createLogger } from '../log' -import type { Device } from 'usb-detection' - -export type { Device } +import type { UsbDevice } from '@opentrons/app/src/redux/system-info/types' export type UsbDeviceMonitorOptions = Partial<{ - onDeviceAdd?: (device: Device) => unknown - onDeviceRemove?: (device: Device) => unknown + onDeviceAdd?: (device: UsbDevice) => void + onDeviceRemove?: (device: UsbDevice) => void }> export interface UsbDeviceMonitor { - getAllDevices: () => Promise + getAllDevices: () => Promise stop: () => void } const log = createLogger('usb-devices') +const webusb = new WebUSB({ + allowAllDevices: true, +}) export function createUsbDeviceMonitor( options: UsbDeviceMonitorOptions = {} ): UsbDeviceMonitor { const { onDeviceAdd, onDeviceRemove } = options - usbDetection.startMonitoring() if (typeof onDeviceAdd === 'function') { - usbDetection.on('add', onDeviceAdd) + usb.on('attach', device => onDeviceAdd) } if (typeof onDeviceRemove === 'function') { - usbDetection.on('remove', onDeviceRemove) + usb.on('detach', device => onDeviceRemove) } return { - getAllDevices: () => usbDetection.find(), + getAllDevices: () => Promise.resolve(webusb.getDevices()), stop: () => { if (typeof onDeviceAdd === 'function') { - usbDetection.off('add', onDeviceAdd) + usb.removeAllListeners('attach') } if (typeof onDeviceRemove === 'function') { - usbDetection.off('remove', onDeviceRemove) + usb.removeAllListeners('detach') } - usbDetection.stopMonitoring() log.debug('usb detection monitoring stopped') }, } @@ -54,11 +53,17 @@ const decToHex = (number: number): string => number.toString(16).toUpperCase().padStart(4, '0') export function getWindowsDriverVersion( - device: Device + device: UsbDevice ): Promise { + console.log('getWindowsDriverVersion', device) const { vendorId: vidDecimal, productId: pidDecimal, serialNumber } = device const [vid, pid] = [decToHex(vidDecimal), decToHex(pidDecimal)] + // USBDevice serialNumber is string | undefined + if (serialNumber == null) { + return Promise.resolve(null) + } + assert( isWindows() || process.env.NODE_ENV === 'test', `getWindowsDriverVersion cannot be called on ${process.platform}` diff --git a/app-shell/src/ui.ts b/app-shell/src/ui.ts index e36a0ac5625..c60118bc0cd 100644 --- a/app-shell/src/ui.ts +++ b/app-shell/src/ui.ts @@ -57,11 +57,14 @@ export function createUi(): BrowserWindow { mainWindow.loadURL(url, { extraHeaders: 'pragma: no-cache\n' }) // open new windows ( { - log.debug('Opening external link', { url }) - event.preventDefault() - // eslint-disable-next-line @typescript-eslint/no-floating-promises - shell.openExternal(url) + mainWindow.webContents.setWindowOpenHandler(({ url, disposition }) => { + if (disposition === 'new-window' && url === 'about:blank') { + // eslint-disable-next-line no-void + void shell.openExternal(url) + return { action: 'deny' } + } else { + return { action: 'allow' } + } }) return mainWindow diff --git a/app-shell/typings/usb-detection.d.ts b/app-shell/typings/usb-detection.d.ts index 194cb8cb6fb..783ab4bd1c8 100644 --- a/app-shell/typings/usb-detection.d.ts +++ b/app-shell/typings/usb-detection.d.ts @@ -1,6 +1,6 @@ -import 'usb-detection' +// import 'usb-detection' -declare module 'usb-detection' { - export function off(event: string, handler: unknown): void - export function emit(event: string, payload: unknown): void -} +// declare module 'usb-detection' { +// export function off(event: string, handler: unknown): void +// export function emit(event: string, payload: unknown): void +// } diff --git a/app/Makefile b/app/Makefile index 244b975c085..cadd9cea220 100644 --- a/app/Makefile +++ b/app/Makefile @@ -43,11 +43,11 @@ clean: # artifacts ##################################################################### - +# override webpack's default hashing algorithm for node 18: https://github.com/webpack/webpack/issues/14532 .PHONY: dist dist: export NODE_ENV := production dist: - webpack --profile + NODE_OPTIONS=--openssl-legacy-provider webpack --profile # development ##################################################################### @@ -71,8 +71,9 @@ dev-odd: .PHONY: dev-server dev-server: export OPENTRONS_PROJECT := $(OPENTRONS_PROJECT) +dev-server: export NODE_OPTIONS := --openssl-legacy-provider dev-server: - webpack-dev-server --hot + webpack-dev-server --hot --host=:: .PHONY: dev-shell dev-shell: @@ -95,4 +96,4 @@ test: .PHONY: test-cov test-cov: - make -C .. test-js-app tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" \ No newline at end of file + make -C .. test-js-app tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" diff --git a/app/src/organisms/AdvancedSettings/U2EInformation.tsx b/app/src/organisms/AdvancedSettings/U2EInformation.tsx index 723d95bcbd3..09533b6dedb 100644 --- a/app/src/organisms/AdvancedSettings/U2EInformation.tsx +++ b/app/src/organisms/AdvancedSettings/U2EInformation.tsx @@ -82,7 +82,7 @@ export function U2EInformation(): JSX.Element { {t('usb_to_ethernet_adapter_description')} - {device?.deviceName} + {device?.productName} {t('usb_to_ethernet_adapter_manufacturer')} - {device?.manufacturer} + {device?.manufacturerName} { 'U2E Vendor ID': Fixtures.mockRealtekDevice.vendorId, 'U2E Product ID': Fixtures.mockRealtekDevice.productId, 'U2E Serial Number': Fixtures.mockRealtekDevice.serialNumber, - 'U2E Device Name': Fixtures.mockRealtekDevice.deviceName, - 'U2E Manufacturer': Fixtures.mockRealtekDevice.manufacturer, + 'U2E Device Name': Fixtures.mockRealtekDevice.productName, + 'U2E Manufacturer': Fixtures.mockRealtekDevice.manufacturerName, }) }) diff --git a/app/src/redux/system-info/selectors.ts b/app/src/redux/system-info/selectors.ts index d263d91fe17..fe7840fd628 100644 --- a/app/src/redux/system-info/selectors.ts +++ b/app/src/redux/system-info/selectors.ts @@ -27,8 +27,8 @@ export const getU2EDeviceAnalyticsProps: ( 'U2E Vendor ID': device.vendorId, 'U2E Product ID': device.productId, 'U2E Serial Number': device.serialNumber, - 'U2E Manufacturer': device.manufacturer, - 'U2E Device Name': device.deviceName, + 'U2E Manufacturer': device.manufacturerName, + 'U2E Device Name': device.productName, } if (device.windowsDriverVersion) { diff --git a/app/src/redux/system-info/types.ts b/app/src/redux/system-info/types.ts index e54dd5fc077..0ea770269a2 100644 --- a/app/src/redux/system-info/types.ts +++ b/app/src/redux/system-info/types.ts @@ -12,13 +12,11 @@ import { } from './constants' export interface UsbDevice { - locationId: number vendorId: number productId: number - deviceName: string - manufacturer: string - serialNumber: string - deviceAddress: number + productName?: string + manufacturerName?: string + serialNumber?: string windowsDriverVersion?: string | null } @@ -43,9 +41,9 @@ export type DriverStatus = export interface U2EAnalyticsProps { 'U2E Vendor ID': number 'U2E Product ID': number - 'U2E Serial Number': string - 'U2E Device Name': string - 'U2E Manufacturer': string + 'U2E Serial Number'?: string + 'U2E Device Name'?: string + 'U2E Manufacturer'?: string 'U2E Windows Driver Version'?: string | null [key: string]: string | number | null | undefined } diff --git a/components/Makefile b/components/Makefile index 18f163e28f7..e56a59cd680 100644 --- a/components/Makefile +++ b/components/Makefile @@ -9,6 +9,9 @@ tests ?= cov_opts ?= --coverage=true --ci=true --collectCoverageFrom='components/src/**/*.(js|ts|tsx)' test_opts ?= +# override webpack's default hashing algorithm for node 18: https://github.com/webpack/webpack/issues/14532 +export NODE_OPTIONS := --openssl-legacy-provider + # standard targets ##################################################################### @@ -44,4 +47,4 @@ test: .PHONY: test-cov test-cov: - make -C .. test-js-components tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" \ No newline at end of file + make -C .. test-js-components tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" diff --git a/labware-designer/Makefile b/labware-designer/Makefile index 5978bf906de..1f9870d4698 100644 --- a/labware-designer/Makefile +++ b/labware-designer/Makefile @@ -6,6 +6,9 @@ SHELL := bash # add node_modules/.bin to PATH PATH := $(shell cd .. && yarn bin):$(PATH) +# override webpack's default hashing algorithm for node 18: https://github.com/webpack/webpack/issues/14532 +export NODE_OPTIONS := --openssl-legacy-provider + # standard targets ##################################################################### @@ -34,7 +37,7 @@ dist: .PHONY: dev dev: export NODE_ENV := development dev: - webpack-dev-server --hot + webpack-dev-server --hot --host=:: .PHONY: test test: diff --git a/labware-library/Makefile b/labware-library/Makefile index 1788f820d39..2c398a7e8de 100644 --- a/labware-library/Makefile +++ b/labware-library/Makefile @@ -22,17 +22,19 @@ clean: shx rm -rf dist # production assets +# override webpack's default hashing algorithm for node 18: https://github.com/webpack/webpack/issues/14532 .PHONY: dist dist: export NODE_ENV := production dist: - webpack --profile + export NODE_OPTIONS=--openssl-legacy-provider && webpack --profile node ./renderStatic.js # development assets server .PHONY: dev dev: export NODE_ENV := development +dev: export NODE_OPTIONS := --openssl-legacy-provider dev: - webpack-dev-server --hot + webpack-dev-server --hot --host=:: # production assets server .PHONY: serve @@ -44,7 +46,8 @@ serve: all test-e2e: concurrently --no-color --kill-others --success first --names "labware-library-server,labware-library-tests" \ "$(MAKE) dev CYPRESS=1 GTM_ID=''" \ - "wait-on http://localhost:8080/ && cypress run --browser chrome --headless --record false" + "wait-on http://localhost:8080/ && echo \"Running cypress at $(date)\" && cypress run --browser chrome --headless --record false" + # unit tests .PHONY: test test: diff --git a/package.json b/package.json index 642ba9ebe2f..ec8e480cb65 100755 --- a/package.json +++ b/package.json @@ -27,7 +27,7 @@ }, "packageManager": "yarn@1.22.19", "engines": { - "node": "^16.9.0" + "node": "^18.19.0" }, "devDependencies": { "@babel/core": "^7.12.10", @@ -40,7 +40,7 @@ "@babel/preset-typescript": "^7.12.7", "@babel/register": "^7.12.10", "@cypress/webpack-preprocessor": "^5.1.2", - "@electron/rebuild": "^3.2.10", + "@electron/rebuild": "3.3.0", "@octokit/rest": "^19.0.5", "@rollup/plugin-alias": "^3.1.2", "@rollup/plugin-babel": "^5.3.0", @@ -87,7 +87,7 @@ "cz-conventional-changelog": "2.1.0", "decompress": "4.2.1", "download": "8.0.0", - "electron": "21.3.1", + "electron": "27.0.0", "electron-builder": "24.0.0", "eslint": "^7.22.0", "eslint-config-prettier": "^8.1.0", diff --git a/protocol-designer/Makefile b/protocol-designer/Makefile index aaffc749e0a..6651c73b517 100644 --- a/protocol-designer/Makefile +++ b/protocol-designer/Makefile @@ -30,11 +30,12 @@ clean: # artifacts ##################################################################### +# override webpack's default hashing algorithm for node 18: https://github.com/webpack/webpack/issues/14532 .PHONY: build build: export NODE_ENV := production build: - webpack --profile + export NODE_OPTIONS=--openssl-legacy-provider && webpack --profile git rev-parse HEAD > dist/.commit # development @@ -49,8 +50,9 @@ benchmarks: .PHONY: dev dev: export NODE_ENV := development +dev: export NODE_OPTIONS := --openssl-legacy-provider dev: - webpack-dev-server --hot + webpack-dev-server --hot --host=:: # production assets server .PHONY: serve @@ -70,4 +72,4 @@ test: .PHONY: test-cov test-cov: - make -C .. test-js-protocol-designer tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" \ No newline at end of file + make -C .. test-js-protocol-designer tests=$(tests) test_opts="$(test_opts)" cov_opts="$(cov_opts)" diff --git a/protocol-library-kludge/Makefile b/protocol-library-kludge/Makefile index db1274a61ec..3cf944cc962 100644 --- a/protocol-library-kludge/Makefile +++ b/protocol-library-kludge/Makefile @@ -36,5 +36,6 @@ dist: .PHONY: dev dev: export NODE_ENV := development +dev: export NODE_OPTIONS := --openssl-legacy-provider dev: - webpack-dev-server --hot + webpack-dev-server --hot --host=:: diff --git a/yarn.lock b/yarn.lock index 7547eb3e42c..1388f7711c1 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1456,21 +1456,20 @@ optionalDependencies: "@types/glob" "^7.1.1" -"@electron/get@^1.14.1": - version "1.14.1" - resolved "https://registry.yarnpkg.com/@electron/get/-/get-1.14.1.tgz#16ba75f02dffb74c23965e72d617adc721d27f40" - integrity sha512-BrZYyL/6m0ZXz/lDxy/nlVhQz+WF+iPS6qXolEU8atw7h6v1aYkjwJZ63m+bJMBTxDE66X+r2tPS4a/8C82sZw== +"@electron/get@^2.0.0": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@electron/get/-/get-2.0.3.tgz#fba552683d387aebd9f3fcadbcafc8e12ee4f960" + integrity sha512-Qkzpg2s9GnVV2I2BjRksUi43U5e6+zaQMcjoJy0C+C5oxaKl+fmckGDQFtRpZpZV0NQekuZZ+tGz7EA9TVnQtQ== dependencies: debug "^4.1.1" env-paths "^2.2.0" fs-extra "^8.1.0" - got "^9.6.0" + got "^11.8.5" progress "^2.0.3" semver "^6.2.0" sumchecker "^3.0.1" optionalDependencies: global-agent "^3.0.0" - global-tunnel-ng "^2.7.1" "@electron/notarize@^1.2.3": version "1.2.3" @@ -1492,6 +1491,25 @@ minimist "^1.2.6" plist "^3.0.5" +"@electron/rebuild@3.3.0": + version "3.3.0" + resolved "https://registry.yarnpkg.com/@electron/rebuild/-/rebuild-3.3.0.tgz#6ba0ae1cb545b2e314901d2ac175ca9c03a2e3da" + integrity sha512-S1vgpzIOS1wCJmsYjdLz97MTUV6UTLcMk/HE3w90HYtVxvW+PQdwxLbgsrECX2bysqcnmM5a0K6mXj/gwVgYtQ== + dependencies: + "@malept/cross-spawn-promise" "^2.0.0" + chalk "^4.0.0" + debug "^4.1.1" + detect-libc "^2.0.1" + fs-extra "^10.0.0" + got "^11.7.0" + node-abi "^3.45.0" + node-api-version "^0.1.4" + node-gyp "^9.0.0" + ora "^5.1.0" + semver "^7.3.5" + tar "^6.0.5" + yargs "^17.0.1" + "@electron/rebuild@^3.2.10": version "3.2.10" resolved "https://registry.yarnpkg.com/@electron/rebuild/-/rebuild-3.2.10.tgz#adc9443179709d4e4b93a68fac6a08b9a3b9e5e6" @@ -2522,11 +2540,6 @@ "@serialport/bindings-interface" "1.2.2" debug "^4.3.2" -"@sindresorhus/is@^0.14.0": - version "0.14.0" - resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" - integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== - "@sindresorhus/is@^0.7.0": version "0.7.0" resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.7.0.tgz#9a06f4f137ee84d7df0460c1fdb1135ffa6c50fd" @@ -3364,13 +3377,6 @@ regenerator-runtime "^0.13.7" resolve-from "^5.0.0" -"@szmarczak/http-timer@^1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" - integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== - dependencies: - defer-to-connect "^1.0.1" - "@szmarczak/http-timer@^4.0.5": version "4.0.6" resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-4.0.6.tgz#b4a914bb62e7c272d4e5989fe4440f812ab1d807" @@ -3806,10 +3812,12 @@ resolved "https://registry.yarnpkg.com/@types/node/-/node-16.11.44.tgz#447e3eecad9d19bd779f4a575f361d34898c0722" integrity sha512-gwP6+QDgL5TDBIWh1lbYh3EFPU11pa+8xcamcsA3ROkp3A9X+/3Y5cRgq93VPEEE+CGfxlQnqkg1kkWGBgh3fw== -"@types/node@^16.11.26": - version "16.11.59" - resolved "https://registry.yarnpkg.com/@types/node/-/node-16.11.59.tgz#823f238b9063ccc3b3b7f13186f143a57926c4f6" - integrity sha512-6u+36Dj3aDzhfBVUf/mfmc92OEdzQ2kx2jcXGdigfl70E/neV21ZHE6UCz4MDzTRcVqGAM27fk+DLXvyDsn3Jw== +"@types/node@^18.11.18": + version "18.19.6" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.19.6.tgz#537beece2c8ad4d9abdaa3b0f428e601eb57dac8" + integrity sha512-X36s5CXMrrJOs2lQCdDF68apW4Rfx9ixYMawlepwmE4Anezv/AV2LSpKD1Ub8DAc+urp5bk0BGZ6NtmBitfnsg== + dependencies: + undici-types "~5.26.4" "@types/normalize-package-data@^2.4.0": version "2.4.0" @@ -4101,6 +4109,11 @@ "@types/unist" "*" "@types/vfile-message" "*" +"@types/w3c-web-usb@^1.0.6": + version "1.0.10" + resolved "https://registry.yarnpkg.com/@types/w3c-web-usb/-/w3c-web-usb-1.0.10.tgz#cf89cccd2d93b6245e784c19afe0a9f5038d4528" + integrity sha512-CHgUI5kTc/QLMP8hODUHhge0D4vx+9UiAwIGiT0sTy/B2XpdX1U5rJt6JSISgr6ikRT7vxV9EVAFeYZqUnl1gQ== + "@types/webpack-env@^1.16.0": version "1.16.0" resolved "https://registry.yarnpkg.com/@types/webpack-env/-/webpack-env-1.16.0.tgz#8c0a9435dfa7b3b1be76562f3070efb3f92637b4" @@ -5588,7 +5601,7 @@ bl@^1.0.0: readable-stream "^2.3.5" safe-buffer "^5.1.1" -bl@^4.0.2, bl@^4.0.3, bl@^4.1.0: +bl@^4.0.2, bl@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/bl/-/bl-4.1.0.tgz#451535264182bec2fbbc83a62ab98cf11d9f7b3a" integrity sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w== @@ -6155,19 +6168,6 @@ cacheable-request@^2.1.1: normalize-url "2.0.1" responselike "1.0.2" -cacheable-request@^6.0.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" - integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== - dependencies: - clone-response "^1.0.2" - get-stream "^5.1.0" - http-cache-semantics "^4.0.0" - keyv "^3.0.0" - lowercase-keys "^2.0.0" - normalize-url "^4.1.0" - responselike "^1.0.2" - cacheable-request@^7.0.2: version "7.0.2" resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-7.0.2.tgz#ea0d0b889364a25854757301ca12b2da77f91d27" @@ -6314,15 +6314,10 @@ caniuse-api@^3.0.0: lodash.memoize "^4.1.2" lodash.uniq "^4.5.0" -caniuse-lite@^1.0.0, caniuse-lite@^1.0.30000981, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001219: - version "1.0.30001237" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001237.tgz#4b7783661515b8e7151fc6376cfd97f0e427b9e5" - integrity sha512-pDHgRndit6p1NR2GhzMbQ6CkRrp4VKuSsqbcLeOQppYPKOYkKT/6ZvZDvKJUqcmtyWIAHuZq3SVS2vc1egCZzw== - -caniuse-lite@^1.0.30001366: - version "1.0.30001366" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001366.tgz#c73352c83830a9eaf2dea0ff71fb4b9a4bbaa89c" - integrity sha512-yy7XLWCubDobokgzudpkKux8e0UOOnLHE6mlNJBzT3lZJz6s5atSEzjoL+fsCPkI0G8MP5uVdDx1ur/fXEWkZA== +caniuse-lite@^1.0.0, caniuse-lite@^1.0.30000981, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001219, caniuse-lite@^1.0.30001366: + version "1.0.30001576" + resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001576.tgz" + integrity sha512-ff5BdakGe2P3SQsMsiqmt1Lc8221NR1VzHj5jXN5vBny9A6fpze94HiVV/n7XRosOlsShJcvMv5mdnpjOGCEgg== capture-exit@^2.0.0: version "2.0.0" @@ -6960,14 +6955,6 @@ conf@^6.2.1: semver "^6.2.0" write-file-atomic "^3.0.0" -config-chain@^1.1.11: - version "1.1.13" - resolved "https://registry.yarnpkg.com/config-chain/-/config-chain-1.1.13.tgz#fad0795aa6a6cdaff9ed1b68e9dff94372c232f4" - integrity sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ== - dependencies: - ini "^1.3.4" - proto-list "~1.2.1" - config-file-ts@^0.2.4: version "0.2.4" resolved "https://registry.yarnpkg.com/config-file-ts/-/config-file-ts-0.2.4.tgz#6c0741fbe118a7cf786c65f139030f0448a2cc99" @@ -8049,11 +8036,6 @@ defaults@^1.0.3: dependencies: clone "^1.0.2" -defer-to-connect@^1.0.1: - version "1.1.3" - resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" - integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== - defer-to-connect@^2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-2.0.1.tgz#8016bdb4143e4632b77a3449c6236277de520587" @@ -8202,7 +8184,7 @@ detect-file@^1.0.0: resolved "https://registry.yarnpkg.com/detect-file/-/detect-file-1.0.0.tgz#f0d66d03672a825cb1b73bdb3fe62310c8e552b7" integrity sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc= -detect-libc@^2.0.0, detect-libc@^2.0.1: +detect-libc@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.0.1.tgz#e1897aa88fa6ad197862937fbc0441ef352ee0cd" integrity sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w== @@ -8683,10 +8665,10 @@ electron-builder@24.0.0: simple-update-notifier "^1.1.0" yargs "^17.6.2" -electron-context-menu@^3.5.0: - version "3.5.0" - resolved "https://registry.yarnpkg.com/electron-context-menu/-/electron-context-menu-3.5.0.tgz#f5d6df982e37555a77666bcecff59b094211b54a" - integrity sha512-z4agpok6YnXlGFs66zU9EBFft4llUFJ41NYFEMMS0fnprMKBztJUCHBA6LMAqJgjabfqsYC7kxlvjvepxodOqg== +electron-context-menu@3.6.1: + version "3.6.1" + resolved "https://registry.yarnpkg.com/electron-context-menu/-/electron-context-menu-3.6.1.tgz#42f117e15309687b22283e6f8f7a0d95a19afe84" + integrity sha512-lcpO6tzzKUROeirhzBjdBWNqayEThmdW+2I2s6H6QMrwqTVyT3EK47jW3Nxm60KTxl5/bWfEoIruoUNn57/QkQ== dependencies: cli-truncate "^2.1.0" electron-dl "^3.2.1" @@ -8822,13 +8804,13 @@ electron-updater@4.1.2: pako "^1.0.10" semver "^6.2.0" -electron@21.3.1: - version "21.3.1" - resolved "https://registry.yarnpkg.com/electron/-/electron-21.3.1.tgz#02a61053ace79ecdc592afc641ff663dec805b42" - integrity sha512-Ik/I9oFHA1h32JRtRm6GMgYdUctFpF/tPnHyATg4r3LXBTUT6habGh3GxSdmmTa5JgtA7uJUEm8EjjZItk7T3g== +electron@27.0.0: + version "27.0.0" + resolved "https://registry.yarnpkg.com/electron/-/electron-27.0.0.tgz#bb6c45881e531b2ec1c7cc46c47aba773f38ee14" + integrity sha512-mr3Zoy82l8XKK/TgguE5FeNeHZ9KHXIGIpUMjbjZWIREfAv+X2Q3vdX6RG0Pmi1K23AFAxANXQezIHBA2Eypwg== dependencies: - "@electron/get" "^1.14.1" - "@types/node" "^16.11.26" + "@electron/get" "^2.0.0" + "@types/node" "^18.11.18" extract-zip "^2.0.1" elegant-spinner@^1.0.1: @@ -8886,7 +8868,7 @@ enabled@1.0.x: dependencies: env-variable "0.0.x" -encodeurl@^1.0.2, encodeurl@~1.0.2: +encodeurl@~1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= @@ -9447,11 +9429,6 @@ etag@~1.8.1: resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= -eventemitter2@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/eventemitter2/-/eventemitter2-5.0.1.tgz#6197a095d5fb6b57e8942f6fd7eaad63a09c9452" - integrity sha512-5EM1GHXycJBS6mauYAbVKT1cVs7POKWb2NXD4Vyt8dDqeZa7LaDK1/sjtL+Zb0lzTpSNil4596Dyu97hz37QLg== - eventemitter2@^6.4.2: version "6.4.4" resolved "https://registry.yarnpkg.com/eventemitter2/-/eventemitter2-6.4.4.tgz#aa96e8275c4dbeb017a5d0e03780c65612a1202b" @@ -9592,11 +9569,6 @@ expand-brackets@^2.1.4: snapdragon "^0.8.1" to-regex "^3.0.1" -expand-template@^2.0.3: - version "2.0.3" - resolved "https://registry.yarnpkg.com/expand-template/-/expand-template-2.0.3.tgz#6e14b3fcee0f3a6340ecb57d2e8918692052a47c" - integrity sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg== - expand-tilde@^2.0.0, expand-tilde@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/expand-tilde/-/expand-tilde-2.0.2.tgz#97e801aa052df02454de46b02bf621642cdc8502" @@ -10714,11 +10686,6 @@ gitconfiglocal@^1.0.0: dependencies: ini "^1.3.2" -github-from-package@0.0.0: - version "0.0.0" - resolved "https://registry.yarnpkg.com/github-from-package/-/github-from-package-0.0.0.tgz#97fb5d96bfde8973313f20e8288ef9a167fa64ce" - integrity sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw== - github-slugger@^1.0.0: version "1.3.0" resolved "https://registry.yarnpkg.com/github-slugger/-/github-slugger-1.3.0.tgz#9bd0a95c5efdfc46005e82a906ef8e2a059124c9" @@ -10836,16 +10803,6 @@ global-prefix@^3.0.0: kind-of "^6.0.2" which "^1.3.1" -global-tunnel-ng@^2.7.1: - version "2.7.1" - resolved "https://registry.yarnpkg.com/global-tunnel-ng/-/global-tunnel-ng-2.7.1.tgz#d03b5102dfde3a69914f5ee7d86761ca35d57d8f" - integrity sha512-4s+DyciWBV0eK148wqXxcmVAbFVPqtc3sEtUE/GTQfuU80rySLcMhUmHKSHI7/LDj8q0gDYI1lIhRRB7ieRAqg== - dependencies: - encodeurl "^1.0.2" - lodash "^4.17.10" - npm-conf "^1.1.3" - tunnel "^0.0.6" - global@^4.4.0: version "4.4.0" resolved "https://registry.yarnpkg.com/global/-/global-4.4.0.tgz#3e7b105179006a323ed71aafca3e9c57a5cc6406" @@ -10972,6 +10929,23 @@ got@^11.7.0: p-cancelable "^2.0.0" responselike "^2.0.0" +got@^11.8.5: + version "11.8.6" + resolved "https://registry.yarnpkg.com/got/-/got-11.8.6.tgz#276e827ead8772eddbcfc97170590b841823233a" + integrity sha512-6tfZ91bOr7bOXnK7PRDCGBLa1H4U080YHNaAQ2KsMGlLEzRbk44nsZF2E1IeRc3vtJHPVbKCYgdFbaGO2ljd8g== + dependencies: + "@sindresorhus/is" "^4.0.0" + "@szmarczak/http-timer" "^4.0.5" + "@types/cacheable-request" "^6.0.1" + "@types/responselike" "^1.0.0" + cacheable-lookup "^5.0.3" + cacheable-request "^7.0.2" + decompress-response "^6.0.0" + http2-wrapper "^1.0.0-beta.5.2" + lowercase-keys "^2.0.0" + p-cancelable "^2.0.0" + responselike "^2.0.0" + got@^8.3.1: version "8.3.2" resolved "https://registry.yarnpkg.com/got/-/got-8.3.2.tgz#1d23f64390e97f776cac52e5b936e5f514d2e937" @@ -10995,23 +10969,6 @@ got@^8.3.1: url-parse-lax "^3.0.0" url-to-options "^1.0.1" -got@^9.6.0: - version "9.6.0" - resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" - integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== - dependencies: - "@sindresorhus/is" "^0.14.0" - "@szmarczak/http-timer" "^1.1.2" - cacheable-request "^6.0.0" - decompress-response "^3.3.0" - duplexer3 "^0.1.4" - get-stream "^4.1.0" - lowercase-keys "^1.0.1" - mimic-response "^1.0.1" - p-cancelable "^1.0.0" - to-readable-stream "^1.0.0" - url-parse-lax "^3.0.0" - graceful-fs@^4.1.10, graceful-fs@^4.2.6, graceful-fs@^4.2.9: version "4.2.10" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" @@ -13544,13 +13501,6 @@ keyv@3.0.0: dependencies: json-buffer "3.0.0" -keyv@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" - integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== - dependencies: - json-buffer "3.0.0" - killable@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/killable/-/killable-1.0.1.tgz#4c8ce441187a061c7474fb87ca08e2a638194892" @@ -13992,7 +13942,7 @@ lowercase-keys@1.0.0: resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.0.tgz#4e3366b39e7f5457e35f1324bdf6f88d0bfc7306" integrity sha1-TjNms55/VFfjXxMkvfb4jQv8cwY= -lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: +lowercase-keys@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== @@ -14500,7 +14450,7 @@ mimic-fn@^2.1.0: resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -mimic-response@^1.0.0, mimic-response@^1.0.1: +mimic-response@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== @@ -14707,11 +14657,6 @@ mixpanel-browser@2.29.1: resolved "https://registry.yarnpkg.com/mixpanel-browser/-/mixpanel-browser-2.29.1.tgz#0e5bda9d43aab5fb74c3bfc527651c4a90fc675d" integrity sha512-RSBqVBznOkKBz3MkCXRrkTEEXqoNNYAbASpjaCxvhpT5pykWhjh7JY54fAmOvtG9XNL3GHYA6XiB7Yos4ngNYQ== -mkdirp-classic@^0.5.2, mkdirp-classic@^0.5.3: - version "0.5.3" - resolved "https://registry.yarnpkg.com/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz#fa10c9115cc6d8865be221ba47ee9bed78601113" - integrity sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A== - mkdirp@0.5.1: version "0.5.1" resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" @@ -14867,11 +14812,6 @@ nan@^2.12.1: resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.2.tgz#f5376400695168f4cc694ac9393d0c9585eeea19" integrity sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ== -nan@^2.15.0: - version "2.17.0" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.17.0.tgz#c0150a2368a182f033e9aa5195ec76ea41a199cb" - integrity sha512-2ZTgtl0nJsO0KQCjEpxcIr5D+Yv90plTitZt9JBfQvVJDS5seMl3FOvsh3+9CoYWXf/1l5OaZzzF6nDm4cagaQ== - nano-time@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/nano-time/-/nano-time-1.0.0.tgz#b0554f69ad89e22d0907f7a12b0993a5d96137ef" @@ -14916,11 +14856,6 @@ nanomatch@^1.2.9: snapdragon "^0.8.1" to-regex "^3.0.1" -napi-build-utils@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/napi-build-utils/-/napi-build-utils-1.0.2.tgz#b1fddc0b2c46e380a0b7a76f984dd47c41a13806" - integrity sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg== - natural-compare@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" @@ -14978,10 +14913,10 @@ node-abi@^3.0.0: dependencies: semver "^7.3.5" -node-abi@^3.3.0: - version "3.25.0" - resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-3.25.0.tgz#ca57dd23ae67679ce152b6c45cae2c57ed04faff" - integrity sha512-p+0xx5ruIQ+8X57CRIMxbTZRT7tU0Tjn2C/aAK68AEMrbGsCo6IjnDdPNhEyyjWCT4bRtzomXchYd3sSgk3BJQ== +node-abi@^3.45.0: + version "3.54.0" + resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-3.54.0.tgz#f6386f7548817acac6434c6cba02999c9aebcc69" + integrity sha512-p7eGEiQil0YUV3ItH4/tBb781L5impVmmx2E9FRKF7d18XXzp4PGT2tdYMFY6wQqgxD0IwNZOiSJ0/K0fSi/OA== dependencies: semver "^7.3.5" @@ -15000,6 +14935,11 @@ node-addon-api@^5.0.0: resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-5.1.0.tgz#49da1ca055e109a23d537e9de43c09cca21eb762" integrity sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA== +node-addon-api@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-7.0.0.tgz#8136add2f510997b3b94814f4af1cce0b0e3962e" + integrity sha512-vgbBJTS4m5/KkE16t5Ly0WW9hz46swAstv0hYYwMtbG7AznRhNyfLRe8HZAiWIpcHzoO7HxhLuBQj9rJ/Ho0ZA== + node-api-version@^0.1.4: version "0.1.4" resolved "https://registry.yarnpkg.com/node-api-version/-/node-api-version-0.1.4.tgz#1ed46a485e462d55d66b5aa1fe2821720dedf080" @@ -15049,6 +14989,11 @@ node-gyp-build@^4.3.0: resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.6.0.tgz#0c52e4cbf54bbd28b709820ef7b6a3c2d6209055" integrity sha512-NTZVKn9IylLwUzaKjkas1e4u2DLNcV4rdYagA4PWdPwW87Bi7z+BznyKSRwS/761tV/lzCGXplWsiaMjLqP2zQ== +node-gyp-build@^4.5.0: + version "4.8.0" + resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.8.0.tgz#3fee9c1731df4581a3f9ead74664369ff00d26dd" + integrity sha512-u6fs2AEUljNho3EYTJNBfImO5QTo/J/1Etd+NVdCj7qWKUSN/bSLkZwhDv7I+w/MSC6qJ4cknepkAYykDdK8og== + node-gyp@^9.0.0: version "9.3.0" resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-9.3.0.tgz#f8eefe77f0ad8edb3b3b898409b53e697642b319" @@ -15211,24 +15156,11 @@ normalize-url@^3.0.0: resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-3.3.0.tgz#b2e1c4dc4f7c6d57743df733a4f5978d18650559" integrity sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg== -normalize-url@^4.1.0: - version "4.5.1" - resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.1.tgz#0dd90cf1288ee1d1313b87081c9a5932ee48518a" - integrity sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA== - normalize-url@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-6.0.1.tgz#a4f27f58cf8c7b287b440b8a8201f42d0b00d256" integrity sha512-VU4pzAuh7Kip71XEmO9aNREYAdMHFGTVj/i+CaTImS8x0i1d3jUZkXhqluy/PRgjPLMgsLQulYY3PJ/aSbSjpQ== -npm-conf@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/npm-conf/-/npm-conf-1.1.3.tgz#256cc47bd0e218c259c4e9550bf413bc2192aff9" - integrity sha512-Yic4bZHJOt9RCFbRP3GgpqhScOY4HH3V2P8yBj6CeYq118Qr+BLXqT2JvpJ00mryLESpgOxf5XlFv4ZjXxLScw== - dependencies: - config-chain "^1.1.11" - pify "^3.0.0" - npm-run-path@^2.0.0: version "2.0.2" resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" @@ -15586,11 +15518,6 @@ p-cancelable@^0.4.0: resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-0.4.1.tgz#35f363d67d52081c8d9585e37bcceb7e0bbcb2a0" integrity sha512-HNa1A8LvB1kie7cERyy21VNeHb2CWJJYqyyC2o3klWFfMGlFmWv2Z7sFgZH8ZiaYL95ydToKTFVXgMV/Os0bBQ== -p-cancelable@^1.0.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" - integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== - p-cancelable@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-2.1.1.tgz#aab7fbd416582fa32a3db49859c122487c5ed2cf" @@ -16880,24 +16807,6 @@ postcss@^7.0.36: picocolors "^0.2.1" source-map "^0.6.1" -prebuild-install@^7.0.1: - version "7.1.1" - resolved "https://registry.yarnpkg.com/prebuild-install/-/prebuild-install-7.1.1.tgz#de97d5b34a70a0c81334fd24641f2a1702352e45" - integrity sha512-jAXscXWMcCK8GgCoHOfIr0ODh5ai8mj63L2nWrjuAgXE6tDyYGnx4/8o/rCgU+B4JSyZBKbeZqzhtwtC3ovxjw== - dependencies: - detect-libc "^2.0.0" - expand-template "^2.0.3" - github-from-package "0.0.0" - minimist "^1.2.3" - mkdirp-classic "^0.5.3" - napi-build-utils "^1.0.1" - node-abi "^3.3.0" - pump "^3.0.0" - rc "^1.2.7" - simple-get "^4.0.0" - tar-fs "^2.0.0" - tunnel-agent "^0.6.0" - precinct@^6.3.1: version "6.3.1" resolved "https://registry.yarnpkg.com/precinct/-/precinct-6.3.1.tgz#8ad735a8afdfc48b56ed39c9ad3bf999b6b928dc" @@ -17095,11 +17004,6 @@ property-information@^5.0.0, property-information@^5.2.0, property-information@^ dependencies: xtend "^4.0.0" -proto-list@~1.2.1: - version "1.2.4" - resolved "https://registry.yarnpkg.com/proto-list/-/proto-list-1.2.4.tgz#212d5bfe1318306a420f6402b8e26ff39647a849" - integrity sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk= - proxy-addr@~2.0.4, proxy-addr@~2.0.5: version "2.0.7" resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" @@ -18408,7 +18312,7 @@ resolve@^2.0.0-next.3: is-core-module "^2.2.0" path-parse "^1.0.6" -responselike@1.0.2, responselike@^1.0.2: +responselike@1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" integrity sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec= @@ -19070,20 +18974,6 @@ signal-exit@^3.0.3, signal-exit@^3.0.7: resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== -simple-concat@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" - integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== - -simple-get@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-4.0.1.tgz#4a39db549287c979d352112fa03fd99fd6bc3543" - integrity sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA== - dependencies: - decompress-response "^6.0.0" - once "^1.3.1" - simple-concat "^1.0.0" - simple-git@^3.15.1: version "3.15.1" resolved "https://registry.yarnpkg.com/simple-git/-/simple-git-3.15.1.tgz#57f595682cb0c2475d5056da078a05c8715a25ef" @@ -20147,16 +20037,6 @@ tapable@^2.1.1, tapable@^2.2.0: resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== -tar-fs@^2.0.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/tar-fs/-/tar-fs-2.1.1.tgz#489a15ab85f1f0befabb370b7de4f9eb5cbe8784" - integrity sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng== - dependencies: - chownr "^1.1.1" - mkdirp-classic "^0.5.2" - pump "^3.0.0" - tar-stream "^2.1.4" - tar-stream@^1.5.2: version "1.6.2" resolved "https://registry.yarnpkg.com/tar-stream/-/tar-stream-1.6.2.tgz#8ea55dab37972253d9a9af90fdcd559ae435c555" @@ -20170,17 +20050,6 @@ tar-stream@^1.5.2: to-buffer "^1.1.1" xtend "^4.0.0" -tar-stream@^2.1.4: - version "2.2.0" - resolved "https://registry.yarnpkg.com/tar-stream/-/tar-stream-2.2.0.tgz#acad84c284136b060dc3faa64474aa9aebd77287" - integrity sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ== - dependencies: - bl "^4.0.3" - end-of-stream "^1.4.1" - fs-constants "^1.0.0" - inherits "^2.0.3" - readable-stream "^3.1.1" - tar@^6.0.2: version "6.1.0" resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.0.tgz#d1724e9bcc04b977b18d5c573b333a2207229a83" @@ -20484,11 +20353,6 @@ to-object-path@^0.3.0: dependencies: kind-of "^3.0.2" -to-readable-stream@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" - integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== - to-regex-range@^2.1.0: version "2.1.1" resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38" @@ -20681,11 +20545,6 @@ tunnel-agent@^0.6.0: dependencies: safe-buffer "^5.0.1" -tunnel@^0.0.6: - version "0.0.6" - resolved "https://registry.yarnpkg.com/tunnel/-/tunnel-0.0.6.tgz#72f1314b34a5b192db012324df2cc587ca47f92c" - integrity sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg== - tweetnacl@^0.14.3, tweetnacl@~0.14.0: version "0.14.5" resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" @@ -20841,6 +20700,11 @@ unbzip2-stream@^1.0.9: buffer "^5.2.1" through "^2.3.8" +undici-types@~5.26.4: + version "5.26.5" + resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" + integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== + unfetch@^4.2.0: version "4.2.0" resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.2.0.tgz#7e21b0ef7d363d8d9af0fb929a5555f6ef97a3be" @@ -21250,15 +21114,14 @@ url@^0.11.0: punycode "1.3.2" querystring "0.2.0" -usb-detection@4.14.1: - version "4.14.1" - resolved "https://registry.yarnpkg.com/usb-detection/-/usb-detection-4.14.1.tgz#fe0d4a28299e98b77fe75e416408ebeda38feb0e" - integrity sha512-o9JCWXILJDXnlNhjc2abMa/9JTrARVGTjTSYNhgTa1iVJvIwuvmZ5r6hvTeAEZhndC0l1BSFdctMD6QeGwLpOw== +usb@^2.11.0: + version "2.11.0" + resolved "https://registry.yarnpkg.com/usb/-/usb-2.11.0.tgz#bbb2257c65534635a450aed3754df7c8844d518e" + integrity sha512-u5+NZ6DtoW8TIBtuSArQGAZZ/K15i3lYvZBAYmcgI+RcDS9G50/KPrUd3CrU8M92ahyCvg5e0gc8BDvr5Hwejg== dependencies: - bindings "^1.5.0" - eventemitter2 "^5.0.1" - nan "^2.15.0" - prebuild-install "^7.0.1" + "@types/w3c-web-usb" "^1.0.6" + node-addon-api "^7.0.0" + node-gyp-build "^4.5.0" use-callback-ref@^1.2.3: version "1.2.5"