mirror of
https://activitypub.software/TransFem-org/Sharkey
synced 2024-11-21 21:45:11 +00:00
feat: sentry integration (#13897)
* wip * wip * wip * wip * Update CHANGELOG.md * Update ApiCallService.ts * Update config.ts
This commit is contained in:
parent
89b27d8587
commit
80f3cb96b0
10 changed files with 776 additions and 28 deletions
|
@ -136,6 +136,21 @@ redis:
|
||||||
|
|
||||||
id: 'aidx'
|
id: 'aidx'
|
||||||
|
|
||||||
|
# ┌────────────────┐
|
||||||
|
#───┘ Error tracking └──────────────────────────────────────────
|
||||||
|
|
||||||
|
# Sentry is available for error tracking.
|
||||||
|
# See the Sentry documentation for more details on options.
|
||||||
|
|
||||||
|
#sentryForBackend:
|
||||||
|
# enableNodeProfiling: true
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
|
#sentryForFrontend:
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
# ┌─────────────────────┐
|
# ┌─────────────────────┐
|
||||||
#───┘ Other configuration └─────────────────────────────────────
|
#───┘ Other configuration └─────────────────────────────────────
|
||||||
|
|
||||||
|
|
|
@ -205,6 +205,21 @@ redis:
|
||||||
|
|
||||||
id: 'aidx'
|
id: 'aidx'
|
||||||
|
|
||||||
|
# ┌────────────────┐
|
||||||
|
#───┘ Error tracking └──────────────────────────────────────────
|
||||||
|
|
||||||
|
# Sentry is available for error tracking.
|
||||||
|
# See the Sentry documentation for more details on options.
|
||||||
|
|
||||||
|
#sentryForBackend:
|
||||||
|
# enableNodeProfiling: true
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
|
#sentryForFrontend:
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
# ┌─────────────────────┐
|
# ┌─────────────────────┐
|
||||||
#───┘ Other configuration └─────────────────────────────────────
|
#───┘ Other configuration └─────────────────────────────────────
|
||||||
|
|
||||||
|
|
|
@ -132,6 +132,21 @@ redis:
|
||||||
|
|
||||||
id: 'aidx'
|
id: 'aidx'
|
||||||
|
|
||||||
|
# ┌────────────────┐
|
||||||
|
#───┘ Error tracking └──────────────────────────────────────────
|
||||||
|
|
||||||
|
# Sentry is available for error tracking.
|
||||||
|
# See the Sentry documentation for more details on options.
|
||||||
|
|
||||||
|
#sentryForBackend:
|
||||||
|
# enableNodeProfiling: true
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
|
#sentryForFrontend:
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
# ┌─────────────────────┐
|
# ┌─────────────────────┐
|
||||||
#───┘ Other configuration └─────────────────────────────────────
|
#───┘ Other configuration └─────────────────────────────────────
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
- 管理者向け権限 `read:admin:show-users` は `read:admin:show-user` に統合されました。必要に応じてAPIトークンを再発行してください。
|
- 管理者向け権限 `read:admin:show-users` は `read:admin:show-user` に統合されました。必要に応じてAPIトークンを再発行してください。
|
||||||
|
|
||||||
### General
|
### General
|
||||||
|
- Feat: エラートラッキングにSentryを使用できるようになりました
|
||||||
- Enhance: URLプレビューの有効化・無効化を設定できるように #13569
|
- Enhance: URLプレビューの有効化・無効化を設定できるように #13569
|
||||||
- Enhance: アンテナでBotによるノートを除外できるように
|
- Enhance: アンテナでBotによるノートを除外できるように
|
||||||
(Cherry-picked from https://github.com/MisskeyIO/misskey/pull/545)
|
(Cherry-picked from https://github.com/MisskeyIO/misskey/pull/545)
|
||||||
|
|
|
@ -152,6 +152,22 @@ redis:
|
||||||
# ID SETTINGS AFTER THAT!
|
# ID SETTINGS AFTER THAT!
|
||||||
|
|
||||||
id: "aidx"
|
id: "aidx"
|
||||||
|
|
||||||
|
# ┌────────────────┐
|
||||||
|
#───┘ Error tracking └──────────────────────────────────────────
|
||||||
|
|
||||||
|
# Sentry is available for error tracking.
|
||||||
|
# See the Sentry documentation for more details on options.
|
||||||
|
|
||||||
|
#sentryForBackend:
|
||||||
|
# enableNodeProfiling: true
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
|
#sentryForFrontend:
|
||||||
|
# options:
|
||||||
|
# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0'
|
||||||
|
|
||||||
# ┌─────────────────────┐
|
# ┌─────────────────────┐
|
||||||
#───┘ Other configuration └─────────────────────────────────────
|
#───┘ Other configuration └─────────────────────────────────────
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=20.10.0"
|
"node": "^20.10.0"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "node ./built/boot/entry.js",
|
"start": "node ./built/boot/entry.js",
|
||||||
|
@ -86,6 +86,8 @@
|
||||||
"@nestjs/core": "10.3.8",
|
"@nestjs/core": "10.3.8",
|
||||||
"@nestjs/testing": "10.3.8",
|
"@nestjs/testing": "10.3.8",
|
||||||
"@peertube/http-signature": "1.7.0",
|
"@peertube/http-signature": "1.7.0",
|
||||||
|
"@sentry/node": "^8.5.0",
|
||||||
|
"@sentry/profiling-node": "^8.5.0",
|
||||||
"@simplewebauthn/server": "10.0.0",
|
"@simplewebauthn/server": "10.0.0",
|
||||||
"@sinonjs/fake-timers": "11.2.2",
|
"@sinonjs/fake-timers": "11.2.2",
|
||||||
"@smithy/node-http-handler": "2.5.0",
|
"@smithy/node-http-handler": "2.5.0",
|
||||||
|
|
|
@ -10,6 +10,8 @@ import * as os from 'node:os';
|
||||||
import cluster from 'node:cluster';
|
import cluster from 'node:cluster';
|
||||||
import chalk from 'chalk';
|
import chalk from 'chalk';
|
||||||
import chalkTemplate from 'chalk-template';
|
import chalkTemplate from 'chalk-template';
|
||||||
|
import * as Sentry from '@sentry/node';
|
||||||
|
import { nodeProfilingIntegration } from '@sentry/profiling-node';
|
||||||
import Logger from '@/logger.js';
|
import Logger from '@/logger.js';
|
||||||
import { loadConfig } from '@/config.js';
|
import { loadConfig } from '@/config.js';
|
||||||
import type { Config } from '@/config.js';
|
import type { Config } from '@/config.js';
|
||||||
|
@ -71,6 +73,24 @@ export async function masterMain() {
|
||||||
|
|
||||||
bootLogger.succ('Misskey initialized');
|
bootLogger.succ('Misskey initialized');
|
||||||
|
|
||||||
|
if (config.sentryForBackend) {
|
||||||
|
Sentry.init({
|
||||||
|
integrations: [
|
||||||
|
...(config.sentryForBackend.enableNodeProfiling ? [nodeProfilingIntegration()] : []),
|
||||||
|
],
|
||||||
|
|
||||||
|
// Performance Monitoring
|
||||||
|
tracesSampleRate: 1.0, // Capture 100% of the transactions
|
||||||
|
|
||||||
|
// Set sampling rate for profiling - this is relative to tracesSampleRate
|
||||||
|
profilesSampleRate: 1.0,
|
||||||
|
|
||||||
|
maxBreadcrumbs: 0,
|
||||||
|
|
||||||
|
...config.sentryForBackend.options,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (envOption.disableClustering) {
|
if (envOption.disableClustering) {
|
||||||
if (envOption.onlyServer) {
|
if (envOption.onlyServer) {
|
||||||
await server();
|
await server();
|
||||||
|
|
|
@ -7,6 +7,7 @@ import * as fs from 'node:fs';
|
||||||
import { fileURLToPath } from 'node:url';
|
import { fileURLToPath } from 'node:url';
|
||||||
import { dirname, resolve } from 'node:path';
|
import { dirname, resolve } from 'node:path';
|
||||||
import * as yaml from 'js-yaml';
|
import * as yaml from 'js-yaml';
|
||||||
|
import * as Sentry from '@sentry/node';
|
||||||
import type { RedisOptions } from 'ioredis';
|
import type { RedisOptions } from 'ioredis';
|
||||||
|
|
||||||
type RedisOptionsSource = Partial<RedisOptions> & {
|
type RedisOptionsSource = Partial<RedisOptions> & {
|
||||||
|
@ -56,6 +57,8 @@ type Source = {
|
||||||
index: string;
|
index: string;
|
||||||
scope?: 'local' | 'global' | string[];
|
scope?: 'local' | 'global' | string[];
|
||||||
};
|
};
|
||||||
|
sentryForBackend?: { options: Partial<Sentry.NodeOptions>; enableNodeProfiling: boolean; };
|
||||||
|
sentryForFrontend?: { options: Partial<Sentry.NodeOptions> };
|
||||||
|
|
||||||
publishTarballInsteadOfProvideRepositoryUrl?: boolean;
|
publishTarballInsteadOfProvideRepositoryUrl?: boolean;
|
||||||
|
|
||||||
|
@ -166,6 +169,8 @@ export type Config = {
|
||||||
redisForPubsub: RedisOptions & RedisOptionsSource;
|
redisForPubsub: RedisOptions & RedisOptionsSource;
|
||||||
redisForJobQueue: RedisOptions & RedisOptionsSource;
|
redisForJobQueue: RedisOptions & RedisOptionsSource;
|
||||||
redisForTimelines: RedisOptions & RedisOptionsSource;
|
redisForTimelines: RedisOptions & RedisOptionsSource;
|
||||||
|
sentryForBackend: { options: Partial<Sentry.NodeOptions>; enableNodeProfiling: boolean; } | undefined;
|
||||||
|
sentryForFrontend: { options: Partial<Sentry.NodeOptions> } | undefined;
|
||||||
perChannelMaxNoteCacheCount: number;
|
perChannelMaxNoteCacheCount: number;
|
||||||
perUserNotificationsMaxCount: number;
|
perUserNotificationsMaxCount: number;
|
||||||
deactivateAntennaThreshold: number;
|
deactivateAntennaThreshold: number;
|
||||||
|
@ -234,6 +239,8 @@ export function loadConfig(): Config {
|
||||||
redisForPubsub: config.redisForPubsub ? convertRedisOptions(config.redisForPubsub, host) : redis,
|
redisForPubsub: config.redisForPubsub ? convertRedisOptions(config.redisForPubsub, host) : redis,
|
||||||
redisForJobQueue: config.redisForJobQueue ? convertRedisOptions(config.redisForJobQueue, host) : redis,
|
redisForJobQueue: config.redisForJobQueue ? convertRedisOptions(config.redisForJobQueue, host) : redis,
|
||||||
redisForTimelines: config.redisForTimelines ? convertRedisOptions(config.redisForTimelines, host) : redis,
|
redisForTimelines: config.redisForTimelines ? convertRedisOptions(config.redisForTimelines, host) : redis,
|
||||||
|
sentryForBackend: config.sentryForBackend,
|
||||||
|
sentryForFrontend: config.sentryForFrontend,
|
||||||
id: config.id,
|
id: config.id,
|
||||||
proxy: config.proxy,
|
proxy: config.proxy,
|
||||||
proxySmtp: config.proxySmtp,
|
proxySmtp: config.proxySmtp,
|
||||||
|
|
|
@ -7,6 +7,7 @@ import { randomUUID } from 'node:crypto';
|
||||||
import * as fs from 'node:fs';
|
import * as fs from 'node:fs';
|
||||||
import * as stream from 'node:stream/promises';
|
import * as stream from 'node:stream/promises';
|
||||||
import { Inject, Injectable } from '@nestjs/common';
|
import { Inject, Injectable } from '@nestjs/common';
|
||||||
|
import * as Sentry from '@sentry/node';
|
||||||
import { DI } from '@/di-symbols.js';
|
import { DI } from '@/di-symbols.js';
|
||||||
import { getIpHash } from '@/misc/get-ip-hash.js';
|
import { getIpHash } from '@/misc/get-ip-hash.js';
|
||||||
import type { MiLocalUser, MiUser } from '@/models/User.js';
|
import type { MiLocalUser, MiUser } from '@/models/User.js';
|
||||||
|
@ -17,6 +18,7 @@ import { MetaService } from '@/core/MetaService.js';
|
||||||
import { createTemp } from '@/misc/create-temp.js';
|
import { createTemp } from '@/misc/create-temp.js';
|
||||||
import { bindThis } from '@/decorators.js';
|
import { bindThis } from '@/decorators.js';
|
||||||
import { RoleService } from '@/core/RoleService.js';
|
import { RoleService } from '@/core/RoleService.js';
|
||||||
|
import type { Config } from '@/config.js';
|
||||||
import { ApiError } from './error.js';
|
import { ApiError } from './error.js';
|
||||||
import { RateLimiterService } from './RateLimiterService.js';
|
import { RateLimiterService } from './RateLimiterService.js';
|
||||||
import { ApiLoggerService } from './ApiLoggerService.js';
|
import { ApiLoggerService } from './ApiLoggerService.js';
|
||||||
|
@ -38,6 +40,9 @@ export class ApiCallService implements OnApplicationShutdown {
|
||||||
private userIpHistoriesClearIntervalId: NodeJS.Timeout;
|
private userIpHistoriesClearIntervalId: NodeJS.Timeout;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
|
@Inject(DI.config)
|
||||||
|
private config: Config,
|
||||||
|
|
||||||
@Inject(DI.userIpsRepository)
|
@Inject(DI.userIpsRepository)
|
||||||
private userIpsRepository: UserIpsRepository,
|
private userIpsRepository: UserIpsRepository,
|
||||||
|
|
||||||
|
@ -88,6 +93,48 @@ export class ApiCallService implements OnApplicationShutdown {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#onExecError(ep: IEndpoint, data: any, err: Error): void {
|
||||||
|
if (err instanceof ApiError || err instanceof AuthenticationError) {
|
||||||
|
throw err;
|
||||||
|
} else {
|
||||||
|
const errId = randomUUID();
|
||||||
|
this.logger.error(`Internal error occurred in ${ep.name}: ${err.message}`, {
|
||||||
|
ep: ep.name,
|
||||||
|
ps: data,
|
||||||
|
e: {
|
||||||
|
message: err.message,
|
||||||
|
code: err.name,
|
||||||
|
stack: err.stack,
|
||||||
|
id: errId,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
console.error(err, errId);
|
||||||
|
|
||||||
|
if (this.config.sentryForBackend) {
|
||||||
|
Sentry.captureMessage(`Internal error occurred in ${ep.name}: ${err.message}`, {
|
||||||
|
extra: {
|
||||||
|
ep: ep.name,
|
||||||
|
ps: data,
|
||||||
|
e: {
|
||||||
|
message: err.message,
|
||||||
|
code: err.name,
|
||||||
|
stack: err.stack,
|
||||||
|
id: errId,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new ApiError(null, {
|
||||||
|
e: {
|
||||||
|
message: err.message,
|
||||||
|
code: err.name,
|
||||||
|
id: errId,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@bindThis
|
@bindThis
|
||||||
public handleRequest(
|
public handleRequest(
|
||||||
endpoint: IEndpoint & { exec: any },
|
endpoint: IEndpoint & { exec: any },
|
||||||
|
@ -362,31 +409,11 @@ export class ApiCallService implements OnApplicationShutdown {
|
||||||
}
|
}
|
||||||
|
|
||||||
// API invoking
|
// API invoking
|
||||||
return await ep.exec(data, user, token, file, request.ip, request.headers).catch((err: Error) => {
|
if (this.config.sentryForBackend) {
|
||||||
if (err instanceof ApiError || err instanceof AuthenticationError) {
|
return await Sentry.startSpan({ name: 'API: ' + ep.name }, () => ep.exec(data, user, token, file, request.ip, request.headers).catch((err: Error) => this.#onExecError(ep, data, err)));
|
||||||
throw err;
|
|
||||||
} else {
|
} else {
|
||||||
const errId = randomUUID();
|
return await ep.exec(data, user, token, file, request.ip, request.headers).catch((err: Error) => this.#onExecError(ep, data, err));
|
||||||
this.logger.error(`Internal error occurred in ${ep.name}: ${err.message}`, {
|
|
||||||
ep: ep.name,
|
|
||||||
ps: data,
|
|
||||||
e: {
|
|
||||||
message: err.message,
|
|
||||||
code: err.name,
|
|
||||||
stack: err.stack,
|
|
||||||
id: errId,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
console.error(err, errId);
|
|
||||||
throw new ApiError(null, {
|
|
||||||
e: {
|
|
||||||
message: err.message,
|
|
||||||
code: err.name,
|
|
||||||
id: errId,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@bindThis
|
@bindThis
|
||||||
|
|
630
pnpm-lock.yaml
630
pnpm-lock.yaml
|
@ -140,6 +140,12 @@ importers:
|
||||||
'@peertube/http-signature':
|
'@peertube/http-signature':
|
||||||
specifier: 1.7.0
|
specifier: 1.7.0
|
||||||
version: 1.7.0
|
version: 1.7.0
|
||||||
|
'@sentry/node':
|
||||||
|
specifier: ^8.5.0
|
||||||
|
version: 8.5.0
|
||||||
|
'@sentry/profiling-node':
|
||||||
|
specifier: ^8.5.0
|
||||||
|
version: 8.5.0
|
||||||
'@simplewebauthn/server':
|
'@simplewebauthn/server':
|
||||||
specifier: 10.0.0
|
specifier: 10.0.0
|
||||||
version: 10.0.0(encoding@0.1.13)
|
version: 10.0.0(encoding@0.1.13)
|
||||||
|
@ -3264,6 +3270,154 @@ packages:
|
||||||
'@open-draft/until@2.1.0':
|
'@open-draft/until@2.1.0':
|
||||||
resolution: {integrity: sha512-U69T3ItWHvLwGg5eJ0n3I62nWuE6ilHlmz7zM0npLBRvPRd7e6NYmg54vvRtP5mZG7kZqZCFVdsTWo7BPtBujg==}
|
resolution: {integrity: sha512-U69T3ItWHvLwGg5eJ0n3I62nWuE6ilHlmz7zM0npLBRvPRd7e6NYmg54vvRtP5mZG7kZqZCFVdsTWo7BPtBujg==}
|
||||||
|
|
||||||
|
'@opentelemetry/api-logs@0.51.1':
|
||||||
|
resolution: {integrity: sha512-E3skn949Pk1z2XtXu/lxf6QAZpawuTM/IUEXcAzpiUkTd73Hmvw26FiN3cJuTmkpM5hZzHwkomVdtrh/n/zzwA==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
|
||||||
|
'@opentelemetry/api@1.8.0':
|
||||||
|
resolution: {integrity: sha512-I/s6F7yKUDdtMsoBWXJe8Qz40Tui5vsuKCWJEWVL+5q9sSWRzzx6v2KeNsOBEwd94j0eWkpWCH4yB6rZg9Mf0w==}
|
||||||
|
engines: {node: '>=8.0.0'}
|
||||||
|
|
||||||
|
'@opentelemetry/context-async-hooks@1.24.1':
|
||||||
|
resolution: {integrity: sha512-R5r6DO4kgEOVBxFXhXjwospLQkv+sYxwCfjvoZBe7Zm6KKXAV9kDSJhi/D1BweowdZmO+sdbENLs374gER8hpQ==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': '>=1.0.0 <1.9.0'
|
||||||
|
|
||||||
|
'@opentelemetry/core@1.24.1':
|
||||||
|
resolution: {integrity: sha512-wMSGfsdmibI88K9wB498zXY04yThPexo8jvwNNlm542HZB7XrrMRBbAyKJqG8qDRJwIBdBrPMi4V9ZPW/sqrcg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': '>=1.0.0 <1.9.0'
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-connect@0.36.0':
|
||||||
|
resolution: {integrity: sha512-k9++bmJZ9zDEs3u3DnKTn2l7QTiNFg3gPx7G9rW0TPnP+xZoBSBTrEcGYBaqflQlrFG23Q58+X1sM2ayWPv5Fg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-express@0.39.0':
|
||||||
|
resolution: {integrity: sha512-AG8U7z7D0JcBu/7dDcwb47UMEzj9/FMiJV2iQZqrsZnxR3FjB9J9oIH2iszJYci2eUdp2WbdvtpD9RV/zmME5A==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-fastify@0.36.1':
|
||||||
|
resolution: {integrity: sha512-3Nfm43PI0I+3EX+1YbSy6xbDu276R1Dh1tqAk68yd4yirnIh52Kd5B+nJ8CgHA7o3UKakpBjj6vSzi5vNCzJIA==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-graphql@0.40.0':
|
||||||
|
resolution: {integrity: sha512-LVRdEHWACWOczv2imD+mhUrLMxsEjPPi32vIZJT57zygR5aUiA4em8X3aiGOCycgbMWkIu8xOSGSxdx3JmzN+w==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-hapi@0.38.0':
|
||||||
|
resolution: {integrity: sha512-ZcOqEuwuutTDYIjhDIStix22ECblG/i9pHje23QGs4Q4YS4RMaZ5hKCoQJxW88Z4K7T53rQkdISmoXFKDV8xMg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-http@0.51.1':
|
||||||
|
resolution: {integrity: sha512-6b3nZnFFEz/3xZ6w8bVxctPUWIPWiXuPQ725530JgxnN1cvYFd8CJ75PrHZNjynmzSSnqBkN3ef4R9N+RpMh8Q==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-ioredis@0.40.0':
|
||||||
|
resolution: {integrity: sha512-Jv/fH7KhpWe4KBirsiqeUJIYrsdR2iu2l4nWhfOlRvaZ+zYIiLEzTQR6QhBbyRoAbU4OuYJzjWusOmmpGBnwng==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-koa@0.40.0':
|
||||||
|
resolution: {integrity: sha512-dJc3H/bKMcgUYcQpLF+1IbmUKus0e5Fnn/+ru/3voIRHwMADT3rFSUcGLWSczkg68BCgz0vFWGDTvPtcWIFr7A==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mongodb@0.43.0':
|
||||||
|
resolution: {integrity: sha512-bMKej7Y76QVUD3l55Q9YqizXybHUzF3pujsBFjqbZrRn2WYqtsDtTUlbCK7fvXNPwFInqZ2KhnTqd0gwo8MzaQ==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mongoose@0.38.1':
|
||||||
|
resolution: {integrity: sha512-zaeiasdnRjXe6VhYCBMdkmAVh1S5MmXC/0spet+yqoaViGnYst/DOxPvhwg3yT4Yag5crZNWsVXnA538UjP6Ow==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mysql2@0.38.1':
|
||||||
|
resolution: {integrity: sha512-qkpHMgWSDTYVB1vlZ9sspf7l2wdS5DDq/rbIepDwX5BA0N0068JTQqh0CgAh34tdFqSCnWXIhcyOXC2TtRb0sg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mysql@0.38.1':
|
||||||
|
resolution: {integrity: sha512-+iBAawUaTfX/HAlvySwozx0C2B6LBfNPXX1W8Z2On1Uva33AGkw2UjL9XgIg1Pj4eLZ9R4EoJ/aFz+Xj4E/7Fw==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-nestjs-core@0.37.1':
|
||||||
|
resolution: {integrity: sha512-ebYQjHZEmGHWEALwwDGhSQVLBaurFnuLIkZD5igPXrt7ohfF4lc5/4al1LO+vKc0NHk8SJWStuRueT86ISA8Vg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-pg@0.41.0':
|
||||||
|
resolution: {integrity: sha512-BSlhpivzBD77meQNZY9fS4aKgydA8AJBzv2dqvxXFy/Hq64b7HURgw/ztbmwFeYwdF5raZZUifiiNSMLpOJoSA==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation@0.43.0':
|
||||||
|
resolution: {integrity: sha512-S1uHE+sxaepgp+t8lvIDuRgyjJWisAb733198kwQTUc9ZtYQ2V2gmyCtR1x21ePGVLoMiX/NWY7WA290hwkjJQ==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation@0.51.1':
|
||||||
|
resolution: {integrity: sha512-JIrvhpgqY6437QIqToyozrUG1h5UhwHkaGK/WAX+fkrpyPtc+RO5FkRtUd9BH0MibabHHvqsnBGKfKVijbmp8w==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.3.0
|
||||||
|
|
||||||
|
'@opentelemetry/redis-common@0.36.2':
|
||||||
|
resolution: {integrity: sha512-faYX1N0gpLhej/6nyp6bgRjzAKXn5GOEMYY7YhciSfCoITAktLUtQ36d24QEWNA1/WA1y6qQunCe0OhHRkVl9g==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
|
||||||
|
'@opentelemetry/resources@1.24.1':
|
||||||
|
resolution: {integrity: sha512-cyv0MwAaPF7O86x5hk3NNgenMObeejZFLJJDVuSeSMIsknlsj3oOZzRv3qSzlwYomXsICfBeFFlxwHQte5mGXQ==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': '>=1.0.0 <1.9.0'
|
||||||
|
|
||||||
|
'@opentelemetry/sdk-metrics@1.24.1':
|
||||||
|
resolution: {integrity: sha512-FrAqCbbGao9iKI+Mgh+OsC9+U2YMoXnlDHe06yH7dvavCKzE3S892dGtX54+WhSFVxHR/TMRVJiK/CV93GR0TQ==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': '>=1.3.0 <1.9.0'
|
||||||
|
|
||||||
|
'@opentelemetry/sdk-trace-base@1.24.1':
|
||||||
|
resolution: {integrity: sha512-zz+N423IcySgjihl2NfjBf0qw1RWe11XIAWVrTNOSSI6dtSPJiVom2zipFB2AEEtJWpv0Iz6DY6+TjnyTV5pWg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': '>=1.0.0 <1.9.0'
|
||||||
|
|
||||||
|
'@opentelemetry/semantic-conventions@1.24.1':
|
||||||
|
resolution: {integrity: sha512-VkliWlS4/+GHLLW7J/rVBA00uXus1SWvwFvcUDxDwmFxYfg/2VI6ekwdXS28cjI8Qz2ky2BzG8OUHo+WeYIWqw==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
|
||||||
|
'@opentelemetry/sql-common@0.40.1':
|
||||||
|
resolution: {integrity: sha512-nSDlnHSqzC3pXn/wZEZVLuAuJ1MYMXPBwtv2qAbCa3847SaHItdE7SzUq/Jtb0KZmh1zfAbNi3AAMjztTT4Ugg==}
|
||||||
|
engines: {node: '>=14'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.1.0
|
||||||
|
|
||||||
'@peculiar/asn1-android@2.3.10':
|
'@peculiar/asn1-android@2.3.10':
|
||||||
resolution: {integrity: sha512-z9Rx9cFJv7UUablZISe7uksNbFJCq13hO0yEAOoIpAymALTLlvUOSLnGiQS7okPaM5dP42oTLhezH6XDXRXjGw==}
|
resolution: {integrity: sha512-z9Rx9cFJv7UUablZISe7uksNbFJCq13hO0yEAOoIpAymALTLlvUOSLnGiQS7okPaM5dP42oTLhezH6XDXRXjGw==}
|
||||||
|
|
||||||
|
@ -3287,6 +3441,9 @@ packages:
|
||||||
resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==}
|
resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==}
|
||||||
engines: {node: '>=14'}
|
engines: {node: '>=14'}
|
||||||
|
|
||||||
|
'@prisma/instrumentation@5.14.0':
|
||||||
|
resolution: {integrity: sha512-DeybWvIZzu/mUsOYP9MVd6AyBj+MP7xIMrcuIn25MX8FiQX39QBnET5KhszTAip/ToctUuDwSJ46QkIoyo3RFA==}
|
||||||
|
|
||||||
'@radix-ui/react-compose-refs@1.0.1':
|
'@radix-ui/react-compose-refs@1.0.1':
|
||||||
resolution: {integrity: sha512-fDSBgd44FKHa1FRMU59qBMPFcl2PZE+2nmqunj+BWFyYYjnhIDWL2ItDs3rrbJDQOtzt5nIebLCQc4QRfz6LJw==}
|
resolution: {integrity: sha512-fDSBgd44FKHa1FRMU59qBMPFcl2PZE+2nmqunj+BWFyYYjnhIDWL2ItDs3rrbJDQOtzt5nIebLCQc4QRfz6LJw==}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
|
@ -3449,6 +3606,37 @@ packages:
|
||||||
'@rushstack/ts-command-line@4.19.2':
|
'@rushstack/ts-command-line@4.19.2':
|
||||||
resolution: {integrity: sha512-cqmXXmBEBlzo9WtyUrHtF9e6kl0LvBY7aTSVX4jfnBfXWZQWnPq9JTFPlQZ+L/ZwjZ4HrNwQsOVvhe9oOucZkw==}
|
resolution: {integrity: sha512-cqmXXmBEBlzo9WtyUrHtF9e6kl0LvBY7aTSVX4jfnBfXWZQWnPq9JTFPlQZ+L/ZwjZ4HrNwQsOVvhe9oOucZkw==}
|
||||||
|
|
||||||
|
'@sentry/core@8.5.0':
|
||||||
|
resolution: {integrity: sha512-SO3ddBzGdha+Oflp+IKwBxj+7ds1q69OAT3VsypTd+WUFQdI9DIhR92Bjf+QQZCIzUNOi79VWOh3aOi3f6hMnw==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
|
||||||
|
'@sentry/node@8.5.0':
|
||||||
|
resolution: {integrity: sha512-t9cHAx/wLJYtdVf2XlzKlRJGvwdAp1wjzG0tC4E1Znx74OuUS1cFNo5WrGuOi0/YcWSxiJaxBvtUcsWK86fIgw==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
|
||||||
|
'@sentry/opentelemetry@8.5.0':
|
||||||
|
resolution: {integrity: sha512-AbxFUNjuTKQ9ugZrssmGtPxWkBr4USNoP7GjaaGCNwNzvIVYCa+i8dv7BROJiW2lsxNAremULEbh+nbVmhGxDA==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
peerDependencies:
|
||||||
|
'@opentelemetry/api': ^1.8.0
|
||||||
|
'@opentelemetry/core': ^1.24.1
|
||||||
|
'@opentelemetry/instrumentation': ^0.51.1
|
||||||
|
'@opentelemetry/sdk-trace-base': ^1.23.0
|
||||||
|
'@opentelemetry/semantic-conventions': ^1.23.0
|
||||||
|
|
||||||
|
'@sentry/profiling-node@8.5.0':
|
||||||
|
resolution: {integrity: sha512-nEXJqVNfZWYi4PakQXBZCJeH59UlnBv+zaYftDNUUXttCmzRXpL1ujNm5mJrJHlWjV7tgIFw02HW3nh2yyKOkw==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
hasBin: true
|
||||||
|
|
||||||
|
'@sentry/types@8.5.0':
|
||||||
|
resolution: {integrity: sha512-eDgkSmKI4+XL0QZm4H3j/n1RgnrbnjXZmjj+LsfccRZQwbPu9bWlc8q7Y7Ty1gOsoUpX+TecNLp2a8CRID4KHA==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
|
||||||
|
'@sentry/utils@8.5.0':
|
||||||
|
resolution: {integrity: sha512-fdrCzo8SAYiw9JBhkJPqYqJkDXZ/wICzN7+zcXIuzKNhE1hdoFjeKcPnpUI3bKZCG6e3hT1PTYQXhVw7GIZV9w==}
|
||||||
|
engines: {node: '>=14.18'}
|
||||||
|
|
||||||
'@shikijs/core@1.4.0':
|
'@shikijs/core@1.4.0':
|
||||||
resolution: {integrity: sha512-CxpKLntAi64h3j+TwWqVIQObPTED0FyXLHTTh3MKXtqiQNn2JGcMQQ362LftDbc9kYbDtrksNMNoVmVXzKFYUQ==}
|
resolution: {integrity: sha512-CxpKLntAi64h3j+TwWqVIQObPTED0FyXLHTTh3MKXtqiQNn2JGcMQQ362LftDbc9kYbDtrksNMNoVmVXzKFYUQ==}
|
||||||
|
|
||||||
|
@ -4254,12 +4442,18 @@ packages:
|
||||||
'@types/connect@3.4.35':
|
'@types/connect@3.4.35':
|
||||||
resolution: {integrity: sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==}
|
resolution: {integrity: sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==}
|
||||||
|
|
||||||
|
'@types/connect@3.4.36':
|
||||||
|
resolution: {integrity: sha512-P63Zd/JUGq+PdrM1lv0Wv5SBYeA2+CORvbrXbngriYY0jzLUWfQMQQxOhjONEz/wlHOAxOdY7CY65rgQdTjq2w==}
|
||||||
|
|
||||||
'@types/content-disposition@0.5.8':
|
'@types/content-disposition@0.5.8':
|
||||||
resolution: {integrity: sha512-QVSSvno3dE0MgO76pJhmv4Qyi/j0Yk9pBp0Y7TJ2Tlj+KCgJWY6qX7nnxCOLkZ3VYRSIk1WTxCvwUSdx6CCLdg==}
|
resolution: {integrity: sha512-QVSSvno3dE0MgO76pJhmv4Qyi/j0Yk9pBp0Y7TJ2Tlj+KCgJWY6qX7nnxCOLkZ3VYRSIk1WTxCvwUSdx6CCLdg==}
|
||||||
|
|
||||||
'@types/cookie@0.6.0':
|
'@types/cookie@0.6.0':
|
||||||
resolution: {integrity: sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==}
|
resolution: {integrity: sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==}
|
||||||
|
|
||||||
|
'@types/cookies@0.9.0':
|
||||||
|
resolution: {integrity: sha512-40Zk8qR147RABiQ7NQnBzWzDcjKzNrntB5BAmeGCb2p/MIyOE+4BVvc17wumsUqUw00bJYqoXFHYygQnEFh4/Q==}
|
||||||
|
|
||||||
'@types/cross-spawn@6.0.2':
|
'@types/cross-spawn@6.0.2':
|
||||||
resolution: {integrity: sha512-KuwNhp3eza+Rhu8IFI5HUXRP0LIhqH5cAjubUvGXXthh4YYBuP2ntwEX+Cz8GJoZUHlKo247wPWOfA9LYEq4cw==}
|
resolution: {integrity: sha512-KuwNhp3eza+Rhu8IFI5HUXRP0LIhqH5cAjubUvGXXthh4YYBuP2ntwEX+Cz8GJoZUHlKo247wPWOfA9LYEq4cw==}
|
||||||
|
|
||||||
|
@ -4323,9 +4517,15 @@ packages:
|
||||||
'@types/htmlescape@1.1.3':
|
'@types/htmlescape@1.1.3':
|
||||||
resolution: {integrity: sha512-tuC81YJXGUe0q8WRtBNW+uyx79rkkzWK651ALIXXYq5/u/IxjX4iHneGF2uUqzsNp+F+9J2mFZOv9jiLTtIq0w==}
|
resolution: {integrity: sha512-tuC81YJXGUe0q8WRtBNW+uyx79rkkzWK651ALIXXYq5/u/IxjX4iHneGF2uUqzsNp+F+9J2mFZOv9jiLTtIq0w==}
|
||||||
|
|
||||||
|
'@types/http-assert@1.5.5':
|
||||||
|
resolution: {integrity: sha512-4+tE/lwdAahgZT1g30Jkdm9PzFRde0xwxBNUyRsCitRvCQB90iuA2uJYdUnhnANRcqGXaWOGY4FEoxeElNAK2g==}
|
||||||
|
|
||||||
'@types/http-cache-semantics@4.0.4':
|
'@types/http-cache-semantics@4.0.4':
|
||||||
resolution: {integrity: sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA==}
|
resolution: {integrity: sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA==}
|
||||||
|
|
||||||
|
'@types/http-errors@2.0.4':
|
||||||
|
resolution: {integrity: sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==}
|
||||||
|
|
||||||
'@types/http-link-header@1.0.5':
|
'@types/http-link-header@1.0.5':
|
||||||
resolution: {integrity: sha512-AxhIKR8UbyoqCTNp9rRepkktHuUOw3DjfOfDCaO9kwI8AYzjhxyrvZq4+mRw/2daD3hYDknrtSeV6SsPwmc71w==}
|
resolution: {integrity: sha512-AxhIKR8UbyoqCTNp9rRepkktHuUOw3DjfOfDCaO9kwI8AYzjhxyrvZq4+mRw/2daD3hYDknrtSeV6SsPwmc71w==}
|
||||||
|
|
||||||
|
@ -4362,9 +4562,21 @@ packages:
|
||||||
'@types/jsrsasign@10.5.14':
|
'@types/jsrsasign@10.5.14':
|
||||||
resolution: {integrity: sha512-lppSlfK6etu+cuKs40K4rg8As79PH6hzIB+v55zSqImbSH3SE6Fm8MBHCiI91cWlAP3Z4igtJK1VL3fSN09blQ==}
|
resolution: {integrity: sha512-lppSlfK6etu+cuKs40K4rg8As79PH6hzIB+v55zSqImbSH3SE6Fm8MBHCiI91cWlAP3Z4igtJK1VL3fSN09blQ==}
|
||||||
|
|
||||||
|
'@types/keygrip@1.0.6':
|
||||||
|
resolution: {integrity: sha512-lZuNAY9xeJt7Bx4t4dx0rYCDqGPW8RXhQZK1td7d4H6E9zYbLoOtjBvfwdTKpsyxQI/2jv+armjX/RW+ZNpXOQ==}
|
||||||
|
|
||||||
'@types/keyv@3.1.4':
|
'@types/keyv@3.1.4':
|
||||||
resolution: {integrity: sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg==}
|
resolution: {integrity: sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg==}
|
||||||
|
|
||||||
|
'@types/koa-compose@3.2.8':
|
||||||
|
resolution: {integrity: sha512-4Olc63RY+MKvxMwVknCUDhRQX1pFQoBZ/lXcRLP69PQkEpze/0cr8LNqJQe5NFb/b19DWi2a5bTi2VAlQzhJuA==}
|
||||||
|
|
||||||
|
'@types/koa@2.14.0':
|
||||||
|
resolution: {integrity: sha512-DTDUyznHGNHAl+wd1n0z1jxNajduyTh8R53xoewuerdBzGo6Ogj6F2299BFtrexJw4NtgjsI5SMPCmV9gZwGXA==}
|
||||||
|
|
||||||
|
'@types/koa__router@12.0.3':
|
||||||
|
resolution: {integrity: sha512-5YUJVv6NwM1z7m6FuYpKfNLTZ932Z6EF6xy2BbtpJSyn13DKNQEkXVffFVSnJHxvwwWh2SAeumpjAYUELqgjyw==}
|
||||||
|
|
||||||
'@types/lodash@4.14.191':
|
'@types/lodash@4.14.191':
|
||||||
resolution: {integrity: sha512-BdZ5BCCvho3EIXw6wUCXHe7rS53AIDPLE+JzwgT+OsJk53oBfbSmZZ7CX4VaRoN78N+TJpFi9QPlfIVNmJYWxQ==}
|
resolution: {integrity: sha512-BdZ5BCCvho3EIXw6wUCXHe7rS53AIDPLE+JzwgT+OsJk53oBfbSmZZ7CX4VaRoN78N+TJpFi9QPlfIVNmJYWxQ==}
|
||||||
|
|
||||||
|
@ -4401,6 +4613,9 @@ packages:
|
||||||
'@types/mute-stream@0.0.4':
|
'@types/mute-stream@0.0.4':
|
||||||
resolution: {integrity: sha512-CPM9nzrCPPJHQNA9keH9CVkVI+WR5kMa+7XEs5jcGQ0VoAGnLv242w8lIVgwAEfmE4oufJRaTc9PNLQl0ioAow==}
|
resolution: {integrity: sha512-CPM9nzrCPPJHQNA9keH9CVkVI+WR5kMa+7XEs5jcGQ0VoAGnLv242w8lIVgwAEfmE4oufJRaTc9PNLQl0ioAow==}
|
||||||
|
|
||||||
|
'@types/mysql@2.15.22':
|
||||||
|
resolution: {integrity: sha512-wK1pzsJVVAjYCSZWQoWHziQZbNggXFDUEIGf54g4ZM/ERuP86uGdWeKZWMYlqTPMZfHJJvLPyogXGvCOg87yLQ==}
|
||||||
|
|
||||||
'@types/node-fetch@2.6.4':
|
'@types/node-fetch@2.6.4':
|
||||||
resolution: {integrity: sha512-1ZX9fcN4Rvkvgv4E6PAY5WXUFWFcRWxZa3EW83UjycOB9ljJCedb2CupIP4RZMEwF/M3eTcCihbBRgwtGbg5Rg==}
|
resolution: {integrity: sha512-1ZX9fcN4Rvkvgv4E6PAY5WXUFWFcRWxZa3EW83UjycOB9ljJCedb2CupIP4RZMEwF/M3eTcCihbBRgwtGbg5Rg==}
|
||||||
|
|
||||||
|
@ -4441,9 +4656,15 @@ packages:
|
||||||
'@types/offscreencanvas@2019.7.0':
|
'@types/offscreencanvas@2019.7.0':
|
||||||
resolution: {integrity: sha512-PGcyveRIpL1XIqK8eBsmRBt76eFgtzuPiSTyKHZxnGemp2yzGzWpjYKAfK3wIMiU7eH+851yEpiuP8JZerTmWg==}
|
resolution: {integrity: sha512-PGcyveRIpL1XIqK8eBsmRBt76eFgtzuPiSTyKHZxnGemp2yzGzWpjYKAfK3wIMiU7eH+851yEpiuP8JZerTmWg==}
|
||||||
|
|
||||||
|
'@types/pg-pool@2.0.4':
|
||||||
|
resolution: {integrity: sha512-qZAvkv1K3QbmHHFYSNRYPkRjOWRLBYrL4B9c+wG0GSVGBw0NtJwPcgx/DSddeDJvRGMHCEQ4VMEVfuJ/0gZ3XQ==}
|
||||||
|
|
||||||
'@types/pg@8.11.5':
|
'@types/pg@8.11.5':
|
||||||
resolution: {integrity: sha512-2xMjVviMxneZHDHX5p5S6tsRRs7TpDHeeK7kTTMe/kAC/mRRNjWHjZg0rkiY+e17jXSZV3zJYDxXV8Cy72/Vuw==}
|
resolution: {integrity: sha512-2xMjVviMxneZHDHX5p5S6tsRRs7TpDHeeK7kTTMe/kAC/mRRNjWHjZg0rkiY+e17jXSZV3zJYDxXV8Cy72/Vuw==}
|
||||||
|
|
||||||
|
'@types/pg@8.6.1':
|
||||||
|
resolution: {integrity: sha512-1Kc4oAGzAl7uqUStZCDvaLFqZrW9qWSjXOmBfdgyBP5La7Us6Mg4GBvRlSoaZMhQF/zSj1C8CtKMBkoiT8eL8w==}
|
||||||
|
|
||||||
'@types/pretty-hrtime@1.0.1':
|
'@types/pretty-hrtime@1.0.1':
|
||||||
resolution: {integrity: sha512-VjID5MJb1eGKthz2qUerWT8+R4b9N+CHvGCzg9fn4kWZgaF9AhdYikQio3R7wV8YY1NsQKPaCwKz1Yff+aHNUQ==}
|
resolution: {integrity: sha512-VjID5MJb1eGKthz2qUerWT8+R4b9N+CHvGCzg9fn4kWZgaF9AhdYikQio3R7wV8YY1NsQKPaCwKz1Yff+aHNUQ==}
|
||||||
|
|
||||||
|
@ -4507,6 +4728,9 @@ packages:
|
||||||
'@types/serviceworker@0.0.67':
|
'@types/serviceworker@0.0.67':
|
||||||
resolution: {integrity: sha512-7TCH7iNsCSNb+aUD9M/36TekrWFSLCjNK8zw/3n5kOtRjbLtDfGYMXTrDnGhSfqXNwpqmt9Vd90w5C/ad1tX6Q==}
|
resolution: {integrity: sha512-7TCH7iNsCSNb+aUD9M/36TekrWFSLCjNK8zw/3n5kOtRjbLtDfGYMXTrDnGhSfqXNwpqmt9Vd90w5C/ad1tX6Q==}
|
||||||
|
|
||||||
|
'@types/shimmer@1.0.5':
|
||||||
|
resolution: {integrity: sha512-9Hp0ObzwwO57DpLFF0InUjUm/II8GmKAvzbefxQTihCb7KI6yc9yzf0nLc4mVdby5N4DRCgQM2wCup9KTieeww==}
|
||||||
|
|
||||||
'@types/simple-oauth2@5.0.7':
|
'@types/simple-oauth2@5.0.7':
|
||||||
resolution: {integrity: sha512-8JbWVJbiTSBQP/7eiyGKyXWAqp3dKQZpaA+pdW16FCi32ujkzRMG8JfjoAzdWt6W8U591ZNdHcPtP2D7ILTKuA==}
|
resolution: {integrity: sha512-8JbWVJbiTSBQP/7eiyGKyXWAqp3dKQZpaA+pdW16FCi32ujkzRMG8JfjoAzdWt6W8U591ZNdHcPtP2D7ILTKuA==}
|
||||||
|
|
||||||
|
@ -4900,6 +5124,16 @@ packages:
|
||||||
resolution: {integrity: sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==}
|
resolution: {integrity: sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==}
|
||||||
engines: {node: '>= 0.6'}
|
engines: {node: '>= 0.6'}
|
||||||
|
|
||||||
|
acorn-import-assertions@1.9.0:
|
||||||
|
resolution: {integrity: sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==}
|
||||||
|
peerDependencies:
|
||||||
|
acorn: ^8
|
||||||
|
|
||||||
|
acorn-import-attributes@1.9.5:
|
||||||
|
resolution: {integrity: sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==}
|
||||||
|
peerDependencies:
|
||||||
|
acorn: ^8
|
||||||
|
|
||||||
acorn-jsx@5.3.2:
|
acorn-jsx@5.3.2:
|
||||||
resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==}
|
resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
|
@ -7111,6 +7345,12 @@ packages:
|
||||||
resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==}
|
resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==}
|
||||||
engines: {node: '>=6'}
|
engines: {node: '>=6'}
|
||||||
|
|
||||||
|
import-in-the-middle@1.4.2:
|
||||||
|
resolution: {integrity: sha512-9WOz1Yh/cvO/p69sxRmhyQwrIGGSp7EIdcb+fFNVi7CzQGQB8U1/1XrKVSbEd/GNOAeM0peJtmi7+qphe7NvAw==}
|
||||||
|
|
||||||
|
import-in-the-middle@1.7.4:
|
||||||
|
resolution: {integrity: sha512-Lk+qzWmiQuRPPulGQeK5qq0v32k2bHnWrRPFgqyvhw7Kkov5L6MOLOIU3pcWeujc9W4q54Cp3Q2WV16eQkc7Bg==}
|
||||||
|
|
||||||
import-lazy@4.0.0:
|
import-lazy@4.0.0:
|
||||||
resolution: {integrity: sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==}
|
resolution: {integrity: sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
|
@ -8275,6 +8515,9 @@ packages:
|
||||||
resolution: {integrity: sha512-qxBgB7Qa2sEQgHFjj0dSigq7fX4k6Saisd5Nelwp2q8mlbAFh5dHV9JTTlF8viYJLSSWgMCZFUom8PJcMNBoJw==}
|
resolution: {integrity: sha512-qxBgB7Qa2sEQgHFjj0dSigq7fX4k6Saisd5Nelwp2q8mlbAFh5dHV9JTTlF8viYJLSSWgMCZFUom8PJcMNBoJw==}
|
||||||
engines: {node: '>= 8'}
|
engines: {node: '>= 8'}
|
||||||
|
|
||||||
|
module-details-from-path@1.0.3:
|
||||||
|
resolution: {integrity: sha512-ySViT69/76t8VhE1xXHK6Ch4NcDd26gx0MzKXLO+F7NOtnqH68d9zF94nT8ZWSxXh8ELOERsnJO/sWt1xZYw5A==}
|
||||||
|
|
||||||
mri@1.2.0:
|
mri@1.2.0:
|
||||||
resolution: {integrity: sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==}
|
resolution: {integrity: sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==}
|
||||||
engines: {node: '>=4'}
|
engines: {node: '>=4'}
|
||||||
|
@ -8393,6 +8636,10 @@ packages:
|
||||||
nise@5.1.4:
|
nise@5.1.4:
|
||||||
resolution: {integrity: sha512-8+Ib8rRJ4L0o3kfmyVCL7gzrohyDe0cMFTBa2d364yIrEGMEoetznKJx899YxjybU6bL9SQkYPSBBs1gyYs8Xg==}
|
resolution: {integrity: sha512-8+Ib8rRJ4L0o3kfmyVCL7gzrohyDe0cMFTBa2d364yIrEGMEoetznKJx899YxjybU6bL9SQkYPSBBs1gyYs8Xg==}
|
||||||
|
|
||||||
|
node-abi@3.62.0:
|
||||||
|
resolution: {integrity: sha512-CPMcGa+y33xuL1E0TcNIu4YyaZCxnnvkVaEXrsosR3FxN+fV8xvb7Mzpb7IgKler10qeMkE6+Dp8qJhpzdq35g==}
|
||||||
|
engines: {node: '>=10'}
|
||||||
|
|
||||||
node-abort-controller@3.1.1:
|
node-abort-controller@3.1.1:
|
||||||
resolution: {integrity: sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==}
|
resolution: {integrity: sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==}
|
||||||
|
|
||||||
|
@ -8626,6 +8873,10 @@ packages:
|
||||||
resolution: {integrity: sha512-es3mGcDXV6TKPo6n3aohzHm0qxhLyR39MhF6mkD1FwFGjhxnqMqfSIgM0eCpInZvqatve4CxmXcMZw3jnnsaXw==}
|
resolution: {integrity: sha512-es3mGcDXV6TKPo6n3aohzHm0qxhLyR39MhF6mkD1FwFGjhxnqMqfSIgM0eCpInZvqatve4CxmXcMZw3jnnsaXw==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
|
|
||||||
|
opentelemetry-instrumentation-fetch-node@1.2.0:
|
||||||
|
resolution: {integrity: sha512-aiSt/4ubOTyb1N5C2ZbGrBvaJOXIZhZvpRPYuUVxQJe27wJZqf/o65iPrqgLcgfeOLaQ8cS2Q+762jrYvniTrA==}
|
||||||
|
engines: {node: '>18.0.0'}
|
||||||
|
|
||||||
optionator@0.9.3:
|
optionator@0.9.3:
|
||||||
resolution: {integrity: sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==}
|
resolution: {integrity: sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==}
|
||||||
engines: {node: '>= 0.8.0'}
|
engines: {node: '>= 0.8.0'}
|
||||||
|
@ -9570,6 +9821,10 @@ packages:
|
||||||
resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==}
|
resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==}
|
||||||
engines: {node: '>=0.10.0'}
|
engines: {node: '>=0.10.0'}
|
||||||
|
|
||||||
|
require-in-the-middle@7.3.0:
|
||||||
|
resolution: {integrity: sha512-nQFEv9gRw6SJAwWD2LrL0NmQvAcO7FBwJbwmr2ttPAacfy0xuiOjE5zt+zM4xDyuyvUaxBi/9gb2SoCyNEVJcw==}
|
||||||
|
engines: {node: '>=8.6.0'}
|
||||||
|
|
||||||
require-main-filename@2.0.0:
|
require-main-filename@2.0.0:
|
||||||
resolution: {integrity: sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==}
|
resolution: {integrity: sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==}
|
||||||
|
|
||||||
|
@ -9784,6 +10039,9 @@ packages:
|
||||||
shiki@1.4.0:
|
shiki@1.4.0:
|
||||||
resolution: {integrity: sha512-5WIn0OL8PWm7JhnTwRWXniy6eEDY234mRrERVlFa646V2ErQqwIFd2UML7e0Pq9eqSKLoMa3Ke+xbsF+DAuy+Q==}
|
resolution: {integrity: sha512-5WIn0OL8PWm7JhnTwRWXniy6eEDY234mRrERVlFa646V2ErQqwIFd2UML7e0Pq9eqSKLoMa3Ke+xbsF+DAuy+Q==}
|
||||||
|
|
||||||
|
shimmer@1.2.1:
|
||||||
|
resolution: {integrity: sha512-sQTKC1Re/rM6XyFM6fIAGHRPVGvyXfgzIDvzoq608vM+jeyVD0Tu1E6Np0Kc2zAIFWIj963V2800iF/9LPieQw==}
|
||||||
|
|
||||||
side-channel@1.0.4:
|
side-channel@1.0.4:
|
||||||
resolution: {integrity: sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==}
|
resolution: {integrity: sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==}
|
||||||
|
|
||||||
|
@ -13733,6 +13991,203 @@ snapshots:
|
||||||
|
|
||||||
'@open-draft/until@2.1.0': {}
|
'@open-draft/until@2.1.0': {}
|
||||||
|
|
||||||
|
'@opentelemetry/api-logs@0.51.1':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
|
||||||
|
'@opentelemetry/api@1.8.0': {}
|
||||||
|
|
||||||
|
'@opentelemetry/context-async-hooks@1.24.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
|
||||||
|
'@opentelemetry/core@1.24.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-connect@0.36.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@types/connect': 3.4.36
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-express@0.39.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-fastify@0.36.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-graphql@0.40.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-hapi@0.38.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-http@0.51.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
semver: 7.6.0
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-ioredis@0.40.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/redis-common': 0.36.2
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-koa@0.40.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@types/koa': 2.14.0
|
||||||
|
'@types/koa__router': 12.0.3
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mongodb@0.43.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/sdk-metrics': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mongoose@0.38.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mysql2@0.38.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@opentelemetry/sql-common': 0.40.1(@opentelemetry/api@1.8.0)
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-mysql@0.38.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@types/mysql': 2.15.22
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-nestjs-core@0.37.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation-pg@0.41.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@opentelemetry/sql-common': 0.40.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@types/pg': 8.6.1
|
||||||
|
'@types/pg-pool': 2.0.4
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation@0.43.0(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@types/shimmer': 1.0.5
|
||||||
|
import-in-the-middle: 1.4.2
|
||||||
|
require-in-the-middle: 7.3.0
|
||||||
|
semver: 7.6.0
|
||||||
|
shimmer: 1.2.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
optional: true
|
||||||
|
|
||||||
|
'@opentelemetry/instrumentation@0.51.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/api-logs': 0.51.1
|
||||||
|
'@types/shimmer': 1.0.5
|
||||||
|
import-in-the-middle: 1.7.4
|
||||||
|
require-in-the-middle: 7.3.0
|
||||||
|
semver: 7.6.0
|
||||||
|
shimmer: 1.2.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@opentelemetry/redis-common@0.36.2': {}
|
||||||
|
|
||||||
|
'@opentelemetry/resources@1.24.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
|
||||||
|
'@opentelemetry/sdk-metrics@1.24.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/resources': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
lodash.merge: 4.6.2
|
||||||
|
|
||||||
|
'@opentelemetry/sdk-trace-base@1.24.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/resources': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
|
||||||
|
'@opentelemetry/semantic-conventions@1.24.1': {}
|
||||||
|
|
||||||
|
'@opentelemetry/sql-common@0.40.1(@opentelemetry/api@1.8.0)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
|
||||||
'@peculiar/asn1-android@2.3.10':
|
'@peculiar/asn1-android@2.3.10':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@peculiar/asn1-schema': 2.3.8
|
'@peculiar/asn1-schema': 2.3.8
|
||||||
|
@ -13776,6 +14231,14 @@ snapshots:
|
||||||
'@pkgjs/parseargs@0.11.0':
|
'@pkgjs/parseargs@0.11.0':
|
||||||
optional: true
|
optional: true
|
||||||
|
|
||||||
|
'@prisma/instrumentation@5.14.0':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/sdk-trace-base': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
'@radix-ui/react-compose-refs@1.0.1(@types/react@18.0.28)(react@18.3.1)':
|
'@radix-ui/react-compose-refs@1.0.1(@types/react@18.0.28)(react@18.3.1)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@babel/runtime': 7.23.4
|
'@babel/runtime': 7.23.4
|
||||||
|
@ -13922,6 +14385,72 @@ snapshots:
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- '@types/node'
|
- '@types/node'
|
||||||
|
|
||||||
|
'@sentry/core@8.5.0':
|
||||||
|
dependencies:
|
||||||
|
'@sentry/types': 8.5.0
|
||||||
|
'@sentry/utils': 8.5.0
|
||||||
|
|
||||||
|
'@sentry/node@8.5.0':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/context-async-hooks': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-connect': 0.36.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-express': 0.39.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-fastify': 0.36.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-graphql': 0.40.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-hapi': 0.38.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-http': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-ioredis': 0.40.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-koa': 0.40.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-mongodb': 0.43.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-mongoose': 0.38.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-mysql': 0.38.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-mysql2': 0.38.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-nestjs-core': 0.37.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation-pg': 0.41.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/resources': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/sdk-trace-base': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@prisma/instrumentation': 5.14.0
|
||||||
|
'@sentry/core': 8.5.0
|
||||||
|
'@sentry/opentelemetry': 8.5.0(@opentelemetry/api@1.8.0)(@opentelemetry/core@1.24.1(@opentelemetry/api@1.8.0))(@opentelemetry/instrumentation@0.51.1(@opentelemetry/api@1.8.0))(@opentelemetry/sdk-trace-base@1.24.1(@opentelemetry/api@1.8.0))(@opentelemetry/semantic-conventions@1.24.1)
|
||||||
|
'@sentry/types': 8.5.0
|
||||||
|
'@sentry/utils': 8.5.0
|
||||||
|
optionalDependencies:
|
||||||
|
opentelemetry-instrumentation-fetch-node: 1.2.0
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@sentry/opentelemetry@8.5.0(@opentelemetry/api@1.8.0)(@opentelemetry/core@1.24.1(@opentelemetry/api@1.8.0))(@opentelemetry/instrumentation@0.51.1(@opentelemetry/api@1.8.0))(@opentelemetry/sdk-trace-base@1.24.1(@opentelemetry/api@1.8.0))(@opentelemetry/semantic-conventions@1.24.1)':
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/core': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/instrumentation': 0.51.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/sdk-trace-base': 1.24.1(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
'@sentry/core': 8.5.0
|
||||||
|
'@sentry/types': 8.5.0
|
||||||
|
'@sentry/utils': 8.5.0
|
||||||
|
|
||||||
|
'@sentry/profiling-node@8.5.0':
|
||||||
|
dependencies:
|
||||||
|
'@sentry/core': 8.5.0
|
||||||
|
'@sentry/node': 8.5.0
|
||||||
|
'@sentry/types': 8.5.0
|
||||||
|
'@sentry/utils': 8.5.0
|
||||||
|
detect-libc: 2.0.3
|
||||||
|
node-abi: 3.62.0
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
|
'@sentry/types@8.5.0': {}
|
||||||
|
|
||||||
|
'@sentry/utils@8.5.0':
|
||||||
|
dependencies:
|
||||||
|
'@sentry/types': 8.5.0
|
||||||
|
|
||||||
'@shikijs/core@1.4.0': {}
|
'@shikijs/core@1.4.0': {}
|
||||||
|
|
||||||
'@sideway/address@4.1.4':
|
'@sideway/address@4.1.4':
|
||||||
|
@ -15301,10 +15830,21 @@ snapshots:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
|
'@types/connect@3.4.36':
|
||||||
|
dependencies:
|
||||||
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
'@types/content-disposition@0.5.8': {}
|
'@types/content-disposition@0.5.8': {}
|
||||||
|
|
||||||
'@types/cookie@0.6.0': {}
|
'@types/cookie@0.6.0': {}
|
||||||
|
|
||||||
|
'@types/cookies@0.9.0':
|
||||||
|
dependencies:
|
||||||
|
'@types/connect': 3.4.35
|
||||||
|
'@types/express': 4.17.17
|
||||||
|
'@types/keygrip': 1.0.6
|
||||||
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
'@types/cross-spawn@6.0.2':
|
'@types/cross-spawn@6.0.2':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
@ -15372,8 +15912,12 @@ snapshots:
|
||||||
|
|
||||||
'@types/htmlescape@1.1.3': {}
|
'@types/htmlescape@1.1.3': {}
|
||||||
|
|
||||||
|
'@types/http-assert@1.5.5': {}
|
||||||
|
|
||||||
'@types/http-cache-semantics@4.0.4': {}
|
'@types/http-cache-semantics@4.0.4': {}
|
||||||
|
|
||||||
|
'@types/http-errors@2.0.4': {}
|
||||||
|
|
||||||
'@types/http-link-header@1.0.5':
|
'@types/http-link-header@1.0.5':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
@ -15411,10 +15955,31 @@ snapshots:
|
||||||
|
|
||||||
'@types/jsrsasign@10.5.14': {}
|
'@types/jsrsasign@10.5.14': {}
|
||||||
|
|
||||||
|
'@types/keygrip@1.0.6': {}
|
||||||
|
|
||||||
'@types/keyv@3.1.4':
|
'@types/keyv@3.1.4':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
|
'@types/koa-compose@3.2.8':
|
||||||
|
dependencies:
|
||||||
|
'@types/koa': 2.14.0
|
||||||
|
|
||||||
|
'@types/koa@2.14.0':
|
||||||
|
dependencies:
|
||||||
|
'@types/accepts': 1.3.7
|
||||||
|
'@types/content-disposition': 0.5.8
|
||||||
|
'@types/cookies': 0.9.0
|
||||||
|
'@types/http-assert': 1.5.5
|
||||||
|
'@types/http-errors': 2.0.4
|
||||||
|
'@types/keygrip': 1.0.6
|
||||||
|
'@types/koa-compose': 3.2.8
|
||||||
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
|
'@types/koa__router@12.0.3':
|
||||||
|
dependencies:
|
||||||
|
'@types/koa': 2.14.0
|
||||||
|
|
||||||
'@types/lodash@4.14.191': {}
|
'@types/lodash@4.14.191': {}
|
||||||
|
|
||||||
'@types/long@4.0.2': {}
|
'@types/long@4.0.2': {}
|
||||||
|
@ -15445,6 +16010,10 @@ snapshots:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
|
'@types/mysql@2.15.22':
|
||||||
|
dependencies:
|
||||||
|
'@types/node': 20.12.7
|
||||||
|
|
||||||
'@types/node-fetch@2.6.4':
|
'@types/node-fetch@2.6.4':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
|
@ -15491,12 +16060,22 @@ snapshots:
|
||||||
|
|
||||||
'@types/offscreencanvas@2019.7.0': {}
|
'@types/offscreencanvas@2019.7.0': {}
|
||||||
|
|
||||||
|
'@types/pg-pool@2.0.4':
|
||||||
|
dependencies:
|
||||||
|
'@types/pg': 8.11.5
|
||||||
|
|
||||||
'@types/pg@8.11.5':
|
'@types/pg@8.11.5':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 20.12.7
|
'@types/node': 20.12.7
|
||||||
pg-protocol: 1.6.0
|
pg-protocol: 1.6.0
|
||||||
pg-types: 4.0.1
|
pg-types: 4.0.1
|
||||||
|
|
||||||
|
'@types/pg@8.6.1':
|
||||||
|
dependencies:
|
||||||
|
'@types/node': 20.12.7
|
||||||
|
pg-protocol: 1.6.1
|
||||||
|
pg-types: 2.2.0
|
||||||
|
|
||||||
'@types/pretty-hrtime@1.0.1': {}
|
'@types/pretty-hrtime@1.0.1': {}
|
||||||
|
|
||||||
'@types/prop-types@15.7.5': {}
|
'@types/prop-types@15.7.5': {}
|
||||||
|
@ -15554,6 +16133,8 @@ snapshots:
|
||||||
|
|
||||||
'@types/serviceworker@0.0.67': {}
|
'@types/serviceworker@0.0.67': {}
|
||||||
|
|
||||||
|
'@types/shimmer@1.0.5': {}
|
||||||
|
|
||||||
'@types/simple-oauth2@5.0.7': {}
|
'@types/simple-oauth2@5.0.7': {}
|
||||||
|
|
||||||
'@types/sinon@10.0.13':
|
'@types/sinon@10.0.13':
|
||||||
|
@ -16096,6 +16677,15 @@ snapshots:
|
||||||
mime-types: 2.1.35
|
mime-types: 2.1.35
|
||||||
negotiator: 0.6.3
|
negotiator: 0.6.3
|
||||||
|
|
||||||
|
acorn-import-assertions@1.9.0(acorn@8.11.3):
|
||||||
|
dependencies:
|
||||||
|
acorn: 8.11.3
|
||||||
|
optional: true
|
||||||
|
|
||||||
|
acorn-import-attributes@1.9.5(acorn@8.11.3):
|
||||||
|
dependencies:
|
||||||
|
acorn: 8.11.3
|
||||||
|
|
||||||
acorn-jsx@5.3.2(acorn@7.4.1):
|
acorn-jsx@5.3.2(acorn@7.4.1):
|
||||||
dependencies:
|
dependencies:
|
||||||
acorn: 7.4.1
|
acorn: 7.4.1
|
||||||
|
@ -19001,6 +19591,21 @@ snapshots:
|
||||||
parent-module: 1.0.1
|
parent-module: 1.0.1
|
||||||
resolve-from: 4.0.0
|
resolve-from: 4.0.0
|
||||||
|
|
||||||
|
import-in-the-middle@1.4.2:
|
||||||
|
dependencies:
|
||||||
|
acorn: 8.11.3
|
||||||
|
acorn-import-assertions: 1.9.0(acorn@8.11.3)
|
||||||
|
cjs-module-lexer: 1.2.2
|
||||||
|
module-details-from-path: 1.0.3
|
||||||
|
optional: true
|
||||||
|
|
||||||
|
import-in-the-middle@1.7.4:
|
||||||
|
dependencies:
|
||||||
|
acorn: 8.11.3
|
||||||
|
acorn-import-attributes: 1.9.5(acorn@8.11.3)
|
||||||
|
cjs-module-lexer: 1.2.2
|
||||||
|
module-details-from-path: 1.0.3
|
||||||
|
|
||||||
import-lazy@4.0.0: {}
|
import-lazy@4.0.0: {}
|
||||||
|
|
||||||
import-local@3.1.0:
|
import-local@3.1.0:
|
||||||
|
@ -20509,6 +21114,8 @@ snapshots:
|
||||||
|
|
||||||
mock-socket@9.3.1: {}
|
mock-socket@9.3.1: {}
|
||||||
|
|
||||||
|
module-details-from-path@1.0.3: {}
|
||||||
|
|
||||||
mri@1.2.0: {}
|
mri@1.2.0: {}
|
||||||
|
|
||||||
ms@2.0.0: {}
|
ms@2.0.0: {}
|
||||||
|
@ -20645,6 +21252,10 @@ snapshots:
|
||||||
just-extend: 4.2.1
|
just-extend: 4.2.1
|
||||||
path-to-regexp: 1.8.0
|
path-to-regexp: 1.8.0
|
||||||
|
|
||||||
|
node-abi@3.62.0:
|
||||||
|
dependencies:
|
||||||
|
semver: 7.6.0
|
||||||
|
|
||||||
node-abort-controller@3.1.1: {}
|
node-abort-controller@3.1.1: {}
|
||||||
|
|
||||||
node-addon-api@3.2.1:
|
node-addon-api@3.2.1:
|
||||||
|
@ -20897,6 +21508,15 @@ snapshots:
|
||||||
undici: 5.28.2
|
undici: 5.28.2
|
||||||
yargs-parser: 21.1.1
|
yargs-parser: 21.1.1
|
||||||
|
|
||||||
|
opentelemetry-instrumentation-fetch-node@1.2.0:
|
||||||
|
dependencies:
|
||||||
|
'@opentelemetry/api': 1.8.0
|
||||||
|
'@opentelemetry/instrumentation': 0.43.0(@opentelemetry/api@1.8.0)
|
||||||
|
'@opentelemetry/semantic-conventions': 1.24.1
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
optional: true
|
||||||
|
|
||||||
optionator@0.9.3:
|
optionator@0.9.3:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@aashutoshrathi/word-wrap': 1.2.6
|
'@aashutoshrathi/word-wrap': 1.2.6
|
||||||
|
@ -21910,6 +22530,14 @@ snapshots:
|
||||||
|
|
||||||
require-from-string@2.0.2: {}
|
require-from-string@2.0.2: {}
|
||||||
|
|
||||||
|
require-in-the-middle@7.3.0:
|
||||||
|
dependencies:
|
||||||
|
debug: 4.3.4(supports-color@8.1.1)
|
||||||
|
module-details-from-path: 1.0.3
|
||||||
|
resolve: 1.22.8
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
require-main-filename@2.0.0: {}
|
require-main-filename@2.0.0: {}
|
||||||
|
|
||||||
requires-port@1.0.0: {}
|
requires-port@1.0.0: {}
|
||||||
|
@ -22168,6 +22796,8 @@ snapshots:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@shikijs/core': 1.4.0
|
'@shikijs/core': 1.4.0
|
||||||
|
|
||||||
|
shimmer@1.2.1: {}
|
||||||
|
|
||||||
side-channel@1.0.4:
|
side-channel@1.0.4:
|
||||||
dependencies:
|
dependencies:
|
||||||
call-bind: 1.0.2
|
call-bind: 1.0.2
|
||||||
|
|
Loading…
Reference in a new issue