From fbc44d0e30f3858a71a90ff1c06c7f7ea6a3d045 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 27 Nov 2023 20:19:18 +0100 Subject: [PATCH 01/21] node 18 and secrets in the manager --- .platform/confighooks/prebuild/env-secret.sh | 11 ++++++++++ .platform/confighooks/predeploy/env-secret.sh | 20 +++++++++++++++++++ .platform/hooks/prebuild/env-secret.sh | 11 ++++++++++ .platform/hooks/predeploy/env-secret.sh | 20 +++++++++++++++++++ buildspec.yml | 4 ++++ 5 files changed, 66 insertions(+) create mode 100644 .platform/confighooks/prebuild/env-secret.sh create mode 100644 .platform/confighooks/predeploy/env-secret.sh create mode 100644 .platform/hooks/prebuild/env-secret.sh create mode 100644 .platform/hooks/predeploy/env-secret.sh diff --git a/.platform/confighooks/prebuild/env-secret.sh b/.platform/confighooks/prebuild/env-secret.sh new file mode 100644 index 000000000..2f7890b2c --- /dev/null +++ b/.platform/confighooks/prebuild/env-secret.sh @@ -0,0 +1,11 @@ +#!/bin/sh +secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +IFS=$'\n' read -r -d '' -a keys <<< "$(echo $secrets | jq -r 'keys[]')" + +touch .env +chown webapp:webapp .env +for key in "${keys[@]}"; do + value=$(echo $secrets | jq -r ".\"$key\"") + printf "%s=%s\n" "$key" "$value" +done > .env diff --git a/.platform/confighooks/predeploy/env-secret.sh b/.platform/confighooks/predeploy/env-secret.sh new file mode 100644 index 000000000..e3997700d --- /dev/null +++ b/.platform/confighooks/predeploy/env-secret.sh @@ -0,0 +1,20 @@ +#!/bin/sh +# In case we merge two env secrets into a flattened one in the same region +# secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +# IFS=$'\n' read -r -d '' -a key_value_pairs <<< "$(echo $secrets | jq -r --arg prefix "$PREFIX" 'to_entries[] | select((.key | ascii_upcase) | startswith(($prefix+"_") | ascii_upcase)) | ((.key | sub(($prefix+"_"); ""; "i")) + "=" + .value)')" + +# for pair in "${key_value_pairs[@]}"; do +# echo "$pair" +# done + +secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +IFS=$'\n' read -r -d '' -a keys <<< "$(echo $secrets | jq -r 'keys[]')" + +touch /var/app/staging/.env +chown webapp:webapp /var/app/staging/.env +for key in "${keys[@]}"; do + value=$(echo $secrets | jq -r ".\"$key\"") + printf "%s=%s\n" "$key" "$value" +done >> /var/app/staging/.env diff --git a/.platform/hooks/prebuild/env-secret.sh b/.platform/hooks/prebuild/env-secret.sh new file mode 100644 index 000000000..2f7890b2c --- /dev/null +++ b/.platform/hooks/prebuild/env-secret.sh @@ -0,0 +1,11 @@ +#!/bin/sh +secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +IFS=$'\n' read -r -d '' -a keys <<< "$(echo $secrets | jq -r 'keys[]')" + +touch .env +chown webapp:webapp .env +for key in "${keys[@]}"; do + value=$(echo $secrets | jq -r ".\"$key\"") + printf "%s=%s\n" "$key" "$value" +done > .env diff --git a/.platform/hooks/predeploy/env-secret.sh b/.platform/hooks/predeploy/env-secret.sh new file mode 100644 index 000000000..e3997700d --- /dev/null +++ b/.platform/hooks/predeploy/env-secret.sh @@ -0,0 +1,20 @@ +#!/bin/sh +# In case we merge two env secrets into a flattened one in the same region +# secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +# IFS=$'\n' read -r -d '' -a key_value_pairs <<< "$(echo $secrets | jq -r --arg prefix "$PREFIX" 'to_entries[] | select((.key | ascii_upcase) | startswith(($prefix+"_") | ascii_upcase)) | ((.key | sub(($prefix+"_"); ""; "i")) + "=" + .value)')" + +# for pair in "${key_value_pairs[@]}"; do +# echo "$pair" +# done + +secrets=$(aws secretsmanager get-secret-value --secret-id api-secrets --region $AWS_REGION | jq -r '.SecretString') + +IFS=$'\n' read -r -d '' -a keys <<< "$(echo $secrets | jq -r 'keys[]')" + +touch /var/app/staging/.env +chown webapp:webapp /var/app/staging/.env +for key in "${keys[@]}"; do + value=$(echo $secrets | jq -r ".\"$key\"") + printf "%s=%s\n" "$key" "$value" +done >> /var/app/staging/.env diff --git a/buildspec.yml b/buildspec.yml index ca5de7c63..047371c61 100644 --- a/buildspec.yml +++ b/buildspec.yml @@ -13,6 +13,8 @@ env: VEBALLOCKS_SUBGRAPH: 'https://api.thegraph.com/subgraphs/name/balancer-labs/balancer-gauges' phases: install: + runtime-versions: + nodejs: 18 commands: - yarn install build: @@ -23,6 +25,8 @@ phases: - yarn build post_build: commands: + - rm -fr node_modules + - yarn install --prod - echo Build completed on `date` # - echo Pushing to graph cdn # - npx graphcdn push From 33c28d3187fcb87083b55ffffc37c886da9a746c Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 27 Nov 2023 20:38:30 +0100 Subject: [PATCH 02/21] new EBS platform in Prisma --- prisma/base.prisma | 2 +- prisma/schema.prisma | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prisma/base.prisma b/prisma/base.prisma index 4318651fd..8a55320cb 100644 --- a/prisma/base.prisma +++ b/prisma/base.prisma @@ -3,7 +3,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "rhel-openssl-1.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-3.0.x"] } datasource db { diff --git a/prisma/schema.prisma b/prisma/schema.prisma index 9ec3e38d1..dd7174384 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -5,7 +5,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "rhel-openssl-1.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-3.0.x"] } datasource db { From fd9f241a71a0605d10a6cdc628ef0826cb3a8fce Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 28 Nov 2023 23:18:04 +0100 Subject: [PATCH 03/21] database_url in .env --- app/env.ts | 5 +++-- prisma/prisma-client.ts | 9 ++++++++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/app/env.ts b/app/env.ts index bda6dec53..7ab6f5689 100644 --- a/app/env.ts +++ b/app/env.ts @@ -31,9 +31,10 @@ export const schema = { type: String, }, WORKER_QUEUE_URL: String, + DATABASE_URL: String, }; export const env: Env = load(schema, { - path: resolve(__dirname, '../.env'), - overrideProcessEnv: process.env.NODE_ENV !== 'production', + path: resolve(__dirname, `../../.env`), + overrideProcessEnv: true, }); diff --git a/prisma/prisma-client.ts b/prisma/prisma-client.ts index 13652ad9f..c31743dd0 100644 --- a/prisma/prisma-client.ts +++ b/prisma/prisma-client.ts @@ -1,6 +1,13 @@ import { PrismaClient } from '@prisma/client'; +import { env } from '../app/env'; -export let prisma = new PrismaClient(); +export let prisma = new PrismaClient({ + datasources: { + db: { + url: env.DATABASE_URL, + }, + }, +}); // Debugging query times // export let prisma = new PrismaClient({ From bb6c2310c928f1f79dd691bf18137b01ed4caa9d Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Wed, 29 Nov 2023 01:17:35 +0100 Subject: [PATCH 04/21] don't work unless JOBS_ENABLED --- worker/job-handlers.ts | 9 ++++++++- worker/job-queue.ts | 6 +++--- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/worker/job-handlers.ts b/worker/job-handlers.ts index 4da33e683..86ca90ba8 100644 --- a/worker/job-handlers.ts +++ b/worker/job-handlers.ts @@ -63,7 +63,14 @@ async function runIfNotAlreadyRunning( export function configureWorkerRoutes(app: Express) { app.post('/', async (req, res, next) => { - const job = req.body as { name: string; chain: string }; + const job = req.body as { name: string; chain: string; run?: boolean }; + + // Worker only works when enabled + if (process.env.JOBS_ENABLED !== 'true' && Boolean(job.run) !== true) { + res.sendStatus(200); + return; + } + console.log(`Current jobqueue length: ${runningJobs.size}`); const chainId = job.chain; initRequestScopedContext(); diff --git a/worker/job-queue.ts b/worker/job-queue.ts index 72a88b281..c41dc8863 100644 --- a/worker/job-queue.ts +++ b/worker/job-queue.ts @@ -10,7 +10,7 @@ class WokerQueue { public async sendWithInterval(json: string, intervalMs: number, deDuplicationId?: string): Promise { try { if (env.WORKER_QUEUE_URL.match(/localhost/)) { - await this.sendLocalMessage(json ); + await this.sendLocalMessage(json); } else { await this.sendMessage(json, deDuplicationId); } @@ -28,8 +28,8 @@ class WokerQueue { public async sendLocalMessage(json: string): Promise { await axios.post(env.WORKER_QUEUE_URL, json, { headers: { - 'Content-Type': 'application/json' - } + 'Content-Type': 'application/json', + }, }); } From 466fbe7262d1614ce2c6764be7216aaa3c15f0c7 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Wed, 29 Nov 2023 03:34:21 +0100 Subject: [PATCH 05/21] use WORKER_QUEUE_URL only in scheduler --- app/env.ts | 5 ++++- worker/job-queue.ts | 16 ++++++++++++---- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/app/env.ts b/app/env.ts index 7ab6f5689..b27d1df07 100644 --- a/app/env.ts +++ b/app/env.ts @@ -30,7 +30,10 @@ export const schema = { optional: true, type: String, }, - WORKER_QUEUE_URL: String, + WORKER_QUEUE_URL: { + optional: true, + type: String, + }, DATABASE_URL: String, }; diff --git a/worker/job-queue.ts b/worker/job-queue.ts index c41dc8863..435db784f 100644 --- a/worker/job-queue.ts +++ b/worker/job-queue.ts @@ -5,16 +5,20 @@ import { SendMessageCommand, SendMessageCommandInput, SQSClient } from '@aws-sdk import { env } from '../app/env'; class WokerQueue { - constructor(private readonly client: SQSClient, private readonly queueUrl: string) {} + constructor(private readonly client: SQSClient, private readonly queueUrl?: string) {} public async sendWithInterval(json: string, intervalMs: number, deDuplicationId?: string): Promise { try { - if (env.WORKER_QUEUE_URL.match(/localhost/)) { + if (this.queueUrl === undefined) { + return; + } + + if (this.queueUrl.match(/localhost/)) { await this.sendLocalMessage(json); } else { await this.sendMessage(json, deDuplicationId); } - console.log(`Sent message to schedule job on queue ${env.WORKER_QUEUE_URL}: ${json}`); + console.log(`Sent message to schedule job on queue ${this.queueUrl}: ${json}`); } catch (error) { console.log(error); Sentry.captureException(error); @@ -26,7 +30,11 @@ class WokerQueue { } public async sendLocalMessage(json: string): Promise { - await axios.post(env.WORKER_QUEUE_URL, json, { + if (this.queueUrl === undefined) { + throw new Error('WORKER_QUEUE_URL is undefined'); + } + + await axios.post(this.queueUrl, json, { headers: { 'Content-Type': 'application/json', }, From 7eed2d5e737c93fbc34ebd96b39aa6617a215d1f Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Thu, 30 Nov 2023 09:14:03 +0100 Subject: [PATCH 06/21] use PROTOCOL only in web tier not needed in workers --- app/env.ts | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/app/env.ts b/app/env.ts index b27d1df07..a782dd24c 100644 --- a/app/env.ts +++ b/app/env.ts @@ -13,7 +13,10 @@ export const schema = { SENTRY_DSN: String, SENTRY_AUTH_TOKEN: String, AWS_REGION: String, - PROTOCOL: String, + PROTOCOL: { + optional: true, + type: String, + }, INFURA_API_KEY: { optional: true, type: String, From ace6b65ecceb0a856d03be370214b0ae3e58bb9c Mon Sep 17 00:00:00 2001 From: franz Date: Fri, 1 Dec 2023 16:05:23 +0100 Subject: [PATCH 07/21] worker switch --- worker/job-handlers.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/worker/job-handlers.ts b/worker/job-handlers.ts index 86ca90ba8..9a0f61675 100644 --- a/worker/job-handlers.ts +++ b/worker/job-handlers.ts @@ -66,7 +66,7 @@ export function configureWorkerRoutes(app: Express) { const job = req.body as { name: string; chain: string; run?: boolean }; // Worker only works when enabled - if (process.env.JOBS_ENABLED !== 'true' && Boolean(job.run) !== true) { + if (process.env.JOBS_ENABLED !== 'true') { res.sendStatus(200); return; } From ba203f1ecd5cf340c192731e65bcd45d277a9991 Mon Sep 17 00:00:00 2001 From: franz Date: Fri, 1 Dec 2023 16:20:23 +0100 Subject: [PATCH 08/21] remove switch --- worker/job-handlers.ts | 6 ------ 1 file changed, 6 deletions(-) diff --git a/worker/job-handlers.ts b/worker/job-handlers.ts index 9a0f61675..802364dae 100644 --- a/worker/job-handlers.ts +++ b/worker/job-handlers.ts @@ -65,12 +65,6 @@ export function configureWorkerRoutes(app: Express) { app.post('/', async (req, res, next) => { const job = req.body as { name: string; chain: string; run?: boolean }; - // Worker only works when enabled - if (process.env.JOBS_ENABLED !== 'true') { - res.sendStatus(200); - return; - } - console.log(`Current jobqueue length: ${runningJobs.size}`); const chainId = job.chain; initRequestScopedContext(); From ad6e4d5d32a9ca571af90801c3c6b53e76a85cde Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 4 Dec 2023 21:44:04 +0100 Subject: [PATCH 09/21] removing run --- worker/job-handlers.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/worker/job-handlers.ts b/worker/job-handlers.ts index 802364dae..a8dffcf31 100644 --- a/worker/job-handlers.ts +++ b/worker/job-handlers.ts @@ -63,7 +63,7 @@ async function runIfNotAlreadyRunning( export function configureWorkerRoutes(app: Express) { app.post('/', async (req, res, next) => { - const job = req.body as { name: string; chain: string; run?: boolean }; + const job = req.body as { name: string; chain: string }; console.log(`Current jobqueue length: ${runningJobs.size}`); const chainId = job.chain; From 532024a2ce5fc1a45df0a0d72aee41f06694d187 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 4 Dec 2023 22:05:06 +0100 Subject: [PATCH 10/21] try to ignore chain errors for sentry --- app.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/app.ts b/app.ts index 0d70d9ef3..49b240ff8 100644 --- a/app.ts +++ b/app.ts @@ -28,6 +28,7 @@ async function startServer() { // tracesSampleRate: 0.005, environment: `multichain-${env.DEPLOYMENT_ENV}`, enabled: env.NODE_ENV === 'production', + ignoreErrors: [/.*error: Provide.*chain.*param/], integrations: [ // new Tracing.Integrations.Apollo(), // new Tracing.Integrations.GraphQL(), From 6effea879154dc116028a69a46eea29beb020aa2 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 4 Dec 2023 22:37:53 +0100 Subject: [PATCH 11/21] sentry job tracing --- worker/job-handlers.ts | 30 +++++++++++++++++++++++++----- worker/worker.ts | 1 + 2 files changed, 26 insertions(+), 5 deletions(-) diff --git a/worker/job-handlers.ts b/worker/job-handlers.ts index a8dffcf31..cc3a2caa6 100644 --- a/worker/job-handlers.ts +++ b/worker/job-handlers.ts @@ -31,14 +31,29 @@ async function runIfNotAlreadyRunning( res.sendStatus(200); return; } + + const sentryTags = { + job: id, + chainId, + }; + + const sentryTransaction = Sentry.startTransaction({ + op: 'http', + name: `POST /${jobId}`, + tags: sentryTags, + }); + + Sentry.configureScope((scope) => scope.setSpan(sentryTransaction)); + + const sentryChildSpan = sentryTransaction.startChild({ + op: 'background-job', + description: `Running job ${jobId}`, + tags: sentryTags, + }); + try { runningJobs.add(jobId); - // TODO, this does not seem to work properly as it is a "global" scope - Sentry.configureScope((scope) => { - scope.setTransactionName(`POST /${jobId}`); - }); - console.time(jobId); console.log(`Start job ${jobId}-start`); @@ -49,12 +64,17 @@ async function runIfNotAlreadyRunning( } console.log(`Successful job ${jobId}-done`); } catch (error) { + Sentry.captureException(error); + if (process.env.AWS_ALERTS === 'true') { await cronsMetricPublisher.publish(`${jobId}-error`); } console.log(`Error job ${jobId}-error`, error); next(error); } finally { + sentryChildSpan.finish(); + sentryTransaction.finish(); + runningJobs.delete(jobId); console.timeEnd(jobId); res.sendStatus(200); diff --git a/worker/worker.ts b/worker/worker.ts index 325aefb2d..5ba9d73be 100644 --- a/worker/worker.ts +++ b/worker/worker.ts @@ -14,6 +14,7 @@ export async function startWorker() { // new Tracing.Integrations.Express({ app }), new Sentry.Integrations.Http({ tracing: true }), ], + tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.2 : 1.0, }); app.use(Sentry.Handlers.requestHandler()); From aca5617b9cc1ee340bffe4ec0680a17ac2e41bae Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Mon, 4 Dec 2023 22:51:54 +0100 Subject: [PATCH 12/21] sentry profiling --- package.json | 3 +- worker/worker.ts | 2 + yarn.lock | 533 ++++++++++++++++++++++++++++++++++++++++++++--- 3 files changed, 505 insertions(+), 33 deletions(-) diff --git a/package.json b/package.json index 5c7bd2869..f02ca2c23 100644 --- a/package.json +++ b/package.json @@ -29,7 +29,8 @@ "@graphql-tools/merge": "^8.2.1", "@prisma/client": "^4.1.1", "@sanity/client": "^2.23.1", - "@sentry/node": "^7.56.0", + "@sentry/node": "^7.0.0", + "@sentry/profiling-node": "^1.2.6", "@sentry/tracing": "^7.56.0", "apollo-server-core": "^3.5.0", "apollo-server-express": "^3.5.0", diff --git a/worker/worker.ts b/worker/worker.ts index 5ba9d73be..857349c42 100644 --- a/worker/worker.ts +++ b/worker/worker.ts @@ -1,5 +1,6 @@ import express from 'express'; import * as Sentry from '@sentry/node'; +import { ProfilingIntegration } from '@sentry/profiling-node'; import { env } from '../app/env'; import { configureWorkerRoutes } from './job-handlers'; @@ -13,6 +14,7 @@ export async function startWorker() { integrations: [ // new Tracing.Integrations.Express({ app }), new Sentry.Integrations.Http({ tracing: true }), + new ProfilingIntegration(), ], tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.2 : 1.0, }); diff --git a/yarn.lock b/yarn.lock index 1c3313ada..4c8f3ad55 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3093,6 +3093,11 @@ "@ethersproject/properties" "^5.5.0" "@ethersproject/strings" "^5.5.0" +"@gar/promisify@^1.1.3": + version "1.1.3" + resolved "https://registry.yarnpkg.com/@gar/promisify/-/promisify-1.1.3.tgz#555193ab2e3bb3b6adc3d551c9c030d9e860daf6" + integrity sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw== + "@gnosis.pm/safe-core-sdk-types@^0.1.1": version "0.1.1" resolved "https://registry.yarnpkg.com/@gnosis.pm/safe-core-sdk-types/-/safe-core-sdk-types-0.1.1.tgz#908c394cb4660493b4e9c8e01b5a7aa36efafd30" @@ -3867,6 +3872,22 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" +"@npmcli/fs@^2.1.0": + version "2.1.2" + resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-2.1.2.tgz#a9e2541a4a2fec2e69c29b35e6060973da79b865" + integrity sha512-yOJKRvohFOaLqipNtwYB9WugyZKhC/DZC4VYPmpaCzDBrA8YpK3qHZ8/HGscMnE4GqbkLNuVcCnxkeQEdGt6LQ== + dependencies: + "@gar/promisify" "^1.1.3" + semver "^7.3.5" + +"@npmcli/move-file@^2.0.0": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-2.0.1.tgz#26f6bdc379d87f75e55739bab89db525b06100e4" + integrity sha512-mJd2Z5TjYWq/ttPLLGqArdtnC74J6bOzg4rMDnN+p1xTacZ2yPRCk2y0oSWQtygLR9YVQXgOcONrwtnk3JupxQ== + dependencies: + mkdirp "^1.0.4" + rimraf "^3.0.2" + "@open-draft/until@^1.0.3": version "1.0.3" resolved "https://registry.yarnpkg.com/@open-draft/until/-/until-1.0.3.tgz#db9cc719191a62e7d9200f6e7bab21c5b848adca" @@ -4003,6 +4024,15 @@ "@sentry/utils" "7.56.0" tslib "^1.9.3" +"@sentry-internal/tracing@7.85.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry-internal/tracing/-/tracing-7.85.0.tgz#1b4781a61e1e43badeff826cf40abe33dd760f1d" + integrity sha512-p3YMUwkPCy2su9cm/3+7QYR4RiMI0+07DU1BZtht9NLTzY2O87/yvUbn1v2yHR3vJQTy/+7N0ud9/mPBFznRQQ== + dependencies: + "@sentry/core" "7.85.0" + "@sentry/types" "7.85.0" + "@sentry/utils" "7.85.0" + "@sentry/core@7.56.0": version "7.56.0" resolved "https://registry.yarnpkg.com/@sentry/core/-/core-7.56.0.tgz#f4253e0d61f55444180a63e5278b62e57303f7cf" @@ -4012,19 +4042,47 @@ "@sentry/utils" "7.56.0" tslib "^1.9.3" -"@sentry/node@^7.56.0": - version "7.56.0" - resolved "https://registry.yarnpkg.com/@sentry/node/-/node-7.56.0.tgz#ddeb34a848c8a544d0dbb5f2c3031615be040d2b" - integrity sha512-QXbWy/ypRxfFd8iP6zLvHInYZyjGKPrkVNYt43mhKAZHm764NxX/29vDfj1FztgG9Z6lVLIG2eyqTvLruYmsWw== +"@sentry/core@7.85.0", "@sentry/core@^7.76.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry/core/-/core-7.85.0.tgz#dd90d772a5f75ff674f931f59b22a3fc286d0983" + integrity sha512-DFDAc4tWmHN5IWhr7XbHCiyF1Xgb95jz8Uj/JTX9atlgodId1UIbER77qpEmH3eQGid/QBdqrlR98zCixgSbwg== dependencies: - "@sentry-internal/tracing" "7.56.0" - "@sentry/core" "7.56.0" - "@sentry/types" "7.56.0" - "@sentry/utils" "7.56.0" - cookie "^0.4.1" + "@sentry/types" "7.85.0" + "@sentry/utils" "7.85.0" + +"@sentry/hub@^7.76.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry/hub/-/hub-7.85.0.tgz#503d1e0acc17a55f79ec27a7722168c0f6b12fb1" + integrity sha512-08Vq+N7P538D68HpIq4GpvGkqc2zj3yk0Xh5z0xYBf4QoTDTzeELt9Ryi5lCW9mgXVzHbKbgzcxIO1EE4FugoA== + dependencies: + "@sentry/core" "7.85.0" + "@sentry/types" "7.85.0" + "@sentry/utils" "7.85.0" + +"@sentry/node@^7.0.0", "@sentry/node@^7.76.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry/node/-/node-7.85.0.tgz#cf4e6022b5cd1f3fb007186c5e04427b108ebe1d" + integrity sha512-uiBtRW9G017NHoCXBlK3ttkTwHXLFyI8ndHpaObtyajKTv3ptGIThVEn7DuK7Pwor//RjwjSEEOa7WDK+FdMVQ== + dependencies: + "@sentry-internal/tracing" "7.85.0" + "@sentry/core" "7.85.0" + "@sentry/types" "7.85.0" + "@sentry/utils" "7.85.0" https-proxy-agent "^5.0.0" - lru_map "^0.3.3" - tslib "^1.9.3" + +"@sentry/profiling-node@^1.2.6": + version "1.2.6" + resolved "https://registry.yarnpkg.com/@sentry/profiling-node/-/profiling-node-1.2.6.tgz#e43494896657bcfd11e75480ed6def4172e86c21" + integrity sha512-WsXO7VmLze5wPWHpvoRZFTtN+wHw9lYWKZs4T2FwPmvfNVaScGJey/+Wp51aM47Yy12Gj9n/BpqFYDsUXRLMvw== + dependencies: + "@sentry/core" "^7.76.0" + "@sentry/hub" "^7.76.0" + "@sentry/node" "^7.76.0" + "@sentry/types" "^7.76.0" + "@sentry/utils" "^7.76.0" + detect-libc "^2.0.2" + node-abi "^3.47.0" + node-gyp "^9.4.0" "@sentry/tracing@^7.56.0": version "7.56.0" @@ -4038,6 +4096,11 @@ resolved "https://registry.yarnpkg.com/@sentry/types/-/types-7.56.0.tgz#9042a099cf9e8816d081886d24b88082a5d9f87a" integrity sha512-5WjhVOQm75ItOytOx2jTx+5yw8/qJ316+g1Di8dS9+kgIi1zniqdMcX00C2yYe3FMUgFB49PegCUYulm9Evapw== +"@sentry/types@7.85.0", "@sentry/types@^7.76.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry/types/-/types-7.85.0.tgz#648488b90f958ca6a86922cc5d26004853410ba6" + integrity sha512-R5jR4XkK5tBU2jDiPdSVqzkmjYRr666bcGaFGUHB/xDQCjPsjk+pEmCCL+vpuWoaZmQJUE1hVU7rgnVX81w8zg== + "@sentry/utils@7.56.0": version "7.56.0" resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-7.56.0.tgz#e60e4935d17b2197584abf6ce61b522ad055352c" @@ -4046,6 +4109,13 @@ "@sentry/types" "7.56.0" tslib "^1.9.3" +"@sentry/utils@7.85.0", "@sentry/utils@^7.76.0": + version "7.85.0" + resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-7.85.0.tgz#b84467fd07bc2ef09fdf382ddcdcdc3f5b0d78b0" + integrity sha512-JZ7seNOLvhjAQ8GeB3GYknPQJkuhF88xAYOaESZP3xPOWBMFUN+IO4RqjMqMLFDniOwsVQS7GB/MfP+hxufieg== + dependencies: + "@sentry/types" "7.85.0" + "@sinclair/typebox@^0.24.1": version "0.24.43" resolved "https://registry.yarnpkg.com/@sinclair/typebox/-/typebox-0.24.43.tgz#2e2bce0e5e493aaf639beed0cd6c88cfde7dd3d7" @@ -4952,7 +5022,7 @@ resolved "https://registry.yarnpkg.com/@zxing/text-encoding/-/text-encoding-0.9.0.tgz#fb50ffabc6c7c66a0c96b4c03e3d9be74864b70b" integrity sha512-U/4aVJ2mxI0aDNI8Uq0wEhMgY+u4CNtEb0om3+y3+niDAsoTCOB33UF0sxpzqzdqXLqmvc+vZyAt4O8pPdfkwA== -abbrev@1: +abbrev@1, abbrev@^1.0.0: version "1.1.1" resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== @@ -4992,13 +5062,28 @@ aes-js@3.0.0: resolved "https://registry.yarnpkg.com/aes-js/-/aes-js-3.0.0.tgz#e21df10ad6c2053295bcbb8dab40b09dbea87e4d" integrity sha1-4h3xCtbCBTKVvLuNq0Cwnb6ofk0= -agent-base@6: +agent-base@6, agent-base@^6.0.2: version "6.0.2" resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== dependencies: debug "4" +agentkeepalive@^4.2.1: + version "4.5.0" + resolved "https://registry.yarnpkg.com/agentkeepalive/-/agentkeepalive-4.5.0.tgz#2673ad1389b3c418c5a20c5d7364f93ca04be923" + integrity sha512-5GG/5IbQQpC9FpkRGsSvZI5QYeSCzlJHdpBQntCsuTOxhKD8lqKhrleg2Yi7yvMIf82Ycmmqln9U8V9qwEiJew== + dependencies: + humanize-ms "^1.2.1" + +aggregate-error@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" + integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== + dependencies: + clean-stack "^2.0.0" + indent-string "^4.0.0" + ansi-align@^3.0.0: version "3.0.1" resolved "https://registry.yarnpkg.com/ansi-align/-/ansi-align-3.0.1.tgz#0cdf12e111ace773a86e9a1fad1225c43cb19a59" @@ -5178,6 +5263,11 @@ apollo-server-types@^3.4.0: apollo-server-caching "^3.3.0" apollo-server-env "^4.2.0" +"aproba@^1.0.3 || ^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" + integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== + archiver-utils@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/archiver-utils/-/archiver-utils-2.1.0.tgz#e8a460e94b693c3e3da182a098ca6285ba9249e2" @@ -5207,6 +5297,14 @@ archiver@^5.3.0: tar-stream "^2.2.0" zip-stream "^4.1.0" +are-we-there-yet@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz#679df222b278c64f2cdba1175cdc00b0d96164bd" + integrity sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg== + dependencies: + delegates "^1.0.0" + readable-stream "^3.6.0" + arg@^4.1.0: version "4.1.3" resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" @@ -5516,6 +5614,13 @@ brace-expansion@^1.1.7: balanced-match "^1.0.0" concat-map "0.0.1" +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + braces@^3.0.1, braces@^3.0.2, braces@~3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" @@ -5652,6 +5757,30 @@ cac@^6.7.14: resolved "https://registry.yarnpkg.com/cac/-/cac-6.7.14.tgz#804e1e6f506ee363cb0e3ccbb09cad5dd9870959" integrity sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ== +cacache@^16.1.0: + version "16.1.3" + resolved "https://registry.yarnpkg.com/cacache/-/cacache-16.1.3.tgz#a02b9f34ecfaf9a78c9f4bc16fceb94d5d67a38e" + integrity sha512-/+Emcj9DAXxX4cwlLmRI9c166RuL3w30zp4R7Joiv2cQTtTtA+jeuCAjH3ZlGnYS3tKENSrKhAzVVP9GVyzeYQ== + dependencies: + "@npmcli/fs" "^2.1.0" + "@npmcli/move-file" "^2.0.0" + chownr "^2.0.0" + fs-minipass "^2.1.0" + glob "^8.0.1" + infer-owner "^1.0.4" + lru-cache "^7.7.1" + minipass "^3.1.6" + minipass-collect "^1.0.2" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.4" + mkdirp "^1.0.4" + p-map "^4.0.0" + promise-inflight "^1.0.1" + rimraf "^3.0.2" + ssri "^9.0.0" + tar "^6.1.11" + unique-filename "^2.0.0" + cacheable-request@^6.0.0: version "6.1.0" resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" @@ -5858,6 +5987,11 @@ chownr@^1.1.1: resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== +chownr@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" + integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== + ci-info@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" @@ -5881,6 +6015,11 @@ cjs-module-lexer@^1.0.0: resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz#9f84ba3244a512f3a54e5277e8eef4c489864e40" integrity sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA== +clean-stack@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" + integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== + cli-boxes@^2.2.1: version "2.2.1" resolved "https://registry.yarnpkg.com/cli-boxes/-/cli-boxes-2.2.1.tgz#ddd5035d25094fce220e9cab40a45840a440318f" @@ -5987,6 +6126,11 @@ color-name@~1.1.4: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== +color-support@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" + integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== + combined-stream@^1.0.8: version "1.0.8" resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" @@ -6050,6 +6194,11 @@ configstore@^5.0.1: write-file-atomic "^3.0.0" xdg-basedir "^4.0.0" +console-control-strings@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" + integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== + constant-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/constant-case/-/constant-case-3.0.4.tgz#3b84a9aeaf4cf31ec45e6bf5de91bdfb0589faf1" @@ -6088,7 +6237,7 @@ cookie@0.4.0: resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== -cookie@^0.4.1, cookie@^0.4.2: +cookie@^0.4.2: version "0.4.2" resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.2.tgz#0e41f24de5ecf317947c82fc789e06a884824432" integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== @@ -6363,6 +6512,11 @@ delayed-stream@~1.0.0: resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== +delegates@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" + integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== + depd@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" @@ -6383,6 +6537,11 @@ detect-indent@^6.0.0: resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-6.1.0.tgz#592485ebbbf6b3b1ab2be175c8393d04ca0d57e6" integrity sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA== +detect-libc@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.0.2.tgz#8ccf2ba9315350e1241b88d0ac3b0e1fbd99605d" + integrity sha512-UX6sGumvvqSaXgdKGUsgZWqcUyIXZ/vZTrlRT/iobiKhGL0zL4d3osHj3uqllWJK+i+sixDS/3COVEOFbupFyw== + detect-newline@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" @@ -6520,7 +6679,7 @@ encodeurl@~1.0.2: resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= -encoding@^0.1.11: +encoding@^0.1.11, encoding@^0.1.13: version "0.1.13" resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== @@ -6539,6 +6698,16 @@ entities@2.2.0: resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== +env-paths@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" + integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== + +err-code@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" + integrity sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA== + error-ex@^1.3.1: version "1.3.2" resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" @@ -6835,6 +7004,11 @@ expect@^28.0.0, expect@^28.1.3: jest-message-util "^28.1.3" jest-util "^28.1.3" +exponential-backoff@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/exponential-backoff/-/exponential-backoff-3.1.1.tgz#64ac7526fe341ab18a39016cd22c787d01e00bf6" + integrity sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw== + express-promise-router@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/express-promise-router/-/express-promise-router-4.1.0.tgz#79160e145c27610ba411bceb0552a36f11dbab4f" @@ -7099,6 +7273,13 @@ fs-constants@^1.0.0: resolved "https://registry.yarnpkg.com/fs-constants/-/fs-constants-1.0.0.tgz#6be0de9be998ce16af8afc24497b9ee9b7ccd9ad" integrity sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow== +fs-minipass@^2.0.0, fs-minipass@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" + integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== + dependencies: + minipass "^3.0.0" + fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" @@ -7129,6 +7310,20 @@ functions-have-names@^1.2.2: resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== +gauge@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/gauge/-/gauge-4.0.4.tgz#52ff0652f2bbf607a989793d53b751bef2328dce" + integrity sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg== + dependencies: + aproba "^1.0.3 || ^2.0.0" + color-support "^1.1.3" + console-control-strings "^1.1.0" + has-unicode "^2.0.1" + signal-exit "^3.0.7" + string-width "^4.2.3" + strip-ansi "^6.0.1" + wide-align "^1.1.5" + gaxios@^5.0.0, gaxios@^5.0.1: version "5.0.2" resolved "https://registry.yarnpkg.com/gaxios/-/gaxios-5.0.2.tgz#ca3a40e851c728d31d7001c2357062d46bf966d1" @@ -7260,6 +7455,17 @@ glob@^7.1.1, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6, glob@^7.2.0: once "^1.3.0" path-is-absolute "^1.0.0" +glob@^8.0.1: + version "8.1.0" + resolved "https://registry.yarnpkg.com/glob/-/glob-8.1.0.tgz#d388f656593ef708ee3e34640fdfb99a9fd1c33e" + integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^5.0.1" + once "^1.3.0" + global-dirs@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-3.0.0.tgz#70a76fe84ea315ab37b1f5576cbde7d48ef72686" @@ -7348,6 +7554,11 @@ graceful-fs@^4.1.2, graceful-fs@^4.2.0, graceful-fs@^4.2.4: resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.8.tgz#e412b8d33f5e006593cbd3cee6df9f2cebbe802a" integrity sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg== +graceful-fs@^4.2.6: + version "4.2.11" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" + integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== + graceful-fs@^4.2.9: version "4.2.10" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" @@ -7495,6 +7706,11 @@ has-tostringtag@^1.0.0: dependencies: has-symbols "^1.0.2" +has-unicode@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" + integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== + has-yarn@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-2.1.0.tgz#137e11354a7b5bf11aa5cb649cf0c6f3ff2b2e77" @@ -7561,6 +7777,11 @@ http-cache-semantics@^4.0.0: resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== +http-cache-semantics@^4.1.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz#abe02fcb2985460bf0323be664436ec3476a6d5a" + integrity sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ== + http-errors@1.7.2: version "1.7.2" resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.2.tgz#4f5029cf13239f31036e5b2e55292bcfbcc85c8f" @@ -7630,6 +7851,13 @@ human-signals@^2.1.0: resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== +humanize-ms@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/humanize-ms/-/humanize-ms-1.2.1.tgz#c46e3159a293f6b896da29316d8b6fe8bb79bbed" + integrity sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ== + dependencies: + ms "^2.0.0" + iconv-lite@0.4.24, iconv-lite@^0.4.24: version "0.4.24" resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" @@ -7700,6 +7928,16 @@ indent-string@^3.0.0: resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-3.2.0.tgz#4a5fd6d27cc332f37e5419a504dbb837105c9289" integrity sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok= +indent-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" + integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== + +infer-owner@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" + integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== + inflight@^1.0.4: version "1.0.6" resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" @@ -7792,6 +8030,11 @@ invariant@^2.2.4: dependencies: loose-envify "^1.0.0" +ip@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ip/-/ip-2.0.0.tgz#4cf4ab182fee2314c75ede1276f8c80b479936da" + integrity sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ== + ipaddr.js@1.9.1: version "1.9.1" resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" @@ -7927,6 +8170,11 @@ is-interactive@^1.0.0: resolved "https://registry.yarnpkg.com/is-interactive/-/is-interactive-1.0.0.tgz#cea6e6ae5c870a7b0a0004070b7b587e0252912e" integrity sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w== +is-lambda@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-lambda/-/is-lambda-1.0.1.tgz#3d9877899e6a53efc0160504cde15f82e6f061d5" + integrity sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ== + is-lower-case@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/is-lower-case/-/is-lower-case-2.0.2.tgz#1c0884d3012c841556243483aa5d522f47396d2a" @@ -9034,10 +9282,10 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" -lru_map@^0.3.3: - version "0.3.3" - resolved "https://registry.yarnpkg.com/lru_map/-/lru_map-0.3.3.tgz#b5c8351b9464cbd750335a79650a0ec0e56118dd" - integrity sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ== +lru-cache@^7.7.1: + version "7.18.3" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-7.18.3.tgz#f793896e0fd0e954a59dfdd82f0773808df6aa89" + integrity sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA== lz-string@1.5.0: version "1.5.0" @@ -9063,6 +9311,28 @@ make-error@1.x, make-error@^1, make-error@^1.1.1, make-error@^1.3.0: resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== +make-fetch-happen@^10.0.3: + version "10.2.1" + resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-10.2.1.tgz#f5e3835c5e9817b617f2770870d9492d28678164" + integrity sha512-NgOPbRiaQM10DYXvN3/hhGVI2M5MtITFryzBGxHM5p4wnFxsVCbxkrBrDsk+EZ5OB4jEOT7AjDxtdF+KVEFT7w== + dependencies: + agentkeepalive "^4.2.1" + cacache "^16.1.0" + http-cache-semantics "^4.1.0" + http-proxy-agent "^5.0.0" + https-proxy-agent "^5.0.0" + is-lambda "^1.0.1" + lru-cache "^7.7.1" + minipass "^3.1.6" + minipass-collect "^1.0.2" + minipass-fetch "^2.0.3" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.4" + negotiator "^0.6.3" + promise-retry "^2.0.1" + socks-proxy-agent "^7.0.0" + ssri "^9.0.0" + makeerror@1.0.12: version "1.0.12" resolved "https://registry.yarnpkg.com/makeerror/-/makeerror-1.0.12.tgz#3e5dd2079a82e812e983cc6610c4a2cb0eaa801a" @@ -9196,17 +9466,83 @@ minimatch@3.0.4, minimatch@^3.0.4: dependencies: brace-expansion "^1.1.7" +minimatch@^5.0.1: + version "5.1.6" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" + integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== + dependencies: + brace-expansion "^2.0.1" + minimist@^1.2.0, minimist@^1.2.5: version "1.2.5" resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== +minipass-collect@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" + integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== + dependencies: + minipass "^3.0.0" + +minipass-fetch@^2.0.3: + version "2.1.2" + resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-2.1.2.tgz#95560b50c472d81a3bc76f20ede80eaed76d8add" + integrity sha512-LT49Zi2/WMROHYoqGgdlQIZh8mLPZmOrN2NdJjMXxYe4nkN6FUyuPuOAOedNJDrx0IRGg9+4guZewtp8hE6TxA== + dependencies: + minipass "^3.1.6" + minipass-sized "^1.0.3" + minizlib "^2.1.2" + optionalDependencies: + encoding "^0.1.13" + +minipass-flush@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" + integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== + dependencies: + minipass "^3.0.0" + +minipass-pipeline@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" + integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== + dependencies: + minipass "^3.0.0" + +minipass-sized@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/minipass-sized/-/minipass-sized-1.0.3.tgz#70ee5a7c5052070afacfbc22977ea79def353b70" + integrity sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g== + dependencies: + minipass "^3.0.0" + +minipass@^3.0.0, minipass@^3.1.1, minipass@^3.1.6: + version "3.3.6" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.3.6.tgz#7bba384db3a1520d18c9c0e5251c3444e95dd94a" + integrity sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw== + dependencies: + yallist "^4.0.0" + +minipass@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" + integrity sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ== + +minizlib@^2.1.1, minizlib@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" + integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== + dependencies: + minipass "^3.0.0" + yallist "^4.0.0" + mkdirp-classic@^0.5.2: 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@^1.0.4: +mkdirp@^1.0.3, mkdirp@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== @@ -9248,7 +9584,7 @@ ms@2.1.2: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== -ms@^2.1.1: +ms@^2.0.0, ms@^2.1.1: version "2.1.3" resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== @@ -9309,6 +9645,11 @@ negotiator@0.6.2: resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== +negotiator@^0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + no-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" @@ -9317,6 +9658,13 @@ no-case@^3.0.4: lower-case "^2.0.2" tslib "^2.0.3" +node-abi@^3.47.0: + version "3.51.0" + resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-3.51.0.tgz#970bf595ef5a26a271307f8a4befa02823d4e87d" + integrity sha512-SQkEP4hmNWjlniS5zdnfIXTk1x7Ome85RDzHlTbBtzE97Gfwz/Ipw4v/Ryk20DWIy3yCNVLVlGKApCnmvYoJbA== + dependencies: + semver "^7.3.5" + node-addon-api@^2.0.0: version "2.0.2" resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-2.0.2.tgz#432cfa82962ce494b132e9d72a15b29f71ff5d32" @@ -9366,6 +9714,23 @@ node-gyp-build@^4.2.0: resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.3.0.tgz#9f256b03e5826150be39c764bf51e993946d71a3" integrity sha512-iWjXZvmboq0ja1pUGULQBexmxq8CV4xBhX7VDOTbL7ZR4FOowwY/VOtRxBN/yKxmdGoIp4j5ysNT4u3S2pDQ3Q== +node-gyp@^9.4.0: + version "9.4.1" + resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-9.4.1.tgz#8a1023e0d6766ecb52764cc3a734b36ff275e185" + integrity sha512-OQkWKbjQKbGkMf/xqI1jjy3oCTgMKJac58G2+bjZb3fza6gW2YrCSdMQYaoTb70crvE//Gngr4f0AgVHmqHvBQ== + dependencies: + env-paths "^2.2.0" + exponential-backoff "^3.1.1" + glob "^7.1.4" + graceful-fs "^4.2.6" + make-fetch-happen "^10.0.3" + nopt "^6.0.0" + npmlog "^6.0.0" + rimraf "^3.0.2" + semver "^7.3.5" + tar "^6.1.2" + which "^2.0.2" + node-int64@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" @@ -9397,6 +9762,13 @@ nodemon@^2.0.15: undefsafe "^2.0.5" update-notifier "^5.1.0" +nopt@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/nopt/-/nopt-6.0.0.tgz#245801d8ebf409c6df22ab9d95b65e1309cdb16d" + integrity sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g== + dependencies: + abbrev "^1.0.0" + nopt@~1.0.10: version "1.0.10" resolved "https://registry.yarnpkg.com/nopt/-/nopt-1.0.10.tgz#6ddd21bd2a31417b92727dd585f8a6f37608ebee" @@ -9428,6 +9800,16 @@ npm-run-path@^4.0.0, npm-run-path@^4.0.1: dependencies: path-key "^3.0.0" +npmlog@^6.0.0: + version "6.0.2" + resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-6.0.2.tgz#c8166017a42f2dea92d6453168dd865186a70830" + integrity sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg== + dependencies: + are-we-there-yet "^3.0.0" + console-control-strings "^1.1.0" + gauge "^4.0.3" + set-blocking "^2.0.0" + nullthrows@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/nullthrows/-/nullthrows-1.1.1.tgz#7818258843856ae971eae4208ad7d7eb19a431b1" @@ -9581,6 +9963,13 @@ p-map@^2.0.0: resolved "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz#310928feef9c9ecc65b68b17693018a665cea175" integrity sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw== +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + p-try@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" @@ -9833,6 +10222,19 @@ progress-stream@^2.0.0: speedometer "~1.0.0" through2 "~2.0.3" +promise-inflight@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" + integrity sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g== + +promise-retry@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" + integrity sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g== + dependencies: + err-code "^2.0.2" + retry "^0.12.0" + promise@^7.1.1: version "7.3.1" resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf" @@ -10143,12 +10545,17 @@ retry@0.13.1: resolved "https://registry.yarnpkg.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" integrity sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg== +retry@^0.12.0: + version "0.12.0" + resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" + integrity sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow== + reusify@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== -rimraf@^3.0.0: +rimraf@^3.0.0, rimraf@^3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== @@ -10419,6 +10826,11 @@ slice-ansi@0.0.4: resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-0.0.4.tgz#edbf8903f66f7ce2f8eafd6ceed65e264c831b35" integrity sha1-7b+JA/ZvfOL46v1s7tZeJkyDGzU= +smart-buffer@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" + integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== + snake-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/snake-case/-/snake-case-3.0.4.tgz#4f2bbd568e9935abdfd593f34c691dadb49c452c" @@ -10427,6 +10839,23 @@ snake-case@^3.0.4: dot-case "^3.0.4" tslib "^2.0.3" +socks-proxy-agent@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-7.0.0.tgz#dc069ecf34436621acb41e3efa66ca1b5fed15b6" + integrity sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww== + dependencies: + agent-base "^6.0.2" + debug "^4.3.3" + socks "^2.6.2" + +socks@^2.6.2: + version "2.7.1" + resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.1.tgz#d8e651247178fde79c0663043e07240196857d55" + integrity sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ== + dependencies: + ip "^2.0.0" + smart-buffer "^4.2.0" + sonic-boom@^2.1.0: version "2.3.1" resolved "https://registry.yarnpkg.com/sonic-boom/-/sonic-boom-2.3.1.tgz#e6572184fb3adf145dbfeccff48141bbd1009e4c" @@ -10511,6 +10940,13 @@ ssh2@^1.4.0: cpu-features "0.0.2" nan "^2.15.0" +ssri@^9.0.0: + version "9.0.1" + resolved "https://registry.yarnpkg.com/ssri/-/ssri-9.0.1.tgz#544d4c357a8d7b71a19700074b6883fcb4eae057" + integrity sha512-o57Wcn66jMQvfHG1FlYbWeZWW/dHZhJXjpIcTfXldXEk5nz5lStPo3mK0OJQfGR3RbZUlbISexbljkJzuEj/8Q== + dependencies: + minipass "^3.1.1" + stack-utils@^2.0.3: version "2.0.5" resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.5.tgz#d25265fca995154659dbbfba3b49254778d2fdd5" @@ -10590,15 +11026,7 @@ string-width@^1.0.1: is-fullwidth-code-point "^1.0.0" strip-ansi "^3.0.0" -string-width@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" - integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== - dependencies: - is-fullwidth-code-point "^2.0.0" - strip-ansi "^4.0.0" - -string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.2, string-width@^4.2.3: +"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.2, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -10607,6 +11035,14 @@ string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2 is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" +string-width@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" + integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== + dependencies: + is-fullwidth-code-point "^2.0.0" + strip-ansi "^4.0.0" + string.prototype.trimend@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.5.tgz#914a65baaab25fbdd4ee291ca7dde57e869cb8d0" @@ -10795,6 +11231,18 @@ tar-stream@^2.0.0, tar-stream@^2.1.4, tar-stream@^2.2.0: inherits "^2.0.3" readable-stream "^3.1.1" +tar@^6.1.11, tar@^6.1.2: + version "6.2.0" + resolved "https://registry.yarnpkg.com/tar/-/tar-6.2.0.tgz#b14ce49a79cb1cd23bc9b016302dea5474493f73" + integrity sha512-/Wo7DcT0u5HUV486xg675HtjNd3BXZ6xDbzsCUZPt5iw8bTQ63bP0Raut3mvro9u+CUyq7YQd8Cx55fsZXxqLQ== + dependencies: + chownr "^2.0.0" + fs-minipass "^2.0.0" + minipass "^5.0.0" + minizlib "^2.1.1" + mkdirp "^1.0.3" + yallist "^4.0.0" + terminal-link@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" @@ -11083,6 +11531,20 @@ undici@^4.9.3: resolved "https://registry.yarnpkg.com/undici/-/undici-4.10.0.tgz#f2684de9cbe2ab0a85a477ce0ec59b739be4438d" integrity sha512-W7NwyQzfiSYIZ+maOvz/u9tPFyAYhstF9XhtohK7txvD1jg41oatcHVq6Zls81LhzGvh4BN5WpQGuMiT4IipoA== +unique-filename@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-2.0.1.tgz#e785f8675a9a7589e0ac77e0b5c34d2eaeac6da2" + integrity sha512-ODWHtkkdx3IAR+veKxFV+VBkUMcN+FaqzUUd7IZzt+0zhDZFPFxhlqwPF3YQvMHx1TD0tdgYl+kuPnJ8E6ql7A== + dependencies: + unique-slug "^3.0.0" + +unique-slug@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-3.0.0.tgz#6d347cf57c8a7a7a6044aabd0e2d74e4d76dc7c9" + integrity sha512-8EyMynh679x/0gqE9fT9oilG+qEt+ibFyqjuVTsZn1+CMxH+XLlpvr2UZx4nVcCwTpx81nICr2JQFkM+HPLq4w== + dependencies: + imurmurhash "^0.1.4" + unique-string@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" @@ -11349,7 +11811,7 @@ which-typed-array@^1.1.2: has-tostringtag "^1.0.0" is-typed-array "^1.1.9" -which@^2.0.1: +which@^2.0.1, which@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== @@ -11364,6 +11826,13 @@ why-is-node-running@^2.2.2: siginfo "^2.0.0" stackback "0.0.2" +wide-align@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" + integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== + dependencies: + string-width "^1.0.2 || 2 || 3 || 4" + widest-line@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" From 0338af5af3c9eb6529476c3b93e564468af8b9f1 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 12:07:10 +0100 Subject: [PATCH 13/21] prisma binary target for linux2 --- prisma/base.prisma | 2 +- prisma/schema.prisma | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prisma/base.prisma b/prisma/base.prisma index 8a55320cb..ed3ed1715 100644 --- a/prisma/base.prisma +++ b/prisma/base.prisma @@ -3,7 +3,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] } datasource db { diff --git a/prisma/schema.prisma b/prisma/schema.prisma index e3de046e7..3872f129d 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -5,7 +5,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] } datasource db { From 06ab601d78d08d655289e750fb4bfdb8c82907d8 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 13:39:49 +0100 Subject: [PATCH 14/21] isolating prisma binary target --- prisma/base.prisma | 2 +- prisma/schema.prisma | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prisma/base.prisma b/prisma/base.prisma index ed3ed1715..5793c1606 100644 --- a/prisma/base.prisma +++ b/prisma/base.prisma @@ -3,7 +3,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] } datasource db { diff --git a/prisma/schema.prisma b/prisma/schema.prisma index 3872f129d..988be5d51 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -5,7 +5,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] } datasource db { From 91049dc4ae1a0ada653a6e6a09fdaaccd5734e8e Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 14:46:05 +0100 Subject: [PATCH 15/21] readding prisma new bin --- prisma/base.prisma | 2 +- prisma/schema.prisma | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prisma/base.prisma b/prisma/base.prisma index 5793c1606..ed3ed1715 100644 --- a/prisma/base.prisma +++ b/prisma/base.prisma @@ -3,7 +3,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] } datasource db { diff --git a/prisma/schema.prisma b/prisma/schema.prisma index 988be5d51..3872f129d 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -5,7 +5,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] } datasource db { From d5469a4bb7f75bf8a1bee15ed5507cb96cffef22 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 17:39:00 +0100 Subject: [PATCH 16/21] prisma bin rollback --- prisma/base.prisma | 2 +- prisma/schema.prisma | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prisma/base.prisma b/prisma/base.prisma index ed3ed1715..5793c1606 100644 --- a/prisma/base.prisma +++ b/prisma/base.prisma @@ -3,7 +3,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] } datasource db { diff --git a/prisma/schema.prisma b/prisma/schema.prisma index 3872f129d..988be5d51 100644 --- a/prisma/schema.prisma +++ b/prisma/schema.prisma @@ -5,7 +5,7 @@ generator client { provider = "prisma-client-js" - binaryTargets = ["native", "linux-arm64-openssl-1.0.x", "linux-arm64-openssl-3.0.x"] + binaryTargets = ["native", "linux-arm64-openssl-1.0.x"] //, "linux-arm64-openssl-3.0.x"] } datasource db { From 38b98190cd655a58972c427eddd360e75ad3bffa Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 18:15:58 +0100 Subject: [PATCH 17/21] fix: pool volumes beyond reasonable range --- modules/pool/lib/pool-usd-data.service.ts | 98 +++++++++++++---------- 1 file changed, 54 insertions(+), 44 deletions(-) diff --git a/modules/pool/lib/pool-usd-data.service.ts b/modules/pool/lib/pool-usd-data.service.ts index 9191a273c..9734446d6 100644 --- a/modules/pool/lib/pool-usd-data.service.ts +++ b/modules/pool/lib/pool-usd-data.service.ts @@ -282,61 +282,71 @@ export class PoolUsdDataService { for (const pool of subgraphPools) { const staked = stakedUsers.find((stakedUser) => stakedUser.poolId === pool.id); - updates.push( - prisma.prismaPoolDynamicData.update({ + // Limit numbers, as we have seen some pools with skewd values + const max = 1e18; + const lifetimeVolume = Math.min(parseFloat(pool.totalSwapVolume), max); + const lifetimeSwapFees = Math.min(parseFloat(pool.totalSwapFee), max); + + // updates.push( + try { + await prisma.prismaPoolDynamicData.update({ where: { id_chain: { id: pool.id, chain: this.chain } }, data: { - lifetimeVolume: parseFloat(pool.totalSwapVolume), - lifetimeSwapFees: parseFloat(pool.totalSwapFee), + lifetimeVolume: lifetimeVolume, + lifetimeSwapFees: lifetimeSwapFees, holdersCount: parseInt(pool.holdersCount) + (staked?._count.userAddress || 0), swapsCount: parseInt(pool.swapsCount), }, - }), - ); + }); + } catch (e) { + console.error(`Error updating lifetime values for pool ${pool.id} (${pool.name})`); + throw e; + } + // ); const snapshots = await prisma.prismaPoolSnapshot.findMany({ where: { poolId: pool.id, chain: this.chain }, }); - if (snapshots.length > 0) { - const sharePriceAth = _.orderBy(snapshots, 'sharePrice', 'desc')[0]; - const sharePriceAtl = _.orderBy(snapshots, 'sharePrice', 'asc')[0]; - const totalLiquidityAth = _.orderBy(snapshots, 'totalLiquidity', 'desc')[0]; - const totalLiquidityAtl = _.orderBy(snapshots, 'totalLiquidity', 'asc')[0]; - const volume24hAth = _.orderBy(snapshots, 'volume24h', 'desc')[0]; - const volume24hAtl = _.orderBy(snapshots, 'volume24h', 'asc')[0]; - const fees24hAth = _.orderBy(snapshots, 'fees24h', 'desc')[0]; - const fees24hAtl = _.orderBy(snapshots, 'fees24h', 'asc')[0]; - - updates.push( - prisma.prismaPoolDynamicData.update({ - where: { id_chain: { id: pool.id, chain: this.chain } }, - data: { - sharePriceAth: sharePriceAth.sharePrice, - sharePriceAthTimestamp: sharePriceAth.timestamp, - sharePriceAtl: sharePriceAtl.sharePrice, - sharePriceAtlTimestamp: sharePriceAtl.timestamp, - - totalLiquidityAth: totalLiquidityAth.totalLiquidity, - totalLiquidityAthTimestamp: totalLiquidityAth.timestamp, - totalLiquidityAtl: totalLiquidityAtl.totalLiquidity, - totalLiquidityAtlTimestamp: totalLiquidityAtl.timestamp, - - volume24hAth: volume24hAth.volume24h, - volume24hAthTimestamp: volume24hAth.timestamp, - volume24hAtl: volume24hAtl.volume24h, - volume24hAtlTimestamp: volume24hAtl.timestamp, - - fees24hAth: fees24hAth.fees24h, - fees24hAthTimestamp: fees24hAth.timestamp, - fees24hAtl: fees24hAtl.fees24h, - fees24hAtlTimestamp: fees24hAtl.timestamp, - }, - }), - ); - } + // if (snapshots.length > 0) { + // const sharePriceAth = _.orderBy(snapshots, 'sharePrice', 'desc')[0]; + // const sharePriceAtl = _.orderBy(snapshots, 'sharePrice', 'asc')[0]; + // const totalLiquidityAth = _.orderBy(snapshots, 'totalLiquidity', 'desc')[0]; + // const totalLiquidityAtl = _.orderBy(snapshots, 'totalLiquidity', 'asc')[0]; + // const volume24hAth = _.orderBy(snapshots, 'volume24h', 'desc')[0]; + // const volume24hAtl = _.orderBy(snapshots, 'volume24h', 'asc')[0]; + // const fees24hAth = _.orderBy(snapshots, 'fees24h', 'desc')[0]; + // const fees24hAtl = _.orderBy(snapshots, 'fees24h', 'asc')[0]; + + // updates.push( + // prisma.prismaPoolDynamicData.update({ + // where: { id_chain: { id: pool.id, chain: this.chain } }, + // data: { + // sharePriceAth: sharePriceAth.sharePrice, + // sharePriceAthTimestamp: sharePriceAth.timestamp, + // sharePriceAtl: sharePriceAtl.sharePrice, + // sharePriceAtlTimestamp: sharePriceAtl.timestamp, + + // totalLiquidityAth: totalLiquidityAth.totalLiquidity, + // totalLiquidityAthTimestamp: totalLiquidityAth.timestamp, + // totalLiquidityAtl: totalLiquidityAtl.totalLiquidity, + // totalLiquidityAtlTimestamp: totalLiquidityAtl.timestamp, + + // volume24hAth: volume24hAth.volume24h, + // volume24hAthTimestamp: volume24hAth.timestamp, + // volume24hAtl: volume24hAtl.volume24h, + // volume24hAtlTimestamp: volume24hAtl.timestamp, + + // fees24hAth: fees24hAth.fees24h, + // fees24hAthTimestamp: fees24hAth.timestamp, + // fees24hAtl: fees24hAtl.fees24h, + // fees24hAtlTimestamp: fees24hAtl.timestamp, + // }, + // }), + // ); + // } } - await prismaBulkExecuteOperations(updates); + // await prismaBulkExecuteOperations(updates); } } From 852fdc27974199ddf4af8e827b9b0a1666dc8637 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 18:16:59 +0100 Subject: [PATCH 18/21] fix: uncommenting updates --- modules/pool/lib/pool-usd-data.service.ts | 89 +++++++++++------------ 1 file changed, 42 insertions(+), 47 deletions(-) diff --git a/modules/pool/lib/pool-usd-data.service.ts b/modules/pool/lib/pool-usd-data.service.ts index 9734446d6..7125c5d6b 100644 --- a/modules/pool/lib/pool-usd-data.service.ts +++ b/modules/pool/lib/pool-usd-data.service.ts @@ -287,9 +287,8 @@ export class PoolUsdDataService { const lifetimeVolume = Math.min(parseFloat(pool.totalSwapVolume), max); const lifetimeSwapFees = Math.min(parseFloat(pool.totalSwapFee), max); - // updates.push( - try { - await prisma.prismaPoolDynamicData.update({ + updates.push( + prisma.prismaPoolDynamicData.update({ where: { id_chain: { id: pool.id, chain: this.chain } }, data: { lifetimeVolume: lifetimeVolume, @@ -297,56 +296,52 @@ export class PoolUsdDataService { holdersCount: parseInt(pool.holdersCount) + (staked?._count.userAddress || 0), swapsCount: parseInt(pool.swapsCount), }, - }); - } catch (e) { - console.error(`Error updating lifetime values for pool ${pool.id} (${pool.name})`); - throw e; - } - // ); + }), + ); const snapshots = await prisma.prismaPoolSnapshot.findMany({ where: { poolId: pool.id, chain: this.chain }, }); - // if (snapshots.length > 0) { - // const sharePriceAth = _.orderBy(snapshots, 'sharePrice', 'desc')[0]; - // const sharePriceAtl = _.orderBy(snapshots, 'sharePrice', 'asc')[0]; - // const totalLiquidityAth = _.orderBy(snapshots, 'totalLiquidity', 'desc')[0]; - // const totalLiquidityAtl = _.orderBy(snapshots, 'totalLiquidity', 'asc')[0]; - // const volume24hAth = _.orderBy(snapshots, 'volume24h', 'desc')[0]; - // const volume24hAtl = _.orderBy(snapshots, 'volume24h', 'asc')[0]; - // const fees24hAth = _.orderBy(snapshots, 'fees24h', 'desc')[0]; - // const fees24hAtl = _.orderBy(snapshots, 'fees24h', 'asc')[0]; - - // updates.push( - // prisma.prismaPoolDynamicData.update({ - // where: { id_chain: { id: pool.id, chain: this.chain } }, - // data: { - // sharePriceAth: sharePriceAth.sharePrice, - // sharePriceAthTimestamp: sharePriceAth.timestamp, - // sharePriceAtl: sharePriceAtl.sharePrice, - // sharePriceAtlTimestamp: sharePriceAtl.timestamp, - - // totalLiquidityAth: totalLiquidityAth.totalLiquidity, - // totalLiquidityAthTimestamp: totalLiquidityAth.timestamp, - // totalLiquidityAtl: totalLiquidityAtl.totalLiquidity, - // totalLiquidityAtlTimestamp: totalLiquidityAtl.timestamp, - - // volume24hAth: volume24hAth.volume24h, - // volume24hAthTimestamp: volume24hAth.timestamp, - // volume24hAtl: volume24hAtl.volume24h, - // volume24hAtlTimestamp: volume24hAtl.timestamp, - - // fees24hAth: fees24hAth.fees24h, - // fees24hAthTimestamp: fees24hAth.timestamp, - // fees24hAtl: fees24hAtl.fees24h, - // fees24hAtlTimestamp: fees24hAtl.timestamp, - // }, - // }), - // ); - // } + if (snapshots.length > 0) { + const sharePriceAth = _.orderBy(snapshots, 'sharePrice', 'desc')[0]; + const sharePriceAtl = _.orderBy(snapshots, 'sharePrice', 'asc')[0]; + const totalLiquidityAth = _.orderBy(snapshots, 'totalLiquidity', 'desc')[0]; + const totalLiquidityAtl = _.orderBy(snapshots, 'totalLiquidity', 'asc')[0]; + const volume24hAth = _.orderBy(snapshots, 'volume24h', 'desc')[0]; + const volume24hAtl = _.orderBy(snapshots, 'volume24h', 'asc')[0]; + const fees24hAth = _.orderBy(snapshots, 'fees24h', 'desc')[0]; + const fees24hAtl = _.orderBy(snapshots, 'fees24h', 'asc')[0]; + + updates.push( + prisma.prismaPoolDynamicData.update({ + where: { id_chain: { id: pool.id, chain: this.chain } }, + data: { + sharePriceAth: sharePriceAth.sharePrice, + sharePriceAthTimestamp: sharePriceAth.timestamp, + sharePriceAtl: sharePriceAtl.sharePrice, + sharePriceAtlTimestamp: sharePriceAtl.timestamp, + + totalLiquidityAth: totalLiquidityAth.totalLiquidity, + totalLiquidityAthTimestamp: totalLiquidityAth.timestamp, + totalLiquidityAtl: totalLiquidityAtl.totalLiquidity, + totalLiquidityAtlTimestamp: totalLiquidityAtl.timestamp, + + volume24hAth: volume24hAth.volume24h, + volume24hAthTimestamp: volume24hAth.timestamp, + volume24hAtl: volume24hAtl.volume24h, + volume24hAtlTimestamp: volume24hAtl.timestamp, + + fees24hAth: fees24hAth.fees24h, + fees24hAthTimestamp: fees24hAth.timestamp, + fees24hAtl: fees24hAtl.fees24h, + fees24hAtlTimestamp: fees24hAtl.timestamp, + }, + }), + ); + } } - // await prismaBulkExecuteOperations(updates); + await prismaBulkExecuteOperations(updates); } } From a6d548961498c9c366089dcd35454aaa3d9855d6 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 21:47:39 +0100 Subject: [PATCH 19/21] add Sentry.profilesSampleRate --- worker/worker.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/worker/worker.ts b/worker/worker.ts index 857349c42..c896cd63b 100644 --- a/worker/worker.ts +++ b/worker/worker.ts @@ -17,6 +17,7 @@ export async function startWorker() { new ProfilingIntegration(), ], tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.2 : 1.0, + profilesSampleRate: 1.0, }); app.use(Sentry.Handlers.requestHandler()); From c197f95c28dc6b8328cfa3da54974e86d99129bd Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 22:27:29 +0100 Subject: [PATCH 20/21] decrease Sentry trace transactions --- worker/worker.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/worker/worker.ts b/worker/worker.ts index c896cd63b..5051ffb4e 100644 --- a/worker/worker.ts +++ b/worker/worker.ts @@ -16,7 +16,7 @@ export async function startWorker() { new Sentry.Integrations.Http({ tracing: true }), new ProfilingIntegration(), ], - tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.2 : 1.0, + tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.1 : 1.0, profilesSampleRate: 1.0, }); From cc15318f79a994ae5a80edf98baa555de2595d93 Mon Sep 17 00:00:00 2001 From: gmbronco <83549293+gmbronco@users.noreply.github.com> Date: Tue, 5 Dec 2023 22:28:38 +0100 Subject: [PATCH 21/21] tuning Sentry tracing --- worker/worker.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/worker/worker.ts b/worker/worker.ts index 5051ffb4e..45cd2e0ed 100644 --- a/worker/worker.ts +++ b/worker/worker.ts @@ -16,7 +16,7 @@ export async function startWorker() { new Sentry.Integrations.Http({ tracing: true }), new ProfilingIntegration(), ], - tracesSampleRate: env.DEPLOYMENT_ENV === 'main' ? 0.1 : 1.0, + tracesSampleRate: 0.2, profilesSampleRate: 1.0, });