From ba0b6ab6ade2a0f6c076f3bd62612f52c74c25a1 Mon Sep 17 00:00:00 2001 From: Rhys Bartels-Waller Date: Sat, 28 Sep 2024 01:10:34 +1000 Subject: [PATCH 1/3] feat: initialize sentry --- .env.template.sentry-build-plugin | 6 + .github/workflows/ci.yml | 2 +- .gitignore | 3 + package-lock.json | 530 +++++++++++++++++++++++++++--- package.json | 2 + secrets.testing.js | 1 + src/features/sentry.js | 26 ++ src/ui/app/tabs/createWallet.jsx | 2 +- src/ui/app/tabs/hw.jsx | 2 +- webpack.config.js | 82 +++-- 10 files changed, 581 insertions(+), 75 deletions(-) create mode 100644 .env.template.sentry-build-plugin create mode 100644 src/features/sentry.js diff --git a/.env.template.sentry-build-plugin b/.env.template.sentry-build-plugin new file mode 100644 index 00000000..a88fc46e --- /dev/null +++ b/.env.template.sentry-build-plugin @@ -0,0 +1,6 @@ +# Copy this file as .env.sentry-build-plugin +# The SENTRY_AUTH_TOKEN variable is picked up by the Sentry Build Plugin. +# It's used for authentication when uploading source maps. +SENTRY_AUTH_TOKEN= +SENTRY_ORG= +SENTRY_PROJECT= diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index af8ec387..1539f29c 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -24,7 +24,7 @@ jobs: run: npm test - name: Generates Secrets File run: | - echo "export default { PROJECT_ID_MAINNET: '${{ secrets.PROJECT_ID_MAINNET }}', PROJECT_ID_PREVIEW: '${{ secrets.PROJECT_ID_PREVIEW }}', PROJECT_ID_PREPROD: '${{ secrets.PROJECT_ID_PREPROD }}'};" > secrets.production.js + echo "export default { PROJECT_ID_MAINNET: '${{ secrets.PROJECT_ID_MAINNET }}', PROJECT_ID_PREVIEW: '${{ secrets.PROJECT_ID_PREVIEW }}', PROJECT_ID_PREPROD: '${{ secrets.PROJECT_ID_PREPROD }}', SENTRY_DSN: '${{ secrets.SENTRY_DSN }}'};" > secrets.production.js - name: Build run: npm run build - name: Upload build diff --git a/.gitignore b/.gitignore index 2d3ed912..5948764d 100644 --- a/.gitignore +++ b/.gitignore @@ -23,3 +23,6 @@ secrets.development.js # IDEs .idea + +# Sentry Config File +.env.sentry-build-plugin diff --git a/package-lock.json b/package-lock.json index 531b009f..36d87ece 100644 --- a/package-lock.json +++ b/package-lock.json @@ -24,6 +24,8 @@ "@emurgo/cip14-js": "^3.0.1", "@fontsource/ubuntu": "^5.0.8", "@ledgerhq/hw-transport-webusb": "^6.28.0", + "@sentry/react": "^8.32.0", + "@sentry/webpack-plugin": "^2.22.4", "@trezor/connect-web": "^9.3.0", "bip39": "^3.0.4", "cardano-hw-interop-lib": "^3.0.2", @@ -116,7 +118,6 @@ "version": "2.2.1", "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", - "dev": true, "dependencies": { "@jridgewell/gen-mapping": "^0.3.0", "@jridgewell/trace-mapping": "^0.3.9" @@ -141,7 +142,6 @@ "version": "7.23.5", "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", - "dev": true, "engines": { "node": ">=6.9.0" } @@ -150,7 +150,6 @@ "version": "7.23.2", "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.2.tgz", "integrity": "sha512-n7s51eWdaWZ3vGT2tD4T7J6eJs3QoBXydv7vkUM06Bf1cbVD2Kc2UrkzhiQwobfV7NwOnQXYL7UBJ5VPU+RGoQ==", - "dev": true, "dependencies": { "@ampproject/remapping": "^2.2.0", "@babel/code-frame": "^7.22.13", @@ -244,7 +243,6 @@ "version": "7.23.6", "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", - "dev": true, "dependencies": { "@babel/compat-data": "^7.23.5", "@babel/helper-validator-option": "^7.23.5", @@ -514,7 +512,6 @@ "version": "7.23.2", "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.2.tgz", "integrity": "sha512-lzchcp8SjTSVe/fPmLwtWVBFC7+Tbn8LGHDVfDp9JGxpAY5opSaEFgt8UQvrnECWOTdji2mOWMz1rOhkHscmGQ==", - "dev": true, "dependencies": { "@babel/template": "^7.22.15", "@babel/traverse": "^7.23.2", @@ -5702,6 +5699,398 @@ "url": "https://paulmillr.com/funding/" } }, + "node_modules/@sentry-internal/browser-utils": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry-internal/browser-utils/-/browser-utils-8.32.0.tgz", + "integrity": "sha512-DpUGhk5O1OVjT0fo9wsbEdO1R/S9gGBRDtn9+FFVeRtieJHwXpeZiLK+tZhTOvaILmtSoTPUEY3L5sK4j5Xq9g==", + "dependencies": { + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry-internal/feedback": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry-internal/feedback/-/feedback-8.32.0.tgz", + "integrity": "sha512-XB7hiVJQW1tNzpoXIHbvm3rjipIt7PZiJJtFg2vxaqu/FzdgOcYqQiwIKivJVAKuRZ9rIeJtK1jdXQFOc/TRJA==", + "dependencies": { + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry-internal/replay": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry-internal/replay/-/replay-8.32.0.tgz", + "integrity": "sha512-yiEUnn2yyo1AIQIFNeRX3tdK8fmyKIkxdFS1WiVQmeYI/hFwYBTZPly0FcO/g3xnRMSA2tvrS+hZEaaXfK4WhA==", + "dependencies": { + "@sentry-internal/browser-utils": "8.32.0", + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry-internal/replay-canvas": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry-internal/replay-canvas/-/replay-canvas-8.32.0.tgz", + "integrity": "sha512-oBbhtDBkD+5z/T0NVJ5VenBWAid/S9QdVrod/UqxVqU7F8N+E9/INFQI48zCWr4iVlUMcszJPDElvJEsMDvvBQ==", + "dependencies": { + "@sentry-internal/replay": "8.32.0", + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry/babel-plugin-component-annotate": { + "version": "2.22.4", + "resolved": "https://registry.npmjs.org/@sentry/babel-plugin-component-annotate/-/babel-plugin-component-annotate-2.22.4.tgz", + "integrity": "sha512-hbSq067KwmeKIEkmyzkTNJbmbtx2KRqvpiy9Q/DynI5Z46Nko/ppvgIfyFXK9DelwvEPOqZic4WXTIhO4iv3DA==", + "engines": { + "node": ">= 14" + } + }, + "node_modules/@sentry/browser": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry/browser/-/browser-8.32.0.tgz", + "integrity": "sha512-AEKFj64g4iYwEMRvVcxiY0FswmClRXCP1IEvCqujn8OBS8AjMOr1z/RwYieEs0D90yNNB3YEqF8adrKENblJmw==", + "dependencies": { + "@sentry-internal/browser-utils": "8.32.0", + "@sentry-internal/feedback": "8.32.0", + "@sentry-internal/replay": "8.32.0", + "@sentry-internal/replay-canvas": "8.32.0", + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry/bundler-plugin-core": { + "version": "2.22.4", + "resolved": "https://registry.npmjs.org/@sentry/bundler-plugin-core/-/bundler-plugin-core-2.22.4.tgz", + "integrity": "sha512-25NiyV3v6mdqOXlpzbbJnq0FHdAu1uTEDr+DU8CzNLjIXlq2Sr2CFZ/mhRcR6daM8OAretJdQ34lu0yHUVeE4Q==", + "dependencies": { + "@babel/core": "^7.18.5", + "@sentry/babel-plugin-component-annotate": "2.22.4", + "@sentry/cli": "^2.33.1", + "dotenv": "^16.3.1", + "find-up": "^5.0.0", + "glob": "^9.3.2", + "magic-string": "0.30.8", + "unplugin": "1.0.1" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/glob": { + "version": "9.3.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-9.3.5.tgz", + "integrity": "sha512-e1LleDykUz2Iu+MTYdkSsuWX8lvAjAcs0Xef0lNIu0S2wOAzuTxCJtcd9S3cijlwYF18EsU3rzb8jPVobxDh9Q==", + "dependencies": { + "fs.realpath": "^1.0.0", + "minimatch": "^8.0.2", + "minipass": "^4.2.4", + "path-scurry": "^1.6.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/minimatch": { + "version": "8.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-8.0.4.tgz", + "integrity": "sha512-W0Wvr9HyFXZRGIDgCicunpQ299OKXs9RgZfaukz4qAW/pJhcpUfupc9c+OObPOFueNy8VSrZgEmDtk6Kh4WzDA==", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@sentry/bundler-plugin-core/node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@sentry/cli": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli/-/cli-2.36.3.tgz", + "integrity": "sha512-sbJpeUByP3b6Xif21lben+4EqGYI/rCTfkPKxBk2FsHX7ISMkVOBw+4/WwELIfIINV2S/XM29jkUG6Bd7axJlA==", + "hasInstallScript": true, + "dependencies": { + "https-proxy-agent": "^5.0.0", + "node-fetch": "^2.6.7", + "progress": "^2.0.3", + "proxy-from-env": "^1.1.0", + "which": "^2.0.2" + }, + "bin": { + "sentry-cli": "bin/sentry-cli" + }, + "engines": { + "node": ">= 10" + }, + "optionalDependencies": { + "@sentry/cli-darwin": "2.36.3", + "@sentry/cli-linux-arm": "2.36.3", + "@sentry/cli-linux-arm64": "2.36.3", + "@sentry/cli-linux-i686": "2.36.3", + "@sentry/cli-linux-x64": "2.36.3", + "@sentry/cli-win32-i686": "2.36.3", + "@sentry/cli-win32-x64": "2.36.3" + } + }, + "node_modules/@sentry/cli-darwin": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-darwin/-/cli-darwin-2.36.3.tgz", + "integrity": "sha512-U0Uean/tW99G5Ma3CjNDXg5bjd4Tmf91Sd/9JKK6dGcEsrWiQpn7ao70kkHy/fwMbeOWE37L7O+NPf86CxHzGA==", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-linux-arm": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-linux-arm/-/cli-linux-arm-2.36.3.tgz", + "integrity": "sha512-Kq8+TG/p/j0GLlJVxnLguAGcp3EqrU4msl4K+7g+6JYnOPLVbUzwZ6ah2WVGtWqlZ3QMFgeeXc7VgPY8KXViqw==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux", + "freebsd" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-linux-arm64": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-linux-arm64/-/cli-linux-arm64-2.36.3.tgz", + "integrity": "sha512-bNr9GUYsn+VcK09FjE+llvxUwtPFAva6FMIcYiAKi6iY3wdmtaOou0Mtkd9dQXkxONAZ0T113x/WQANKBjl4+A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux", + "freebsd" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-linux-i686": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-linux-i686/-/cli-linux-i686-2.36.3.tgz", + "integrity": "sha512-5J5lOzZgvhcjbtuw/JD7jMq1liNbtYXvEuSd+qZa7D8i+Va5cFF8fQui3eev2RxqeYLLwkJWE/djLjeWjMZ7jQ==", + "cpu": [ + "x86", + "ia32" + ], + "optional": true, + "os": [ + "linux", + "freebsd" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-linux-x64": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-linux-x64/-/cli-linux-x64-2.36.3.tgz", + "integrity": "sha512-48pyk93yRiQ7x7ABobYupVfGg1f/vUrBZG7CcaIsDiQL66/kIRjYoh7d7kH8Da/x/LKMiVf/i8/rh2Vr1pcSEw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux", + "freebsd" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-win32-i686": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-win32-i686/-/cli-win32-i686-2.36.3.tgz", + "integrity": "sha512-IEuTCeQjgffvBjDGVYV9d2uWBzmFGmwWIyWUTEMjy76tRnIz0MJaW59Lxd7JdTd1s9xO1F2K7Iz+zxd/kufMRg==", + "cpu": [ + "x86", + "ia32" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/cli-win32-x64": { + "version": "2.36.3", + "resolved": "https://registry.npmjs.org/@sentry/cli-win32-x64/-/cli-win32-x64-2.36.3.tgz", + "integrity": "sha512-ygJLd3nazoNcDMJu1sl8xoSWmmjeBJMMUH6MnDhtQdM9T2j+ndqfL0fZZNO0/kyMv0Bo7/n5kRmKiX2m9Dsi/g==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=10" + } + }, + "node_modules/@sentry/core": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry/core/-/core-8.32.0.tgz", + "integrity": "sha512-+xidTr0lZ0c755tq4k75dXPEb8PA+qvIefW3U9+dQMORLokBrYoKYMf5zZTG2k/OfSJS6OSxatUj36NFuCs3aA==", + "dependencies": { + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry/react": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry/react/-/react-8.32.0.tgz", + "integrity": "sha512-YljqK+k80XOvyXjK2p2neTncRcSuwlpL7qHtNgwR1MHx18FEi7HXlnm13J4g3kxao4ORMxlCXCEPNXlLT+vqQg==", + "dependencies": { + "@sentry/browser": "8.32.0", + "@sentry/core": "8.32.0", + "@sentry/types": "8.32.0", + "@sentry/utils": "8.32.0", + "hoist-non-react-statics": "^3.3.2" + }, + "engines": { + "node": ">=14.18" + }, + "peerDependencies": { + "react": "^16.14.0 || 17.x || 18.x || 19.x" + } + }, + "node_modules/@sentry/types": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry/types/-/types-8.32.0.tgz", + "integrity": "sha512-hxckvN2MzS5SgGDgVQ0/QpZXk13Vrq4BtZLwXhPhyeTmZtUiUfWvcL5TFQqLinfKdTKPe9q2MxeAJ0D4LalhMg==", + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry/utils": { + "version": "8.32.0", + "resolved": "https://registry.npmjs.org/@sentry/utils/-/utils-8.32.0.tgz", + "integrity": "sha512-t1WVERhgmYURxbBj9J4/H2P2X+VKqm7B3ce9iQyrZbdf5NekhcU4jHIecPUWCPHjQkFIqkVTorqeBmDTlg/UmQ==", + "dependencies": { + "@sentry/types": "8.32.0" + }, + "engines": { + "node": ">=14.18" + } + }, + "node_modules/@sentry/webpack-plugin": { + "version": "2.22.4", + "resolved": "https://registry.npmjs.org/@sentry/webpack-plugin/-/webpack-plugin-2.22.4.tgz", + "integrity": "sha512-Y7+RBrXBZlEuvoC0SbuClHZ8VC0nM0wZXroFuY/157EfUFtWr0J8f3b8+mzNshDGaCWV/UzFn6092M/BlAXCQA==", + "dependencies": { + "@sentry/bundler-plugin-core": "2.22.4", + "unplugin": "1.0.1", + "uuid": "^9.0.0" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "webpack": ">=4.40.0" + } + }, + "node_modules/@sentry/webpack-plugin/node_modules/uuid": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.1.tgz", + "integrity": "sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA==", + "funding": [ + "https://github.com/sponsors/broofa", + "https://github.com/sponsors/ctavan" + ], + "bin": { + "uuid": "dist/bin/uuid" + } + }, "node_modules/@sinclair/typebox": { "version": "0.27.8", "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", @@ -7308,7 +7697,6 @@ "version": "8.11.2", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.2.tgz", "integrity": "sha512-nc0Axzp/0FILLEVsm4fNwLCwMttvhEI263QtVPQcbpfZZ3ts0hLsZGOpE6czNlid7CJ9MlyH8reXkpsf3YUY4w==", - "dev": true, "bin": { "acorn": "bin/acorn" }, @@ -7507,7 +7895,6 @@ "version": "3.1.3", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dev": true, "dependencies": { "normalize-path": "^3.0.0", "picomatch": "^2.0.4" @@ -8091,8 +8478,7 @@ "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", - "dev": true + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" }, "node_modules/base-x": { "version": "3.0.9", @@ -8213,7 +8599,6 @@ "version": "2.2.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true, "engines": { "node": ">=8" } @@ -8437,7 +8822,6 @@ "version": "3.0.2", "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "dev": true, "dependencies": { "fill-range": "^7.0.1" }, @@ -8524,7 +8908,6 @@ "version": "4.22.2", "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", - "dev": true, "funding": [ { "type": "opencollective", @@ -8717,7 +9100,6 @@ "version": "1.0.30001579", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001579.tgz", "integrity": "sha512-u5AUVkixruKHJjw/pj9wISlcMpgFWzSrczLZbrqBSxukQixmg0SJ5sZTpvaFvxU0HoQKd4yoyAogyrAz9pzJnA==", - "dev": true, "funding": [ { "type": "opencollective", @@ -8863,7 +9245,6 @@ "version": "3.5.3", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, "funding": [ { "type": "individual", @@ -9189,8 +9570,7 @@ "node_modules/convert-source-map": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", - "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", - "dev": true + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==" }, "node_modules/cookie-signature": { "version": "1.0.6", @@ -10154,6 +10534,17 @@ "tslib": "^2.0.3" } }, + "node_modules/dotenv": { + "version": "16.4.5", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", + "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://dotenvx.com" + } + }, "node_modules/easy-peasy": { "version": "6.0.4", "resolved": "https://registry.npmjs.org/easy-peasy/-/easy-peasy-6.0.4.tgz", @@ -10198,8 +10589,7 @@ "node_modules/electron-to-chromium": { "version": "1.4.637", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.637.tgz", - "integrity": "sha512-G7j3UCOukFtxVO1vWrPQUoDk3kL70mtvjc/DC/k2o7lE0wAdq+Vwp1ipagOow+BH0uVztFysLWbkM/RTIrbK3w==", - "dev": true + "integrity": "sha512-G7j3UCOukFtxVO1vWrPQUoDk3kL70mtvjc/DC/k2o7lE0wAdq+Vwp1ipagOow+BH0uVztFysLWbkM/RTIrbK3w==" }, "node_modules/elliptic": { "version": "6.5.4", @@ -10469,7 +10859,6 @@ "version": "3.1.1", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "dev": true, "engines": { "node": ">=6" } @@ -11554,7 +11943,6 @@ "version": "7.0.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "dev": true, "dependencies": { "to-regex-range": "^5.0.1" }, @@ -11930,14 +12318,12 @@ "node_modules/fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", - "dev": true + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" }, "node_modules/fsevents": { "version": "2.3.3", "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", - "dev": true, "hasInstallScript": true, "optional": true, "os": [ @@ -11986,7 +12372,6 @@ "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", - "dev": true, "engines": { "node": ">=6.9.0" } @@ -12102,7 +12487,6 @@ "version": "5.1.2", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, "dependencies": { "is-glob": "^4.0.1" }, @@ -12948,7 +13332,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dev": true, "dependencies": { "binary-extensions": "^2.0.0" }, @@ -13028,7 +13411,6 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -13081,7 +13463,6 @@ "version": "4.0.3", "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, "dependencies": { "is-extglob": "^2.1.1" }, @@ -13129,7 +13510,6 @@ "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true, "engines": { "node": ">=0.12.0" } @@ -13359,8 +13739,7 @@ "node_modules/isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", - "dev": true + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" }, "node_modules/iso-url": { "version": "1.2.1", @@ -15406,7 +15785,6 @@ "version": "2.2.3", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", - "dev": true, "bin": { "json5": "lib/cli.js" }, @@ -15683,11 +16061,21 @@ "version": "5.1.1", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", - "dev": true, "dependencies": { "yallist": "^3.0.2" } }, + "node_modules/magic-string": { + "version": "0.30.8", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.8.tgz", + "integrity": "sha512-ISQTe55T2ao7XtlAStud6qwYPZjE4GK1S/BeVPus4jrq6JuOnQ00YKQC581RWhR122W7msZV263KzVeLoqidyQ==", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.4.15" + }, + "engines": { + "node": ">=12" + } + }, "node_modules/make-dir": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", @@ -15935,6 +16323,14 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/minipass": { + "version": "4.2.8", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-4.2.8.tgz", + "integrity": "sha512-fNzuVyifolSLFL4NzpF+wEF4qrgqaaKX0haXPQEdQ7NKAN+WecoKMHV09YcuL/DHxrUsYQOK3MiuDf7Ip2OXfQ==", + "engines": { + "node": ">=8" + } + }, "node_modules/mkdirp-classic": { "version": "0.5.3", "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", @@ -16156,8 +16552,7 @@ "node_modules/node-releases": { "version": "2.0.14", "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", - "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", - "dev": true + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "node_modules/nofilter": { "version": "3.1.0", @@ -16171,7 +16566,6 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -19456,7 +19850,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, "dependencies": { "yocto-queue": "^0.1.0" }, @@ -19663,7 +20056,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true, "engines": { "node": ">=8" } @@ -19697,6 +20089,34 @@ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" }, + "node_modules/path-scurry": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", + "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", + "dependencies": { + "lru-cache": "^10.2.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" + }, + "engines": { + "node": ">=16 || 14 >=14.18" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/path-scurry/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==" + }, + "node_modules/path-scurry/node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, "node_modules/path-type": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", @@ -19734,7 +20154,6 @@ "version": "2.3.1", "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, "engines": { "node": ">=8.6" }, @@ -19995,6 +20414,14 @@ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", "dev": true }, + "node_modules/progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/progress-events": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/progress-events/-/progress-events-1.0.1.tgz", @@ -20575,7 +21002,6 @@ "version": "3.6.0", "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, "dependencies": { "picomatch": "^2.2.1" }, @@ -22253,7 +22679,6 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, "dependencies": { "is-number": "^7.0.0" }, @@ -22877,11 +23302,21 @@ "node": ">= 0.8" } }, + "node_modules/unplugin": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/unplugin/-/unplugin-1.0.1.tgz", + "integrity": "sha512-aqrHaVBWW1JVKBHmGo33T5TxeL0qWzfvjWokObHA9bYmN7eNDkwOxmLjhioHl9878qDFMAaT51XNroRyuz7WxA==", + "dependencies": { + "acorn": "^8.8.1", + "chokidar": "^3.5.3", + "webpack-sources": "^3.2.3", + "webpack-virtual-modules": "^0.5.0" + } + }, "node_modules/update-browserslist-db": { "version": "1.0.13", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", - "dev": true, "funding": [ { "type": "opencollective", @@ -23443,11 +23878,15 @@ "version": "3.2.3", "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", - "dev": true, "engines": { "node": ">=10.13.0" } }, + "node_modules/webpack-virtual-modules": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/webpack-virtual-modules/-/webpack-virtual-modules-0.5.0.tgz", + "integrity": "sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw==" + }, "node_modules/webpack/node_modules/schema-utils": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", @@ -23527,7 +23966,6 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, "dependencies": { "isexe": "^2.0.0" }, @@ -23777,8 +24215,7 @@ "node_modules/yallist": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", - "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", - "dev": true + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" }, "node_modules/yaml": { "version": "1.10.2", @@ -23819,7 +24256,6 @@ "version": "0.1.0", "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true, "engines": { "node": ">=10" }, diff --git a/package.json b/package.json index 829931a9..7c2754d3 100644 --- a/package.json +++ b/package.json @@ -29,6 +29,8 @@ "@emurgo/cip14-js": "^3.0.1", "@fontsource/ubuntu": "^5.0.8", "@ledgerhq/hw-transport-webusb": "^6.28.0", + "@sentry/react": "^8.32.0", + "@sentry/webpack-plugin": "^2.22.4", "@trezor/connect-web": "^9.3.0", "bip39": "^3.0.4", "cardano-hw-interop-lib": "^3.0.2", diff --git a/secrets.testing.js b/secrets.testing.js index c27a809e..47d34a01 100644 --- a/secrets.testing.js +++ b/secrets.testing.js @@ -3,4 +3,5 @@ export default { PROJECT_ID_TESTNET: 'DUMMY_TESTNET', PROJECT_ID_PREVIEW: 'DUMMY_PREVIEW', PROJECT_ID_PREPROD: 'DUMMY_PREPROD', + SENTRY_DSN: 'DUMMY_SENTRY_DSN' }; diff --git a/src/features/sentry.js b/src/features/sentry.js new file mode 100644 index 00000000..72047a3d --- /dev/null +++ b/src/features/sentry.js @@ -0,0 +1,26 @@ +import * as Sentry from '@sentry/react'; +import secrets from 'secrets'; + +Sentry.init({ + environment: process.env.NODE_ENV, + dsn: secrets.SENTRY_DSN, + integrations: [ + Sentry.browserTracingIntegration(), + Sentry.browserProfilingIntegration(), + Sentry.replayIntegration(), + ], + // Set `tracePropagationTargets` to control for which URLs trace propagation should be enabled + tracePropagationTargets: ["localhost", "chrome-extension://bpmphiofbkjfgclgimheipflhladbngo"], + // .5% + tracesSampleRate: 0.05, + profilesSampleRate: 0.05, + // Since profilesSampleRate is relative to tracesSampleRate, + // the final profiling rate can be computed as tracesSampleRate * profilesSampleRate + // A tracesSampleRate of 0.05 and profilesSampleRate of 0.05 results in 2.5% of + // transactions being profiled (0.05*0.05=0.0025) + + // Capture Replay for 0.5% of all sessions, + replaysSessionSampleRate: 0.005, + // ...plus for 100% of sessions with an error + replaysOnErrorSampleRate: 1.0, +}); diff --git a/src/ui/app/tabs/createWallet.jsx b/src/ui/app/tabs/createWallet.jsx index 263a6966..c33b666a 100644 --- a/src/ui/app/tabs/createWallet.jsx +++ b/src/ui/app/tabs/createWallet.jsx @@ -1,5 +1,5 @@ /** - * hw.jsx is the entry point for the harware wallet extension tab + * hw.jsx is the entry point for the hardware wallet extension tab */ import React from 'react'; diff --git a/src/ui/app/tabs/hw.jsx b/src/ui/app/tabs/hw.jsx index 1cad0f84..28547355 100644 --- a/src/ui/app/tabs/hw.jsx +++ b/src/ui/app/tabs/hw.jsx @@ -1,5 +1,5 @@ /** - * hw.jsx is the entry point for the harware wallet extension tab + * hw.jsx is the entry point for the hardware wallet extension tab */ import React from 'react'; diff --git a/webpack.config.js b/webpack.config.js index 06e647a5..2ce4fa19 100755 --- a/webpack.config.js +++ b/webpack.config.js @@ -8,6 +8,7 @@ var webpack = require('webpack'), TerserPlugin = require('terser-webpack-plugin'), NodePolyfillPlugin = require('node-polyfill-webpack-plugin'), ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin'); +const { sentryWebpackPlugin } = require("@sentry/webpack-plugin"); const ASSET_PATH = process.env.ASSET_PATH || '/'; @@ -36,33 +37,59 @@ if (fileSystem.existsSync(secretsPath)) { const isDevelopment = process.env.NODE_ENV === 'development'; var options = { + devtool: 'source-map', experiments: { asyncWebAssembly: true, }, mode: process.env.NODE_ENV || 'development', entry: { - mainPopup: path.join(__dirname, 'src', 'ui', 'indexMain.jsx'), - internalPopup: path.join(__dirname, 'src', 'ui', 'indexInternal.jsx'), - hwTab: path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'hw.jsx'), - createWalletTab: path.join( - __dirname, - 'src', - 'ui', - 'app', - 'tabs', - 'createWallet.jsx' - ), - trezorTx: path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'trezorTx.jsx'), - background: path.join(__dirname, 'src', 'pages', 'Background', 'index.js'), - contentScript: path.join(__dirname, 'src', 'pages', 'Content', 'index.js'), - injected: path.join(__dirname, 'src', 'pages', 'Content', 'injected.js'), - trezorContentScript: path.join( - __dirname, - 'src', - 'pages', - 'Content', - 'trezorContentScript.js' - ), + mainPopup: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'ui', 'indexMain.jsx') + ], + internalPopup: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'ui', 'indexInternal.jsx') + ], + hwTab: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'hw.jsx') + ], + createWalletTab: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join( + __dirname, + 'src', + 'ui', + 'app', + 'tabs', + 'createWallet.jsx' + )], + trezorTx: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'trezorTx.jsx') + ], + background: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'pages', 'Background', 'index.js') + ], + contentScript: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'pages', 'Content', 'index.js') + ], + injected: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join(__dirname, 'src', 'pages', 'Content', 'injected.js') + ], + trezorContentScript: [ + path.join(__dirname, 'src', 'features', 'sentry.js'), + path.join( + __dirname, + 'src', + 'pages', + 'Content', + 'trezorContentScript.js' + )] }, chromeExtensionBoilerplate: { notHotReload: ['contentScript', 'devtools', 'injected'], @@ -148,6 +175,13 @@ var options = { }, plugins: [ ...(isDevelopment ? [new ReactRefreshWebpackPlugin()] : []), + sentryWebpackPlugin({ + authToken: process.env.SENTRY_AUTH_TOKEN, + org: process.env.SENTRY_ORG, + project: process.env.SENTRY_PROJECT, + telemetry: false, + url: 'https://sentry.io/' + }), new webpack.BannerPlugin({ banner: () => { return 'globalThis.document={getElementsByTagName:()=>[],createElement:()=>({ setAttribute:()=>{}}),head:{appendChild:()=>{}}};'; @@ -249,9 +283,7 @@ var options = { }, }; -if (env.NODE_ENV === 'development') { - options.devtool = 'cheap-module-source-map'; -} else { +if (!isDevelopment) { options.optimization = { minimize: true, minimizer: [ From 36d03c341640b46447e686c4b18261a7741a5d35 Mon Sep 17 00:00:00 2001 From: Rhys Bartels-Waller Date: Tue, 1 Oct 2024 01:45:39 +1000 Subject: [PATCH 2/3] fixup! feat: initialize sentry --- webpack.config.js | 58 ++++++++++++++++------------------------------- 1 file changed, 20 insertions(+), 38 deletions(-) diff --git a/webpack.config.js b/webpack.config.js index 2ce4fa19..85f765b9 100755 --- a/webpack.config.js +++ b/webpack.config.js @@ -36,6 +36,13 @@ if (fileSystem.existsSync(secretsPath)) { const isDevelopment = process.env.NODE_ENV === 'development'; +const hasSentryConfig = + process.env.SENTRY_AUTH_TOKEN && + process.env.SENTRY_ORG && + process.env.SENTRY_PROJECT + +const withMaybeSentry = (p) => hasSentryConfig ? [ path.join(__dirname, 'src', 'features', 'sentry.js'), p ] : p; + var options = { devtool: 'source-map', experiments: { @@ -43,53 +50,28 @@ var options = { }, mode: process.env.NODE_ENV || 'development', entry: { - mainPopup: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'ui', 'indexMain.jsx') - ], - internalPopup: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'ui', 'indexInternal.jsx') - ], - hwTab: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'hw.jsx') - ], - createWalletTab: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join( + mainPopup: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'indexMain.jsx')), + internalPopup: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'indexInternal.jsx')), + hwTab: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'hw.jsx')), + createWalletTab: withMaybeSentry(path.join( __dirname, 'src', 'ui', 'app', 'tabs', 'createWallet.jsx' - )], - trezorTx: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'trezorTx.jsx') - ], - background: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'pages', 'Background', 'index.js') - ], - contentScript: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'pages', 'Content', 'index.js') - ], - injected: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join(__dirname, 'src', 'pages', 'Content', 'injected.js') - ], - trezorContentScript: [ - path.join(__dirname, 'src', 'features', 'sentry.js'), - path.join( + )), + trezorTx: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'trezorTx.jsx')), + background: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Background', 'index.js')), + contentScript: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Content', 'index.js')), + injected: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Content', 'injected.js')), + trezorContentScript: withMaybeSentry(path.join( __dirname, 'src', 'pages', 'Content', 'trezorContentScript.js' - )] + )) }, chromeExtensionBoilerplate: { notHotReload: ['contentScript', 'devtools', 'injected'], @@ -175,13 +157,13 @@ var options = { }, plugins: [ ...(isDevelopment ? [new ReactRefreshWebpackPlugin()] : []), - sentryWebpackPlugin({ + ...(hasSentryConfig ? [sentryWebpackPlugin({ authToken: process.env.SENTRY_AUTH_TOKEN, org: process.env.SENTRY_ORG, project: process.env.SENTRY_PROJECT, telemetry: false, url: 'https://sentry.io/' - }), + })] : []), new webpack.BannerPlugin({ banner: () => { return 'globalThis.document={getElementsByTagName:()=>[],createElement:()=>({ setAttribute:()=>{}}),head:{appendChild:()=>{}}};'; From 65fedc51c92fed2969f7c06ecf5bc0eab9e74fb7 Mon Sep 17 00:00:00 2001 From: Rhys Bartels-Waller Date: Tue, 1 Oct 2024 15:29:00 +1000 Subject: [PATCH 3/3] fixup! feat: initialize sentry --- .env.template | 6 +++++ .env.template.sentry-build-plugin | 6 ----- .github/workflows/ci.yml | 7 ++++- .gitignore | 4 +-- package-lock.json | 19 ++++++++++++++ package.json | 1 + secrets.testing.js | 1 - src/features/sentry.js | 3 +-- src/ui/app/tabs/createWallet.jsx | 2 +- src/ui/app/tabs/hw.jsx | 2 +- webpack.config.js | 43 +++++++++++++++++++------------ 11 files changed, 62 insertions(+), 32 deletions(-) create mode 100644 .env.template delete mode 100644 .env.template.sentry-build-plugin diff --git a/.env.template b/.env.template new file mode 100644 index 00000000..2ae1c34e --- /dev/null +++ b/.env.template @@ -0,0 +1,6 @@ +# Copy this file as .env +# It's used for authentication when uploading source maps. +SENTRY_AUTH_TOKEN= +SENTRY_ORG= +SENTRY_PROJECT= +SENTRY_DSN= diff --git a/.env.template.sentry-build-plugin b/.env.template.sentry-build-plugin deleted file mode 100644 index a88fc46e..00000000 --- a/.env.template.sentry-build-plugin +++ /dev/null @@ -1,6 +0,0 @@ -# Copy this file as .env.sentry-build-plugin -# The SENTRY_AUTH_TOKEN variable is picked up by the Sentry Build Plugin. -# It's used for authentication when uploading source maps. -SENTRY_AUTH_TOKEN= -SENTRY_ORG= -SENTRY_PROJECT= diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 1539f29c..bd1f2acd 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -24,9 +24,14 @@ jobs: run: npm test - name: Generates Secrets File run: | - echo "export default { PROJECT_ID_MAINNET: '${{ secrets.PROJECT_ID_MAINNET }}', PROJECT_ID_PREVIEW: '${{ secrets.PROJECT_ID_PREVIEW }}', PROJECT_ID_PREPROD: '${{ secrets.PROJECT_ID_PREPROD }}', SENTRY_DSN: '${{ secrets.SENTRY_DSN }}'};" > secrets.production.js + echo "export default { PROJECT_ID_MAINNET: '${{ secrets.PROJECT_ID_MAINNET }}', PROJECT_ID_PREVIEW: '${{ secrets.PROJECT_ID_PREVIEW }}', PROJECT_ID_PREPROD: '${{ secrets.PROJECT_ID_PREPROD }}'};" > secrets.production.js - name: Build run: npm run build + with: + SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} + SENTRY_DSN: ${{ vars.SENTRY_DSN }} + SENTRY_ORG: ${{ vars.SENTRY_ORG }} + SENTRY_PROJECT: ${{ vars.SENTRY_PROJECT }} - name: Upload build uses: actions/upload-artifact@v4 with: diff --git a/.gitignore b/.gitignore index 5948764d..0dc5ac09 100644 --- a/.gitignore +++ b/.gitignore @@ -11,6 +11,7 @@ # misc .DS_Store +.env .env.local .env.development.local .env.test.local @@ -23,6 +24,3 @@ secrets.development.js # IDEs .idea - -# Sentry Config File -.env.sentry-build-plugin diff --git a/package-lock.json b/package-lock.json index 36d87ece..216f343f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -72,6 +72,7 @@ "clean-webpack-plugin": "^4.0.0", "copy-webpack-plugin": "^11.0.0", "css-loader": "^6.8.1", + "dotenv-defaults": "^5.0.2", "eslint": "^8.54.0", "eslint-config-react-app": "^7.0.1", "eslint-plugin-flowtype": "^8.0.3", @@ -10545,6 +10546,24 @@ "url": "https://dotenvx.com" } }, + "node_modules/dotenv-defaults": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/dotenv-defaults/-/dotenv-defaults-5.0.2.tgz", + "integrity": "sha512-y5z4NhblzwNk8XBIYVzjLcFkANK0rxbRDO6kGOfH9QrVYIGVEX52IqwSprKVsaLHM9pnNkCSxazZF/JPydDPvA==", + "dev": true, + "dependencies": { + "dotenv": "^14.0.0" + } + }, + "node_modules/dotenv-defaults/node_modules/dotenv": { + "version": "14.3.2", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-14.3.2.tgz", + "integrity": "sha512-vwEppIphpFdvaMCaHfCEv9IgwcxMljMw2TnAQBB4VWPvzXQLTb82jwmdOKzlEVUL3gNFT4l4TPKO+Bn+sqcrVQ==", + "dev": true, + "engines": { + "node": ">=12" + } + }, "node_modules/easy-peasy": { "version": "6.0.4", "resolved": "https://registry.npmjs.org/easy-peasy/-/easy-peasy-6.0.4.tgz", diff --git a/package.json b/package.json index 7c2754d3..006813ea 100644 --- a/package.json +++ b/package.json @@ -77,6 +77,7 @@ "clean-webpack-plugin": "^4.0.0", "copy-webpack-plugin": "^11.0.0", "css-loader": "^6.8.1", + "dotenv-defaults": "^5.0.2", "eslint": "^8.54.0", "eslint-config-react-app": "^7.0.1", "eslint-plugin-flowtype": "^8.0.3", diff --git a/secrets.testing.js b/secrets.testing.js index 47d34a01..c27a809e 100644 --- a/secrets.testing.js +++ b/secrets.testing.js @@ -3,5 +3,4 @@ export default { PROJECT_ID_TESTNET: 'DUMMY_TESTNET', PROJECT_ID_PREVIEW: 'DUMMY_PREVIEW', PROJECT_ID_PREPROD: 'DUMMY_PREPROD', - SENTRY_DSN: 'DUMMY_SENTRY_DSN' }; diff --git a/src/features/sentry.js b/src/features/sentry.js index 72047a3d..bc8a9bf8 100644 --- a/src/features/sentry.js +++ b/src/features/sentry.js @@ -1,9 +1,8 @@ import * as Sentry from '@sentry/react'; -import secrets from 'secrets'; Sentry.init({ environment: process.env.NODE_ENV, - dsn: secrets.SENTRY_DSN, + dsn: process.env.SENTRY_DSN, integrations: [ Sentry.browserTracingIntegration(), Sentry.browserProfilingIntegration(), diff --git a/src/ui/app/tabs/createWallet.jsx b/src/ui/app/tabs/createWallet.jsx index c33b666a..263a6966 100644 --- a/src/ui/app/tabs/createWallet.jsx +++ b/src/ui/app/tabs/createWallet.jsx @@ -1,5 +1,5 @@ /** - * hw.jsx is the entry point for the hardware wallet extension tab + * hw.jsx is the entry point for the harware wallet extension tab */ import React from 'react'; diff --git a/src/ui/app/tabs/hw.jsx b/src/ui/app/tabs/hw.jsx index 28547355..1cad0f84 100644 --- a/src/ui/app/tabs/hw.jsx +++ b/src/ui/app/tabs/hw.jsx @@ -1,5 +1,5 @@ /** - * hw.jsx is the entry point for the hardware wallet extension tab + * hw.jsx is the entry point for the harware wallet extension tab */ import React from 'react'; diff --git a/webpack.config.js b/webpack.config.js index 85f765b9..a4ce8be1 100755 --- a/webpack.config.js +++ b/webpack.config.js @@ -17,6 +17,11 @@ var alias = {}; // load the secrets var secretsPath = path.join(__dirname, 'secrets.' + env.NODE_ENV + '.js'); +require('dotenv-defaults').config({ + path: './.env', + encoding: 'utf8' +}); + var fileExtensions = [ 'jpg', 'jpeg', @@ -37,12 +42,16 @@ if (fileSystem.existsSync(secretsPath)) { const isDevelopment = process.env.NODE_ENV === 'development'; const hasSentryConfig = - process.env.SENTRY_AUTH_TOKEN && - process.env.SENTRY_ORG && - process.env.SENTRY_PROJECT + !!process.env.SENTRY_AUTH_TOKEN && + !!process.env.SENTRY_ORG && + !!process.env.SENTRY_PROJECT && + !!process.env.SENTRY_DSN const withMaybeSentry = (p) => hasSentryConfig ? [ path.join(__dirname, 'src', 'features', 'sentry.js'), p ] : p; +const envsToExpose = ['NODE_ENV']; +if (hasSentryConfig) envsToExpose.push('SENTRY_DSN'); + var options = { devtool: 'source-map', experiments: { @@ -54,24 +63,24 @@ var options = { internalPopup: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'indexInternal.jsx')), hwTab: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'hw.jsx')), createWalletTab: withMaybeSentry(path.join( - __dirname, - 'src', - 'ui', - 'app', - 'tabs', - 'createWallet.jsx' - )), + __dirname, + 'src', + 'ui', + 'app', + 'tabs', + 'createWallet.jsx' + )), trezorTx: withMaybeSentry(path.join(__dirname, 'src', 'ui', 'app', 'tabs', 'trezorTx.jsx')), background: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Background', 'index.js')), contentScript: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Content', 'index.js')), injected: withMaybeSentry(path.join(__dirname, 'src', 'pages', 'Content', 'injected.js')), trezorContentScript: withMaybeSentry(path.join( - __dirname, - 'src', - 'pages', - 'Content', - 'trezorContentScript.js' - )) + __dirname, + 'src', + 'pages', + 'Content', + 'trezorContentScript.js' + )) }, chromeExtensionBoilerplate: { notHotReload: ['contentScript', 'devtools', 'injected'], @@ -179,7 +188,7 @@ var options = { cleanStaleWebpackAssets: true, }), // expose and write the allowed env vars on the compiled bundle - new webpack.EnvironmentPlugin(['NODE_ENV']), + new webpack.EnvironmentPlugin(envsToExpose), new CopyWebpackPlugin({ patterns: [ {