From ce12d9ef0418e872e3e18cb60d2d5b0bcd1e9522 Mon Sep 17 00:00:00 2001 From: Theophilus Isah Date: Mon, 26 Sep 2022 13:25:25 +0100 Subject: [PATCH] feat: add client tracing to on-chain & intra-ledger payments --- package.json | 7 + src/components/root.tsx | 15 +- src/components/send/send-action-display.tsx | 12 + .../send/send-intra-ledger-action.tsx | 36 ++- src/components/send/send-onchain-action.tsx | 36 ++- src/store/client-tracing/trace-provider.tsx | 34 +++ src/store/client-tracing/tracing.ts | 42 +++ yarn.lock | 265 +++++++++++++++++- 8 files changed, 413 insertions(+), 34 deletions(-) create mode 100644 src/store/client-tracing/trace-provider.tsx create mode 100644 src/store/client-tracing/tracing.ts diff --git a/package.json b/package.json index bf9448aa..ab1ec989 100644 --- a/package.json +++ b/package.json @@ -26,14 +26,21 @@ "@galoymoney/client": "^0.1.48", "@galoymoney/react": "^0.1.12", "@opentelemetry/api": "^1.1.0", + "@opentelemetry/context-zone": "^1.7.0", "@opentelemetry/core": "^1.5.0", + "@opentelemetry/exporter-collector": "^0.25.0", "@opentelemetry/exporter-jaeger": "^1.5.0", + "@opentelemetry/exporter-trace-otlp-http": "^0.33.0", "@opentelemetry/instrumentation": "^0.31.0", + "@opentelemetry/instrumentation-document-load": "^0.30.0", + "@opentelemetry/instrumentation-fetch": "^0.33.0", "@opentelemetry/instrumentation-http": "^0.31.0", "@opentelemetry/resources": "^1.5.0", "@opentelemetry/sdk-trace-base": "^1.5.0", "@opentelemetry/sdk-trace-node": "^1.5.0", "@opentelemetry/semantic-conventions": "^1.5.0", + "@opentelemetry/tracing": "^0.24.0", + "@opentelemetry/web": "^0.24.0", "@ory/client": "^0.2.0-alpha.4", "@ory/integrations": "^0.2.6", "@ory/kratos-client": "^0.10.1", diff --git a/src/components/root.tsx b/src/components/root.tsx index 28dd574d..84c53e70 100644 --- a/src/components/root.tsx +++ b/src/components/root.tsx @@ -9,6 +9,7 @@ import { KratosFlowData } from "kratos/index" import { AuthProvider } from "components/auth-provider" import RootComponent from "components/root-component" +import TraceProvider from "store/client-tracing/trace-provider" type RootFCT = React.FC<{ GwwState: GwwStateType }> @@ -38,12 +39,14 @@ const Root: RootFCT = ({ GwwState }) => { return ( - + + + ) diff --git a/src/components/send/send-action-display.tsx b/src/components/send/send-action-display.tsx index ca9a8724..5b9ddf85 100644 --- a/src/components/send/send-action-display.tsx +++ b/src/components/send/send-action-display.tsx @@ -2,8 +2,10 @@ import { MouseEvent } from "react" import { formatUsd, GaloyGQL } from "@galoymoney/client" import { SatFormat, Spinner, SuccessCheckmark } from "@galoymoney/react" +import { Span } from "@opentelemetry/api" import { translate } from "store/index" +import { getTracer, withTracing } from "store/client-tracing/tracing" import useMyUpdates from "hooks/use-my-updates" @@ -59,7 +61,17 @@ const SendActionDisplay: SendActionDisplayFCT = ({ reset, handleSend, }) => { + const recordErrors = (sendError: string, span: Span) => { + span.setAttribute("Error sending payment", sendError) + withTracing("send bitcoin error", span) + } + if (error) { + if (typeof error === "string") { + const tracer = getTracer() + const span = tracer.startSpan("web wallet error") + recordErrors(error, span) + } return
{error}
} diff --git a/src/components/send/send-intra-ledger-action.tsx b/src/components/send/send-intra-ledger-action.tsx index 5f12f4a8..c208181d 100644 --- a/src/components/send/send-intra-ledger-action.tsx +++ b/src/components/send/send-intra-ledger-action.tsx @@ -1,8 +1,11 @@ import { useMutation } from "@galoymoney/client" -import { MouseEvent } from "react" +import React, { MouseEvent } from "react" import SendActionDisplay from "components/send/send-action-display" import { SendActionProps } from "components/send/send-action" +import { getTracer, withTracing, reportSpan } from "store/client-tracing/tracing" + +const tracer = getTracer() export type SendIntraLedgerActionProps = SendActionProps & { recipientWalletId: string @@ -12,23 +15,36 @@ export type SendIntraLedgerActionProps = SendActionProps & { type FCT = React.FC const SendIntraLedgerAction: FCT = (props) => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + const [parentSpan, setParentSpan] = React.useState(null) const [sendPayment, { loading, errorsMessage, data }] = useMutation.intraLedgerPaymentSend() - const handleSend = (event: MouseEvent) => { + const handleSend = async (event: MouseEvent) => { event.preventDefault() - sendPayment({ - variables: { - input: { - walletId: props.btcWalletId, - recipientWalletId: props.recipientWalletId, - amount: props.satAmount, - memo: props.memo, + const rootSpan = tracer.startSpan("web wallet") + await withTracing("intra-ledger send", rootSpan, async () => { + sendPayment({ + variables: { + input: { + walletId: props.btcWalletId, + recipientWalletId: props.recipientWalletId, + amount: props.satAmount, + memo: props.memo, + }, }, - }, + }) }) + setParentSpan(rootSpan) } + React.useEffect(() => { + if (parentSpan) { + parentSpan.end() + reportSpan(parentSpan) + } + }, [parentSpan]) + return ( const SendOnChainAction: FCT = (props) => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + const [parentSpan, setParentSpan] = React.useState(null) const [sendPayment, { loading, data, errorsMessage: paymentError }] = useMutation.onChainPaymentSend() @@ -29,20 +34,31 @@ const SendOnChainAction: FCT = (props) => { const feeSatAmount = feeData?.onChainTxFee?.amount - const handleSend = (event: MouseEvent) => { + const handleSend = async (event: MouseEvent) => { event.preventDefault() - sendPayment({ - variables: { - input: { - walletId: props.btcWalletId, - address: props.address, - amount: props.satAmount, - memo: props.memo, + const rootSpan = tracer.startSpan("web wallet") + await withTracing("on-chain send", rootSpan, async () => { + sendPayment({ + variables: { + input: { + walletId: props.btcWalletId, + address: props.address, + amount: props.satAmount, + memo: props.memo, + }, }, - }, + }) }) + setParentSpan(rootSpan) } + React.useEffect(() => { + if (parentSpan) { + parentSpan.end() + reportSpan(parentSpan) + } + }, [parentSpan]) + return ( {children} +} diff --git a/src/store/client-tracing/tracing.ts b/src/store/client-tracing/tracing.ts new file mode 100644 index 00000000..77804085 --- /dev/null +++ b/src/store/client-tracing/tracing.ts @@ -0,0 +1,42 @@ +import { trace, context, Span } from "@opentelemetry/api" + +export const reportSpan = (span: Span) => { + console.log("report span:", span) + + fetch("./send-trace", { + method: "POST", + headers: { + "Content-Type": "application/json", + }, + body: JSON.stringify(span), + }) + .then((response) => response.json()) + .then((data) => console.log(data)) + .catch((error) => { + console.error("Error:", error) + }) +} + +export const withTracing = async (name: string, parentSpan: Span, cb?: () => void) => { + const tracer = trace.getTracer("galoy-web-wallet") + let span = trace.getSpan(context.active()) + + if (parentSpan) { + const ctx = trace.setSpan(context.active(), parentSpan) + span = tracer.startSpan(name, undefined, ctx) + } else { + span = tracer.startSpan(name) + } + + if (cb) { + await cb() + } + + span.end() + + reportSpan(span) +} + +export const getTracer = () => { + return trace.getTracer("galoy-web-wallet") +} diff --git a/yarn.lock b/yarn.lock index 3045797f..8873c979 100644 --- a/yarn.lock +++ b/yarn.lock @@ -922,6 +922,11 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" +"@opentelemetry/api-metrics@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/api-metrics/-/api-metrics-0.25.0.tgz#3b996842c8043068da4d11a6e96960e757ad6be9" + integrity sha512-9T0c9NQAEGRujUC7HzPa2/qZ5px/UvB2sfSU5CAKFRrAlDl2gn25B0oUbDqSRHW/IG1X2rnQ3z2bBQkJyJvE4g== + "@opentelemetry/api-metrics@0.31.0": version "0.31.0" resolved "https://registry.yarnpkg.com/@opentelemetry/api-metrics/-/api-metrics-0.31.0.tgz#0ed4cf4d7c731f968721c2b303eaf5e9fd42f736" @@ -929,6 +934,20 @@ dependencies: "@opentelemetry/api" "^1.0.0" +"@opentelemetry/api-metrics@0.32.0": + version "0.32.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/api-metrics/-/api-metrics-0.32.0.tgz#0f09f78491a4b301ddf54a8b8a38ffa99981f645" + integrity sha512-g1WLhpG8B6iuDyZJFRGsR+JKyZ94m5LEmY2f+duEJ9Xb4XRlLHrZvh6G34OH6GJ8iDHxfHb/sWjJ1ZpkI9yGMQ== + dependencies: + "@opentelemetry/api" "^1.0.0" + +"@opentelemetry/api-metrics@0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/api-metrics/-/api-metrics-0.33.0.tgz#753d355289b7811ad254d6e5b0193bd1b9f23ab0" + integrity sha512-78evfPRRRnJA6uZ3xuBuS3VZlXTO/LRs+Ff1iv3O/7DgibCtq9k27T6Zlj8yRdJDFmcjcbQrvC0/CpDpWHaZYA== + dependencies: + "@opentelemetry/api" "^1.0.0" + "@opentelemetry/api@^1.0.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@opentelemetry/api/-/api-1.1.0.tgz#563539048255bbe1a5f4f586a4a10a1bb737f44a" @@ -944,6 +963,35 @@ resolved "https://registry.yarnpkg.com/@opentelemetry/context-async-hooks/-/context-async-hooks-1.7.0.tgz#b78d1f4f30b484d92d7926dc9d29ec1ccd489cf5" integrity sha512-g4bMzyVW5dVBeMkyadaf3NRFpmNrdD4Pp9OJsrP29HwIam/zVMNfIWQpT5IBzjtTSMhl/ED5YQYR+UOSjVq3sQ== +"@opentelemetry/context-zone-peer-dep@1.7.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/context-zone-peer-dep/-/context-zone-peer-dep-1.7.0.tgz#7e8e642db519d7a4a3168a7bdc4f1a8ad7344383" + integrity sha512-lyY6gXmVTSsx8rdxvQ3EqiEwvyK3iWDJyt2G6nc/kpMon4gQsqPaOylevdVVw9FL5fhJMmJJPiRVHu3qDP63Zg== + +"@opentelemetry/context-zone@^1.7.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/context-zone/-/context-zone-1.7.0.tgz#4d891827d2d9bad79d44ed3b42d8978cdef5c675" + integrity sha512-ngl8uGzQM6/GMX4FtwrZ69qcvsCBA0u2AMwbO+j2aji/SXEqIOr8L9nM7A8/XzBo2UkmOte0jq2Mbir9TnWuZg== + dependencies: + "@opentelemetry/context-zone-peer-dep" "1.7.0" + zone.js "^0.11.0" + +"@opentelemetry/core@0.24.0": + version "0.24.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/core/-/core-0.24.0.tgz#94033ebab10fdf008f8dae19c9547dadef30a2b2" + integrity sha512-KpsfxBbFTZT9zaB4Es/fFLbvSzVl9Io/8UUu/TYl4/HgqkmyVInNlWTgRiKyz9nsHzFpGP1kdZJj+YIut0IFsw== + dependencies: + "@opentelemetry/semantic-conventions" "0.24.0" + semver "^7.1.3" + +"@opentelemetry/core@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/core/-/core-0.25.0.tgz#44fae79865483be5dacdf72f99db9f1a603c4bae" + integrity sha512-8OTWF4vfCENU112XB5ElLqf0eq/FhsY0SBvvY65vB3+fbZ2Oi+CPsRASrUZWGtC9MJ5rK2lBlY+/jI4a/NPPBg== + dependencies: + "@opentelemetry/semantic-conventions" "0.25.0" + semver "^7.3.5" + "@opentelemetry/core@1.5.0": version "1.5.0" resolved "https://registry.yarnpkg.com/@opentelemetry/core/-/core-1.5.0.tgz#717bceee15d4c69d4c7321c1fe0f5a562b60eb81" @@ -958,6 +1006,24 @@ dependencies: "@opentelemetry/semantic-conventions" "1.7.0" +"@opentelemetry/core@1.7.0", "@opentelemetry/core@^1.0.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/core/-/core-1.7.0.tgz#83bdd1b7a4ceafcdffd6590420657caec5f7b34c" + integrity sha512-AVqAi5uc8DrKJBimCTFUT4iFI+5eXpo4sYmGbQ0CypG0piOTHE2g9c5aSoTGYXu3CzOmJZf7pT6Xh+nwm5d6yQ== + dependencies: + "@opentelemetry/semantic-conventions" "1.7.0" + +"@opentelemetry/exporter-collector@^0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/exporter-collector/-/exporter-collector-0.25.0.tgz#5c6a6a95cb2220aba6085f79b561166e150737df" + integrity sha512-xZYstLt4hz1aTloJaepWdjMMf9305MqwqbUWjcU/X9pOxvgFWRlchO6x/HQTw7ow0i/S+ShzC+greKnb+1WvLA== + dependencies: + "@opentelemetry/api-metrics" "0.25.0" + "@opentelemetry/core" "0.25.0" + "@opentelemetry/resources" "0.25.0" + "@opentelemetry/sdk-metrics-base" "0.25.0" + "@opentelemetry/sdk-trace-base" "0.25.0" + "@opentelemetry/exporter-jaeger@^1.5.0": version "1.7.0" resolved "https://registry.yarnpkg.com/@opentelemetry/exporter-jaeger/-/exporter-jaeger-1.7.0.tgz#65fd4a4222683a90205e23020ce629457e1ff84d" @@ -968,6 +1034,38 @@ "@opentelemetry/semantic-conventions" "1.7.0" jaeger-client "^3.15.0" +"@opentelemetry/exporter-trace-otlp-http@^0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/exporter-trace-otlp-http/-/exporter-trace-otlp-http-0.33.0.tgz#3b03847ec266c6acf098d89ce160347826358acc" + integrity sha512-bRMseTWB1NSrJtbCgf/ema5XO+o9Nj+Y4YbdTLg2n7gnsdoEW/l2Li+JXyxP7rgAsE3cLeekTmNp0IWq5t4TnA== + dependencies: + "@opentelemetry/core" "1.7.0" + "@opentelemetry/otlp-exporter-base" "0.33.0" + "@opentelemetry/otlp-transformer" "0.33.0" + "@opentelemetry/resources" "1.7.0" + "@opentelemetry/sdk-trace-base" "1.7.0" + +"@opentelemetry/instrumentation-document-load@^0.30.0": + version "0.30.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/instrumentation-document-load/-/instrumentation-document-load-0.30.0.tgz#b6c67823f3ded002f4a9c97d6f362e1ed353df2c" + integrity sha512-/QW7nkfXamdRmiPKPS7pky2PxJ32wbYNMgXQk99wiZoW7oXTmW/1e33jtAXayHqzufq45y5WY+EetQ2gtPNH/Q== + dependencies: + "@opentelemetry/core" "^1.0.0" + "@opentelemetry/instrumentation" "^0.32.0" + "@opentelemetry/sdk-trace-base" "^1.0.0" + "@opentelemetry/sdk-trace-web" "^1.0.0" + "@opentelemetry/semantic-conventions" "^1.0.0" + +"@opentelemetry/instrumentation-fetch@^0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/instrumentation-fetch/-/instrumentation-fetch-0.33.0.tgz#9225444665fafb38a730650c88821ceea490a86f" + integrity sha512-HrQUPIpQQBm3h1EWhiaGDLUaoCwxXwoOICcfGNaNBel93UZETDPCiVOje8V1vTcsMcOkcl1xLQEx1BLZ4eUwkQ== + dependencies: + "@opentelemetry/core" "1.7.0" + "@opentelemetry/instrumentation" "0.33.0" + "@opentelemetry/sdk-trace-web" "1.7.0" + "@opentelemetry/semantic-conventions" "1.7.0" + "@opentelemetry/instrumentation-http@^0.31.0": version "0.31.0" resolved "https://registry.yarnpkg.com/@opentelemetry/instrumentation-http/-/instrumentation-http-0.31.0.tgz#5c6dea9cdb636543c6ed1f1a4e55d4422e50fa89" @@ -988,10 +1086,48 @@ semver "^7.3.2" shimmer "^1.2.1" -"@opentelemetry/propagator-b3@1.7.0": - version "1.7.0" - resolved "https://registry.yarnpkg.com/@opentelemetry/propagator-b3/-/propagator-b3-1.7.0.tgz#8c089c2bab733ea7122cb4a5f7ffaaa355127555" - integrity sha512-8kKGS1KwArvkThdhubMZlomuREE9FaBcn9L4JrYHh2jly1FZpqOtFNO2byHymVRjH59d43Pa+eJuFpD0Fp7kSw== +"@opentelemetry/instrumentation@0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/instrumentation/-/instrumentation-0.33.0.tgz#7bced3a13bc2731670d5a23a2fb45353142d8da4" + integrity sha512-8joPjKJ6TznNt04JbnzZG+m1j/4wm1OIrX7DEw/V5lyZ9/2fahIqG72jeZ26VKOZnLOpVzUUnU/dweURqBzT3Q== + dependencies: + "@opentelemetry/api-metrics" "0.33.0" + require-in-the-middle "^5.0.3" + semver "^7.3.2" + shimmer "^1.2.1" + +"@opentelemetry/instrumentation@^0.32.0": + version "0.32.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/instrumentation/-/instrumentation-0.32.0.tgz#27c5975a323a2ba83d9bf2ea8b11faaab37c5827" + integrity sha512-y6ADjHpkUz/v1nkyyYjsQa/zorhX+0qVGpFvXMcbjU4sHnBnC02c6wcc93sIgZfiQClIWo45TGku1KQxJ5UUbQ== + dependencies: + "@opentelemetry/api-metrics" "0.32.0" + require-in-the-middle "^5.0.3" + semver "^7.3.2" + shimmer "^1.2.1" + +"@opentelemetry/otlp-exporter-base@0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/otlp-exporter-base/-/otlp-exporter-base-0.33.0.tgz#bfbdf9bd7b54b92f9d939df99639f30d6a917481" + integrity sha512-st+nsgv23BXSARFwugy6pheulDfOKjIFvzoYOUzPQDVhQtU8+l7dc50rIEybwXghb13o7mZs6Nb8KOvRk57qww== + dependencies: + "@opentelemetry/core" "1.7.0" + +"@opentelemetry/otlp-transformer@0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/otlp-transformer/-/otlp-transformer-0.33.0.tgz#6fd3ddc944f017da08d445f142cad1779770e0e0" + integrity sha512-L4OpsUaki9/Fib17t44YkDvAz3RpMZTtl6hYBhcTqAnqY0wVBpQf0ra25GyHQTKj+oiA//ZxvOlmmM/dXCYxoQ== + dependencies: + "@opentelemetry/api-metrics" "0.33.0" + "@opentelemetry/core" "1.7.0" + "@opentelemetry/resources" "1.7.0" + "@opentelemetry/sdk-metrics" "0.33.0" + "@opentelemetry/sdk-trace-base" "1.7.0" + +"@opentelemetry/propagator-b3@1.6.0": + version "1.6.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/propagator-b3/-/propagator-b3-1.6.0.tgz#db0dee4f28cb4f1830f3cd35013b652b8078f355" + integrity sha512-azs3aCIFrr3qkA/6lNIAYJ+wgDQ6cFoyeHVcZXP0E96AiOeVqtAu5ZXSA63Cw/63pSw0Itmx6CHUGu41enc0TQ== dependencies: "@opentelemetry/core" "1.7.0" @@ -1002,7 +1138,31 @@ dependencies: "@opentelemetry/core" "1.7.0" -"@opentelemetry/resources@1.7.0", "@opentelemetry/resources@^1.5.0": +"@opentelemetry/resources@0.24.0": + version "0.24.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/resources/-/resources-0.24.0.tgz#834e5a4d0a64ed4de085add8308be203959c44b4" + integrity sha512-uEr2m13IRkjQAjX6fsYqJ21aONCspRvuQunaCl8LbH1NS1Gj82TuRUHF6TM82ulBPK8pU+nrrqXKuky2cMcIzw== + dependencies: + "@opentelemetry/core" "0.24.0" + "@opentelemetry/semantic-conventions" "0.24.0" + +"@opentelemetry/resources@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/resources/-/resources-0.25.0.tgz#a780ab536577359ca9ebe93ccc5d02ba8c3fb2ce" + integrity sha512-O46u53vDBlxCML8O9dIjsRcCC2VT5ri1upwhp02ITobgJ16aVD/iScCo1lPl/x2E7yq9uwzMINENiiYZRFb6XA== + dependencies: + "@opentelemetry/core" "0.25.0" + "@opentelemetry/semantic-conventions" "0.25.0" + +"@opentelemetry/resources@1.6.0", "@opentelemetry/resources@^1.5.0": + version "1.6.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/resources/-/resources-1.6.0.tgz#9756894131b9b0dfbcc0cecb5d4bd040d9c1b09d" + integrity sha512-07GlHuq72r2rnJugYVdGumviQvfrl8kEPidkZSVoseLVfIjV7nzxxt5/vqs9pK7JItWOrvjRdr/jTBVayFBr/w== + dependencies: + "@opentelemetry/core" "1.7.0" + "@opentelemetry/semantic-conventions" "1.7.0" + +"@opentelemetry/resources@1.7.0": version "1.7.0" resolved "https://registry.yarnpkg.com/@opentelemetry/resources/-/resources-1.7.0.tgz#90ccd3a6a86b4dfba4e833e73944bd64958d78c5" integrity sha512-u1M0yZotkjyKx8dj+46Sg5thwtOTBmtRieNXqdCRiWUp6SfFiIP0bI+1XK3LhuXqXkBXA1awJZaTqKduNMStRg== @@ -1010,7 +1170,46 @@ "@opentelemetry/core" "1.7.0" "@opentelemetry/semantic-conventions" "1.7.0" -"@opentelemetry/sdk-trace-base@1.7.0", "@opentelemetry/sdk-trace-base@^1.5.0": +"@opentelemetry/sdk-metrics-base@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-metrics-base/-/sdk-metrics-base-0.25.0.tgz#3ac340ef9f1ff7c649339bb031f6c390a2c8ed70" + integrity sha512-7fwPlAFB5Xw8mnVQfq0wqKNw3RXiAMad9T1bk5Sza9LK/L6hz8RTuHWCsFMsj+1OOSAaiPFuUMYrK1J75+2IAg== + dependencies: + "@opentelemetry/api-metrics" "0.25.0" + "@opentelemetry/core" "0.25.0" + "@opentelemetry/resources" "0.25.0" + lodash.merge "^4.6.2" + +"@opentelemetry/sdk-metrics@0.33.0": + version "0.33.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-metrics/-/sdk-metrics-0.33.0.tgz#c4e51decc6e3bb0e1e97c7b081955d357e46c2fe" + integrity sha512-ZXPixOlTd/FHLwpkmm5nTpJE7bZOPfmbSz8hBVFCEHkXE1aKEKaM38UFnZ+2xzOY1tDsDwyxEiiBiDX8y3039A== + dependencies: + "@opentelemetry/api-metrics" "0.33.0" + "@opentelemetry/core" "1.7.0" + "@opentelemetry/resources" "1.7.0" + lodash.merge "4.6.2" + +"@opentelemetry/sdk-trace-base@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-trace-base/-/sdk-trace-base-0.25.0.tgz#4393903a7db8a5ae81a99c4a34121df67e4fdfbe" + integrity sha512-TInkLSF/ThM3GNVM+9tgnCVjyNLnRxvAkG585Fhu0HNwaEtCTUwI0r7AvMRIREOreeRWttBG6kvT0LOKdo8yjw== + dependencies: + "@opentelemetry/core" "0.25.0" + "@opentelemetry/resources" "0.25.0" + "@opentelemetry/semantic-conventions" "0.25.0" + lodash.merge "^4.6.2" + +"@opentelemetry/sdk-trace-base@1.6.0", "@opentelemetry/sdk-trace-base@^1.5.0": + version "1.6.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-trace-base/-/sdk-trace-base-1.6.0.tgz#8b1511c0b0f3e6015e345f5ed4a683adf03e3e3c" + integrity sha512-yx/uuzHdT0QNRSEbCgXHc0GONk90uvaFcPGaNowIFSl85rTp4or4uIIMkG7R8ckj8xWjDSjsaztH6yQxoZrl5g== + dependencies: + "@opentelemetry/core" "1.7.0" + "@opentelemetry/resources" "1.7.0" + "@opentelemetry/semantic-conventions" "1.7.0" + +"@opentelemetry/sdk-trace-base@1.7.0", "@opentelemetry/sdk-trace-base@^1.0.0": version "1.7.0" resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-trace-base/-/sdk-trace-base-1.7.0.tgz#b498424e0c6340a9d80de63fd408c5c2130a60a5" integrity sha512-Iz84C+FVOskmauh9FNnj4+VrA+hG5o+tkMzXuoesvSfunVSioXib0syVFeNXwOm4+M5GdWCuW632LVjqEXStIg== @@ -1031,6 +1230,25 @@ "@opentelemetry/sdk-trace-base" "1.7.0" semver "^7.3.5" +"@opentelemetry/sdk-trace-web@1.7.0", "@opentelemetry/sdk-trace-web@^1.0.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-trace-web/-/sdk-trace-web-1.7.0.tgz#6c8b8a1f5775f27755cb207b8444579c4b9d14c4" + integrity sha512-c+Aq9lMv6MIItJF6XiXCfqyCq/x4VgF6GoKY5aygsxapu1bVk96qaLfGkuQvlUlT2KlyaI6INQiFwQegBXoYiQ== + dependencies: + "@opentelemetry/core" "1.7.0" + "@opentelemetry/sdk-trace-base" "1.7.0" + "@opentelemetry/semantic-conventions" "1.7.0" + +"@opentelemetry/semantic-conventions@0.24.0": + version "0.24.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-0.24.0.tgz#1028ef0e0923b24916158d80d2ddfd67ea8b6740" + integrity sha512-a/szuMQV0Quy0/M7kKdglcbRSoorleyyOwbTNNJ32O+RBN766wbQlMTvdimImTmwYWGr+NJOni1EcC242WlRcA== + +"@opentelemetry/semantic-conventions@0.25.0": + version "0.25.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-0.25.0.tgz#c100d146957949608c6b9614267ae044cdcb5315" + integrity sha512-V3N+MDBiv0TUlorbgiSqk6CvcP876CYUk/41Tg6s8OIyvniTwprE6vPvFQayuABiVkGlHOxv1Mlvp0w4qNdnVg== + "@opentelemetry/semantic-conventions@1.5.0": version "1.5.0" resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-1.5.0.tgz#cea9792bfcf556c87ded17c6ac729348697bb632" @@ -1041,6 +1259,30 @@ resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-1.7.0.tgz#af80a1ef7cf110ea3a68242acd95648991bcd763" integrity sha512-FGBx/Qd09lMaqQcogCHyYrFEpTx4cAjeS+48lMIR12z7LdH+zofGDVQSubN59nL6IpubfKqTeIDu9rNO28iHVA== +"@opentelemetry/semantic-conventions@1.7.0", "@opentelemetry/semantic-conventions@^1.0.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-1.7.0.tgz#af80a1ef7cf110ea3a68242acd95648991bcd763" + integrity sha512-FGBx/Qd09lMaqQcogCHyYrFEpTx4cAjeS+48lMIR12z7LdH+zofGDVQSubN59nL6IpubfKqTeIDu9rNO28iHVA== + +"@opentelemetry/tracing@0.24.0", "@opentelemetry/tracing@^0.24.0": + version "0.24.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/tracing/-/tracing-0.24.0.tgz#63077fe77b2f450442cb36710ea355db76f60faa" + integrity sha512-sTLEs1SIon3xV8vLe53PzfbU0FahoxL9NPY/CYvA1mwGbMu4zHkHAjqy1Tc8JmqRrfa+XrHkmzeSM4hrvloBaA== + dependencies: + "@opentelemetry/core" "0.24.0" + "@opentelemetry/resources" "0.24.0" + "@opentelemetry/semantic-conventions" "0.24.0" + lodash.merge "^4.6.2" + +"@opentelemetry/web@^0.24.0": + version "0.24.0" + resolved "https://registry.yarnpkg.com/@opentelemetry/web/-/web-0.24.0.tgz#911bcb81e34c0419e49f0cfb9e1be845a5475dc6" + integrity sha512-yxAKj7bQ3czfif9MtYXaSJrgRcrLUNltslyhEE+Oh7Ojh9XQ0Q5RhPnE9cwHdR7yp1+HjbEHE+I91QIMKMlVWA== + dependencies: + "@opentelemetry/core" "0.24.0" + "@opentelemetry/semantic-conventions" "0.24.0" + "@opentelemetry/tracing" "0.24.0" + "@ory/client@^0.2.0-alpha.16", "@ory/client@^0.2.0-alpha.4": version "0.2.0-alpha.48" resolved "https://registry.yarnpkg.com/@ory/client/-/client-0.2.0-alpha.48.tgz#d1e3b1950d5790b8872a0386477df5804c41d1a2" @@ -5236,7 +5478,7 @@ lodash.memoize@4.x: resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== -lodash.merge@^4.6.2: +lodash.merge@4.6.2, lodash.merge@^4.6.2: version "4.6.2" resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== @@ -6868,7 +7110,7 @@ secp256k1@^4.0.2: node-addon-api "^2.0.0" node-gyp-build "^4.2.0" -semver@7.x, semver@^7.3.4, semver@^7.3.5, semver@^7.3.7: +semver@7.x, semver@^7.1.3, semver@^7.3.5, semver@^7.3.7: version "7.3.7" resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.7.tgz#12c5b649afdbf9049707796e22a4028814ce523f" integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== @@ -8115,3 +8357,10 @@ zen-observable@0.8.15: version "0.8.15" resolved "https://registry.yarnpkg.com/zen-observable/-/zen-observable-0.8.15.tgz#96415c512d8e3ffd920afd3889604e30b9eaac15" integrity sha512-PQ2PC7R9rslx84ndNBZB/Dkv8V8fZEpk83RLgXtYd0fwUgEjseMn1Dgajh2x6S8QbZAFa9p2qVCEuYZNgve0dQ== + +zone.js@^0.11.0: + version "0.11.8" + resolved "https://registry.yarnpkg.com/zone.js/-/zone.js-0.11.8.tgz#40dea9adc1ad007b5effb2bfed17f350f1f46a21" + integrity sha512-82bctBg2hKcEJ21humWIkXRlLBBmrc3nN7DFh5LGGhcyycO2S7FN8NmdvlcKaGFDNVL4/9kFLmwmInTavdJERA== + dependencies: + tslib "^2.3.0"